NAME String::ToIdentifier::EN - Convert Strings to English Program Identifiers SYNOPSIS use utf8; use String::ToIdentifier::EN 'to_identifier'; to_identifier 'foo-bar'; # fooDashBar to_identifier 'foo-bar', '_'; # foo_dash_bar to_identifier 'foo.bar', '_'; # foo_dot_bar to_identifier "foo\x{4EB0}bar"; # fooJingBar to_identifier "foo\x00bar"; # fooNullCharBar to_identifier "foo\x00\x00bar"; # foo2NullCharsBar to_identifier "foo\x00\x00bar", '_'; # foo_2_null_chars_bar { no utf8; to_identifier "foo\xFF\xFFbar.baz"; # foo_2_0xFF_BarDotBaz to_identifier "foo\xFF\xFFbar.baz", '_'; # foo_2_0xFF_bar_dot_baz } DESCRIPTION This module provides a utility method, "to_identifier" for converting an arbitrary string into a readable representation using the ASCII subset of "\w" for use as an identifier in a computer program. The intent is to make unique identifier names from which the content of the original string can be easily inferred by a human just by reading the identifier. If you need the full set of "\w" including Unicode, see the subclass String::ToIdentifier::EN::Unicode. Currently, this process is one way only, and will likely remain this way. The default is to create camelCase identifiers, or you may pass in a separator char of your choice such as "_". Binary char groups will be separated by "_" even in camelCase identifiers to make them easier to read, e.g.: "foo_2_0xFF_Bar". EXPORT Optionally exports the "to_identifier" function. SUBROUTINES to_identifier Takes the string to be converted to an identifier, and optionally a separator char such as "_". If a separator char is not provided, a camelCase identifier will be returned. METHODS string_to_identifier The class method version of "to_identifier", if you want to use the object oriented interface. SEE ALSO String::ToIdentifier::EN::Unicode, Text::Unidecode, Lingua::EN::Inflect::Phrase AUTHOR Rafael Kitover, "<rkitover@cpan.org>" BUGS Please report any bugs or feature requests to "bug-string-toidentifier-en at rt.cpan.org", or through the web interface at <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=String-ToIdentifier-EN>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. REPOSITORY <http://github.com/rkitover/string-toidentifier-en> SUPPORT More information on this module is available at: * RT: CPAN's request tracker (report bugs here) <http://rt.cpan.org/NoAuth/Bugs.html?Dist=String-ToIdentifier-EN> * AnnoCPAN: Annotated CPAN documentation <http://annocpan.org/dist/String-ToIdentifier-EN> * CPAN Ratings <http://cpanratings.perl.org/d/String-ToIdentifier-EN> * MetaCPAN <https://metacpan.org/module/String::ToIdentifier::EN> * Search CPAN <http://search.cpan.org/dist/String-ToIdentifier-EN/> LICENSE AND COPYRIGHT Copyright (c) 2011 Rafael Kitover <rkitover@cpan.org>. This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License. See http://dev.perl.org/licenses/ for more information.