* ext/syck/handler.c, ext/syck/syck.h: removed syck_fold_format().

* ext/syck/gram.c: flexibility for aliases and anchors.

* ext/syck/token.c: folding now handled in the tokenizer.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3880 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
why 2003-05-29 23:33:10 +00:00
parent 4ca5e66ee7
commit 5d47fda3f8
5 changed files with 482 additions and 566 deletions

View File

@ -1,3 +1,11 @@
Thu May 29 23:41:34 2003 why the lucky stiff <ruby-cvs@whytheluckystiff.net>
* ext/syck/handler.c, ext/syck/syck.h: removed syck_fold_format().
* ext/syck/gram.c: flexibility for aliases and anchors.
* ext/syck/token.c: folding now handled in the tokenizer.
Fri May 30 06:21:18 2003 Nobuyoshi Nakada <nobu.nokada@softhome.net> Fri May 30 06:21:18 2003 Nobuyoshi Nakada <nobu.nokada@softhome.net>
* variable.c (rb_autoload_load): should delete autoloaded * variable.c (rb_autoload_load): should delete autoloaded
@ -111,7 +119,7 @@ Fri May 23 14:19:29 2003 Yukihiro Matsumoto <matz@ruby-lang.org>
Thu May 22 18:07:46 2003 why the lucky stiff <ruby-cvs@whytheluckystiff.net> Thu May 22 18:07:46 2003 why the lucky stiff <ruby-cvs@whytheluckystiff.net>
* lib/token.c: single- and double-quoted root-level fix. * ext/syck/token.c: single- and double-quoted root-level fix.
* lib/yaml.rb (YAML::object_maker): can create object attributes (such as * lib/yaml.rb (YAML::object_maker): can create object attributes (such as
found in Exception class) found in Exception class)

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 33 #define YYFINAL 34
#define YYLAST 196 #define YYLAST 217
/* YYNTOKENS -- Number of terminals. */ /* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 23 #define YYNTOKENS 23
/* YYNNTS -- Number of nonterminals. */ /* YYNNTS -- Number of nonterminals. */
#define YYNNTS 22 #define YYNNTS 23
/* YYNRULES -- Number of rules. */ /* YYNRULES -- Number of rules. */
#define YYNRULES 51 #define YYNRULES 54
/* YYNRULES -- Number of states. */ /* YYNRULES -- Number of states. */
#define YYNSTATES 84 #define YYNSTATES 88
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2 #define YYUNDEFTOK 2
@ -284,43 +284,44 @@ static const unsigned char yytranslate[] =
YYRHS. */ YYRHS. */
static const unsigned char yyprhs[] = static const unsigned char yyprhs[] =
{ {
0, 0, 3, 5, 8, 9, 11, 13, 16, 18, 0, 0, 3, 5, 8, 9, 11, 13, 15, 18,
22, 24, 25, 27, 30, 32, 34, 36, 39, 42, 22, 26, 28, 29, 31, 34, 36, 38, 40, 43,
45, 47, 49, 52, 54, 56, 58, 60, 62, 66, 46, 49, 52, 54, 56, 58, 61, 63, 65, 67,
72, 75, 77, 81, 84, 88, 91, 93, 97, 101, 69, 71, 75, 81, 84, 86, 90, 93, 97, 100,
107, 111, 113, 119, 121, 125, 129, 132, 136, 140, 102, 106, 110, 116, 120, 122, 128, 130, 134, 138,
143, 145 141, 145, 149, 152, 154
}; };
/* YYRHS -- A `-1'-separated list of the rules' RHS. */ /* YYRHS -- A `-1'-separated list of the rules' RHS. */
static const yysigned_char yyrhs[] = static const yysigned_char yyrhs[] =
{ {
24, 0, -1, 32, -1, 10, 26, -1, -1, 31, 24, 0, -1, 33, -1, 10, 27, -1, -1, 32,
-1, 32, -1, 3, 25, -1, 4, -1, 27, 25, -1, 26, -1, 33, -1, 3, 26, -1, 28, 32,
30, -1, 25, -1, -1, 11, -1, 27, 12, -1, 31, -1, 28, 26, 31, -1, 25, -1, -1, 11,
13, -1, 12, -1, 13, -1, 29, 30, -1, 5, -1, 28, 12, -1, 13, -1, 12, -1, 13, -1,
31, -1, 6, 31, -1, 7, -1, 8, -1, 5, 30, 31, -1, 5, 32, -1, 6, 32, -1, 3,
32, -1, 9, -1, 33, -1, 36, -1, 38, -1, 32, -1, 4, -1, 7, -1, 8, -1, 5, 33,
43, -1, 27, 35, 28, -1, 27, 5, 29, 35, -1, 9, -1, 34, -1, 37, -1, 39, -1, 44,
28, -1, 14, 26, -1, 34, -1, 35, 29, 34, -1, 28, 36, 29, -1, 28, 5, 30, 36, 29,
-1, 35, 29, -1, 17, 37, 18, -1, 17, 18, -1, 14, 27, -1, 35, -1, 36, 30, 35, -1,
-1, 25, -1, 37, 21, 25, -1, 27, 41, 28, 36, 30, -1, 17, 38, 18, -1, 17, 18, -1,
-1, 27, 5, 29, 41, 28, -1, 31, 15, 26, 25, -1, 38, 21, 25, -1, 28, 42, 29, -1,
-1, 39, -1, 22, 25, 29, 15, 26, -1, 40, 28, 5, 30, 42, 29, -1, 32, 15, 27, -1,
-1, 41, 29, 34, -1, 41, 29, 40, -1, 41, 40, -1, 22, 25, 30, 15, 27, -1, 41, -1,
29, -1, 25, 15, 26, -1, 19, 44, 20, -1, 42, 30, 35, -1, 42, 30, 41, -1, 42, 30,
19, 20, -1, 42, -1, 44, 21, 42, -1 -1, 25, 15, 27, -1, 19, 45, 20, -1, 19,
20, -1, 43, -1, 45, 21, 43, -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, 60, 69, 77, 0, 44, 44, 48, 52, 58, 59, 62, 63, 72,
83, 84, 102, 103, 106, 109, 112, 113, 121, 126, 76, 82, 83, 101, 102, 105, 108, 111, 112, 120,
134, 147, 154, 159, 160, 161, 162, 163, 169, 173, 125, 133, 137, 145, 158, 165, 170, 171, 172, 173,
180, 186, 190, 195, 204, 208, 214, 218, 228, 233, 174, 180, 184, 191, 197, 201, 206, 215, 219, 225,
241, 256, 257, 265, 266, 278, 285, 294, 302, 306, 229, 239, 244, 252, 267, 268, 276, 277, 289, 296,
312, 313 305, 313, 317, 323, 324
}; };
#endif #endif
@ -332,7 +333,7 @@ static const char *const yytname[] =
"$end", "error", "$undefined", "ANCHOR", "ALIAS", "TRANSFER", "ITRANSFER", "$end", "error", "$undefined", "ANCHOR", "ALIAS", "TRANSFER", "ITRANSFER",
"WORD", "PLAIN", "BLOCK", "DOCSEP", "IOPEN", "INDENT", "IEND", "'-'", "WORD", "PLAIN", "BLOCK", "DOCSEP", "IOPEN", "INDENT", "IEND", "'-'",
"':'", "'+'", "'['", "']'", "'{'", "'}'", "','", "'?'", "$accept", "':'", "'+'", "'['", "']'", "'{'", "'}'", "','", "'?'", "$accept",
"doc", "atom", "atom_or_empty", "indent_open", "indent_end", "doc", "atom", "ind_rep", "atom_or_empty", "indent_open", "indent_end",
"indent_sep", "indent_flex_end", "word_rep", "struct_rep", "indent_sep", "indent_flex_end", "word_rep", "struct_rep",
"implicit_seq", "basic_seq", "in_implicit_seq", "inline_seq", "implicit_seq", "basic_seq", "in_implicit_seq", "inline_seq",
"in_inline_seq", "implicit_map", "basic_mapping", "complex_mapping", "in_inline_seq", "implicit_map", "basic_mapping", "complex_mapping",
@ -354,23 +355,23 @@ static const unsigned short yytoknum[] =
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */ /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
static const unsigned char yyr1[] = static const unsigned char yyr1[] =
{ {
0, 23, 24, 24, 24, 25, 25, 25, 25, 25, 0, 23, 24, 24, 24, 25, 25, 26, 26, 26,
26, 26, 27, 27, 28, 29, 30, 30, 31, 31, 26, 27, 27, 28, 28, 29, 30, 31, 31, 32,
31, 31, 32, 32, 32, 32, 32, 32, 33, 33, 32, 32, 32, 32, 32, 33, 33, 33, 33, 33,
34, 35, 35, 35, 36, 36, 37, 37, 38, 38, 33, 34, 34, 35, 36, 36, 36, 37, 37, 38,
39, 40, 40, 41, 41, 41, 41, 42, 43, 43, 38, 39, 39, 40, 41, 41, 42, 42, 42, 42,
44, 44 43, 44, 44, 45, 45
}; };
/* 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, 2, 1, 3, 0, 2, 1, 2, 0, 1, 1, 1, 2, 3,
1, 0, 1, 2, 1, 1, 1, 2, 2, 2, 3, 1, 0, 1, 2, 1, 1, 1, 2, 2,
1, 1, 2, 1, 1, 1, 1, 1, 3, 5, 2, 2, 1, 1, 1, 2, 1, 1, 1, 1,
2, 1, 3, 2, 3, 2, 1, 3, 3, 5, 1, 3, 5, 2, 1, 3, 2, 3, 2, 1,
3, 1, 5, 1, 3, 3, 2, 3, 3, 2, 3, 3, 5, 3, 1, 5, 1, 3, 3, 2,
1, 3 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
@ -378,47 +379,47 @@ 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, 23, 11, 12, 0, 0, 0, 0, 2, 4, 0, 26, 12, 13, 0, 0, 0, 0, 2,
24, 25, 26, 27, 22, 0, 8, 0, 0, 20, 27, 28, 29, 30, 25, 0, 22, 0, 0, 23,
21, 10, 3, 0, 5, 6, 35, 36, 0, 49, 24, 11, 6, 3, 0, 5, 7, 38, 39, 0,
0, 50, 0, 1, 0, 13, 11, 0, 0, 31, 52, 0, 53, 0, 1, 0, 0, 14, 12, 0,
0, 41, 43, 0, 7, 18, 0, 19, 0, 0, 0, 34, 0, 44, 46, 0, 8, 21, 19, 0,
5, 34, 0, 11, 48, 0, 15, 0, 30, 0, 20, 0, 0, 0, 37, 0, 12, 51, 0, 16,
11, 14, 28, 33, 38, 46, 16, 0, 9, 37, 0, 33, 0, 12, 15, 31, 36, 41, 49, 17,
47, 51, 0, 0, 0, 40, 32, 44, 45, 17, 0, 10, 9, 40, 50, 54, 0, 0, 0, 43,
29, 39, 11, 42 35, 47, 48, 18, 32, 42, 12, 45
}; };
/* YYDEFGOTO[NTERM-NUM]. */ /* YYDEFGOTO[NTERM-NUM]. */
static const yysigned_char yydefgoto[] = static const yysigned_char yydefgoto[] =
{ {
-1, 7, 21, 22, 23, 62, 57, 68, 24, 25, -1, 7, 21, 22, 23, 24, 65, 70, 71, 25,
10, 39, 40, 11, 28, 12, 41, 42, 43, 31, 26, 10, 41, 42, 11, 29, 12, 43, 44, 45,
13, 32 32, 13, 33
}; };
/* 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 -50 #define YYPACT_NINF -51
static const short yypact[] = static const short yypact[] =
{ {
169, 13, -50, 134, -50, 117, 79, 3, 95, -50, 13, 188, -51, 166, -51, 132, 114, 19, 90, -51,
-50, -50, -50, -50, -50, 134, -50, 164, 86, -50, -51, -51, -51, -51, -51, 166, -51, 183, 61, -51,
-50, -50, -50, 59, -50, -50, -50, -50, -1, -50, -51, -51, -51, -51, 70, -51, -51, -51, -51, -7,
-7, -50, 14, -50, 184, -50, 134, 134, 10, -50, -51, 10, -51, 18, -51, 61, 205, -51, 166, 166,
32, -50, -50, 32, -50, -50, 86, -50, 149, 62, 27, -51, 46, -51, -51, 46, -51, -51, -51, 61,
10, -50, 134, 134, -50, 134, -50, 105, -50, 15, -51, 149, 49, 32, -51, 166, 166, -51, 166, -51,
134, -50, -50, 25, -50, 105, -50, 62, -50, -50, 102, -51, 38, 166, -51, -51, 39, -51, 102, -51,
-50, -50, 32, 32, 26, -50, -50, -50, -50, -50, 49, -51, -51, -51, -51, -51, 46, 46, 55, -51,
-50, -50, 134, -50 -51, -51, -51, -51, -51, -51, 166, -51
}; };
/* YYPGOTO[NTERM-NUM]. */ /* YYPGOTO[NTERM-NUM]. */
static const yysigned_char yypgoto[] = static const yysigned_char yypgoto[] =
{ {
-50, -50, -4, -24, 4, -30, -12, -21, -8, 6, -51, -51, -4, -9, -30, 4, -28, -5, -50, -8,
-50, -49, 2, -50, -50, -50, -50, -15, 12, -2, 12, -51, -32, 20, -51, -51, -51, -51, 15, 25,
-50, -50 28, -51, -51
}; };
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
@ -428,65 +429,69 @@ static const yysigned_char yypgoto[] =
#define YYTABLE_NINF -1 #define YYTABLE_NINF -1
static const unsigned char yytable[] = static const unsigned char yytable[] =
{ {
38, 27, 30, 33, 8, 8, 9, 14, 53, 45, 40, 28, 31, 72, 8, 8, 46, 47, 61, 48,
47, 44, 58, 64, 76, 50, 77, 51, 1, 49, 50, 54, 9, 14, 55, 52, 53, 67, 1, 34,
52, 8, 2, 14, 4, 60, 45, 56, 63, 70, 83, 8, 2, 3, 4, 56, 74, 47, 48, 14,
5, 65, 6, 59, 54, 55, 75, 67, 45, 36, 5, 60, 6, 79, 80, 62, 81, 66, 57, 58,
45, 82, 80, 81, 56, 61, 79, 74, 69, 38, 68, 48, 63, 48, 59, 69, 60, 63, 84, 85,
78, 30, 8, 71, 14, 67, 0, 38, 83, 72, 59, 73, 40, 38, 31, 8, 87, 78, 59, 64,
63, 65, 15, 16, 48, 18, 19, 20, 2, 73, 40, 59, 69, 14, 35, 16, 49, 18, 19, 20,
4, 35, 0, 36, 56, 66, 5, 0, 6, 0, 86, 66, 68, 15, 16, 51, 18, 19, 20, 2,
0, 37, 15, 16, 17, 18, 19, 20, 2, 0, 76, 4, 37, 82, 38, 77, 75, 5, 0, 6,
4, 46, 18, 19, 20, 0, 5, 0, 6, 29, 0, 0, 39, 35, 16, 36, 18, 19, 20, 0,
34, 18, 19, 20, 0, 0, 0, 35, 0, 36, 0, 0, 37, 0, 38, 35, 16, 49, 18, 19,
46, 18, 19, 20, 0, 0, 0, 37, 0, 36, 20, 0, 39, 0, 0, 0, 38, 15, 16, 17,
15, 16, 17, 18, 19, 20, 2, 37, 4, 0, 18, 19, 20, 2, 39, 4, 0, 0, 0, 0,
0, 0, 0, 0, 5, 26, 6, 15, 16, 17, 0, 5, 0, 6, 30, 15, 16, 17, 18, 19,
18, 19, 20, 2, 0, 4, 0, 0, 0, 0, 20, 2, 0, 4, 0, 0, 0, 0, 0, 5,
0, 5, 0, 6, 17, 18, 19, 20, 2, 0, 27, 6, 35, 16, 17, 18, 19, 20, 2, 0,
4, 56, 0, 0, 0, 0, 5, 0, 6, 17, 4, 59, 0, 0, 0, 0, 5, 0, 6, 15,
18, 19, 20, 2, 1, 4, 0, 0, 2, 3, 16, 17, 18, 19, 20, 2, 0, 4, 0, 0,
4, 5, 0, 6, 0, 0, 5, 0, 6, 46, 0, 0, 0, 5, 0, 6, 35, 16, 17, 18,
18, 19, 20, 0, 0, 0, 56 19, 20, 2, 1, 4, 0, 0, 2, 0, 4,
5, 0, 6, 0, 0, 5, 0, 6, 35, 16,
49, 18, 19, 20, 0, 0, 0, 59
}; };
static const yysigned_char yycheck[] = static const yysigned_char yycheck[] =
{ {
8, 5, 6, 0, 0, 1, 0, 1, 15, 17, 8, 5, 6, 53, 0, 1, 15, 15, 38, 17,
18, 15, 36, 43, 63, 23, 65, 18, 5, 23, 18, 18, 0, 1, 21, 24, 24, 45, 5, 0,
21, 17, 9, 17, 11, 15, 34, 12, 40, 53, 70, 17, 9, 10, 11, 15, 56, 35, 36, 17,
17, 43, 19, 37, 20, 21, 60, 49, 46, 14, 17, 36, 19, 63, 66, 39, 68, 42, 20, 21,
48, 15, 72, 73, 12, 13, 67, 59, 52, 57, 45, 49, 15, 51, 12, 13, 51, 15, 76, 77,
65, 55, 48, 55, 48, 67, -1, 65, 82, 57, 12, 55, 60, 14, 58, 51, 86, 62, 12, 13,
72, 73, 3, 4, 5, 6, 7, 8, 9, 57, 68, 12, 13, 51, 3, 4, 5, 6, 7, 8,
11, 12, -1, 14, 12, 13, 17, -1, 19, -1, 15, 76, 77, 3, 4, 5, 6, 7, 8, 9,
-1, 22, 3, 4, 5, 6, 7, 8, 9, -1, 60, 11, 12, 68, 14, 60, 58, 17, -1, 19,
11, 5, 6, 7, 8, -1, 17, -1, 19, 20, -1, -1, 22, 3, 4, 5, 6, 7, 8, -1,
5, 6, 7, 8, -1, -1, -1, 12, -1, 14, -1, -1, 12, -1, 14, 3, 4, 5, 6, 7,
5, 6, 7, 8, -1, -1, -1, 22, -1, 14, 8, -1, 22, -1, -1, -1, 14, 3, 4, 5,
3, 4, 5, 6, 7, 8, 9, 22, 11, -1, 6, 7, 8, 9, 22, 11, -1, -1, -1, -1,
-1, -1, -1, -1, 17, 18, 19, 3, 4, 5, -1, 17, -1, 19, 20, 3, 4, 5, 6, 7,
6, 7, 8, 9, -1, 11, -1, -1, -1, -1, 8, 9, -1, 11, -1, -1, -1, -1, -1, 17,
-1, 17, -1, 19, 5, 6, 7, 8, 9, -1, 18, 19, 3, 4, 5, 6, 7, 8, 9, -1,
11, 12, -1, -1, -1, -1, 17, -1, 19, 5, 11, 12, -1, -1, -1, -1, 17, -1, 19, 3,
6, 7, 8, 9, 5, 11, -1, -1, 9, 10, 4, 5, 6, 7, 8, 9, -1, 11, -1, -1,
11, 17, -1, 19, -1, -1, 17, -1, 19, 5, -1, -1, -1, 17, -1, 19, 3, 4, 5, 6,
6, 7, 8, -1, -1, -1, 12 7, 8, 9, 5, 11, -1, -1, 9, -1, 11,
17, -1, 19, -1, -1, 17, -1, 19, 3, 4,
5, 6, 7, 8, -1, -1, -1, 12
}; };
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
symbol of state STATE-NUM. */ symbol of state STATE-NUM. */
static const unsigned char yystos[] = static const unsigned char yystos[] =
{ {
0, 5, 9, 10, 11, 17, 19, 24, 27, 32, 0, 5, 9, 10, 11, 17, 19, 24, 28, 33,
33, 36, 38, 43, 32, 3, 4, 5, 6, 7, 34, 37, 39, 44, 33, 3, 4, 5, 6, 7,
8, 25, 26, 27, 31, 32, 18, 25, 37, 20, 8, 25, 26, 27, 28, 32, 33, 18, 25, 38,
25, 42, 44, 0, 5, 12, 14, 22, 31, 34, 20, 25, 43, 45, 0, 3, 5, 12, 14, 22,
35, 39, 40, 41, 25, 31, 5, 31, 5, 25, 32, 35, 36, 40, 41, 42, 26, 32, 32, 5,
31, 18, 21, 15, 20, 21, 12, 29, 26, 25, 32, 5, 26, 32, 18, 21, 15, 20, 21, 12,
15, 13, 28, 29, 28, 29, 13, 29, 30, 25, 30, 27, 25, 15, 13, 29, 30, 29, 30, 13,
26, 42, 35, 41, 29, 26, 34, 34, 40, 30, 30, 31, 31, 25, 27, 43, 36, 42, 30, 27,
28, 28, 15, 26 35, 35, 41, 31, 29, 29, 15, 27
}; };
#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
@ -1061,8 +1066,8 @@ yyreduce:
} }
break; break;
case 7: case 8:
#line 61 "gram.y" #line 64 "gram.y"
{ {
/* /*
* _Anchors_: The language binding must keep a separate symbol table * _Anchors_: The language binding must keep a separate symbol table
@ -1073,26 +1078,22 @@ yyreduce:
} }
break; break;
case 8:
#line 70 "gram.y"
{
/*
* _Aliases_: The anchor symbol table is scanned for the anchor name.
* The anchor's ID in the language's symbol table is returned.
*/
yyval.nodeData = syck_hdlr_add_alias( (SyckParser *)parser, yyvsp[0].name );
}
break;
case 9: case 9:
#line 78 "gram.y" #line 73 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 11: case 10:
#line 85 "gram.y" #line 77 "gram.y"
{
yyval.nodeData = yyvsp[-1].nodeData;
}
break;
case 12:
#line 84 "gram.y"
{ {
SyckNode *n = syck_new_str( "" ); SyckNode *n = syck_new_str( "" );
if ( ((SyckParser *)parser)->taguri_expansion == 1 ) if ( ((SyckParser *)parser)->taguri_expansion == 1 )
@ -1107,16 +1108,16 @@ yyreduce:
} }
break; break;
case 18: case 19:
#line 122 "gram.y" #line 121 "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 19: case 20:
#line 127 "gram.y" #line 126 "gram.y"
{ {
if ( ((SyckParser *)parser)->implicit_typing == 1 ) if ( ((SyckParser *)parser)->implicit_typing == 1 )
{ {
@ -1126,8 +1127,26 @@ yyreduce:
} }
break; break;
case 20: case 21:
#line 135 "gram.y" #line 134 "gram.y"
{
yyval.nodeData = syck_hdlr_add_anchor( (SyckParser *)parser, yyvsp[-1].name, yyvsp[0].nodeData );
}
break;
case 22:
#line 138 "gram.y"
{
/*
* _Aliases_: The anchor symbol table is scanned for the anchor name.
* The anchor's ID in the language's symbol table is returned.
*/
yyval.nodeData = syck_hdlr_add_alias( (SyckParser *)parser, yyvsp[0].name );
}
break;
case 23:
#line 146 "gram.y"
{ {
SyckNode *n = yyvsp[0].nodeData; SyckNode *n = yyvsp[0].nodeData;
if ( ((SyckParser *)parser)->taguri_expansion == 1 ) if ( ((SyckParser *)parser)->taguri_expansion == 1 )
@ -1142,97 +1161,97 @@ yyreduce:
} }
break; break;
case 22: case 25:
#line 155 "gram.y" #line 166 "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 28: case 31:
#line 170 "gram.y" #line 181 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 29: case 32:
#line 174 "gram.y" #line 185 "gram.y"
{ {
syck_add_transfer( yyvsp[-3].name, yyvsp[-1].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-3].name, yyvsp[-1].nodeData, ((SyckParser *)parser)->taguri_expansion );
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 30: case 33:
#line 181 "gram.y" #line 192 "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 31: case 34:
#line 187 "gram.y" #line 198 "gram.y"
{ {
yyval.nodeData = syck_new_seq( yyvsp[0].nodeId ); yyval.nodeData = syck_new_seq( yyvsp[0].nodeId );
} }
break; break;
case 32: case 35:
#line 191 "gram.y" #line 202 "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 33: case 36:
#line 196 "gram.y" #line 207 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 34: case 37:
#line 205 "gram.y" #line 216 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 35: case 38:
#line 209 "gram.y" #line 220 "gram.y"
{ {
yyval.nodeData = syck_alloc_seq(); yyval.nodeData = syck_alloc_seq();
} }
break; break;
case 36: case 39:
#line 215 "gram.y" #line 226 "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 37: case 40:
#line 219 "gram.y" #line 230 "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 38: case 41:
#line 229 "gram.y" #line 240 "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;
} }
break; break;
case 39: case 42:
#line 234 "gram.y" #line 245 "gram.y"
{ {
apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData ); apply_seq_in_map( (SyckParser *)parser, yyvsp[-1].nodeData );
syck_add_transfer( yyvsp[-3].name, yyvsp[-1].nodeData, ((SyckParser *)parser)->taguri_expansion ); syck_add_transfer( yyvsp[-3].name, yyvsp[-1].nodeData, ((SyckParser *)parser)->taguri_expansion );
@ -1240,8 +1259,8 @@ yyreduce:
} }
break; break;
case 40: case 43:
#line 242 "gram.y" #line 253 "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 ),
@ -1249,8 +1268,8 @@ yyreduce:
} }
break; break;
case 42: case 45:
#line 258 "gram.y" #line 269 "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 ),
@ -1258,8 +1277,8 @@ yyreduce:
} }
break; break;
case 44: case 47:
#line 267 "gram.y" #line 278 "gram.y"
{ {
if ( yyvsp[-2].nodeData->shortcut == NULL ) if ( yyvsp[-2].nodeData->shortcut == NULL )
{ {
@ -1273,8 +1292,8 @@ yyreduce:
} }
break; break;
case 45: case 48:
#line 279 "gram.y" #line 290 "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 );
@ -1283,15 +1302,15 @@ yyreduce:
} }
break; break;
case 46: case 49:
#line 286 "gram.y" #line 297 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 47: case 50:
#line 295 "gram.y" #line 306 "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 ),
@ -1299,22 +1318,22 @@ yyreduce:
} }
break; break;
case 48: case 51:
#line 303 "gram.y" #line 314 "gram.y"
{ {
yyval.nodeData = yyvsp[-1].nodeData; yyval.nodeData = yyvsp[-1].nodeData;
} }
break; break;
case 49: case 52:
#line 307 "gram.y" #line 318 "gram.y"
{ {
yyval.nodeData = syck_alloc_map(); yyval.nodeData = syck_alloc_map();
} }
break; break;
case 51: case 54:
#line 314 "gram.y" #line 325 "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 );
@ -1326,7 +1345,7 @@ yyreduce:
} }
/* Line 1016 of /usr/local/share/bison/yacc.c. */ /* Line 1016 of /usr/local/share/bison/yacc.c. */
#line 1330 "y.tab.c" #line 1349 "y.tab.c"
yyvsp -= yylen; yyvsp -= yylen;
yyssp -= yylen; yyssp -= yylen;
@ -1545,7 +1564,7 @@ yyreturn:
} }
#line 321 "gram.y" #line 332 "gram.y"
void void

View File

@ -13,6 +13,7 @@ SYMID
syck_hdlr_add_node( SyckParser *p, SyckNode *n ) syck_hdlr_add_node( SyckParser *p, SyckNode *n )
{ {
SYMID id; SYMID id;
if ( ! n->id ) if ( ! n->id )
{ {
n->id = (p->handler)( p, n ); n->id = (p->handler)( p, n );
@ -44,6 +45,9 @@ syck_hdlr_add_alias( SyckParser *p, char *a )
return n; return n;
} }
//
// FIXME: Return an InvalidAnchor object
//
return syck_new_str( "..." ); return syck_new_str( "..." );
} }
@ -97,100 +101,3 @@ syck_try_implicit( SyckNode *n )
return 1; return 1;
} }
void
syck_fold_format( struct SyckStr *n, int blockType, int indt_len, int nlDisp )
{
char *spc;
char *eol = NULL;
char *first_nl = NULL;
char *fc = n->ptr;
int keep_nl = 0;
int nl_count = 0;
//
// Scan the sucker for newlines and strip indent
//
while ( fc < n->ptr + n->len )
{
if ( *fc == '\n' )
{
spc = fc;
while ( *(++spc) == ' ' )
{
if ( blockType != BLOCK_PLAIN && spc - fc > indt_len )
break;
}
if ( blockType != BLOCK_LIT && *spc != ' ' )
{
if ( eol != NULL ) fc = eol;
if ( first_nl == NULL && keep_nl == 1 )
{
first_nl = fc;
*first_nl = ' ';
}
if ( nl_count == 1 )
{
*first_nl = '\n';
keep_nl = 0;
}
}
fc += keep_nl;
if ( fc != spc && ( n->len - ( spc - n->ptr ) ) > 0 )
{
S_MEMMOVE( fc, spc, char, n->len - ( spc - n->ptr ) );
}
n->len -= spc - fc;
keep_nl = 1;
eol = NULL;
nl_count++;
}
else
{
//
// eol tracks the last space on a line
//
if ( *fc == ' ' )
{
if ( eol == NULL ) eol = fc;
}
else
{
eol = NULL;
}
first_nl = NULL;
nl_count = 0;
fc++;
}
}
n->ptr[n->len] = '\n';
//
// Chomp or keep?
//
if ( nlDisp != NL_KEEP )
{
fc = n->ptr + n->len - 1;
while ( *fc == '\n' )
fc--;
if ( nlDisp != NL_CHOMP )
fc += 1;
n->len = fc - n->ptr + 1;
}
else
{
//
// Force last line break which I gave back
// to the tokenizer.
//
n->len++;
n->ptr[n->len] = '\n';
}
n->ptr[ n->len ] = '\0';
}

View File

@ -10,7 +10,7 @@
#ifndef SYCK_H #ifndef SYCK_H
#define SYCK_H #define SYCK_H
#define SYCK_VERSION "0.29" #define SYCK_VERSION "0.32"
#define YAML_DOMAIN "yaml.org,2002" #define YAML_DOMAIN "yaml.org,2002"
#include <stdio.h> #include <stdio.h>
@ -202,7 +202,6 @@ int syck_add_sym( SyckParser *, char * );
int syck_lookup_sym( SyckParser *, SYMID, char ** ); int syck_lookup_sym( SyckParser *, SYMID, char ** );
int syck_try_implicit( SyckNode * ); int syck_try_implicit( SyckNode * );
char *syck_type_id_to_uri( char * ); char *syck_type_id_to_uri( char * );
void syck_fold_format( struct SyckStr *, int, int, int );
void try_tag_implicit( SyckNode *, int ); void try_tag_implicit( SyckNode *, int );
char *syck_match_implicit( char *, size_t ); char *syck_match_implicit( char *, size_t );

File diff suppressed because it is too large Load Diff