NAME
Telephony::CountryDialingCodes - convert international dialing codes to country codes and vice versa.
SYNOPSIS
# Usage method 1 (using object methods):
use Telephony::CountryDialingCodes;
my $o = new Telephony::CountryDialingCodes();
my $country_code = 'NL';
print "The dialing access code for country $country_code is " . $o->dialing_code($country_code) . "\n";
my $dialing_code = 1;
my @country_codes = $o->country_codes($dialing_code);
print "The country code(s) for dialing access code $dialing_code is/are: " . join(',',@country_codes) . "\n";
# Usage method 2 (using class methods):
use Telephony::CountryDialingCodes;
my $country_code = 'NL';
print "The dialing access code for country $country_code is " . Telephony::CountryDialingCodes->dialing_code($country_code) . "\n";
my $dialing_code = 1;
my @country_codes = Telephony::CountryDialingCodes->country_codes($dialing_code);
print "The country code(s) for dialing access code $dialing_code is/are: " . join(',',@country_codes) . "\n";
# Extracting an int'l dialing code from an int'l phone number:
use Telephony::CountryDialingCodes;
my $o = new Telephony::CountryDialingCodes();
my $dialing_code = $o->extract_dialing_code('+521234567890');
# $dialing_code will contain 52.
DESCRIPTION
This class exports a method for determining a country's international dialing code, and another method for doing the reverse: i.e. determining the country code(s) that belong(s) to a given international dialing code.
You can call these methods as class methods or you can create an object and call these methods as object methods. The difference is that if you call them in object context that the internal lookup tables are free'd when the object is destroyed, otherwise if you call the methods in class context, then the internal lookup tables are global and will persist for the lifespan of the current process. It's not really a big deal which approach you choose, so for the sake of style, use the object method approach if you have no clue which is better.
PUBLIC CLASS METHODS
new
Constructor.
Parameters: none
Returns: object
PRIVATE CLASS METHODS
_init_lookup_tables
Loads the data into internal lookup tables if necessary.
Parameters: none
Returns: void
PUBLIC CLASS OR OBJECT METHODS
country_codes
Returns the ISO-3166 alpha2 country code(s) for the given dialing code
Parameters: unsigned int, international dialing access code
Returns: array of country codes
dialing_code
Returns the international dialing code for the given ISO-3166 alpha2 country code, or undef if no match could be found.
Parameters: ISO-3166 alpha2 country code
Returns: unsigned int or undef
extract_dialing_code
Extracts the international dialing code from the given international telephone number.
Parameters: international telephone number, for example '+521234567890'.
Returns: string or undef
REFERENCES
- [1]
-
TheFreeDictionary.com List of country calling codes http://encyclopedia.thefreedictionary.com/list%20of%20country%20calling%20codes. 2004-11-16
- [2]
-
Country / Internet Code / Dialing Code http://www.loglink.com/countrystats.asp?mode=cs17. 2004-11-18
SEE ALSO
Geography::Countries for ISO-3166 alpha2 country codes and names.
COPYRIGHT
Copyright (C) 2004 Craig Manley. All rights reserved.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
AUTHOR
Craig Manley (google your ass off for my email address thanks to spam)