class Object::Syck::Parser
Define YAML::Syck::Parser class
Attributes
          input[RW]
        
        
          options[RW]
        
        
          resolver[RW]
        
        Public Class Methods
            new(p1 = v1)
            click to toggle source
          
        YAML::Syck::Parser.initialize( resolver, options )
static VALUE
syck_parser_initialize(int argc, VALUE *argv, VALUE self)
{
    VALUE options;
    if (rb_scan_args(argc, argv, "01", &options) == 0)
    {
        options = rb_hash_new();
    }
    else
    {
        Check_Type(options, T_HASH);
    }
    rb_ivar_set(self, s_options, options);
    rb_ivar_set(self, s_input, Qnil);
    return self;
}
          Public Instance Methods
            bufsize()
            click to toggle source
          
        YAML::Syck::Parser.bufsize => Integer
static VALUE
syck_parser_bufsize_get(VALUE self)
{
    SyckParser *parser;
    Data_Get_Struct(self, SyckParser, parser);
    return INT2FIX( parser->bufsize );
}
          
            bufsize=(p1)
            click to toggle source
          
        YAML::Syck::Parser.bufsize = Integer
static VALUE
syck_parser_bufsize_set(VALUE self, VALUE size)
{
    SyckParser *parser;
    if ( rb_respond_to( size, s_to_i ) ) {
        int n = NUM2INT(rb_funcall(size, s_to_i, 0));
        Data_Get_Struct(self, SyckParser, parser);
        parser->bufsize = n;
    }
    return self;
}
          
            load(p1, p2 = v2)
            click to toggle source
          
        YAML::Syck::Parser.load( IO or String )
VALUE
syck_parser_load(int argc, VALUE *argv, VALUE self)
{
    VALUE port, proc, model, input;
    SyckParser *parser;
    struct parser_xtra *bonus;
    rb_scan_args(argc, argv, "11", &port, &proc);
    input = rb_hash_aref( rb_attr_get( self, s_options ), sym_input );
    model = rb_hash_aref( rb_attr_get( self, s_options ), sym_model );
    Data_Get_Struct(self, SyckParser, parser);
    syck_set_model( self, input, model );
    bonus = (struct parser_xtra *)parser->bonus;
    bonus->taint = syck_parser_assign_io(parser, &port);
    bonus->data = rb_hash_new();
    bonus->resolver = rb_attr_get( self, s_resolver );
    if ( NIL_P( proc ) ) bonus->proc = 0;
    else                 bonus->proc = proc;
    return syck_parse( parser );
}
          
            load_documents(p1, &block)
            click to toggle source
          
        YAML::Syck::Parser.load_documents( IO or String ) { |doc| }
VALUE
syck_parser_load_documents(int argc, VALUE *argv, VALUE self)
{
    VALUE port, proc, v, input, model;
    SyckParser *parser;
    struct parser_xtra *bonus;
    rb_scan_args(argc, argv, "1&", &port, &proc);
    input = rb_hash_aref( rb_attr_get( self, s_options ), sym_input );
    model = rb_hash_aref( rb_attr_get( self, s_options ), sym_model );
    Data_Get_Struct(self, SyckParser, parser);
    syck_set_model( self, input, model );
    bonus = (struct parser_xtra *)parser->bonus;
    bonus->taint = syck_parser_assign_io(parser, &port);
    bonus->resolver = rb_attr_get( self, s_resolver );
    bonus->proc = 0;
    while ( 1 )
    {
        /* Reset hash for tracking nodes */
        bonus->data = rb_hash_new();
        /* Parse a document */
        v = syck_parse( parser );
        if ( parser->eof == 1 )
        {
            break;
        }
        /* Pass document to block */
        rb_funcall( proc, s_call, 1, v );
    }
    return Qnil;
}
          
            set_resolver(p1)
            click to toggle source
          
        YAML::Syck::Parser#set_resolver
VALUE
syck_parser_set_resolver(VALUE self, VALUE resolver)
{
    rb_ivar_set( self, s_resolver, resolver );
    return self;
}