Parent

Range

Public Class Methods

yaml_new( klass, tag, val ) click to toggle source
 
               # File syck/lib/syck/rubytypes.rb, line 210
def Range.yaml_new( klass, tag, val )
    inr = %r(\w+|[+-]?\d+(?:\.\d+)?(?:e[+-]\d+)?|"(?:[^\"]|\.)*")'
    opts = {}
    if String === val and val =~ /^#{inr}(\.{2,3})#{inr}$/
        r1, rdots, r2 = $1, $2, $3
        opts = {
            'begin' => YAML.load( "--- #{r1}" ),
            'end' => YAML.load( "--- #{r2}" ),
            'excl' => rdots.length == 3
        }
        val = {}
    elsif Hash === val
        opts['begin'] = val.delete('begin')
        opts['end'] = val.delete('end')
        opts['excl'] = val.delete('excl')
    end
    if Hash === opts
        r = YAML::object_maker( klass, {} )
        # Thank you, NaHi
        Range.instance_method(:initialize).
              bind(r).
              call( opts['begin'], opts['end'], opts['excl'] )
        val.each { |k,v| r.instance_variable_set( k, v ) }
        r
    else
        raise YAML::TypeError, "Invalid Range: " + val.inspect
    end
end
            

Public Instance Methods

to_yaml( opts = {} ) click to toggle source
 
               # File syck/lib/syck/rubytypes.rb, line 238
def to_yaml( opts = {} )
return super unless YAML::ENGINE.syck?
        YAML::quick_emit( self, opts ) do |out|
    # if self.begin.is_complex_yaml? or self.begin.respond_to? :to_str or
    #   self.end.is_complex_yaml? or self.end.respond_to? :to_str or
    #   not to_yaml_properties.empty?
        out.map( taguri, to_yaml_style ) do |map|
            map.add( 'begin', self.begin )
            map.add( 'end', self.end )
            map.add( 'excl', self.exclude_end? )
            to_yaml_properties.each do |m|
                map.add( m, instance_variable_get( m ) )
            end
        end
    # else
    #     out.scalar( taguri ) do |sc|
    #         sc.embed( self.begin )
    #         sc.concat( self.exclude_end? ? "..." : ".." )
    #         sc.embed( self.end )
    #     end
    # end
end
end
            

Commenting is here to help enhance the documentation. For example, sample code, or clarification of the documentation.

If you are posting code samples in your comments, please wrap them in "<pre><code class="ruby" > ... </code></pre>" markup in order to get syntax highlighting.

If you have questions about Ruby or the documentation, please post to one of the Ruby mailing lists. You will get better, faster, help that way.

If you wish to post a correction of the docs, please do so, but also file a bug report so that it can be corrected for the next release. Thank you.

blog comments powered by Disqus