NAME

DateTime::Language - base class for DateTime.pm-related language localization

SYNOPSIS

package DateTime::Language::Gibberish;

use base qw(DateTime::Language);

DESCRIPTION

This class provides most of the methods needed to implement language localization for DateTime.pm. A subclass of this language simply provides a set of data structures containing things like day and months names.

This module is a factory for language subclasses, and can load a class either based on the language portion of its name, such as "English", or based on its ISO code, such as "en" or "eng".

USAGE

This module provides the following methods:

  • new( language => $language )

    This method loads the requested language and returns an object of the appropriate class. The "language" parameter may be the name of the language subclass to be used, such as "English", as returned by the languages() method. It can also be an ISO 639 two-letter language code. The language code may include an ISO 3166 two-letter country after a dash, so things like "en" or "en-us" are both legal. If a country code is given, then the most specific match is used. For example, if "en-au" (English, Australian) is given, then the nearest match will be "en", which will be used instead.

    If you want to subclass this module outside of the DateTime::Language namespace, simply call new() on your subclass, without a "language" parameter. For example, you can simply do this:

    package Foo::Language::PigLatin;
    use base 'DateTime::Language';
    
    ...
    
    DateTime->new( ..., language => Foo::Language::PigLatin->new );
  • load( $language )

    This tells the module to load the specified language without creating an object. The language given can be anything accepted by the new() method.

  • languages

    Returns a list of supported language names.

  • iso_codes

    Returns a list of supported ISO language codes. See the new() method documentation for details.

SUBCLASSING

People who want to add support for new languages may be interested in subclassing this module.

The simplest way to do this is to simply declare your new module, let's call it DateTime::Language::Inhumi, a subclass of DateTime::Language, and to define a set of global variables in your namespace.

These globals are:

  • @DayNames

    The names of each day, starting with Monday.

  • @DayAbbreviations

    Abbreviated names for each day.

  • @MonthNames

    The names of each month, starting with January.

  • @MonthAbbreviations

    Abbreviated names for each month.

  • @AMPM

    The terms used for AM and PM in the language you are implementing.

The DateTime::Language module implements methods that use these globals as needed. If you need to implement more complex algorithms, you can override the following methods:

  • name

    Returns the language name, which is the module name without the leading "DateTime::Language::" piece.

  • month_names

    Returns a list of month names.

  • month_name( $dt )

    Given a DateTime object, this method should return the correct month name.

  • month_abbreviations

    Returns a list of month abbreviations.

  • month_abbreviation( $dt )

    Given a DateTime object, this method should return the correct month abbreviation.

  • day_names

    Returns a list of day names.

  • day_name( $dt )

    Given a DateTime object, this method should return the correct day name.

  • day_abbreviations

    Returns a list of day abbreviations.

  • day_abbreviation( $dt )

    Given a DateTime object, this method should return the correct day abbreviation.

  • am_pm_list

    Returns a list of the AM/PM texts. First item should be the AM, the second should be the PM.

  • am_pm( $dt )

    Given a DateTime object, returns the correct AM or PM abbreviation.

SUPPORT

Support for this module is provided via the datetime@perl.org email list. See http://lists.perl.org/ for more details.

AUTHOR

Dave Rolsky <autarch@urth.org>

However, please see the CREDITS file for more details on who I really stole all the code from.

COPYRIGHT

Copyright (c) 2003 David Rolsky. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

Portions of the code in this distribution are derived from other works. Please see the CREDITS file for more details.

The full text of the license can be found in the LICENSE file included with this module.

SEE ALSO

datetime@perl.org mailing list

http://datetime.perl.org/