Blame JP/JP.pm

Packit d0f5c2
package Encode::JP;
Packit d0f5c2
BEGIN {
Packit d0f5c2
    if ( ord("A") == 193 ) {
Packit d0f5c2
        die "Encode::JP not supported on EBCDIC\n";
Packit d0f5c2
    }
Packit d0f5c2
}
Packit d0f5c2
use strict;
Packit d0f5c2
use warnings;
Packit d0f5c2
use Encode;
Packit d0f5c2
our $VERSION = do { my @r = ( q$Revision: 2.4 $ =~ /\d+/g ); sprintf "%d." . "%02d" x $#r, @r };
Packit d0f5c2
Packit d0f5c2
use XSLoader;
Packit d0f5c2
XSLoader::load( __PACKAGE__, $VERSION );
Packit d0f5c2
Packit d0f5c2
use Encode::JP::JIS7;
Packit d0f5c2
Packit d0f5c2
1;
Packit d0f5c2
__END__
Packit d0f5c2
Packit d0f5c2
=head1 NAME
Packit d0f5c2
Packit d0f5c2
Encode::JP - Japanese Encodings
Packit d0f5c2
Packit d0f5c2
=head1 SYNOPSIS
Packit d0f5c2
Packit d0f5c2
    use Encode qw/encode decode/; 
Packit d0f5c2
    $euc_jp = encode("euc-jp", $utf8);   # loads Encode::JP implicitly
Packit d0f5c2
    $utf8   = decode("euc-jp", $euc_jp); # ditto
Packit d0f5c2
Packit d0f5c2
=head1 ABSTRACT
Packit d0f5c2
Packit d0f5c2
This module implements Japanese charset encodings.  Encodings
Packit d0f5c2
supported are as follows.
Packit d0f5c2
Packit d0f5c2
  Canonical   Alias		Description
Packit d0f5c2
  --------------------------------------------------------------------
Packit d0f5c2
  euc-jp      /\beuc.*jp$/i	EUC (Extended Unix Character)
Packit d0f5c2
              /\bjp.*euc/i   
Packit d0f5c2
          /\bujis$/i
Packit d0f5c2
  shiftjis    /\bshift.*jis$/i	Shift JIS (aka MS Kanji)
Packit d0f5c2
          /\bsjis$/i
Packit d0f5c2
  7bit-jis    /\bjis$/i		7bit JIS
Packit d0f5c2
  iso-2022-jp			ISO-2022-JP                  [RFC1468]
Packit d0f5c2
                = 7bit JIS with all Halfwidth Kana 
Packit d0f5c2
                  converted to Fullwidth
Packit d0f5c2
  iso-2022-jp-1			ISO-2022-JP-1                [RFC2237]
Packit d0f5c2
                                = ISO-2022-JP with JIS X 0212-1990
Packit d0f5c2
                  support.  See below
Packit d0f5c2
  MacJapanese	                Shift JIS + Apple vendor mappings
Packit d0f5c2
  cp932       /\bwindows-31j$/i Code Page 932
Packit d0f5c2
                                = Shift JIS + MS/IBM vendor mappings
Packit d0f5c2
  jis0201-raw                   JIS0201, raw format
Packit d0f5c2
  jis0208-raw                   JIS0201, raw format
Packit d0f5c2
  jis0212-raw                   JIS0201, raw format
Packit d0f5c2
  --------------------------------------------------------------------
Packit d0f5c2
Packit d0f5c2
=head1 DESCRIPTION
Packit d0f5c2
Packit d0f5c2
To find out how to use this module in detail, see L<Encode>.
Packit d0f5c2
Packit d0f5c2
=head1 Note on ISO-2022-JP(-1)?
Packit d0f5c2
Packit d0f5c2
ISO-2022-JP-1 (RFC2237) is a superset of ISO-2022-JP (RFC1468) which
Packit d0f5c2
adds support for JIS X 0212-1990.  That means you can use the same
Packit d0f5c2
code to decode to utf8 but not vice versa.
Packit d0f5c2
Packit d0f5c2
  $utf8 = decode('iso-2022-jp-1', $stream);
Packit d0f5c2
Packit d0f5c2
and
Packit d0f5c2
Packit d0f5c2
  $utf8 = decode('iso-2022-jp',   $stream);
Packit d0f5c2
Packit d0f5c2
yield the same result but
Packit d0f5c2
Packit d0f5c2
  $with_0212 = encode('iso-2022-jp-1', $utf8);
Packit d0f5c2
Packit d0f5c2
is now different from
Packit d0f5c2
Packit d0f5c2
  $without_0212 = encode('iso-2022-jp', $utf8 );
Packit d0f5c2
Packit d0f5c2
In the latter case, characters that map to 0212 are first converted
Packit d0f5c2
to U+3013 (0xA2AE in EUC-JP; a white square also known as 'Tofu' or
Packit d0f5c2
'geta mark') then fed to the decoding engine.  U+FFFD is not used,
Packit d0f5c2
in order to preserve text layout as much as possible.
Packit d0f5c2
Packit d0f5c2
=head1 BUGS
Packit d0f5c2
Packit d0f5c2
The ASCII region (0x00-0x7f) is preserved for all encodings, even
Packit d0f5c2
though this conflicts with mappings by the Unicode Consortium.
Packit d0f5c2
Packit d0f5c2
=head1 SEE ALSO
Packit d0f5c2
Packit d0f5c2
L<Encode>
Packit d0f5c2
Packit d0f5c2
=cut