diff options
author | why <why@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-05-18 06:10:45 +0000 |
---|---|---|
committer | why <why@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-05-18 06:10:45 +0000 |
commit | 75db654808404ad6f7ec79c3f9ae6fda8a3c827e (patch) | |
tree | efdfe2050baaa4500e18b10412e948bc5f480332 /lib/yaml.rb | |
parent | 62289f13673c5af189d4314bf509f0ffbb342766 (diff) | |
download | ruby-75db654808404ad6f7ec79c3f9ae6fda8a3c827e.tar.gz |
* lib/yaml.rb: added rdoc to beginning of lib.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6358 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/yaml.rb')
-rw-r--r-- | lib/yaml.rb | 76 |
1 files changed, 58 insertions, 18 deletions
diff --git a/lib/yaml.rb b/lib/yaml.rb index 05cab0c376..023c4ab84b 100644 --- a/lib/yaml.rb +++ b/lib/yaml.rb @@ -1,16 +1,16 @@ # -*- mode: ruby; ruby-indent-level: 4; tab-width: 4 -*- vim: sw=4 ts=4 # $Id$ # +# = yaml.rb: top-level module with methods for loading and parsing YAML documents +# +# Author:: why the lucky stiff +# require 'yaml/syck' require 'yaml/loader' require 'yaml/stream' -# = yaml.rb: top-level module with methods for loading and parsing YAML documents -# -# Author:: why the lucky stiff -# -# == About YAML +# == YAML # # YAML(tm) (rhymes with 'camel') is a # straightforward machine parsable data serialization format designed for @@ -89,13 +89,13 @@ module YAML # Converts _obj_ to YAML and writes the YAML result to _io_. # # File.open( 'animals.yaml', 'w' ) do |out| - # YAML::dump( ['badger', 'elephant', 'tiger'], out ) + # YAML.dump( ['badger', 'elephant', 'tiger'], out ) # end # # If no _io_ is provided, a string containing the dumped YAML # is returned. # - # YAML::dump( :locked ) + # YAML.dump( :locked ) # #=> "--- :locked" # def YAML.dump( obj, io = nil ) @@ -107,7 +107,7 @@ module YAML # # Load the first document from the current _io_ stream. # - # File.open( 'animals.yml' ) { |yml| YAML::load( yml ) } + # File.open( 'animals.yaml' ) { |yf| YAML::load( yf ) } # #=> ['badger', 'elephant', 'tiger'] # # Can also load from a string. @@ -122,7 +122,7 @@ module YAML # # Parse the first document from the current _io_ stream # - # File.open( 'animals.yml' ) { |yml| YAML::load( yml ) } + # File.open( 'animals.yaml' ) { |yf| YAML::load( yf ) } # #=> #<YAML::Syck::Node:0x82ccce0 # @kind=:seq, # @value= @@ -151,35 +151,69 @@ module YAML end # - # Load all documents from the current stream + # Calls _block_ with each consecutive document in the YAML + # stream contained in _io_. + # + # File.open( 'many-docs.yaml' ) do |yf| + # YAML.each_document( yf ) do |ydoc| + # ## ydoc contains the single object + # ## from the YAML document + # end + # end # - def YAML.each_document( io, &doc_proc ) - yp = @@parser.new.load_documents( io, &doc_proc ) + def YAML.each_document( io, &block ) + yp = @@parser.new.load_documents( io, &block ) end # - # Identical to each_document + # Calls _block_ with each consecutive document in the YAML + # stream contained in _io_. + # + # File.open( 'many-docs.yaml' ) do |yf| + # YAML.load_documents( yf ) do |ydoc| + # ## ydoc contains the single object + # ## from the YAML document + # end + # end # def YAML.load_documents( io, &doc_proc ) YAML.each_document( io, &doc_proc ) end # - # Parse all documents from the current stream + # Calls _block_ with a tree of +YAML::BaseNodes+, one tree for + # each consecutive document in the YAML stream contained in _io_. + # + # File.open( 'many-docs.yaml' ) do |yf| + # YAML.each_node( yf ) do |ydoc| + # ## ydoc contains a tree of nodes + # ## from the YAML document + # end + # end # def YAML.each_node( io, &doc_proc ) yp = @@parser.new( :Model => :Generic ).load_documents( io, &doc_proc ) end # - # Parse all documents from the current stream + # Calls _block_ with a tree of +YAML::BaseNodes+, one tree for + # each consecutive document in the YAML stream contained in _io_. + # + # File.open( 'many-docs.yaml' ) do |yf| + # YAML.parse_documents( yf ) do |ydoc| + # ## ydoc contains a tree of nodes + # ## from the YAML document + # end + # end # def YAML.parse_documents( io, &doc_proc ) YAML.each_node( io, &doc_proc ) end # - # Load all documents from the current stream + # Loads all documents from the current _io_ stream, + # returning a +YAML::Stream+ object containing all + # loaded documents. # def YAML.load_stream( io ) yp = @@parser.new @@ -192,7 +226,13 @@ module YAML end # - # Dump documents to a stream + # Returns a YAML stream containing each of the items in +objs+, + # each having their own document. + # + # YAML.dump_stream( 0, [], {} ) + # #=> --- 0 + # --- [] + # --- {} # def YAML.dump_stream( *objs ) d = YAML::Stream.new @@ -203,7 +243,7 @@ module YAML end # - # Add a transfer method to a domain + # Add a global handler for a YAML domain type. # def YAML.add_domain_type( domain, type_re, &transfer_proc ) @@loader.add_domain_type( domain, type_re, &transfer_proc ) |