NAME
    Convert::RACE - Conversion between Unicode and RACE

SYNOPSIS
      use Convert::RACE;

      $domain = to_race($utf16str);
      $utf16str = from_race($domain);

DESCRIPTION
    This module provides functions to convert between RACE (Row-based ASCII-
    Compatible Encoding) and Unicode Encodings.

    RACE converts strings with internationalized characters into strings of
    US-ASCII that are acceptable as host name parts in current DNS host naming
    usage.

    See http://www.ietf.org/internet-drafts/draft-ietf-idn-race-03.txt for
    more details.

FUNCTION
    Following functions are provided; they are all in @EXPORT array. See the
    Exporter manpage for details.

    to_race($utf16)
        to_race() takes UTF-16 encoding and returns RACE-encoded strings such
        as 'bq--aewrcsy'.

        This function throws an exception such as 'String includes no
        internationalized characters', 'String too long' and 'Invalid encoding
        to compress'. Exceptions are thrown with Carp::croak(), so you can
        cath 'em with eval {};

    from_race($domain_name)
        from_race() takes 'bq--' prefixed string and returns original UTF-16
        string.

        This function throws an exception such as 'String not begin with bq--
        ', 'Decoded string includes no internationalized characters' and '
        Invalid format to decompress'. Exceptions are thrown with
        Carp::croak(), so you can cath 'em with eval {};

    See the Unicode::String manpage, the Unicode::Map8 manpage, the Jcode
    manpage for Unicode conversions.

CLASS METHOD
    Following class methods are provided to change the behaviour of
    Convert::RACE.

    prefix_tag()
        Set and get the domain prefix tag. By default, 'bq--'.

EXAMPLES
      use Jcode;
      use Unicode::String 'latin1';
      use Convert::RACE 'to_race';

      # EUC-japanese here
      $name = to_race(Jcode->new('���ܸ�','euc')->ucs2);
      
      # or, Latin here
      $name = to_race(latin1($latin_string)->utf16);

      # in doubt of exception
      eval { $name = to_race($utf); };
      if ($@) { 
          warn "Can't encode to RACE: $@";
      }

      # change the prefix
      Convert::RACE->prefix_tag('xx--');

TODO AND CAVEATS
    *   Using XS would be by far efficient.

    *   No validation is done for the input UTF-16 string in to_race(). The
        internet draft says checking for prohibited name parts must be done
        before doing the conversion.

AUTHOR
    Tatsuhiko Miyagawa <miyagawa@bulknews.net>, with much help from Eugen
    SAVIN <seugen@serifu.com>, Philip Newton <pne@cpan.org>, Michael J Schout
    <mschout@gkg.net>.

    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.

SEE ALSO
    http://www.i-d-n.net/, http://www.ietf.org/internet-drafts/draft-ietf-idn-
    race-03.txt, RFC 1035, the Unicode::String manpage, the Jcode manpage, the
    Convert::Base32 manpage.

Revision history for Perl extension Convert::RACE.

0.05  Tue Mar  6 16:44:33 JST 2001
	- fixed bug in case that input strings contain characters
	  from only 2 rows, both of which are not 0x00.
	  Thanks to Michael J Schout <mschout@gkg.net>

0.04  Thu Mar  1 23:03:06 JST 2001
	- fixed the bug that if a character has a byte of 0x0a, 
	  it is ignored.
	  Thanks to Philip Newton <pne@cpan.org>

0.02  Wed Feb 28 02:52:49 JST 2001
	- fixed the bug in case that all of the upper octets are 
	  either 0x00 or one single other value.
	  Thanks to Eugen SAVIN <seugen@serifu.com>

0.01  Sat Dec  9 21:01:11 2000
	- original version; created by h2xs 1.19