###############################################################################
##
##    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 surf_key   = "surface";
        string surf_value = util->showString($var->words[i].surf);

        SV* sv = newSVpvn( surf_value.c_str(), surf_value.length() );
        hv_store(hv, surf_key.c_str(), surf_key.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_key   = "feature";
                string feature_value = util->showString($var->words[i].tags[j][k].first);

                string score_key   = "score";
                double score_value = $var->words[i].tags[j][k].second;

                sv = newSVpvn( feature_value.c_str(), feature_value.length() );
                hv_store(tag, feature_key.c_str(), feature_key.length(), sv, 0);

                sv = newSVnv(score_value);
                hv_store(tag, score_key.c_str(), score_key.length(), sv, 0);

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

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

        string tags_key = "tags";
        hv_store(hv, tags_key.c_str(), tags_key.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;
    }

