diff --git a/ChangeLog b/ChangeLog index e02b8a8143..d082bde674 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +Sat May 15 13:38:33 2004 Nobuyoshi Nakada + + * ext/syck/MANIFEST, ext/syck/depend: new file. + + * lib/yaml/rubytypes.rb: range of exponential floats. [ruby-core:02824] + + * test/yaml/test_yaml.rb: tests for strings start with colon and some + round trip. + Sat May 15 12:04:58 2004 why the lucky stiff * lib/yaml.rb: removed fallback to pure Ruby parser. @@ -44,7 +53,7 @@ Fri May 14 21:29:26 2004 Yukihiro Matsumoto Fri May 14 18:37:49 2004 Hidetoshi NAGAI * ext/tk/lib/tk/canvas.rb: improve coords support for canvas - items. Now, supports all of the followings. + items. Now, supports all of the followings. TkcLine.new(c, 0, 0, 100, 100, :fill=>'red') TkcLine.new(c, [0, 0, 100, 100], :fill=>'red') TkcLine.new(c, [0, 0], [100, 100], :fill=>'red') diff --git a/ext/syck/MANIFEST b/ext/syck/MANIFEST index bb126fa530..d1e7ef4e58 100644 --- a/ext/syck/MANIFEST +++ b/ext/syck/MANIFEST @@ -1,4 +1,5 @@ MANIFEST +depend extconf.rb bytecode.c emitter.c diff --git a/ext/syck/depend b/ext/syck/depend new file mode 100644 index 0000000000..05303cdf47 --- /dev/null +++ b/ext/syck/depend @@ -0,0 +1,10 @@ +handler.o: handler.c syck.h +emitter.o: emitter.c syck.h +implicit.o: implicit.c syck.h +gram.o: gram.c syck.h +bytecode.o: bytecode.c syck.h gram.h +node.o: node.c syck.h +syck.o: syck.c syck.h +token.o: token.c syck.h gram.h +yaml2byte.o: yaml2byte.c syck.h yamlbyte.h +rubyext.o: rubyext.c syck.h diff --git a/lib/yaml/rubytypes.rb b/lib/yaml/rubytypes.rb index 1f7f49633c..239688a6b2 100644 --- a/lib/yaml/rubytypes.rb +++ b/lib/yaml/rubytypes.rb @@ -371,7 +371,7 @@ end symbol_proc = Proc.new { |type, val| if String === val - val = YAML::load( "--- #{val}") if val =~ /^["'].*["']$/ + val = YAML::load( "--- #{val}") if val =~ /^["'].*['"]$/ val.intern else raise YAML::Error, "Invalid Symbol: " + val.inspect @@ -414,9 +414,9 @@ end YAML.add_ruby_type( /^range/ ) { |type, val| type, obj_class = YAML.read_type_class( type, ::Range ) - inr = '(\w+|[+-]*\d+(?:\.\d+)?|"(?:[^\\"]|\\.)*")' + inr = %r'(\w+|[+-]?\d+(?:\.\d+)?(?:e[+-]\d+)?|"(?:[^\\"]|\\.)*")' opts = {} - if String === val and val =~ /^#{inr}(\.{2,3})#{inr}$/ + if String === val and val =~ /^#{inr}(\.{2,3})#{inr}$/o r1, rdots, r2 = $1, $2, $3 opts = { 'begin' => YAML.load( "--- #{r1}" ), diff --git a/test/yaml/test_yaml.rb b/test/yaml/test_yaml.rb index 9b1a4f4d3b..05332a6e40 100644 --- a/test/yaml/test_yaml.rb +++ b/test/yaml/test_yaml.rb @@ -33,6 +33,10 @@ class YAML_Unit_Tests < Test::Unit::TestCase assert_equal( obj, YAML::parse( yaml ).transform ) end + def assert_cycle( obj ) + assert_equal( obj, YAML::load( obj.to_yaml ) ) + end + def assert_path_segments( path, segments ) YAML::YPath.each_path( path ) { |choice| assert_equal( choice.segments, segments.shift ) @@ -71,10 +75,14 @@ EOY def test_basic_strings # Common string types + assert_cycle("x") + assert_cycle(":x") + assert_cycle(":") assert_parse_only( { 1 => 'simple string', 2 => 42, 3 => '1 Single Quoted String', 4 => 'YAML\'s Double "Quoted" String', 5 => "A block\n with several\n lines.\n", - 6 => "A \"chomped\" block", 7 => "A folded\n string\n" }, < "A \"chomped\" block", 7 => "A folded\n string\n", 8 => ": started string" }, + < - Mark McGwire's + Mark McGwire\'s year was crippled by a knee injury. EOY @@ -909,7 +918,7 @@ literal: | single line break, but does not start with one. -is equal to: "The \\ \' \\" characters may \\ +is equal to: "The \\ ' \\" characters may \\ be\\nfreely used. Leading white\\n space \\ is significant.\\n\\nLine breaks are \\ significant.\\nThus this value contains \\ @@ -1031,7 +1040,7 @@ EOY def test_ruby_regexp # Test Ruby regular expressions assert_to_yaml( - { 'simple' => /a.b/, 'complex' => /\A"((?:[^"]|\")+)"/, + { 'simple' => /a.b/, 'complex' => %r'\A"((?:[^"]|\")+)"', 'case-insensitive' => /George McFly/i }, <