NAME

    OpusVL::Text::Util - Simple text utilities

VERSION

    version 0.08

SYNOPSIS

    This provides a couple of simple methods for playing with text.

        use OpusVL::Text::Util qw/truncate_text wrap_text/;
    
        my $truncated = truncate_text('a long string really', 10);
        # 'a long...'
        my $wrapped = truncate_text('a long string really', 10);
        $wrapped = "a long\nstring really";

EXPORT

 truncate_text

    This truncates a string close to the limit provided. It tries to break
    it on a word break if possible. It then appends a '...' to the string.
    This isn't included in the calculation of the length, so you may end up
    with 3 more characters than you specified.

        my $truncated = truncate_text('a long string really', 10);
        # 'a long...'

 wrap_text

    This method has a go at wrapping a line of text. Note that it isn't
    designed to work on multiple lines of text. It will attempt to split at
    convenient points within the required width and if that fails it will
    simply display what is there. All the text should be displayed with
    this method.

    You can also specify the linefeed characters as the last parameter.

        my $wrapped = wrap_text('a long string really', 10);
        # "a long\nstring\nreally"
        my $wrapped = wrap_text('a long string really', 10, "\r\n");
        # "a long\r\nstring\r\nreally"

 string_to_id

    Makes a string safe to use as an HTML id. Converts all non safe
    characters to _.

        string_to_id('thuds-!this') # 'thuds__this'

 line_split

    Splits a string on line breaks. Accounts for all 3 types of line break,
    DOS, MAC and Unix.

        line_split("a\nb\r\nc") # qw/a b c/

 missing_array_items

    Returns the list of items missing.

        $mandatory = [qw/a b c/];
        $cols = [qw/a b d e f/];
        missing_array_items($mandatory, $cols); # ['c']

 not_blank

    Returns true if the string provided is not blank.

        not_blank('0') # 0
        not_blank('')  # 1

 split_words

    Splits a list of words in a string. Looks for commas to split the list
    and strips whitespace.

        split_words('veh1,veh2,veh3') #  qw/veh1 veh2 veh3/

 mask_text

    Mask text field contents using a simple regex.

        mask_text('*', '(\d{4}).*(\d{3})', '456456564654654');
        # '4564********654'

    Specify a fill character, a regex (as a string), and the text to mask
    out.

    This does not guard against rogue regexes. Capture the parts you expect
    to be retained.

AUTHOR

    Colin Newell <colin@opusvl.com>

COPYRIGHT AND LICENSE

    This software is copyright (c) 2012 - 2016 by Colin Newell.

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