* ext/syck/gram.c: added grammar for certain empty sequence entries.

* ext/syck/handler.c, ext/syck/syck.c, ext/syck/syck.h: track bad anchors.

* ext/syck/token.c: added pause token, tag possible circular references.

* lib/yaml/rubytypes.rb: parsing YMD time as Date instance.

* ext/syck/rubyext.c: ditto. DomainType, PrivateType, BadAlias classes.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3954 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
why 2003-06-17 16:55:54 +00:00
parent 77e941269f
commit ae28f1b6b3
9 changed files with 1085 additions and 801 deletions

View File

@ -1,3 +1,15 @@
Tue Jun 17 17:01:08 2003 why the lucky stiff <ruby-cvs@whytheluckystiff.net>
* ext/syck/gram.c: added grammar for certain empty sequence entries.
* ext/syck/handler.c, ext/syck/syck.c, ext/syck/syck.h: track bad anchors.
* ext/syck/token.c: added pause token, tag possible circular references.
* lib/yaml/rubytypes.rb: parsing YMD time as Date instance.
* ext/syck/rubyext.c: ditto. DomainType, PrivateType, BadAlias classes.
Tue Jun 17 21:28:27 2003 Ariff Abdullah <skywizard@time.net.my> Tue Jun 17 21:28:27 2003 Ariff Abdullah <skywizard@time.net.my>
* win32/win32.c (rb_w32_opendir): need to set errno. [ruby-talk:73761] * win32/win32.c (rb_w32_opendir): need to set errno. [ruby-talk:73761]

View File

@ -306,6 +306,22 @@ lib/rexml/parsers/sax2parser.rb
lib/rexml/parsers/streamparser.rb lib/rexml/parsers/streamparser.rb
lib/rexml/parsers/ultralightparser.rb lib/rexml/parsers/ultralightparser.rb
lib/rexml/parsers/xpathparser.rb lib/rexml/parsers/xpathparser.rb
lib/yaml.rb
lib/yaml/basenode.rb
lib/yaml/constants.rb
lib/yaml/dbm.rb
lib/yaml/emitter.rb
lib/yaml/encoding.rb
lib/yaml/error.rb
lib/yaml/loader.rb
lib/yaml/rubytypes.rb
lib/yaml/store.rb
lib/yaml/stream.rb
lib/yaml/stringio.rb
lib/yaml/syck.rb
lib/yaml/types.rb
lib/yaml/yamlnode.rb
lib/yaml/ypath.rb
misc/README misc/README
misc/inf-ruby.el misc/inf-ruby.el
misc/ruby-mode.el misc/ruby-mode.el

View File

@ -228,17 +228,17 @@ union yyalloc
#endif #endif
/* YYFINAL -- State number of the termination state. */ /* YYFINAL -- State number of the termination state. */
#define YYFINAL 34 #define YYFINAL 35
#define YYLAST 307 #define YYLAST 333
/* YYNTOKENS -- Number of terminals. */ /* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 23 #define YYNTOKENS 23
/* YYNNTS -- Number of nonterminals. */ /* YYNNTS -- Number of nonterminals. */
#define YYNNTS 25 #define YYNNTS 25
/* YYNRULES -- Number of rules. */ /* YYNRULES -- Number of rules. */
#define YYNRULES 62 #define YYNRULES 63
/* YYNRULES -- Number of states. */ /* YYNRULES -- Number of states. */
#define YYNSTATES 104 #define YYNSTATES 106
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2 #define YYUNDEFTOK 2
@ -285,12 +285,12 @@ static const unsigned char yytranslate[] =
static const unsigned char yyprhs[] = static const unsigned char yyprhs[] =
{ {
0, 0, 3, 5, 8, 9, 11, 13, 15, 18, 0, 0, 3, 5, 8, 9, 11, 13, 15, 18,
22, 26, 28, 29, 31, 34, 36, 38, 40, 43, 22, 26, 28, 31, 32, 34, 37, 39, 41, 43,
46, 49, 52, 54, 56, 58, 61, 63, 65, 67, 46, 49, 52, 55, 57, 59, 61, 64, 66, 68,
69, 71, 75, 78, 80, 84, 87, 91, 94, 96, 70, 72, 74, 78, 81, 83, 87, 90, 94, 97,
100, 103, 107, 110, 112, 116, 120, 124, 128, 131, 99, 103, 106, 110, 113, 115, 119, 123, 127, 131,
135, 138, 142, 144, 150, 152, 156, 160, 163, 167, 134, 138, 141, 145, 147, 153, 155, 159, 163, 166,
171, 174, 176 170, 174, 177, 179
}; };
/* YYRHS -- A `-1'-separated list of the rules' RHS. */ /* YYRHS -- A `-1'-separated list of the rules' RHS. */
@ -298,34 +298,35 @@ static const yysigned_char yyrhs[] =
{ {
24, 0, -1, 33, -1, 10, 27, -1, -1, 32, 24, 0, -1, 33, -1, 10, 27, -1, -1, 32,
-1, 26, -1, 33, -1, 3, 26, -1, 28, 32, -1, 26, -1, 33, -1, 3, 26, -1, 28, 32,
31, -1, 28, 26, 31, -1, 25, -1, -1, 11, 31, -1, 28, 26, 31, -1, 25, -1, 28, 29,
-1, 28, 12, -1, 13, -1, 12, -1, 13, -1, -1, -1, 11, -1, 28, 12, -1, 13, -1, 12,
30, 31, -1, 5, 32, -1, 6, 32, -1, 3, -1, 13, -1, 30, 31, -1, 5, 32, -1, 6,
32, -1, 4, -1, 7, -1, 8, -1, 5, 33, 32, -1, 3, 32, -1, 4, -1, 7, -1, 8,
-1, 9, -1, 34, -1, 38, -1, 40, -1, 46, -1, 5, 33, -1, 9, -1, 34, -1, 38, -1,
-1, 28, 36, 29, -1, 14, 27, -1, 37, -1, 40, -1, 46, -1, 28, 36, 29, -1, 14, 27,
5, 30, 36, -1, 5, 36, -1, 3, 30, 36, -1, 37, -1, 5, 30, 36, -1, 5, 36, -1,
-1, 3, 36, -1, 35, -1, 37, 30, 35, -1, 3, 30, 36, -1, 3, 36, -1, 35, -1, 37,
37, 30, -1, 17, 39, 18, -1, 17, 18, -1, 30, 35, -1, 37, 30, -1, 17, 39, 18, -1,
25, -1, 39, 21, 25, -1, 28, 41, 29, -1, 17, 18, -1, 25, -1, 39, 21, 25, -1, 28,
28, 44, 29, -1, 5, 30, 44, -1, 5, 41, 41, 29, -1, 28, 44, 29, -1, 5, 30, 44,
-1, 3, 30, 44, -1, 3, 41, -1, 32, 15, -1, 5, 41, -1, 3, 30, 44, -1, 3, 41,
27, -1, 42, -1, 22, 25, 30, 15, 27, -1, -1, 32, 15, 27, -1, 42, -1, 22, 25, 30,
43, -1, 44, 30, 35, -1, 44, 30, 43, -1, 15, 27, -1, 43, -1, 44, 30, 35, -1, 44,
44, 30, -1, 25, 15, 27, -1, 19, 47, 20, 30, 43, -1, 44, 30, -1, 25, 15, 27, -1,
-1, 19, 20, -1, 45, -1, 47, 21, 45, -1 19, 47, 20, -1, 19, 20, -1, 45, -1, 47,
21, 45, -1
}; };
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */ /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
static const unsigned short yyrline[] = static const unsigned short yyrline[] =
{ {
0, 44, 44, 48, 52, 58, 59, 62, 63, 72, 0, 44, 44, 48, 52, 58, 59, 62, 63, 72,
76, 82, 83, 101, 102, 105, 108, 111, 112, 120, 76, 82, 83, 96, 114, 115, 118, 121, 124, 125,
125, 133, 137, 145, 158, 165, 170, 171, 172, 173, 133, 138, 146, 150, 158, 171, 178, 183, 184, 185,
174, 180, 186, 192, 193, 198, 203, 207, 213, 217, 186, 187, 193, 199, 205, 206, 211, 216, 220, 226,
222, 231, 235, 241, 245, 255, 260, 267, 272, 277, 230, 235, 244, 248, 254, 258, 268, 273, 280, 285,
281, 287, 302, 303, 311, 312, 324, 331, 340, 348, 290, 294, 300, 315, 316, 324, 325, 337, 344, 353,
352, 358, 359 361, 365, 371, 372
}; };
#endif #endif
@ -361,24 +362,24 @@ static const unsigned short yytoknum[] =
static const unsigned char yyr1[] = static const unsigned char yyr1[] =
{ {
0, 23, 24, 24, 24, 25, 25, 26, 26, 26, 0, 23, 24, 24, 24, 25, 25, 26, 26, 26,
26, 27, 27, 28, 28, 29, 30, 31, 31, 32, 26, 27, 27, 27, 28, 28, 29, 30, 31, 31,
32, 32, 32, 32, 32, 33, 33, 33, 33, 33, 32, 32, 32, 32, 32, 32, 33, 33, 33, 33,
33, 34, 35, 36, 36, 36, 36, 36, 37, 37, 33, 33, 34, 35, 36, 36, 36, 36, 36, 37,
37, 38, 38, 39, 39, 40, 40, 41, 41, 41, 37, 37, 38, 38, 39, 39, 40, 40, 41, 41,
41, 42, 43, 43, 44, 44, 44, 44, 45, 46, 41, 41, 42, 43, 43, 44, 44, 44, 44, 45,
46, 47, 47 46, 46, 47, 47
}; };
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */ /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
static const unsigned char yyr2[] = static const unsigned char yyr2[] =
{ {
0, 2, 1, 2, 0, 1, 1, 1, 2, 3, 0, 2, 1, 2, 0, 1, 1, 1, 2, 3,
3, 1, 0, 1, 2, 1, 1, 1, 2, 2, 3, 1, 2, 0, 1, 2, 1, 1, 1, 2,
2, 2, 1, 1, 1, 2, 1, 1, 1, 1, 2, 2, 2, 1, 1, 1, 2, 1, 1, 1,
1, 3, 2, 1, 3, 2, 3, 2, 1, 3, 1, 1, 3, 2, 1, 3, 2, 3, 2, 1,
2, 3, 2, 1, 3, 3, 3, 3, 2, 3, 3, 2, 3, 2, 1, 3, 3, 3, 3, 2,
2, 3, 1, 5, 1, 3, 3, 2, 3, 3, 3, 2, 3, 1, 5, 1, 3, 3, 2, 3,
2, 1, 3 3, 2, 1, 3
}; };
/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
@ -386,51 +387,51 @@ static const unsigned char yyr2[] =
means the default is an error. */ means the default is an error. */
static const unsigned char yydefact[] = static const unsigned char yydefact[] =
{ {
4, 0, 26, 12, 13, 0, 0, 0, 0, 2, 4, 0, 27, 13, 14, 0, 0, 0, 0, 2,
27, 28, 29, 30, 25, 0, 22, 0, 0, 23, 28, 29, 30, 31, 26, 0, 23, 0, 0, 24,
24, 11, 6, 3, 0, 5, 7, 42, 43, 0, 25, 11, 6, 3, 0, 5, 7, 43, 44, 0,
60, 0, 61, 0, 1, 0, 0, 14, 12, 0, 0, 61, 0, 62, 0, 1, 0, 0, 15, 13,
0, 38, 0, 33, 0, 52, 54, 0, 8, 21, 0, 0, 39, 0, 34, 0, 53, 55, 0, 8,
0, 19, 0, 20, 0, 0, 0, 0, 41, 0, 22, 0, 20, 0, 21, 0, 0, 16, 0, 12,
12, 59, 0, 16, 0, 37, 50, 0, 35, 48, 0, 42, 0, 13, 60, 0, 17, 0, 38, 51,
32, 0, 12, 15, 31, 40, 45, 46, 57, 17, 0, 36, 49, 33, 0, 13, 32, 41, 46, 47,
0, 10, 9, 44, 58, 62, 0, 0, 36, 49, 58, 18, 0, 10, 9, 45, 59, 63, 0, 0,
34, 47, 0, 51, 39, 55, 56, 18, 0, 0, 37, 50, 35, 48, 0, 52, 40, 56, 57, 19,
12, 0, 0, 53 0, 0, 13, 0, 0, 54
}; };
/* YYDEFGOTO[NTERM-NUM]. */ /* YYDEFGOTO[NTERM-NUM]. */
static const yysigned_char yydefgoto[] = static const yysigned_char yydefgoto[] =
{ {
-1, 7, 21, 22, 23, 24, 74, 78, 81, 25, -1, 7, 21, 22, 23, 29, 59, 80, 83, 25,
26, 10, 41, 65, 43, 11, 29, 12, 44, 45, 26, 10, 42, 68, 44, 11, 30, 12, 45, 46,
46, 47, 32, 13, 33 47, 48, 33, 13, 34
}; };
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */ STATE-NUM. */
#define YYPACT_NINF -48 #define YYPACT_NINF -54
static const short yypact[] = static const short yypact[] =
{ {
241, 252, -48, 219, -48, 202, 150, 13, 114, -48, 267, 278, -54, 245, -54, 228, 176, 8, 140, -54,
-48, -48, -48, -48, -48, 219, -48, 236, 299, -48, -54, -54, -54, -54, -54, 245, -54, 262, 325, -54,
-48, -48, -48, -48, 94, -48, -48, -48, -48, 4, -54, -54, -54, -54, 100, -54, -54, -54, -54, 120,
-48, 2, -48, -15, -48, 269, 269, -48, 219, 219, 48, -54, -5, -54, 52, -54, 295, 295, -54, 245,
6, -48, 23, 20, 23, -48, -48, 54, -48, -48, 245, -3, -54, 13, 9, 13, -54, -54, 76, -54,
299, -48, 299, -48, 168, 185, 75, 38, -48, 219, -54, 325, -54, 325, -54, 194, 211, -54, 108, -54,
219, -48, 219, -48, 126, -48, -48, 126, -48, -48, 103, -54, 245, 245, -54, 245, -54, 152, -54, -54,
-48, 20, 219, -48, -48, 12, -48, -48, 138, -48, 152, -54, -54, -54, 9, 245, -54, 24, -54, -54,
75, -48, -48, -48, -48, -48, 281, 281, -48, 20, 164, -54, 108, -54, -54, -54, -54, -54, 307, 307,
-48, 20, 37, -48, -48, -48, -48, -48, 79, 79, -54, 9, -54, 9, 32, -54, -54, -54, -54, -54,
219, 287, 287, -48 6, 6, 245, 313, 313, -54
}; };
/* YYPGOTO[NTERM-NUM]. */ /* YYPGOTO[NTERM-NUM]. */
static const yysigned_char yypgoto[] = static const yysigned_char yypgoto[] =
{ {
-48, -48, -2, 19, -37, 7, 21, -16, -47, -6, -54, -54, 31, -10, -35, 0, 12, -12, -53, -2,
14, -48, -33, -8, -48, -48, -48, -48, 41, -48, 41, -54, -47, -6, -54, -54, -54, -54, 44, -54,
-24, 11, 27, -48, -48 -28, 15, 14, -54, -54
}; };
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
@ -440,72 +441,78 @@ static const yysigned_char yypgoto[] =
#define YYTABLE_NINF -1 #define YYTABLE_NINF -1
static const unsigned char yytable[] = static const unsigned char yytable[] =
{ {
42, 70, 40, 28, 31, 61, 62, 8, 8, 49, 8, 8, 43, 24, 73, 49, 41, 84, 35, 103,
82, 51, 53, 34, 9, 14, 42, 60, 57, 64, 63, 104, 75, 50, 58, 52, 54, 8, 43, 58,
67, 72, 58, 84, 8, 59, 38, 75, 68, 49, 39, 66, 60, 43, 67, 70, 57, 60, 86, 99,
51, 14, 63, 97, 48, 93, 73, 71, 64, 67, 96, 71, 77, 97, 50, 52, 28, 32, 39, 24,
80, 80, 94, 56, 49, 95, 51, 68, 49, 51, 95, 9, 14, 67, 70, 49, 82, 102, 82, 50,
63, 79, 100, 72, 96, 92, 88, 83, 40, 90, 71, 52, 98, 50, 52, 76, 8, 78, 14, 0,
31, 40, 8, 103, 80, 76, 63, 73, 77, 14, 79, 90, 94, 24, 92, 41, 61, 105, 41, 62,
98, 99, 40, 48, 0, 89, 66, 69, 91, 68, 82, 74, 64, 65, 0, 24, 100, 101, 41, 87,
49, 51, 101, 0, 102, 98, 99, 63, 79, 85, 69, 72, 91, 71, 0, 93, 50, 52, 66, 57,
88, 90, 0, 38, 68, 66, 69, 54, 16, 55, 0, 100, 101, 85, 90, 92, 32, 14, 71, 69,
18, 19, 20, 2, 0, 4, 37, 0, 38, 0, 72, 0, 24, 55, 16, 56, 18, 19, 20, 2,
0, 5, 0, 6, 0, 0, 39, 35, 16, 36, 0, 4, 38, 57, 39, 66, 81, 5, 75, 6,
18, 19, 20, 0, 0, 0, 37, 0, 38, 86, 66, 81, 40, 55, 16, 56, 18, 19, 20, 2,
16, 87, 18, 19, 20, 0, 39, 0, 0, 0, 0, 4, 38, 0, 39, 0, 0, 5, 0, 6,
38, 50, 16, 52, 18, 19, 20, 0, 39, 0, 0, 0, 40, 36, 16, 37, 18, 19, 20, 0,
0, 0, 38, 15, 16, 17, 18, 19, 20, 2, 0, 0, 38, 0, 39, 88, 16, 89, 18, 19,
39, 4, 0, 0, 0, 0, 0, 5, 0, 6, 20, 0, 40, 0, 0, 0, 39, 51, 16, 53,
30, 54, 16, 55, 18, 19, 20, 2, 0, 4, 18, 19, 20, 0, 40, 0, 0, 0, 39, 15,
63, 0, 38, 0, 0, 5, 0, 6, 35, 16, 16, 17, 18, 19, 20, 2, 40, 4, 0, 0,
55, 18, 19, 20, 2, 0, 4, 63, 0, 38, 0, 0, 0, 5, 0, 6, 31, 55, 16, 56,
0, 0, 5, 0, 6, 15, 16, 17, 18, 19, 18, 19, 20, 2, 0, 4, 66, 0, 39, 0,
20, 2, 0, 4, 0, 0, 0, 0, 0, 5, 0, 5, 0, 6, 36, 16, 56, 18, 19, 20,
27, 6, 15, 16, 17, 18, 19, 20, 2, 0, 2, 0, 4, 66, 0, 39, 0, 0, 5, 0,
4, 0, 0, 0, 0, 0, 5, 0, 6, 50, 6, 15, 16, 17, 18, 19, 20, 2, 0, 4,
16, 17, 18, 19, 20, 2, 1, 4, 0, 0, 0, 0, 0, 0, 0, 5, 27, 6, 15, 16,
2, 3, 4, 5, 0, 6, 0, 1, 5, 0, 17, 18, 19, 20, 2, 0, 4, 0, 0, 0,
6, 2, 0, 4, 0, 0, 0, 0, 0, 5, 0, 0, 5, 0, 6, 51, 16, 17, 18, 19,
0, 6, 35, 16, 36, 18, 19, 20, 0, 0, 20, 2, 1, 4, 0, 0, 2, 3, 4, 5,
0, 63, 0, 38, 86, 16, 87, 18, 19, 20, 0, 6, 0, 1, 5, 0, 6, 2, 0, 4,
101, 0, 102, 63, 0, 38, 0, 0, 0, 63, 0, 0, 0, 0, 0, 5, 0, 6, 36, 16,
0, 38, 50, 16, 52, 18, 19, 20 37, 18, 19, 20, 0, 0, 0, 66, 0, 39,
88, 16, 89, 18, 19, 20, 103, 0, 104, 66,
0, 39, 0, 0, 0, 66, 0, 39, 51, 16,
53, 18, 19, 20
}; };
static const yysigned_char yycheck[] = static const yysigned_char yycheck[] =
{ {
8, 38, 8, 5, 6, 20, 21, 0, 1, 15, 0, 1, 8, 3, 39, 15, 8, 60, 0, 3,
57, 17, 18, 0, 0, 1, 24, 15, 24, 35, 15, 5, 15, 15, 24, 17, 18, 17, 24, 29,
36, 15, 18, 60, 17, 21, 14, 43, 36, 35, 14, 12, 24, 29, 36, 37, 13, 29, 63, 82,
36, 17, 12, 80, 15, 72, 13, 39, 54, 55, 77, 37, 44, 80, 36, 37, 5, 6, 14, 39,
56, 57, 75, 24, 50, 78, 52, 55, 54, 55, 75, 0, 1, 55, 56, 55, 58, 15, 60, 51,
12, 13, 15, 15, 78, 71, 64, 59, 64, 67, 56, 53, 80, 55, 56, 43, 56, 45, 17, -1,
62, 67, 55, 100, 80, 44, 12, 13, 47, 55, 48, 67, 74, 63, 70, 67, 18, 102, 70, 21,
86, 87, 78, 54, -1, 64, 35, 36, 67, 87, 82, 40, 20, 21, -1, 75, 88, 89, 80, 65,
86, 87, 3, -1, 5, 101, 102, 12, 13, 62, 36, 37, 67, 89, -1, 70, 88, 89, 12, 13,
98, 99, -1, 14, 102, 54, 55, 3, 4, 5, -1, 103, 104, 62, 100, 101, 65, 56, 104, 55,
56, -1, 102, 3, 4, 5, 6, 7, 8, 9,
-1, 11, 12, 13, 14, 12, 13, 17, 15, 19,
12, 13, 22, 3, 4, 5, 6, 7, 8, 9,
-1, 11, 12, -1, 14, -1, -1, 17, -1, 19,
-1, -1, 22, 3, 4, 5, 6, 7, 8, -1,
-1, -1, 12, -1, 14, 3, 4, 5, 6, 7,
8, -1, 22, -1, -1, -1, 14, 3, 4, 5,
6, 7, 8, -1, 22, -1, -1, -1, 14, 3,
4, 5, 6, 7, 8, 9, 22, 11, -1, -1,
-1, -1, -1, 17, -1, 19, 20, 3, 4, 5,
6, 7, 8, 9, -1, 11, 12, -1, 14, -1, 6, 7, 8, 9, -1, 11, 12, -1, 14, -1,
-1, 17, -1, 19, -1, -1, 22, 3, 4, 5, -1, 17, -1, 19, 3, 4, 5, 6, 7, 8,
6, 7, 8, -1, -1, -1, 12, -1, 14, 3, 9, -1, 11, 12, -1, 14, -1, -1, 17, -1,
4, 5, 6, 7, 8, -1, 22, -1, -1, -1, 19, 3, 4, 5, 6, 7, 8, 9, -1, 11,
14, 3, 4, 5, 6, 7, 8, -1, 22, -1, -1, -1, -1, -1, -1, 17, 18, 19, 3, 4,
-1, -1, 14, 3, 4, 5, 6, 7, 8, 9, 5, 6, 7, 8, 9, -1, 11, -1, -1, -1,
22, 11, -1, -1, -1, -1, -1, 17, -1, 19,
20, 3, 4, 5, 6, 7, 8, 9, -1, 11,
12, -1, 14, -1, -1, 17, -1, 19, 3, 4,
5, 6, 7, 8, 9, -1, 11, 12, -1, 14,
-1, -1, 17, -1, 19, 3, 4, 5, 6, 7, -1, -1, 17, -1, 19, 3, 4, 5, 6, 7,
8, 9, -1, 11, -1, -1, -1, -1, -1, 17, 8, 9, 5, 11, -1, -1, 9, 10, 11, 17,
18, 19, 3, 4, 5, 6, 7, 8, 9, -1, -1, 19, -1, 5, 17, -1, 19, 9, -1, 11,
11, -1, -1, -1, -1, -1, 17, -1, 19, 3, -1, -1, -1, -1, -1, 17, -1, 19, 3, 4,
4, 5, 6, 7, 8, 9, 5, 11, -1, -1, 5, 6, 7, 8, -1, -1, -1, 12, -1, 14,
9, 10, 11, 17, -1, 19, -1, 5, 17, -1, 3, 4, 5, 6, 7, 8, 3, -1, 5, 12,
19, 9, -1, 11, -1, -1, -1, -1, -1, 17, -1, 14, -1, -1, -1, 12, -1, 14, 3, 4,
-1, 19, 3, 4, 5, 6, 7, 8, -1, -1, 5, 6, 7, 8
-1, 12, -1, 14, 3, 4, 5, 6, 7, 8,
3, -1, 5, 12, -1, 14, -1, -1, -1, 12,
-1, 14, 3, 4, 5, 6, 7, 8
}; };
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
@ -514,15 +521,15 @@ static const unsigned char yystos[] =
{ {
0, 5, 9, 10, 11, 17, 19, 24, 28, 33, 0, 5, 9, 10, 11, 17, 19, 24, 28, 33,
34, 38, 40, 46, 33, 3, 4, 5, 6, 7, 34, 38, 40, 46, 33, 3, 4, 5, 6, 7,
8, 25, 26, 27, 28, 32, 33, 18, 25, 39, 8, 25, 26, 27, 28, 32, 33, 18, 25, 28,
20, 25, 45, 47, 0, 3, 5, 12, 14, 22, 39, 20, 25, 45, 47, 0, 3, 5, 12, 14,
32, 35, 36, 37, 41, 42, 43, 44, 26, 32, 22, 32, 35, 36, 37, 41, 42, 43, 44, 26,
3, 32, 5, 32, 3, 5, 26, 32, 18, 21, 32, 3, 32, 5, 32, 3, 5, 13, 26, 29,
15, 20, 21, 12, 30, 36, 41, 30, 36, 41, 32, 18, 21, 15, 20, 21, 12, 30, 36, 41,
27, 25, 15, 13, 29, 30, 29, 29, 30, 13, 30, 36, 41, 27, 25, 15, 29, 30, 29, 29,
30, 31, 31, 25, 27, 45, 3, 5, 36, 44, 30, 13, 30, 31, 31, 25, 27, 45, 3, 5,
36, 44, 30, 27, 35, 35, 43, 31, 30, 30, 36, 44, 36, 44, 30, 27, 35, 35, 43, 31,
15, 3, 5, 27 30, 30, 15, 3, 5, 27
}; };
#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
@ -1139,16 +1146,32 @@ yyreduce:
} }
break; break;
case 19: case 13:
#line 121 "gram.y" #line 97 "gram.y"
{
SyckNode *n = syck_new_str( "" );
if ( ((SyckParser *)parser)->taguri_expansion == 1 )
{
n->type_id = syck_taguri( YAML_DOMAIN, "null", 4 );
}
else
{
n->type_id = syck_strndup( "null", 4 );
}
yyval.nodeData = n;
}
break;
case 20:
#line 134 "gram.y"
{ {
syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 20: case 21:
#line 126 "gram.y" #line 139 "gram.y"
{ {
if ( ((SyckParser *)parser)->implicit_typing == 1 ) if ( ((SyckParser *)parser)->implicit_typing == 1 )
{ {
@ -1158,26 +1181,26 @@ yyreduce:
} }
break; break;
case 21: case 22:
#line 134 "gram.y" #line 147 "gram.y"
{ {
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData ); yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData );
} }
break; break;
case 22: case 23:
#line 138 "gram.y" #line 151 "gram.y"
{ {
/* /*
* _Aliases_: The anchor symbol table is scanned for the anchor name. * _Aliases_: The anchor symbol table is scanned for the anchor name.
* The anchor's ID in the language's symbol table is returned. * The anchor's ID in the language's symbol table is returned.
*/ */
yyval.nodeData = syck_hdlr_add_alias( (SyckParser *)parser, yyvsp[0].name ); yyval.nodeData = syck_hdlr_get_anchor( (SyckParser *)parser, yyvsp[0].name );
} }
break; break;
case 23: case 24:
#line 146 "gram.y" #line 159 "gram.y"
{ {
SyckNode *n = yyvsp[0].nodeData; SyckNode *n = yyvsp[0].nodeData;
if ( ((SyckParser *)parser)->taguri_expansion == 1 ) if ( ((SyckParser *)parser)->taguri_expansion == 1 )
@ -1192,119 +1215,111 @@ yyreduce:
} }
break; break;
case 25: case 26:
#line 166 "gram.y" #line 179 "gram.y"
{ {
syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 31: case 32:
#line 181 "gram.y" #line 194 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 32: case 33:
#line 187 "gram.y" #line 200 "gram.y"
{ {
yyval.nodeId = syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData ); yyval.nodeId = syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData );
} }
break; break;
case 34: case 35:
#line 194 "gram.y" #line 207 "gram.y"
{ {
syck_add_transfer( yyvsp[-2].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-2].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 35: case 36:
#line 199 "gram.y" #line 212 "gram.y"
{ {
syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 36: case 37:
#line 204 "gram.y" #line 217 "gram.y"
{ {
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-2].name, yyvsp[0].nodeData ); yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-2].name, yyvsp[0].nodeData );
} }
break; break;
case 37: case 38:
#line 208 "gram.y" #line 221 "gram.y"
{ {
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData ); yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData );
} }
break; break;
case 38: case 39:
#line 214 "gram.y" #line 227 "gram.y"
{ {
yyval.nodeData = syck_new_seq( yyvsp[0].nodeId ); yyval.nodeData = syck_new_seq( yyvsp[0].nodeId );
} }
break; break;
case 39: case 40:
#line 218 "gram.y" #line 231 "gram.y"
{ {
syck_seq_add( yyvsp[-2].nodeData, yyvsp[0].nodeId ); syck_seq_add( yyvsp[-2].nodeData, yyvsp[0].nodeId );
yyval.nodeData = yyvsp[-2].nodeData; yyval.nodeData = yyvsp[-2].nodeData;
} }
break; break;
case 40:
#line 223 "gram.y"
{
yyval.nodeData = yyvsp[-1].nodeData;
}
break;
case 41: case 41:
#line 232 "gram.y" #line 236 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 42: case 42:
#line 236 "gram.y" #line 245 "gram.y"
{
yyval.nodeData = yyvsp[-1].nodeData;
}
break;
case 43:
#line 249 "gram.y"
{ {
yyval.nodeData = syck_alloc_seq(); yyval.nodeData = syck_alloc_seq();
} }
break; break;
case 43: case 44:
#line 242 "gram.y" #line 255 "gram.y"
{ {
yyval.nodeData = syck_new_seq( syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData ) ); yyval.nodeData = syck_new_seq( syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData ) );
} }
break; break;
case 44: case 45:
#line 246 "gram.y" #line 259 "gram.y"
{ {
syck_seq_add( yyvsp[-2].nodeData, syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData ) ); syck_seq_add( yyvsp[-2].nodeData, syck_hdlr_add_node( (SyckParser *)parser, yyvsp[0].nodeData ) );
yyval.nodeData = yyvsp[-2].nodeData; yyval.nodeData = yyvsp[-2].nodeData;
} }
break; break;
case 45:
#line 256 "gram.y"
{
apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData );
yyval.nodeData = yyvsp[-1].nodeData;
}
break;
case 46: case 46:
#line 261 "gram.y" #line 269 "gram.y"
{ {
apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData ); apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData );
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
@ -1312,37 +1327,45 @@ yyreduce:
break; break;
case 47: case 47:
#line 268 "gram.y" #line 274 "gram.y"
{
apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData );
yyval.nodeData = yyvsp[-1].nodeData;
}
break;
case 48:
#line 281 "gram.y"
{ {
syck_add_transfer( yyvsp[-2].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-2].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 48: case 49:
#line 273 "gram.y" #line 286 "gram.y"
{ {
syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-1].name, yyvsp[0].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[0].nodeData; yyval.nodeData = yyvsp[0].nodeData;
} }
break; break;
case 49: case 50:
#line 278 "gram.y" #line 291 "gram.y"
{ {
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-2].name, yyvsp[0].nodeData ); yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-2].name, yyvsp[0].nodeData );
} }
break; break;
case 50: case 51:
#line 282 "gram.y" #line 295 "gram.y"
{ {
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData ); yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData );
} }
break; break;
case 51: case 52:
#line 288 "gram.y" #line 301 "gram.y"
{ {
yyval.nodeData = syck_new_map( yyval.nodeData = syck_new_map(
syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-2].nodeData ), syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-2].nodeData ),
@ -1350,8 +1373,8 @@ yyreduce:
} }
break; break;
case 53: case 54:
#line 304 "gram.y" #line 317 "gram.y"
{ {
yyval.nodeData = syck_new_map( yyval.nodeData = syck_new_map(
syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-3].nodeData ), syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-3].nodeData ),
@ -1359,8 +1382,8 @@ yyreduce:
} }
break; break;
case 55: case 56:
#line 313 "gram.y" #line 326 "gram.y"
{ {
if ( yyvsp[-2].nodeData->shortcut == NULL ) if ( yyvsp[-2].nodeData->shortcut == NULL )
{ {
@ -1374,8 +1397,8 @@ yyreduce:
} }
break; break;
case 56: case 57:
#line 325 "gram.y" #line 338 "gram.y"
{ {
apply_seq_in_map( (SyckParser *)parser, yyvsp[-2].nodeData ); apply_seq_in_map( (SyckParser *)parser, yyvsp[-2].nodeData );
syck_map_update( yyvsp[-2].nodeData, yyvsp[0].nodeData ); syck_map_update( yyvsp[-2].nodeData, yyvsp[0].nodeData );
@ -1384,15 +1407,15 @@ yyreduce:
} }
break; break;
case 57: case 58:
#line 332 "gram.y" #line 345 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 58: case 59:
#line 341 "gram.y" #line 354 "gram.y"
{ {
yyval.nodeData = syck_new_map( yyval.nodeData = syck_new_map(
syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-2].nodeData ), syck_hdlr_add_node( (SyckParser *)parser, yyvsp[-2].nodeData ),
@ -1400,22 +1423,22 @@ yyreduce:
} }
break; break;
case 59: case 60:
#line 349 "gram.y" #line 362 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 60: case 61:
#line 353 "gram.y" #line 366 "gram.y"
{ {
yyval.nodeData = syck_alloc_map(); yyval.nodeData = syck_alloc_map();
} }
break; break;
case 62: case 63:
#line 360 "gram.y" #line 373 "gram.y"
{ {
syck_map_update( yyvsp[-2].nodeData, yyvsp[0].nodeData ); syck_map_update( yyvsp[-2].nodeData, yyvsp[0].nodeData );
syck_free_node( yyvsp[0].nodeData ); syck_free_node( yyvsp[0].nodeData );
@ -1427,7 +1450,7 @@ yyreduce:
} }
/* Line 1016 of /usr/local/share/bison/yacc.c. */ /* Line 1016 of /usr/local/share/bison/yacc.c. */
#line 1431 "y.tab.c" #line 1454 "y.tab.c"
yyvsp -= yylen; yyvsp -= yylen;
yyssp -= yylen; yyssp -= yylen;
@ -1646,7 +1669,7 @@ yyreturn:
} }
#line 367 "gram.y" #line 380 "gram.y"
void void

View File

@ -31,6 +31,18 @@ SyckNode *
syck_hdlr_add_anchor( SyckParser *p, char *a, SyckNode *n ) syck_hdlr_add_anchor( SyckParser *p, char *a, SyckNode *n )
{ {
n->anchor = a; n->anchor = a;
if ( p->bad_anchors != NULL )
{
SyckNode *bad;
if ( st_lookup( p->bad_anchors, (st_data_t)a, (st_data_t *)&bad ) )
{
if ( n->kind != syck_str_kind )
{
n->id = bad->id;
(p->handler)( p, n );
}
}
}
if ( p->anchors == NULL ) if ( p->anchors == NULL )
{ {
p->anchors = st_init_strtable(); p->anchors = st_init_strtable();
@ -39,23 +51,50 @@ syck_hdlr_add_anchor( SyckParser *p, char *a, SyckNode *n )
return n; return n;
} }
SyckNode * void
syck_hdlr_add_alias( SyckParser *p, char *a ) syck_hdlr_remove_anchor( SyckParser *p, char *a )
{ {
SyckNode *n; if ( p->anchors == NULL )
{
p->anchors = st_init_strtable();
}
st_insert( p->anchors, (st_data_t)a, (st_data_t)1 );
}
SyckNode *
syck_hdlr_get_anchor( SyckParser *p, char *a )
{
SyckNode *n = NULL;
if ( p->anchors != NULL ) if ( p->anchors != NULL )
{ {
if ( st_lookup( p->anchors, (st_data_t)a, (st_data_t *)&n ) ) if ( st_lookup( p->anchors, (st_data_t)a, (st_data_t *)&n ) )
{
if ( n != (void *)1 )
{ {
return n; return n;
} }
else
{
if ( p->bad_anchors == NULL )
{
p->bad_anchors = st_init_strtable();
}
if ( ! st_lookup( p->bad_anchors, (st_data_t)a, (st_data_t *)&n ) )
{
n = (p->bad_anchor_handler)( p, a );
st_insert( p->bad_anchors, (st_data_t)a, (st_data_t)n );
}
}
}
} }
// if ( n == NULL )
// FIXME: Return an InvalidAnchor object {
// n = (p->bad_anchor_handler)( p, a );
return syck_new_str( "..." ); }
n->anchor = a;
return n;
} }
void void

View File

@ -12,12 +12,23 @@
#include <sys/types.h> #include <sys/types.h>
#include <time.h> #include <time.h>
typedef struct RVALUE {
union {
struct RBasic basic;
struct RObject object;
struct RClass klass;
struct RArray array;
struct RHash hash;
struct RStruct rstruct;
} as;
} RVALUE;
#define RUBY_DOMAIN "ruby.yaml.org,2002" #define RUBY_DOMAIN "ruby.yaml.org,2002"
static ID s_utc, s_at, s_to_f, s_read, s_binmode; static ID s_new, s_utc, s_at, s_to_f, s_read, s_binmode, s_call, s_transfer;
static VALUE sym_model, sym_generic; static VALUE sym_model, sym_generic;
static VALUE sym_scalar, sym_seq, sym_map; static VALUE sym_scalar, sym_seq, sym_map;
VALUE cParser, cLoader, cNode, oDefaultLoader; VALUE cDate, cParser, cLoader, cNode, cPrivateType, cDomainType, cBadAlias, oDefaultLoader;
/* /*
* my private collection of numerical oddities. * my private collection of numerical oddities.
@ -32,6 +43,7 @@ static VALUE syck_node_transform( VALUE );
SYMID rb_syck_parse_handler _((SyckParser *, SyckNode *)); SYMID rb_syck_parse_handler _((SyckParser *, SyckNode *));
SYMID rb_syck_load_handler _((SyckParser *, SyckNode *)); SYMID rb_syck_load_handler _((SyckParser *, SyckNode *));
void rb_syck_err_handler _((SyckParser *, char *)); void rb_syck_err_handler _((SyckParser *, char *));
SyckNode * rb_syck_bad_anchor_handler _((SyckParser *, char *));
struct parser_xtra { struct parser_xtra {
VALUE data; // Borrowed this idea from marshal.c to fix [ruby-dev:8067] problem VALUE data; // Borrowed this idea from marshal.c to fix [ruby-dev:8067] problem
@ -249,7 +261,7 @@ rb_syck_parse_handler(p, n)
bonus = (struct parser_xtra *)p->bonus; bonus = (struct parser_xtra *)p->bonus;
if ( bonus->proc != 0 ) if ( bonus->proc != 0 )
{ {
rb_funcall(bonus->proc, rb_intern("call"), 1, v); rb_funcall(bonus->proc, s_call, 1, v);
} }
rb_iv_set(obj, "@value", v); rb_iv_set(obj, "@value", v);
@ -333,9 +345,28 @@ rb_syck_load_handler(p, n)
} }
else if ( strcmp( n->type_id, "timestamp#ymd" ) == 0 ) else if ( strcmp( n->type_id, "timestamp#ymd" ) == 0 )
{ {
S_REALLOC_N( n->data.str->ptr, char, 22 ); char *ptr = n->data.str->ptr;
strcat( n->data.str->ptr, "t00:00:00Z" ); VALUE year, mon, day;
obj = rb_syck_mktime( n->data.str->ptr );
// Year
ptr[4] = '\0';
year = INT2FIX(strtol(ptr, NULL, 10));
// Month
ptr += 4;
while ( !isdigit( *ptr ) ) ptr++;
mon = INT2FIX(strtol(ptr, NULL, 10));
// Day
ptr += 2;
while ( !isdigit( *ptr ) ) ptr++;
day = INT2FIX(strtol(ptr, NULL, 10));
obj = rb_funcall( cDate, s_new, 3, year, mon, day );
// S_REALLOC_N( n->data.str->ptr, char, 22 );
// strcat( n->data.str->ptr, "t00:00:00Z" );
// obj = rb_syck_mktime( n->data.str->ptr );
} }
else if ( strncmp( n->type_id, "timestamp", 9 ) == 0 ) else if ( strncmp( n->type_id, "timestamp", 9 ) == 0 )
{ {
@ -367,15 +398,25 @@ rb_syck_load_handler(p, n)
break; break;
} }
//
// ID already set, let's alter the symbol table to accept the new object
//
if (n->id > 0)
{
MEMCPY((void *)n->id, (void *)obj, RVALUE, 1);
MEMZERO((void *)obj, RVALUE, 1);
obj = n->id;
}
bonus = (struct parser_xtra *)p->bonus; bonus = (struct parser_xtra *)p->bonus;
if ( bonus->proc != 0 ) if ( bonus->proc != 0 )
{ {
rb_funcall(bonus->proc, rb_intern("call"), 1, obj); rb_funcall(bonus->proc, s_call, 1, obj);
} }
if ( check_transfers == 1 && n->type_id != NULL ) if ( check_transfers == 1 && n->type_id != NULL )
{ {
obj = rb_funcall( oDefaultLoader, rb_intern( "transfer" ), 2, rb_str_new2( n->type_id ), obj ); obj = rb_funcall( oDefaultLoader, s_transfer, 2, rb_str_new2( n->type_id ), obj );
} }
rb_hash_aset(bonus->data, INT2FIX(RHASH(bonus->data)->tbl->num_entries), obj); rb_hash_aset(bonus->data, INT2FIX(RHASH(bonus->data)->tbl->num_entries), obj);
@ -403,6 +444,16 @@ rb_syck_err_handler(p, msg)
p->lineptr); p->lineptr);
} }
SyckNode *
rb_syck_bad_anchor_handler(p, a)
SyckParser *p;
char *a;
{
SyckNode *badanc = syck_new_map( rb_str_new2( "name" ), rb_str_new2( a ) );
badanc->type_id = syck_strndup( "taguri:ruby.yaml.org,2002:object:YAML::Syck::BadAlias", 53 );
return badanc;
}
/* /*
* data loaded based on the model requested. * data loaded based on the model requested.
*/ */
@ -414,17 +465,17 @@ syck_set_model( parser, model )
if ( model == sym_generic ) if ( model == sym_generic )
{ {
syck_parser_handler( parser, rb_syck_parse_handler ); syck_parser_handler( parser, rb_syck_parse_handler );
syck_parser_error_handler( parser, rb_syck_err_handler );
syck_parser_implicit_typing( parser, 1 ); syck_parser_implicit_typing( parser, 1 );
syck_parser_taguri_expansion( parser, 1 ); syck_parser_taguri_expansion( parser, 1 );
} }
else else
{ {
syck_parser_handler( parser, rb_syck_load_handler ); syck_parser_handler( parser, rb_syck_load_handler );
syck_parser_error_handler( parser, rb_syck_err_handler );
syck_parser_implicit_typing( parser, 1 ); syck_parser_implicit_typing( parser, 1 );
syck_parser_taguri_expansion( parser, 0 ); syck_parser_taguri_expansion( parser, 0 );
} }
syck_parser_error_handler( parser, rb_syck_err_handler );
syck_parser_bad_anchor_handler( parser, rb_syck_bad_anchor_handler );
} }
/* /*
@ -561,7 +612,7 @@ syck_parser_load_documents(argc, argv, self)
} }
/* Pass document to block */ /* Pass document to block */
rb_funcall( proc, rb_intern("call"), 1, v ); rb_funcall( proc, s_call, 1, v );
} }
return Qnil; return Qnil;
@ -732,7 +783,7 @@ syck_loader_transfer( self, type, val )
if ( taguri != NULL ) if ( taguri != NULL )
{ {
VALUE scheme, name, type_hash, type_proc; VALUE scheme, domain, name, type_hash, type_proc = Qnil;
VALUE type_uri = rb_str_new2( taguri ); VALUE type_uri = rb_str_new2( taguri );
VALUE str_taguri = rb_str_new2("taguri"); VALUE str_taguri = rb_str_new2("taguri");
VALUE str_xprivate = rb_str_new2("x-private"); VALUE str_xprivate = rb_str_new2("x-private");
@ -748,7 +799,7 @@ syck_loader_transfer( self, type, val )
} }
else if ( rb_str_cmp( scheme, str_taguri ) == 0 ) else if ( rb_str_cmp( scheme, str_taguri ) == 0 )
{ {
VALUE domain = rb_ary_shift( parts ); domain = rb_ary_shift( parts );
name = rb_ary_join( parts, rb_str_new2( ":" ) ); name = rb_ary_join( parts, rb_str_new2( ":" ) );
type_hash = rb_iv_get(self, "@families"); type_hash = rb_iv_get(self, "@families");
type_hash = rb_hash_aref(type_hash, domain); type_hash = rb_hash_aref(type_hash, domain);
@ -773,15 +824,59 @@ syck_loader_transfer( self, type, val )
// rb_funcall(rb_mKernel, rb_intern("p"), 2, name, type_proc); // rb_funcall(rb_mKernel, rb_intern("p"), 2, name, type_proc);
} }
if ( rb_respond_to( type_proc, rb_intern("call") ) ) if ( rb_respond_to( type_proc, s_call ) )
{ {
val = rb_funcall(type_proc, rb_intern("call"), 2, type_uri, val); val = rb_funcall(type_proc, s_call, 2, type_uri, val);
}
else if ( rb_str_cmp( scheme, str_xprivate ) == 0 )
{
val = rb_funcall(cPrivateType, s_new, 2, name, val);
}
else
{
val = rb_funcall(cDomainType, s_new, 3, domain, name, val);
} }
} }
return val; return val;
} }
/*
* YAML::Syck::BadAlias.initialize
*/
VALUE
syck_badalias_initialize( self, val )
VALUE self, val;
{
rb_iv_set( self, "@name", val );
return self;
}
/*
* YAML::Syck::DomainType.initialize
*/
VALUE
syck_domaintype_initialize( self, domain, type_id, val )
VALUE self, type_id, val;
{
rb_iv_set( self, "@domain", domain );
rb_iv_set( self, "@type_id", type_id );
rb_iv_set( self, "@value", val );
return self;
}
/*
* YAML::Syck::PrivateType.initialize
*/
VALUE
syck_privatetype_initialize( self, type_id, val )
VALUE self, type_id, val;
{
rb_iv_set( self, "@type_id", type_id );
rb_iv_set( self, "@value", val );
return self;
}
/* /*
* YAML::Syck::Node.initialize * YAML::Syck::Node.initialize
*/ */
@ -838,7 +933,7 @@ syck_node_transform( self )
{ {
t = val; t = val;
} }
return rb_funcall( oDefaultLoader, rb_intern( "transfer" ), 2, type_id, t ); return rb_funcall( oDefaultLoader, s_transfer, 2, type_id, t );
} }
/* /*
@ -854,17 +949,26 @@ Init_syck()
// //
// Global symbols // Global symbols
// //
s_new = rb_intern("new");
s_utc = rb_intern("utc"); s_utc = rb_intern("utc");
s_at = rb_intern("at"); s_at = rb_intern("at");
s_to_f = rb_intern("to_f"); s_to_f = rb_intern("to_f");
s_read = rb_intern("read"); s_read = rb_intern("read");
s_binmode = rb_intern("binmode"); s_binmode = rb_intern("binmode");
s_transfer = rb_intern("transfer");
s_call = rb_intern("call");
sym_model = ID2SYM(rb_intern("Model")); sym_model = ID2SYM(rb_intern("Model"));
sym_generic = ID2SYM(rb_intern("Generic")); sym_generic = ID2SYM(rb_intern("Generic"));
sym_map = ID2SYM(rb_intern("map")); sym_map = ID2SYM(rb_intern("map"));
sym_scalar = ID2SYM(rb_intern("scalar")); sym_scalar = ID2SYM(rb_intern("scalar"));
sym_seq = ID2SYM(rb_intern("seq")); sym_seq = ID2SYM(rb_intern("seq"));
//
// Load Date module
//
rb_require( "date" );
cDate = rb_funcall( rb_cObject, rb_intern("const_get"), 1, rb_str_new2("Date") );
// //
// Define YAML::Syck::Loader class // Define YAML::Syck::Loader class
// //
@ -902,5 +1006,29 @@ Init_syck()
rb_define_attr( cNode, "anchor", 1, 1 ); rb_define_attr( cNode, "anchor", 1, 1 );
rb_define_method( cNode, "initialize", syck_node_initialize, 2); rb_define_method( cNode, "initialize", syck_node_initialize, 2);
rb_define_method( cNode, "transform", syck_node_transform, 0); rb_define_method( cNode, "transform", syck_node_transform, 0);
//
// Define YAML::Syck::PrivateType class
//
cPrivateType = rb_define_class_under( rb_syck, "PrivateType", rb_cObject );
rb_define_attr( cPrivateType, "type_id", 1, 1 );
rb_define_attr( cPrivateType, "value", 1, 1 );
rb_define_method( cPrivateType, "initialize", syck_privatetype_initialize, 2);
//
// Define YAML::Syck::DomainType class
//
cDomainType = rb_define_class_under( rb_syck, "DomainType", rb_cObject );
rb_define_attr( cDomainType, "domain", 1, 1 );
rb_define_attr( cDomainType, "type_id", 1, 1 );
rb_define_attr( cDomainType, "value", 1, 1 );
rb_define_method( cDomainType, "initialize", syck_domaintype_initialize, 3);
//
// Define YAML::Syck::BadAlias class
//
cBadAlias = rb_define_class_under( rb_syck, "BadAlias", rb_cObject );
rb_define_attr( cBadAlias, "name", 1, 1 );
rb_define_method( cBadAlias, "initialize", syck_badalias_initialize, 1);
} }

View File

@ -170,6 +170,7 @@ syck_new_parser()
p->io.str = NULL; p->io.str = NULL;
p->syms = NULL; p->syms = NULL;
p->anchors = NULL; p->anchors = NULL;
p->bad_anchors = NULL;
p->implicit_typing = 1; p->implicit_typing = 1;
p->taguri_expansion = 0; p->taguri_expansion = 0;
p->bufsize = SYCK_BUFFERSIZE; p->bufsize = SYCK_BUFFERSIZE;
@ -219,7 +220,7 @@ syck_st_free( SyckParser *p )
} }
// //
// Free the anchor table // Free the anchor tables
// //
if ( p->anchors != NULL ) if ( p->anchors != NULL )
{ {
@ -227,6 +228,13 @@ syck_st_free( SyckParser *p )
st_free_table( p->anchors ); st_free_table( p->anchors );
p->anchors = NULL; p->anchors = NULL;
} }
if ( p->bad_anchors != NULL )
{
st_foreach( p->bad_anchors, syck_st_free_nodes, 0 );
st_free_table( p->bad_anchors );
p->bad_anchors = NULL;
}
} }
void void
@ -277,6 +285,13 @@ syck_parser_error_handler( SyckParser *p, SyckErrorHandler hdlr )
p->error_handler = hdlr; p->error_handler = hdlr;
} }
void
syck_parser_bad_anchor_handler( SyckParser *p, SyckBadAnchorHandler hdlr )
{
ASSERT( p != NULL );
p->bad_anchor_handler = hdlr;
}
void void
syck_parser_file( SyckParser *p, FILE *fp, SyckIoFileRead read ) syck_parser_file( SyckParser *p, FILE *fp, SyckIoFileRead read )
{ {

View File

@ -121,6 +121,7 @@ struct _syck_node {
*/ */
typedef SYMID (*SyckNodeHandler)(SyckParser *, SyckNode *); typedef SYMID (*SyckNodeHandler)(SyckParser *, SyckNode *);
typedef void (*SyckErrorHandler)(SyckParser *, char *); typedef void (*SyckErrorHandler)(SyckParser *, char *);
typedef SyckNode * (*SyckBadAnchorHandler)(SyckParser *, char *);
typedef long (*SyckIoFileRead)(char *, SyckIoFile *, long, long); typedef long (*SyckIoFileRead)(char *, SyckIoFile *, long, long);
typedef long (*SyckIoStrRead)(char *, SyckIoStr *, long, long); typedef long (*SyckIoStrRead)(char *, SyckIoStr *, long, long);
@ -150,6 +151,8 @@ struct _syck_parser {
SyckNodeHandler handler; SyckNodeHandler handler;
// Error handler // Error handler
SyckErrorHandler error_handler; SyckErrorHandler error_handler;
// InvalidAnchor handler
SyckBadAnchorHandler bad_anchor_handler;
// IO type // IO type
enum syck_io_type io_type; enum syck_io_type io_type;
// Custom buffer size // Custom buffer size
@ -174,8 +177,8 @@ struct _syck_parser {
SyckIoStrRead read; SyckIoStrRead read;
} *str; } *str;
} io; } io;
// Symbol table // Symbol table for anchors
st_table *anchors; st_table *anchors, *bad_anchors;
// Optional symbol table for SYMIDs // Optional symbol table for SYMIDs
st_table *syms; st_table *syms;
// Levels of indentation // Levels of indentation
@ -194,7 +197,8 @@ struct _syck_parser {
*/ */
SYMID syck_hdlr_add_node( SyckParser *, SyckNode * ); SYMID syck_hdlr_add_node( SyckParser *, SyckNode * );
SyckNode *syck_hdlr_add_anchor( SyckParser *, char *, SyckNode * ); SyckNode *syck_hdlr_add_anchor( SyckParser *, char *, SyckNode * );
SyckNode *syck_hdlr_add_alias( SyckParser *, char * ); void syck_hdlr_remove_anchor( SyckParser *, char * );
SyckNode *syck_hdlr_get_anchor( SyckParser *, char * );
void syck_add_transfer( char *, SyckNode *, int ); void syck_add_transfer( char *, SyckNode *, int );
char *syck_xprivate( char *, int ); char *syck_xprivate( char *, int );
char *syck_taguri( char *, char *, int ); char *syck_taguri( char *, char *, int );
@ -218,6 +222,7 @@ void syck_parser_implicit_typing( SyckParser *, int );
void syck_parser_taguri_expansion( SyckParser *, int ); void syck_parser_taguri_expansion( SyckParser *, int );
void syck_parser_handler( SyckParser *, SyckNodeHandler ); void syck_parser_handler( SyckParser *, SyckNodeHandler );
void syck_parser_error_handler( SyckParser *, SyckErrorHandler ); void syck_parser_error_handler( SyckParser *, SyckErrorHandler );
void syck_parser_bad_anchor_handler( SyckParser *, SyckBadAnchorHandler );
void syck_parser_file( SyckParser *, FILE *, SyckIoFileRead ); void syck_parser_file( SyckParser *, FILE *, SyckIoFileRead );
void syck_parser_str( SyckParser *, char *, long, SyckIoStrRead ); void syck_parser_str( SyckParser *, char *, long, SyckIoStrRead );
void syck_parser_str_auto( SyckParser *, char *, SyckIoStrRead ); void syck_parser_str_auto( SyckParser *, char *, SyckIoStrRead );

File diff suppressed because it is too large Load Diff

View File

@ -451,17 +451,9 @@ class Time
end end
end end
YAML.add_builtin_type( 'time' ) { |type, val| YAML.add_builtin_type( 'time#ymd' ) { |type, val|
if val =~ /\A(\d{4})\-(\d{1,2})\-(\d{1,2})[Tt](\d{2})\:(\d{2})\:(\d{2})(\.\d{1,2})?(Z|[-+][0-9][0-9](?:\:[0-9][0-9])?)\Z/ if val =~ /\A(\d{4})\-(\d{1,2})\-(\d{1,2})\Z/
YAML.mktime( *$~.to_a[1,8] )
elsif val =~ /\A(\d{4})\-(\d{1,2})\-(\d{1,2})[ \t]+(\d{2})\:(\d{2})\:(\d{2})(\.\d+)?[ \t]+(Z|[-+][0-9][0-9](?:\:[0-9][0-9])?)\Z/
YAML.mktime( *$~.to_a[1,8] )
elsif val =~ /\A(\d{4})\-(\d{1,2})\-(\d{1,2})[ \t]+(\d{2})\:(\d{2})\:(\d{2})(\.\d{1,2})?\Z/
YAML.mktime( *$~.to_a[1,7] )
elsif val =~ /\A(\d{4})\-(\d{1,2})\-(\d{1,2})\Z/
Date.new($1.to_i, $2.to_i, $3.to_i) Date.new($1.to_i, $2.to_i, $3.to_i)
elsif type == :Implicit
:InvalidType
else else
raise YAML::TypeError, "Invalid !time string: " + val.inspect raise YAML::TypeError, "Invalid !time string: " + val.inspect
end end