Locale::RecodeData - Abstract Base Class for Charset Converters


libintl-perl documentation Contained in the libintl-perl distribution.

Index


Code Index:

NAME

Top

Locale::RecodeData - Abstract Base Class for Charset Converters

SYNOPSIS

Top

    # For compatibility with Perl 5.005 and earlier, you must
    # *use* the module before inheriting from it!
    use qw (Locale::RecodeData);
    use base qw (Locale::RecodeData);

DESCRIPTION

Top

The module Locale::RecodeData serves as an abstract base class to all converters used by Locale::Recode(3).

Adding new conversion modules is currently not straightforward, and you will have to edit the sources of some modules for that purpose.

First, you have to add your new converter class to the list found in Locale::_Conversions(3), so that Locale::Recode(3) knows about its presence. If there are valid aliases for the codeset of your converter, you will also have to edit Locale::_Aliases(3).

Finally, you have to implement the (protected) conversion routine _recode(). See below ("INTERFACE") for details.

CONSTRUCTOR

Top

new (from => FROM_CODESET, to => TO_CODESET)

The constructor takes two (named) arguments:

from

The canonical name of the source codeset. Aliases have already been resolved and the name is converted to uppercase.

to

The canonical name of the destination codeset. Aliases have already been resolved and the name is converted to uppercase.

You normally don't have to implement the constructor. The default constructor implemented here will store the source and destination codesets in the protected members _from and _to.

METHODS

Top

The class implements one method:

_getError

Returns the (protected) member _error.

INTERFACE

Top

New conversion classes must provide the following interface:

new (from => FROM_CODESET, to => TO_CODESET)

The constructor takes two (named) arguments:

from

The canonical name of the source codeset. Aliases have already been resolved and the name is converted to uppercase.

to

The canonical name of the destination codeset. Aliases have already been resolved and the name is converted to uppercase.

_getError

Should return the last error (as a string) or false if there was no error.

This method is implemented in the base class already.

_recode STRINGREF

Should convert the argument STRINGREF in-place. In case of failure, return false, and make provisions that the method _getError() returns an informative error message.

AUTHOR

Top

Copyright (C) 2002-2009, Guido Flohr <guido@imperia.net>, all rights reserved. See the source code for details.

This software is contributed to the Perl community by Imperia (http://www.imperia.net/).

SEE ALSO

Top

Locale::Recode::_Aliases(3pm), Locale::Recode::_Conversions(3pm), Locale::Recode(3pm), perl(1)


libintl-perl documentation Contained in the libintl-perl distribution.

#! /bin/false

# vim: set autoindent shiftwidth=4 tabstop=4:
# $Id$

# Virtual base class for Locale::Recode converters.
# Copyright (C) 2002-2009 Guido Flohr <guido@imperia.net>,
# all rights reserved.

# This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU Library General Public License as published
# by the Free Software Foundation; either version 2, or (at your option)
# any later version.
                                                                                
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# Library General Public License for more details.
                                                                                
# You should have received a copy of the GNU Library General Public 
# License along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 
# USA.

package Locale::RecodeData;

use strict;

sub new
{
    my ($class, %args) = @_;

    bless {
		_from => $args{from},
		_to => $args{to},
    }, $class;
}

sub _getError
{
	shift->{_error};
}

1;

__END__

Local Variables:
mode: perl
perl-indent-level: 4
perl-continued-statement-offset: 4
perl-continued-brace-offset: 0
perl-brace-offset: -4
perl-brace-imaginary-offset: 0
perl-label-offset: -4
cperl-indent-level: 4
cperl-continued-statement-offset: 2
tab-width: 4
End:
=cut