| | 1109 | /* |
|---|
| | 1110 | * Check the list of potential simple keys and remove the positions that |
|---|
| | 1111 | * cannot contain simple keys anymore. |
|---|
| | 1112 | */ |
|---|
| | 1113 | |
|---|
| | 1114 | static int |
|---|
| | 1115 | yaml_parser_stale_simple_keys(yaml_parser_t *parser) |
|---|
| | 1116 | { |
|---|
| | 1117 | int level; |
|---|
| | 1118 | |
|---|
| | 1119 | /* Check for a potential simple key for each flow level. */ |
|---|
| | 1120 | |
|---|
| | 1121 | for (level = 0; level <= parser->flow_level; level++) |
|---|
| | 1122 | { |
|---|
| | 1123 | yaml_simple_key_t *simple_key = parser->simple_keys[level]; |
|---|
| | 1124 | |
|---|
| | 1125 | /* |
|---|
| | 1126 | * The specification requires that a simple key |
|---|
| | 1127 | * |
|---|
| | 1128 | * - is limited to a single line, |
|---|
| | 1129 | * - is shorter than 1024 characters. |
|---|
| | 1130 | */ |
|---|
| | 1131 | |
|---|
| | 1132 | if (simple_key && (simple_key->line < parser->line || |
|---|
| | 1133 | simple_key->index < parser->index+1024)) { |
|---|
| | 1134 | |
|---|
| | 1135 | /* Check if the potential simple key to be removed is required. */ |
|---|
| | 1136 | |
|---|
| | 1137 | if (simple_key->required) { |
|---|
| | 1138 | return yaml_parser_set_scanner_error(parser, |
|---|
| | 1139 | "while scanning a simple key", simple_key->mark, |
|---|
| | 1140 | "could not found expected ':'"); |
|---|
| | 1141 | } |
|---|
| | 1142 | |
|---|
| | 1143 | yaml_free(simple_key); |
|---|
| | 1144 | parser->simple_keys[level] = NULL; |
|---|
| | 1145 | } |
|---|
| | 1146 | } |
|---|
| | 1147 | |
|---|
| | 1148 | return 1; |
|---|
| | 1149 | } |
|---|
| | 1150 | |
|---|
| | 1151 | /* |
|---|
| | 1152 | * Check if a simple key may start at the current position and add it if |
|---|
| | 1153 | * needed. |
|---|
| | 1154 | */ |
|---|
| | 1155 | |
|---|
| | 1156 | static int |
|---|
| | 1157 | yaml_parser_save_simple_key(yaml_parser_t *parser) |
|---|
| | 1158 | { |
|---|
| | 1159 | /* |
|---|
| | 1160 | * A simple key is required at the current position if the scanner is in |
|---|
| | 1161 | * the block context and the current column coincides with the indentation |
|---|
| | 1162 | * level. |
|---|
| | 1163 | */ |
|---|
| | 1164 | |
|---|
| | 1165 | int required = (!parser->flow_level && parser->indent == parser->column); |
|---|
| | 1166 | |
|---|
| | 1167 | /* |
|---|
| | 1168 | * A simple key is required only when it is the first token in the current |
|---|
| | 1169 | * line. Therefore it is always allowed. But we add a check anyway. |
|---|
| | 1170 | */ |
|---|
| | 1171 | |
|---|
| | 1172 | assert(parser->simple_key_allowed || !required); /* Impossible. */ |
|---|
| | 1173 | |
|---|
| | 1174 | /* |
|---|
| | 1175 | * If the current position may start a simple key, save it. |
|---|
| | 1176 | */ |
|---|
| | 1177 | |
|---|
| | 1178 | if (parser->simple_key_allowed) |
|---|
| | 1179 | { |
|---|
| | 1180 | yaml_simple_key_t simple_key = { required, |
|---|
| | 1181 | parser->tokens_parsed + parser->tokens_tail - parser->tokens_head, |
|---|
| | 1182 | parser->index, parser->line, parser->column, |
|---|
| | 1183 | yaml_parser_get_mark(parser) }; |
|---|
| | 1184 | |
|---|
| | 1185 | if (!yaml_parser_remove_simple_key(parser)) return 0; |
|---|
| | 1186 | |
|---|
| | 1187 | parser->simple_keys[parser->flow_level] = |
|---|
| | 1188 | yaml_malloc(sizeof(yaml_simple_key_t)); |
|---|
| | 1189 | if (!parser->simple_keys[parser->flow_level]) { |
|---|
| | 1190 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1191 | return 0; |
|---|
| | 1192 | } |
|---|
| | 1193 | |
|---|
| | 1194 | *(parser->simple_keys[parser->flow_level]) = simple_key; |
|---|
| | 1195 | } |
|---|
| | 1196 | |
|---|
| | 1197 | return 1; |
|---|
| | 1198 | } |
|---|
| | 1199 | |
|---|
| | 1200 | /* |
|---|
| | 1201 | * Remove a potential simple key at the current flow level. |
|---|
| | 1202 | */ |
|---|
| | 1203 | |
|---|
| | 1204 | static int |
|---|
| | 1205 | yaml_parser_remove_simple_key(yaml_parser_t *parser) |
|---|
| | 1206 | { |
|---|
| | 1207 | yaml_simple_key_t *simple_key = parser->simple_keys[parser->flow_level]; |
|---|
| | 1208 | |
|---|
| | 1209 | if (simple_key) |
|---|
| | 1210 | { |
|---|
| | 1211 | /* If the key is required, it is an error. */ |
|---|
| | 1212 | |
|---|
| | 1213 | if (simple_key->required) { |
|---|
| | 1214 | return yaml_parser_set_scanner_error(parser, |
|---|
| | 1215 | "while scanning a simple key", simple_key->mark, |
|---|
| | 1216 | "could not found expected ':'"); |
|---|
| | 1217 | } |
|---|
| | 1218 | |
|---|
| | 1219 | /* Remove the key from the list. */ |
|---|
| | 1220 | |
|---|
| | 1221 | yaml_free(simple_key); |
|---|
| | 1222 | parser->simple_keys[parser->flow_level] = NULL; |
|---|
| | 1223 | } |
|---|
| | 1224 | |
|---|
| | 1225 | return 1; |
|---|
| | 1226 | } |
|---|
| | 1227 | |
|---|
| | 1228 | /* |
|---|
| | 1229 | * Increase the flow level and resize the simple key list if needed. |
|---|
| | 1230 | */ |
|---|
| | 1231 | |
|---|
| | 1232 | static int |
|---|
| | 1233 | yaml_parser_increase_flow_level(yaml_parser_t *parser) |
|---|
| | 1234 | { |
|---|
| | 1235 | /* Check if we need to resize the list. */ |
|---|
| | 1236 | |
|---|
| | 1237 | if (parser->flow_level == parser->simple_keys_size-1) |
|---|
| | 1238 | { |
|---|
| | 1239 | yaml_simple_key_t **new_simple_keys = |
|---|
| | 1240 | yaml_realloc(parser->simple_keys, |
|---|
| | 1241 | sizeof(yaml_simple_key_t *) * parser->simple_keys_size * 2); |
|---|
| | 1242 | |
|---|
| | 1243 | if (!new_simple_keys) { |
|---|
| | 1244 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1245 | return 0; |
|---|
| | 1246 | } |
|---|
| | 1247 | |
|---|
| | 1248 | memset(new_simple_keys+parser->simple_keys_size, 0, |
|---|
| | 1249 | sizeof(yaml_simple_key_t *)*parser->simple_keys_size); |
|---|
| | 1250 | |
|---|
| | 1251 | parser->simple_keys = new_simple_keys; |
|---|
| | 1252 | parser->simple_keys_size *= 2; |
|---|
| | 1253 | } |
|---|
| | 1254 | |
|---|
| | 1255 | /* Increase the flow level and reset the simple key. */ |
|---|
| | 1256 | |
|---|
| | 1257 | parser->simple_keys[++parser->flow_level] = NULL; |
|---|
| | 1258 | |
|---|
| | 1259 | return 1; |
|---|
| | 1260 | } |
|---|
| | 1261 | |
|---|
| | 1262 | /* |
|---|
| | 1263 | * Decrease the flow level. |
|---|
| | 1264 | */ |
|---|
| | 1265 | |
|---|
| | 1266 | static int |
|---|
| | 1267 | yaml_parser_decrease_flow_level(yaml_parser_t *parser) |
|---|
| | 1268 | { |
|---|
| | 1269 | assert(parser->flow_level); /* Greater than 0. */ |
|---|
| | 1270 | assert(!parser->simple_keys[parser->flow_level]); /* Must be removed. */ |
|---|
| | 1271 | |
|---|
| | 1272 | parser->flow_level --; |
|---|
| | 1273 | |
|---|
| | 1274 | return 1; |
|---|
| | 1275 | } |
|---|
| | 1276 | |
|---|
| | 1277 | /* |
|---|
| | 1278 | * Add a token to the tail of the tokens queue. |
|---|
| | 1279 | */ |
|---|
| | 1280 | |
|---|
| | 1281 | static int |
|---|
| | 1282 | yaml_parser_append_token(yaml_parser_t *parser, yaml_token_t *token) |
|---|
| | 1283 | { |
|---|
| | 1284 | return yaml_parser_insert_token(parser, -1, token); |
|---|
| | 1285 | } |
|---|
| | 1286 | |
|---|
| | 1287 | /* |
|---|
| | 1288 | * Insert the token into the tokens queue. The number parameter is the |
|---|
| | 1289 | * ordinal number of the token. If the number is equal to -1, add the token |
|---|
| | 1290 | * to the tail of the queue. |
|---|
| | 1291 | */ |
|---|
| | 1292 | |
|---|
| | 1293 | static int |
|---|
| | 1294 | yaml_parser_insert_token(yaml_parser_t *parser, |
|---|
| | 1295 | int number, yaml_token_t *token) |
|---|
| | 1296 | { |
|---|
| | 1297 | /* The index of the token in the queue. */ |
|---|
| | 1298 | |
|---|
| | 1299 | int index = (number == -1) |
|---|
| | 1300 | ? parser->tokens_tail - parser->tokens_head |
|---|
| | 1301 | : number - parser->tokens_parsed; |
|---|
| | 1302 | |
|---|
| | 1303 | assert(index >= 0 && index <= (parser->tokens_tail-parser->tokens_head)); |
|---|
| | 1304 | |
|---|
| | 1305 | /* Check if we need to resize the queue. */ |
|---|
| | 1306 | |
|---|
| | 1307 | if (parser->tokens_head == 0 && parser->tokens_tail == parser->tokens_size) |
|---|
| | 1308 | { |
|---|
| | 1309 | yaml_token_t **new_tokens = yaml_realloc(parser->tokens, |
|---|
| | 1310 | sizeof(yaml_token_t *) * parser->tokens_size * 2); |
|---|
| | 1311 | |
|---|
| | 1312 | if (!new_tokens) { |
|---|
| | 1313 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1314 | return 0; |
|---|
| | 1315 | } |
|---|
| | 1316 | |
|---|
| | 1317 | memset(new_tokens+parser->tokens_size, 0, |
|---|
| | 1318 | sizeof(yaml_token_t *)*parser->tokens_size); |
|---|
| | 1319 | |
|---|
| | 1320 | parser->tokens = new_tokens; |
|---|
| | 1321 | parser->tokens_size *= 2; |
|---|
| | 1322 | } |
|---|
| | 1323 | |
|---|
| | 1324 | /* Check if we need to move the queue to the beginning of the buffer. */ |
|---|
| | 1325 | |
|---|
| | 1326 | if (parser->tokens_tail == parser->tokens_size) |
|---|
| | 1327 | { |
|---|
| | 1328 | if (parser->tokens_head < parser->tokens_tail) { |
|---|
| | 1329 | memmove(parser->tokens, parser->tokens+parser->tokens_head, |
|---|
| | 1330 | sizeof(yaml_token_t *)*(parser->tokens_tail-parser->tokens_head)); |
|---|
| | 1331 | } |
|---|
| | 1332 | parser->tokens_tail -= parser->tokens_head; |
|---|
| | 1333 | parser->tokens_head = 0; |
|---|
| | 1334 | } |
|---|
| | 1335 | |
|---|
| | 1336 | /* Check if we need to free space within the queue. */ |
|---|
| | 1337 | |
|---|
| | 1338 | if (index < (parser->tokens_tail-parser->tokens_head)) { |
|---|
| | 1339 | memmove(parser->tokens+parser->tokens_head+index+1, |
|---|
| | 1340 | parser->tokens+parser->tokens_head+index, |
|---|
| | 1341 | sizeof(yaml_token_t *)*(parser->tokens_tail-parser->tokens_head-index)); |
|---|
| | 1342 | } |
|---|
| | 1343 | |
|---|
| | 1344 | /* Insert the token. */ |
|---|
| | 1345 | |
|---|
| | 1346 | parser->tokens[parser->tokens_head+index] = token; |
|---|
| | 1347 | parser->tokens_tail ++; |
|---|
| | 1348 | |
|---|
| | 1349 | return 1; |
|---|
| | 1350 | } |
|---|
| | 1351 | |
|---|
| | 1352 | /* |
|---|
| | 1353 | * Push the current indentation level to the stack and set the new level |
|---|
| | 1354 | * the current column is greater than the indentation level. In this case, |
|---|
| | 1355 | * append or insert the specified token into the token queue. |
|---|
| | 1356 | * |
|---|
| | 1357 | */ |
|---|
| | 1358 | |
|---|
| | 1359 | static int |
|---|
| | 1360 | yaml_parser_roll_indent(yaml_parser_t *parser, int column, |
|---|
| | 1361 | int number, yaml_token_type_t type, yaml_mark_t mark) |
|---|
| | 1362 | { |
|---|
| | 1363 | yaml_token_t *token; |
|---|
| | 1364 | |
|---|
| | 1365 | /* In the flow context, do nothing. */ |
|---|
| | 1366 | |
|---|
| | 1367 | if (parser->flow_level) |
|---|
| | 1368 | return 1; |
|---|
| | 1369 | |
|---|
| | 1370 | if (parser->indent < column) |
|---|
| | 1371 | { |
|---|
| | 1372 | /* Check if we need to expand the indents stack. */ |
|---|
| | 1373 | |
|---|
| | 1374 | if (parser->indents_length == parser->indents_size) |
|---|
| | 1375 | { |
|---|
| | 1376 | int *new_indents = yaml_realloc(parser->indents, |
|---|
| | 1377 | sizeof(int) * parser->indents_size * 2); |
|---|
| | 1378 | |
|---|
| | 1379 | if (!new_indents) { |
|---|
| | 1380 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1381 | return 0; |
|---|
| | 1382 | } |
|---|
| | 1383 | |
|---|
| | 1384 | memset(new_indents+parser->indents_size, 0, |
|---|
| | 1385 | sizeof(int)*parser->indents_size); |
|---|
| | 1386 | |
|---|
| | 1387 | parser->indents = new_indents; |
|---|
| | 1388 | parser->indents_size *= 2; |
|---|
| | 1389 | } |
|---|
| | 1390 | |
|---|
| | 1391 | /* |
|---|
| | 1392 | * Push the current indentation level to the stack and set the new |
|---|
| | 1393 | * indentation level. |
|---|
| | 1394 | */ |
|---|
| | 1395 | |
|---|
| | 1396 | parser->indents[parser->indents_length++] = parser->indent; |
|---|
| | 1397 | parser->indent = column; |
|---|
| | 1398 | |
|---|
| | 1399 | /* Create a token. */ |
|---|
| | 1400 | |
|---|
| | 1401 | token = yaml_token_new(type, mark, mark); |
|---|
| | 1402 | if (!token) { |
|---|
| | 1403 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1404 | return 0; |
|---|
| | 1405 | } |
|---|
| | 1406 | |
|---|
| | 1407 | /* Insert the token into the queue. */ |
|---|
| | 1408 | |
|---|
| | 1409 | if (!yaml_parser_insert_token(parser, number, token)) { |
|---|
| | 1410 | yaml_token_delete(token); |
|---|
| | 1411 | return 0; |
|---|
| | 1412 | } |
|---|
| | 1413 | } |
|---|
| | 1414 | |
|---|
| | 1415 | return 1; |
|---|
| | 1416 | } |
|---|
| | 1417 | |
|---|
| | 1418 | /* |
|---|
| | 1419 | * Pop indentation levels from the indents stack until the current level |
|---|
| | 1420 | * becomes less or equal to the column. For each intendation level, append |
|---|
| | 1421 | * the BLOCK-END token. |
|---|
| | 1422 | */ |
|---|
| | 1423 | |
|---|
| | 1424 | |
|---|
| | 1425 | static int |
|---|
| | 1426 | yaml_parser_unroll_indent(yaml_parser_t *parser, int column) |
|---|
| | 1427 | { |
|---|
| | 1428 | yaml_token_t *token; |
|---|
| | 1429 | |
|---|
| | 1430 | /* In the flow context, do nothing. */ |
|---|
| | 1431 | |
|---|
| | 1432 | if (parser->flow_level) |
|---|
| | 1433 | return 1; |
|---|
| | 1434 | |
|---|
| | 1435 | /* Loop through the intendation levels in the stack. */ |
|---|
| | 1436 | |
|---|
| | 1437 | while (parser->indent > column) |
|---|
| | 1438 | { |
|---|
| | 1439 | yaml_mark_t mark = yaml_parser_get_mark(parser); |
|---|
| | 1440 | |
|---|
| | 1441 | /* Create a token. */ |
|---|
| | 1442 | |
|---|
| | 1443 | token = yaml_token_new(YAML_BLOCK_END_TOKEN, mark, mark); |
|---|
| | 1444 | if (!token) { |
|---|
| | 1445 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1446 | return 0; |
|---|
| | 1447 | } |
|---|
| | 1448 | |
|---|
| | 1449 | /* Append the token to the queue. */ |
|---|
| | 1450 | |
|---|
| | 1451 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1452 | yaml_token_delete(token); |
|---|
| | 1453 | return 0; |
|---|
| | 1454 | } |
|---|
| | 1455 | |
|---|
| | 1456 | /* Pop the indentation level. */ |
|---|
| | 1457 | |
|---|
| | 1458 | assert(parser->indents_length); /* Non-empty stack expected. */ |
|---|
| | 1459 | |
|---|
| | 1460 | parser->indent = parser->indents[--parser->indents_length]; |
|---|
| | 1461 | } |
|---|
| | 1462 | |
|---|
| | 1463 | return 1; |
|---|
| | 1464 | } |
|---|
| | 1465 | |
|---|
| | 1466 | /* |
|---|
| | 1467 | * Initialize the scanner and produce the STREAM-START token. |
|---|
| | 1468 | */ |
|---|
| | 1469 | |
|---|
| | 1470 | static int |
|---|
| | 1471 | yaml_parser_fetch_stream_start(yaml_parser_t *parser) |
|---|
| | 1472 | { |
|---|
| | 1473 | yaml_mark_t mark = yaml_parser_get_mark(parser); |
|---|
| | 1474 | yaml_token_t *token; |
|---|
| | 1475 | |
|---|
| | 1476 | /* Set the initial indentation. */ |
|---|
| | 1477 | |
|---|
| | 1478 | parser->indent = -1; |
|---|
| | 1479 | |
|---|
| | 1480 | /* A simple key is allowed at the beginning of the stream. */ |
|---|
| | 1481 | |
|---|
| | 1482 | parser->simple_key_allowed = 1; |
|---|
| | 1483 | |
|---|
| | 1484 | /* We have started. */ |
|---|
| | 1485 | |
|---|
| | 1486 | parser->stream_start_produced = 1; |
|---|
| | 1487 | |
|---|
| | 1488 | /* Create the STREAM-START token. */ |
|---|
| | 1489 | |
|---|
| | 1490 | token = yaml_stream_start_token_new(parser->encoding, mark, mark); |
|---|
| | 1491 | if (!token) { |
|---|
| | 1492 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1493 | return 0; |
|---|
| | 1494 | } |
|---|
| | 1495 | |
|---|
| | 1496 | /* Append the token to the queue. */ |
|---|
| | 1497 | |
|---|
| | 1498 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1499 | yaml_token_delete(token); |
|---|
| | 1500 | return 0; |
|---|
| | 1501 | } |
|---|
| | 1502 | |
|---|
| | 1503 | return 1; |
|---|
| | 1504 | } |
|---|
| | 1505 | |
|---|
| | 1506 | /* |
|---|
| | 1507 | * Produce the STREAM-END token and shut down the scanner. |
|---|
| | 1508 | */ |
|---|
| | 1509 | |
|---|
| | 1510 | static int |
|---|
| | 1511 | yaml_parser_fetch_stream_end(yaml_parser_t *parser) |
|---|
| | 1512 | { |
|---|
| | 1513 | yaml_mark_t mark = yaml_parser_get_mark(parser); |
|---|
| | 1514 | yaml_token_t *token; |
|---|
| | 1515 | |
|---|
| | 1516 | /* Reset the indentation level. */ |
|---|
| | 1517 | |
|---|
| | 1518 | if (!yaml_parser_unroll_indent(parser, -1)) |
|---|
| | 1519 | return 0; |
|---|
| | 1520 | |
|---|
| | 1521 | /* We have finished. */ |
|---|
| | 1522 | |
|---|
| | 1523 | parser->stream_end_produced = 1; |
|---|
| | 1524 | |
|---|
| | 1525 | /* Create the STREAM-END token. */ |
|---|
| | 1526 | |
|---|
| | 1527 | token = yaml_stream_end_token_new(mark, mark); |
|---|
| | 1528 | if (!token) { |
|---|
| | 1529 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1530 | return 0; |
|---|
| | 1531 | } |
|---|
| | 1532 | |
|---|
| | 1533 | /* Append the token to the queue. */ |
|---|
| | 1534 | |
|---|
| | 1535 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1536 | yaml_token_delete(token); |
|---|
| | 1537 | return 0; |
|---|
| | 1538 | } |
|---|
| | 1539 | |
|---|
| | 1540 | return 1; |
|---|
| | 1541 | } |
|---|
| | 1542 | |
|---|
| | 1543 | /* |
|---|
| | 1544 | * Produce the YAML-DIRECTIVE or TAG-DIRECTIVE token. |
|---|
| | 1545 | */ |
|---|
| | 1546 | |
|---|
| | 1547 | static int |
|---|
| | 1548 | yaml_parser_fetch_directive(yaml_parser_t *parser) |
|---|
| | 1549 | { |
|---|
| | 1550 | yaml_token_t *token; |
|---|
| | 1551 | |
|---|
| | 1552 | /* Reset the indentation level. */ |
|---|
| | 1553 | |
|---|
| | 1554 | if (!yaml_parser_unroll_indent(parser, -1)) |
|---|
| | 1555 | return 0; |
|---|
| | 1556 | |
|---|
| | 1557 | /* Reset simple keys. */ |
|---|
| | 1558 | |
|---|
| | 1559 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1560 | return 0; |
|---|
| | 1561 | |
|---|
| | 1562 | parser->simple_key_allowed = 0; |
|---|
| | 1563 | |
|---|
| | 1564 | /* Create the YAML-DIRECTIVE or TAG-DIRECTIVE token. */ |
|---|
| | 1565 | |
|---|
| | 1566 | token = yaml_parser_scan_directive(parser); |
|---|
| | 1567 | if (!token) return 0; |
|---|
| | 1568 | |
|---|
| | 1569 | /* Append the token to the queue. */ |
|---|
| | 1570 | |
|---|
| | 1571 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1572 | yaml_token_delete(token); |
|---|
| | 1573 | return 0; |
|---|
| | 1574 | } |
|---|
| | 1575 | |
|---|
| | 1576 | return 1; |
|---|
| | 1577 | } |
|---|
| | 1578 | |
|---|
| | 1579 | /* |
|---|
| | 1580 | * Produce the DOCUMENT-START or DOCUMENT-END token. |
|---|
| | 1581 | */ |
|---|
| | 1582 | |
|---|
| | 1583 | static int |
|---|
| | 1584 | yaml_parser_fetch_document_indicator(yaml_parser_t *parser, |
|---|
| | 1585 | yaml_token_type_t type) |
|---|
| | 1586 | { |
|---|
| | 1587 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1588 | yaml_token_t *token; |
|---|
| | 1589 | |
|---|
| | 1590 | /* Reset the indentation level. */ |
|---|
| | 1591 | |
|---|
| | 1592 | if (!yaml_parser_unroll_indent(parser, -1)) |
|---|
| | 1593 | return 0; |
|---|
| | 1594 | |
|---|
| | 1595 | /* Reset simple keys. */ |
|---|
| | 1596 | |
|---|
| | 1597 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1598 | return 0; |
|---|
| | 1599 | |
|---|
| | 1600 | parser->simple_key_allowed = 0; |
|---|
| | 1601 | |
|---|
| | 1602 | /* Consume the token. */ |
|---|
| | 1603 | |
|---|
| | 1604 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1605 | |
|---|
| | 1606 | FORWARD(parser); |
|---|
| | 1607 | FORWARD(parser); |
|---|
| | 1608 | FORWARD(parser); |
|---|
| | 1609 | |
|---|
| | 1610 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1611 | |
|---|
| | 1612 | /* Create the DOCUMENT-START or DOCUMENT-END token. */ |
|---|
| | 1613 | |
|---|
| | 1614 | token = yaml_token_new(type, start_mark, end_mark); |
|---|
| | 1615 | if (!token) { |
|---|
| | 1616 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1617 | return 0; |
|---|
| | 1618 | } |
|---|
| | 1619 | |
|---|
| | 1620 | /* Append the token to the queue. */ |
|---|
| | 1621 | |
|---|
| | 1622 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1623 | yaml_token_delete(token); |
|---|
| | 1624 | return 0; |
|---|
| | 1625 | } |
|---|
| | 1626 | |
|---|
| | 1627 | return 1; |
|---|
| | 1628 | } |
|---|
| | 1629 | |
|---|
| | 1630 | /* |
|---|
| | 1631 | * Produce the FLOW-SEQUENCE-START or FLOW-MAPPING-START token. |
|---|
| | 1632 | */ |
|---|
| | 1633 | |
|---|
| | 1634 | static int |
|---|
| | 1635 | yaml_parser_fetch_flow_collection_start(yaml_parser_t *parser, |
|---|
| | 1636 | yaml_token_type_t type) |
|---|
| | 1637 | { |
|---|
| | 1638 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1639 | yaml_token_t *token; |
|---|
| | 1640 | |
|---|
| | 1641 | /* The indicators '[' and '{' may start a simple key. */ |
|---|
| | 1642 | |
|---|
| | 1643 | if (!yaml_parser_save_simple_key(parser)) |
|---|
| | 1644 | return 0; |
|---|
| | 1645 | |
|---|
| | 1646 | /* Increase the flow level. */ |
|---|
| | 1647 | |
|---|
| | 1648 | if (!yaml_parser_increase_flow_level(parser)) |
|---|
| | 1649 | return 0; |
|---|
| | 1650 | |
|---|
| | 1651 | /* A simple key may follow the indicators '[' and '{'. */ |
|---|
| | 1652 | |
|---|
| | 1653 | parser->simple_key_allowed = 1; |
|---|
| | 1654 | |
|---|
| | 1655 | /* Consume the token. */ |
|---|
| | 1656 | |
|---|
| | 1657 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1658 | FORWARD(parser); |
|---|
| | 1659 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1660 | |
|---|
| | 1661 | /* Create the FLOW-SEQUENCE-START of FLOW-MAPPING-START token. */ |
|---|
| | 1662 | |
|---|
| | 1663 | token = yaml_token_new(type, start_mark, end_mark); |
|---|
| | 1664 | if (!token) { |
|---|
| | 1665 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1666 | return 0; |
|---|
| | 1667 | } |
|---|
| | 1668 | |
|---|
| | 1669 | /* Append the token to the queue. */ |
|---|
| | 1670 | |
|---|
| | 1671 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1672 | yaml_token_delete(token); |
|---|
| | 1673 | return 0; |
|---|
| | 1674 | } |
|---|
| | 1675 | |
|---|
| | 1676 | return 1; |
|---|
| | 1677 | } |
|---|
| | 1678 | |
|---|
| | 1679 | /* |
|---|
| | 1680 | * Produce the FLOW-SEQUENCE-END or FLOW-MAPPING-END token. |
|---|
| | 1681 | */ |
|---|
| | 1682 | |
|---|
| | 1683 | static int |
|---|
| | 1684 | yaml_parser_fetch_flow_collection_end(yaml_parser_t *parser, |
|---|
| | 1685 | yaml_token_type_t type) |
|---|
| | 1686 | { |
|---|
| | 1687 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1688 | yaml_token_t *token; |
|---|
| | 1689 | |
|---|
| | 1690 | /* Reset any potential simple key on the current flow level. */ |
|---|
| | 1691 | |
|---|
| | 1692 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1693 | return 0; |
|---|
| | 1694 | |
|---|
| | 1695 | /* Decrease the flow level. */ |
|---|
| | 1696 | |
|---|
| | 1697 | if (!yaml_parser_decrease_flow_level(parser)) |
|---|
| | 1698 | return 0; |
|---|
| | 1699 | |
|---|
| | 1700 | /* No simple keys after the indicators ']' and '}'. */ |
|---|
| | 1701 | |
|---|
| | 1702 | parser->simple_key_allowed = 0; |
|---|
| | 1703 | |
|---|
| | 1704 | /* Consume the token. */ |
|---|
| | 1705 | |
|---|
| | 1706 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1707 | FORWARD(parser); |
|---|
| | 1708 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1709 | |
|---|
| | 1710 | /* Create the FLOW-SEQUENCE-END of FLOW-MAPPING-END token. */ |
|---|
| | 1711 | |
|---|
| | 1712 | token = yaml_token_new(type, start_mark, end_mark); |
|---|
| | 1713 | if (!token) { |
|---|
| | 1714 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1715 | return 0; |
|---|
| | 1716 | } |
|---|
| | 1717 | |
|---|
| | 1718 | /* Append the token to the queue. */ |
|---|
| | 1719 | |
|---|
| | 1720 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1721 | yaml_token_delete(token); |
|---|
| | 1722 | return 0; |
|---|
| | 1723 | } |
|---|
| | 1724 | |
|---|
| | 1725 | return 1; |
|---|
| | 1726 | } |
|---|
| | 1727 | |
|---|
| | 1728 | /* |
|---|
| | 1729 | * Produce the FLOW-ENTRY token. |
|---|
| | 1730 | */ |
|---|
| | 1731 | |
|---|
| | 1732 | static int |
|---|
| | 1733 | yaml_parser_fetch_flow_entry(yaml_parser_t *parser) |
|---|
| | 1734 | { |
|---|
| | 1735 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1736 | yaml_token_t *token; |
|---|
| | 1737 | |
|---|
| | 1738 | /* Reset any potential simple keys on the current flow level. */ |
|---|
| | 1739 | |
|---|
| | 1740 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1741 | return 0; |
|---|
| | 1742 | |
|---|
| | 1743 | /* Simple keys are allowed after ','. */ |
|---|
| | 1744 | |
|---|
| | 1745 | parser->simple_key_allowed = 1; |
|---|
| | 1746 | |
|---|
| | 1747 | /* Consume the token. */ |
|---|
| | 1748 | |
|---|
| | 1749 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1750 | FORWARD(parser); |
|---|
| | 1751 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1752 | |
|---|
| | 1753 | /* Create the FLOW-ENTRY token. */ |
|---|
| | 1754 | |
|---|
| | 1755 | token = yaml_token_new(YAML_FLOW_ENTRY_TOKEN, start_mark, end_mark); |
|---|
| | 1756 | if (!token) { |
|---|
| | 1757 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1758 | return 0; |
|---|
| | 1759 | } |
|---|
| | 1760 | |
|---|
| | 1761 | /* Append the token to the queue. */ |
|---|
| | 1762 | |
|---|
| | 1763 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1764 | yaml_token_delete(token); |
|---|
| | 1765 | return 0; |
|---|
| | 1766 | } |
|---|
| | 1767 | |
|---|
| | 1768 | return 1; |
|---|
| | 1769 | } |
|---|
| | 1770 | |
|---|
| | 1771 | /* |
|---|
| | 1772 | * Produce the BLOCK-ENTRY token. |
|---|
| | 1773 | */ |
|---|
| | 1774 | |
|---|
| | 1775 | static int |
|---|
| | 1776 | yaml_parser_fetch_block_entry(yaml_parser_t *parser) |
|---|
| | 1777 | { |
|---|
| | 1778 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1779 | yaml_token_t *token; |
|---|
| | 1780 | |
|---|
| | 1781 | /* Check if the scanner is in the block context. */ |
|---|
| | 1782 | |
|---|
| | 1783 | if (!parser->flow_level) |
|---|
| | 1784 | { |
|---|
| | 1785 | /* Check if we are allowed to start a new entry. */ |
|---|
| | 1786 | |
|---|
| | 1787 | if (!parser->simple_key_allowed) { |
|---|
| | 1788 | return yaml_parser_set_scanner_error(parser, NULL, |
|---|
| | 1789 | yaml_parser_get_mark(parser), |
|---|
| | 1790 | "block sequence entries are not allowed in this context"); |
|---|
| | 1791 | } |
|---|
| | 1792 | |
|---|
| | 1793 | /* Add the BLOCK-SEQUENCE-START token if needed. */ |
|---|
| | 1794 | |
|---|
| | 1795 | if (!yaml_parser_roll_indent(parser, parser->column, -1, |
|---|
| | 1796 | YAML_BLOCK_SEQUENCE_START_TOKEN, yaml_parser_get_mark(parser))) |
|---|
| | 1797 | return 0; |
|---|
| | 1798 | } |
|---|
| | 1799 | else |
|---|
| | 1800 | { |
|---|
| | 1801 | /* |
|---|
| | 1802 | * It is an error for the '-' indicator to occur in the flow context, |
|---|
| | 1803 | * but we let the Parser detect and report about it because the Parser |
|---|
| | 1804 | * is able to point to the context. |
|---|
| | 1805 | */ |
|---|
| | 1806 | } |
|---|
| | 1807 | |
|---|
| | 1808 | /* Reset any potential simple keys on the current flow level. */ |
|---|
| | 1809 | |
|---|
| | 1810 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1811 | return 0; |
|---|
| | 1812 | |
|---|
| | 1813 | /* Simple keys are allowed after '-'. */ |
|---|
| | 1814 | |
|---|
| | 1815 | parser->simple_key_allowed = 1; |
|---|
| | 1816 | |
|---|
| | 1817 | /* Consume the token. */ |
|---|
| | 1818 | |
|---|
| | 1819 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1820 | FORWARD(parser); |
|---|
| | 1821 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1822 | |
|---|
| | 1823 | /* Create the BLOCK-ENTRY token. */ |
|---|
| | 1824 | |
|---|
| | 1825 | token = yaml_token_new(YAML_BLOCK_ENTRY_TOKEN, start_mark, end_mark); |
|---|
| | 1826 | if (!token) { |
|---|
| | 1827 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1828 | return 0; |
|---|
| | 1829 | } |
|---|
| | 1830 | |
|---|
| | 1831 | /* Append the token to the queue. */ |
|---|
| | 1832 | |
|---|
| | 1833 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1834 | yaml_token_delete(token); |
|---|
| | 1835 | return 0; |
|---|
| | 1836 | } |
|---|
| | 1837 | |
|---|
| | 1838 | return 1; |
|---|
| | 1839 | } |
|---|
| | 1840 | |
|---|
| | 1841 | /* |
|---|
| | 1842 | * Produce the KEY token. |
|---|
| | 1843 | */ |
|---|
| | 1844 | |
|---|
| | 1845 | static int |
|---|
| | 1846 | yaml_parser_fetch_key(yaml_parser_t *parser) |
|---|
| | 1847 | { |
|---|
| | 1848 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1849 | yaml_token_t *token; |
|---|
| | 1850 | |
|---|
| | 1851 | /* In the block context, additional checks are required. */ |
|---|
| | 1852 | |
|---|
| | 1853 | if (!parser->flow_level) |
|---|
| | 1854 | { |
|---|
| | 1855 | /* Check if we are allowed to start a new key (not nessesary simple). */ |
|---|
| | 1856 | |
|---|
| | 1857 | if (!parser->simple_key_allowed) { |
|---|
| | 1858 | return yaml_parser_set_scanner_error(parser, NULL, |
|---|
| | 1859 | yaml_parser_get_mark(parser), |
|---|
| | 1860 | "mapping keys are not allowed in this context"); |
|---|
| | 1861 | } |
|---|
| | 1862 | |
|---|
| | 1863 | /* Add the BLOCK-MAPPING-START token if needed. */ |
|---|
| | 1864 | |
|---|
| | 1865 | if (!yaml_parser_roll_indent(parser, parser->column, -1, |
|---|
| | 1866 | YAML_BLOCK_MAPPING_START_TOKEN, yaml_parser_get_mark(parser))) |
|---|
| | 1867 | return 0; |
|---|
| | 1868 | } |
|---|
| | 1869 | |
|---|
| | 1870 | /* Reset any potential simple keys on the current flow level. */ |
|---|
| | 1871 | |
|---|
| | 1872 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 1873 | return 0; |
|---|
| | 1874 | |
|---|
| | 1875 | /* Simple keys are allowed after '?' in the block context. */ |
|---|
| | 1876 | |
|---|
| | 1877 | parser->simple_key_allowed = (!parser->flow_level); |
|---|
| | 1878 | |
|---|
| | 1879 | /* Consume the token. */ |
|---|
| | 1880 | |
|---|
| | 1881 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1882 | FORWARD(parser); |
|---|
| | 1883 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1884 | |
|---|
| | 1885 | /* Create the KEY token. */ |
|---|
| | 1886 | |
|---|
| | 1887 | token = yaml_token_new(YAML_KEY_TOKEN, start_mark, end_mark); |
|---|
| | 1888 | if (!token) { |
|---|
| | 1889 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1890 | return 0; |
|---|
| | 1891 | } |
|---|
| | 1892 | |
|---|
| | 1893 | /* Append the token to the queue. */ |
|---|
| | 1894 | |
|---|
| | 1895 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1896 | yaml_token_delete(token); |
|---|
| | 1897 | return 0; |
|---|
| | 1898 | } |
|---|
| | 1899 | |
|---|
| | 1900 | return 1; |
|---|
| | 1901 | } |
|---|
| | 1902 | |
|---|
| | 1903 | /* |
|---|
| | 1904 | * Produce the VALUE token. |
|---|
| | 1905 | */ |
|---|
| | 1906 | |
|---|
| | 1907 | static int |
|---|
| | 1908 | yaml_parser_fetch_value(yaml_parser_t *parser) |
|---|
| | 1909 | { |
|---|
| | 1910 | yaml_mark_t start_mark, end_mark; |
|---|
| | 1911 | yaml_token_t *token; |
|---|
| | 1912 | |
|---|
| | 1913 | /* Have we found a simple key? */ |
|---|
| | 1914 | |
|---|
| | 1915 | if (parser->simple_keys[parser->flow_level]) |
|---|
| | 1916 | { |
|---|
| | 1917 | yaml_simple_key_t *simple_key = parser->simple_keys[parser->flow_level]; |
|---|
| | 1918 | |
|---|
| | 1919 | /* Create the KEY token. */ |
|---|
| | 1920 | |
|---|
| | 1921 | token = yaml_token_new(YAML_KEY_TOKEN, simple_key->mark, simple_key->mark); |
|---|
| | 1922 | if (!token) { |
|---|
| | 1923 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1924 | return 0; |
|---|
| | 1925 | } |
|---|
| | 1926 | |
|---|
| | 1927 | /* Insert the token into the queue. */ |
|---|
| | 1928 | |
|---|
| | 1929 | if (!yaml_parser_insert_token(parser, simple_key->token_number, token)) { |
|---|
| | 1930 | yaml_token_delete(token); |
|---|
| | 1931 | return 0; |
|---|
| | 1932 | } |
|---|
| | 1933 | |
|---|
| | 1934 | /* In the block context, we may need to add the BLOCK-MAPPING-START token. */ |
|---|
| | 1935 | |
|---|
| | 1936 | if (!yaml_parser_roll_indent(parser, parser->column, |
|---|
| | 1937 | simple_key->token_number, |
|---|
| | 1938 | YAML_BLOCK_MAPPING_START_TOKEN, simple_key->mark)) |
|---|
| | 1939 | return 0; |
|---|
| | 1940 | |
|---|
| | 1941 | /* Remove the simple key from the list. */ |
|---|
| | 1942 | |
|---|
| | 1943 | if (!yaml_parser_remove_simple_key(parser)) return 0; |
|---|
| | 1944 | |
|---|
| | 1945 | /* A simple key cannot follow another simple key. */ |
|---|
| | 1946 | |
|---|
| | 1947 | parser->simple_key_allowed = 0; |
|---|
| | 1948 | } |
|---|
| | 1949 | else |
|---|
| | 1950 | { |
|---|
| | 1951 | /* The ':' indicator follows a complex key. */ |
|---|
| | 1952 | |
|---|
| | 1953 | /* In the block context, extra checks are required. */ |
|---|
| | 1954 | |
|---|
| | 1955 | if (!parser->flow_level) |
|---|
| | 1956 | { |
|---|
| | 1957 | /* Check if we are allowed to start a complex value. */ |
|---|
| | 1958 | |
|---|
| | 1959 | if (!parser->simple_key_allowed) { |
|---|
| | 1960 | return yaml_parser_set_scanner_error(parser, NULL, |
|---|
| | 1961 | yaml_parser_get_mark(parser), |
|---|
| | 1962 | "mapping values are not allowed in this context"); |
|---|
| | 1963 | } |
|---|
| | 1964 | |
|---|
| | 1965 | /* Add the BLOCK-MAPPING-START token if needed. */ |
|---|
| | 1966 | |
|---|
| | 1967 | if (!yaml_parser_roll_indent(parser, parser->column, -1, |
|---|
| | 1968 | YAML_BLOCK_MAPPING_START_TOKEN, yaml_parser_get_mark(parser))) |
|---|
| | 1969 | return 0; |
|---|
| | 1970 | } |
|---|
| | 1971 | |
|---|
| | 1972 | /* Remove a potential simple key from the list. */ |
|---|
| | 1973 | |
|---|
| | 1974 | if (!yaml_parser_remove_simple_key(parser)) return 0; |
|---|
| | 1975 | |
|---|
| | 1976 | /* Simple keys after ':' are allowed in the block context. */ |
|---|
| | 1977 | |
|---|
| | 1978 | parser->simple_key_allowed = (!parser->flow_level); |
|---|
| | 1979 | } |
|---|
| | 1980 | |
|---|
| | 1981 | /* Consume the token. */ |
|---|
| | 1982 | |
|---|
| | 1983 | start_mark = yaml_parser_get_mark(parser); |
|---|
| | 1984 | FORWARD(parser); |
|---|
| | 1985 | end_mark = yaml_parser_get_mark(parser); |
|---|
| | 1986 | |
|---|
| | 1987 | /* Create the VALUE token. */ |
|---|
| | 1988 | |
|---|
| | 1989 | token = yaml_token_new(YAML_VALUE_TOKEN, start_mark, end_mark); |
|---|
| | 1990 | if (!token) { |
|---|
| | 1991 | parser->error = YAML_MEMORY_ERROR; |
|---|
| | 1992 | return 0; |
|---|
| | 1993 | } |
|---|
| | 1994 | |
|---|
| | 1995 | /* Append the token to the queue. */ |
|---|
| | 1996 | |
|---|
| | 1997 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 1998 | yaml_token_delete(token); |
|---|
| | 1999 | return 0; |
|---|
| | 2000 | } |
|---|
| | 2001 | |
|---|
| | 2002 | return 1; |
|---|
| | 2003 | } |
|---|
| | 2004 | |
|---|
| | 2005 | /* |
|---|
| | 2006 | * Produce the ALIAS or ANCHOR token. |
|---|
| | 2007 | */ |
|---|
| | 2008 | |
|---|
| | 2009 | static int |
|---|
| | 2010 | yaml_parser_fetch_anchor(yaml_parser_t *parser, yaml_token_type_t type) |
|---|
| | 2011 | { |
|---|
| | 2012 | yaml_token_t *token; |
|---|
| | 2013 | |
|---|
| | 2014 | /* An anchor or an alias could be a simple key. */ |
|---|
| | 2015 | |
|---|
| | 2016 | if (!yaml_parser_save_simple_key(parser)) |
|---|
| | 2017 | return 0; |
|---|
| | 2018 | |
|---|
| | 2019 | /* A simple key cannot follow an anchor or an alias. */ |
|---|
| | 2020 | |
|---|
| | 2021 | parser->simple_key_allowed = 0; |
|---|
| | 2022 | |
|---|
| | 2023 | /* Create the ALIAS or ANCHOR token. */ |
|---|
| | 2024 | |
|---|
| | 2025 | token = yaml_parser_scan_anchor(parser, type); |
|---|
| | 2026 | if (!token) return 0; |
|---|
| | 2027 | |
|---|
| | 2028 | /* Append the token to the queue. */ |
|---|
| | 2029 | |
|---|
| | 2030 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 2031 | yaml_token_delete(token); |
|---|
| | 2032 | return 0; |
|---|
| | 2033 | } |
|---|
| | 2034 | |
|---|
| | 2035 | return 1; |
|---|
| | 2036 | } |
|---|
| | 2037 | |
|---|
| | 2038 | /* |
|---|
| | 2039 | * Produce the TAG token. |
|---|
| | 2040 | */ |
|---|
| | 2041 | |
|---|
| | 2042 | static int |
|---|
| | 2043 | yaml_parser_fetch_tag(yaml_parser_t *parser) |
|---|
| | 2044 | { |
|---|
| | 2045 | yaml_token_t *token; |
|---|
| | 2046 | |
|---|
| | 2047 | /* A tag could be a simple key. */ |
|---|
| | 2048 | |
|---|
| | 2049 | if (!yaml_parser_save_simple_key(parser)) |
|---|
| | 2050 | return 0; |
|---|
| | 2051 | |
|---|
| | 2052 | /* A simple key cannot follow a tag. */ |
|---|
| | 2053 | |
|---|
| | 2054 | parser->simple_key_allowed = 0; |
|---|
| | 2055 | |
|---|
| | 2056 | /* Create the TAG token. */ |
|---|
| | 2057 | |
|---|
| | 2058 | token = yaml_parser_scan_tag(parser); |
|---|
| | 2059 | if (!token) return 0; |
|---|
| | 2060 | |
|---|
| | 2061 | /* Append the token to the queue. */ |
|---|
| | 2062 | |
|---|
| | 2063 | if (!yaml_parser_append_token(parser, token)) { |
|---|
| | 2064 | yaml_token_delete(token); |
|---|
| | 2065 | return 0; |
|---|
| | 2066 | } |
|---|
| | 2067 | |
|---|
| | 2068 | return 1; |
|---|
| | 2069 | } |
|---|
| | 2070 | |
|---|
| | 2071 | /* |
|---|
| | 2072 | * Produce the SCALAR(...,literal) or SCALAR(...,folded) tokens. |
|---|
| | 2073 | */ |
|---|
| | 2074 | |
|---|
| | 2075 | static int |
|---|
| | 2076 | yaml_parser_fetch_block_scalar(yaml_parser_t *parser, int literal) |
|---|
| | 2077 | { |
|---|
| | 2078 | yaml_token_t *token; |
|---|
| | 2079 | |
|---|
| | 2080 | /* Remove any potential simple keys. */ |
|---|
| | 2081 | |
|---|
| | 2082 | if (!yaml_parser_remove_simple_key(parser)) |
|---|
| | 2083 | return 0; |
|---|
| | 2084 | |
|---|
| | 2085 | /* A simple key may follow a block scalar. */ |
|---|
| | 2086 | |
|---|
| | 2087 | |
|---|