###############################################################################
##
##    Typemap for Text::KyTea
##
##    Copyright (c) pawa
##    All rights reserved.
##
###############################################################################

TYPEMAP
TextKyTea *        O_OBJECT
KyteaSentence *    T_KYTEA_SENTENCE


OUTPUT
T_KYTEA_SENTENCE

    AV* av = (AV*)sv_2mortal( (SV*)newAV() );

    StringUtil* util = THIS->_get_string_util();

    for (int i = 0; i < (int)$var->words.size(); ++i)
    {
        HV* hv = (HV*)sv_2mortal( (SV*)newHV() );

        string surface = util->showString($var->words[i].surf);

        SV* sv = newSVpvn( surface.c_str(), surface.length() );
        hv_store(hv, tkt_keys[0].c_str(), tkt_keys[0].length(), sv, 0);

        AV* tags = (AV*)sv_2mortal( (SV*)newAV() );

        for (int j = 0; j < (int)$var->words[i].tags.size(); ++j)
        {
            AV* tag_pairs = (AV*)sv_2mortal( (SV*)newAV() );

            for (int k = 0; k < (int)$var->words[i].tags[j].size(); ++k)
            {
                HV* tag = (HV*)sv_2mortal( (SV*)newHV() );

                string feature = util->showString($var->words[i].tags[j][k].first);
                double score   = $var->words[i].tags[j][k].second;

                sv = newSVpvn( feature.c_str(), feature.length() );
                hv_store(tag, tkt_keys[1].c_str(), tkt_keys[1].length(), sv, 0);
                hv_store(tag, tkt_keys[2].c_str(), tkt_keys[2].length(), newSVnv(score), 0);

                av_push( tag_pairs, newRV_inc((SV*)tag) );
            }

            av_push( tags, newRV_inc((SV*)tag_pairs) );
        }

        hv_store(hv, tkt_keys[3].c_str(), tkt_keys[3].length(), newRV_inc((SV*)tags), 0);

        av_push( av, newRV_inc((SV*)hv) );
    }

    $arg = sv_2mortal( newRV_inc((SV*)av) );

###############################################################################




# "perlobject.map"  Dean Roehrich, version 19960302
#
# TYPEMAPs
#
# HV *        -> unblessed Perl HV object.
# AV *        -> unblessed Perl AV object.
#
# INPUT/OUTPUT maps
#
# O_*        -> opaque blessed objects
# T_*        -> opaque blessed or unblessed objects
#
# O_OBJECT    -> link an opaque C or C++ object to a blessed Perl object.
# T_OBJECT    -> link an opaque C or C++ object to an unblessed Perl object.
# O_HvRV    -> a blessed Perl HV object.
# T_HvRV    -> an unblessed Perl HV object.
# O_AvRV    -> a blessed Perl AV object.
# T_AvRV    -> an unblessed Perl AV object.

TYPEMAP

HV *        T_HvRV
AV *        T_AvRV


######################################################################
OUTPUT

# The Perl object is blessed into 'CLASS', which should be a
# char* having the name of the package for the blessing.
O_OBJECT
    sv_setref_pv( $arg, CLASS, (void*)$var );

T_OBJECT
    sv_setref_pv( $arg, Nullch, (void*)$var );

# Cannot use sv_setref_pv() because that will destroy
# the HV-ness of the object.  Remember that newRV() will increment
# the refcount.
O_HvRV
    $arg = sv_bless( newRV((SV*)$var), gv_stashpv(CLASS,1) );

T_HvRV
    $arg = newRV((SV*)$var);

# Cannot use sv_setref_pv() because that will destroy
# the AV-ness of the object.  Remember that newRV() will increment
# the refcount.
O_AvRV
    $arg = sv_bless( newRV((SV*)$var), gv_stashpv(CLASS,1) );

T_AvRV
    $arg = newRV((SV*)$var);


######################################################################
INPUT

O_OBJECT
    if( sv_isobject($arg) && (SvTYPE(SvRV($arg)) == SVt_PVMG) )
        $var = ($type)SvIV((SV*)SvRV( $arg ));
    else{
        warn( \"${Package}::$func_name() -- $var is not a blessed SV reference\" );
        XSRETURN_UNDEF;
    }

T_OBJECT
    if( SvROK($arg) )
        $var = ($type)SvIV((SV*)SvRV( $arg ));
    else{
        warn( \"${Package}::$func_name() -- $var is not an SV reference\" );
        XSRETURN_UNDEF;
    }

O_HvRV
    if( sv_isobject($arg) && (SvTYPE(SvRV($arg)) == SVt_PVHV) )
        $var = (HV*)SvRV( $arg );
    else {
        warn( \"${Package}::$func_name() -- $var is not a blessed HV reference\" );
        XSRETURN_UNDEF;
    }

T_HvRV
    if( SvROK($arg) && (SvTYPE(SvRV($arg)) == SVt_PVHV) )
        $var = (HV*)SvRV( $arg );
    else {
        warn( \"${Package}::$func_name() -- $var is not an HV reference\" );
        XSRETURN_UNDEF;
    }

O_AvRV
    if( sv_isobject($arg) && (SvTYPE(SvRV($arg)) == SVt_PVAV) )
        $var = (AV*)SvRV( $arg );
    else {
        warn( \"${Package}::$func_name() -- $var is not a blessed AV reference\" );
        XSRETURN_UNDEF;
    }

T_AvRV
    if( SvROK($arg) && (SvTYPE(SvRV($arg)) == SVt_PVAV) )
        $var = (AV*)SvRV( $arg );
    else {
        warn( \"${Package}::$func_name() -- $var is not an AV reference\" );
        XSRETURN_UNDEF;
    }

