NAME

String::ShortenHostname - tries to shorten hostnames while keeping them meaningful

SYNOPSIS

use String::ShortenHostname;

$sh = String::ShortenHostname->new( length => 20, keep_digits_per_domain => 3 );
$sh->shorten('zumsel.haushaltswarenabteilung.einzelhandel.de');
# zumsel.hau.ein.de
$sh->keep_digits_per_domain(5);
$sh->shorten('zumsel.haushaltswarenabteilung.einzelhandel.de');
# zumsel.haush.einze.de

$sh->domain_edge('~');
$sh->shorten('zumsel.haushaltswarenabteilung.einzelhandel.de');
# zumsel.haus~.einz~.de

$sh->keep_digits_per_domain(3);
$sh->shorten('verylonghostnamepartcannotbeshortend.some-domain.de');
# verylonghostnamepartcannotbeshortend.so~.de -> still 43 chars 

$sh->force(1);
$sh->shorten('verylonghostnamepartcannotbeshortend.some-domain.de');
# verylonghostnamepart

$sh->force_edge('~>');
$sh->shorten('verylonghostnamepartcannotbeshortend.some-domain.de');
# verylonghostnamepa~>

DESCRIPTION

String::ShortenHostname will try to shorten the hostname string to the length specified. It will cut each domain part to a given length from right to left till the string is short enough or the end of the domain has been reached.

Options:

length (required)

The desired maximum length of the hostname string.

keep_digits_per_domain (default: 3)

Cut each domain part at this length.

domain_edge (default: undef)

If defined this string will be used to replace the end of each domain truncated to indicate that it was truncated.

force (default: 0)

If specified the module will force the length by cutting the result string.

force_edge (default: undef)

If defined this string will be used to replace the end of the string to indicate that it was truncated.

COPYRIGHT

Copyright 2014 Markus Benning <me@w3r3wolf.de>

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.