The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
###############################################################################
##
##    Typemap for Text::KyTea
##
##    Copyright (C) pawa
##    All rights reserved.
##
###############################################################################

TYPEMAP
text_kytea_TextKyTea *   O_OBJECT
kytea_KyteaSentence      T_KYTEA_SENTENCE
const char * const       T_PV
std_string               T_STRING

OUTPUT
T_STRING
    sv_setpvn( $arg, $var.c_str(), $var.length() );

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

    kytea::StringUtil* util = THIS->util;

    const kytea::KyteaSentence::Words& words = $var.words;

    for (size_t i = 0; i < words.size(); ++i)
    {
        HV* hv = (HV*)sv_2mortal( (SV*)newHV() );

        std::string surface = util->showString(words[i].surface);

        hv_store(hv, text_kytea::tkt_keys[0].c_str(), text_kytea::tkt_keys[0].length(), newSVpvn( surface.c_str(), surface.length() ), 0);

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

        for (size_t j = 0; j < words[i].tags.size(); ++j)
        {
            AV* tag_pairs = (AV*)sv_2mortal( (SV*)newAV() );

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

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

                hv_store(tag, text_kytea::tkt_keys[1].c_str(), text_kytea::tkt_keys[1].length(), newSVpvn( feature.c_str(), feature.length() ), 0);
                hv_store(tag, text_kytea::tkt_keys[2].c_str(), text_kytea::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, text_kytea::tkt_keys[3].c_str(), text_kytea::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;
    }