16#ifndef PRISM_EXCLUDE_SERIALIZATION
21pm_ptrdifft_to_u32(ptrdiff_t value) {
22 assert(value >= 0 && ((
unsigned long) value) < UINT32_MAX);
23 return (uint32_t) value;
27pm_sizet_to_u32(
size_t value) {
28 assert(value < UINT32_MAX);
29 return (uint32_t) value;
34 assert(location->
start);
35 assert(location->
end);
36 assert(location->
start <= location->
end);
38 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(location->
start - parser->
start));
39 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(location->
end - location->
start));
44 switch (string->
type) {
45 case PM_STRING_SHARED: {
46 pm_buffer_append_byte(buffer, 1);
52 case PM_STRING_CONSTANT: {
54 pm_buffer_append_byte(buffer, 2);
55 pm_buffer_append_varuint(buffer, length);
60 case PM_STRING_MAPPED:
61 assert(
false &&
"Cannot serialize mapped strings.");
69 pm_buffer_append_byte(buffer, integer->
negative ? 1 : 0);
70 if (integer->
values == NULL) {
71 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(1));
72 pm_buffer_append_varuint(buffer, integer->
value);
74 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(integer->
length));
75 for (
size_t i = 0; i < integer->
length; i++) {
76 pm_buffer_append_varuint(buffer, integer->
values[i]);
83 pm_buffer_append_byte(buffer, (uint8_t) PM_NODE_TYPE(node));
85 size_t offset = buffer->
length;
87 pm_buffer_append_varuint(buffer, node->
node_id);
88 pm_serialize_location(parser, &node->
location, buffer);
90 switch (PM_NODE_TYPE(node)) {
95 case PM_ALIAS_GLOBAL_VARIABLE_NODE: {
96 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
102 case PM_ALIAS_METHOD_NODE: {
103 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
109 case PM_ALTERNATION_PATTERN_NODE: {
110 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
117 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
120 pm_serialize_location(parser, &((
pm_and_node_t *)node)->operator_loc, buffer);
123 case PM_ARGUMENTS_NODE: {
124 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
126 pm_buffer_append_varuint(buffer, arguments_size);
127 for (uint32_t index = 0; index < arguments_size; index++) {
132 case PM_ARRAY_NODE: {
133 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
134 uint32_t elements_size = pm_sizet_to_u32(((
pm_array_node_t *)node)->elements.size);
135 pm_buffer_append_varuint(buffer, elements_size);
136 for (uint32_t index = 0; index < elements_size; index++) {
140 pm_buffer_append_byte(buffer, 0);
142 pm_buffer_append_byte(buffer, 1);
143 pm_serialize_location(parser, &((
pm_array_node_t *)node)->opening_loc, buffer);
146 pm_buffer_append_byte(buffer, 0);
148 pm_buffer_append_byte(buffer, 1);
149 pm_serialize_location(parser, &((
pm_array_node_t *)node)->closing_loc, buffer);
153 case PM_ARRAY_PATTERN_NODE: {
154 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
156 pm_buffer_append_byte(buffer, 0);
161 pm_buffer_append_varuint(buffer, requireds_size);
162 for (uint32_t index = 0; index < requireds_size; index++) {
166 pm_buffer_append_byte(buffer, 0);
171 pm_buffer_append_varuint(buffer, posts_size);
172 for (uint32_t index = 0; index < posts_size; index++) {
176 pm_buffer_append_byte(buffer, 0);
178 pm_buffer_append_byte(buffer, 1);
182 pm_buffer_append_byte(buffer, 0);
184 pm_buffer_append_byte(buffer, 1);
189 case PM_ASSOC_NODE: {
190 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
194 pm_buffer_append_byte(buffer, 0);
196 pm_buffer_append_byte(buffer, 1);
197 pm_serialize_location(parser, &((
pm_assoc_node_t *)node)->operator_loc, buffer);
201 case PM_ASSOC_SPLAT_NODE: {
202 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
204 pm_buffer_append_byte(buffer, 0);
211 case PM_BACK_REFERENCE_READ_NODE: {
212 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
216 case PM_BEGIN_NODE: {
217 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
219 pm_buffer_append_byte(buffer, 0);
221 pm_buffer_append_byte(buffer, 1);
222 pm_serialize_location(parser, &((
pm_begin_node_t *)node)->begin_keyword_loc, buffer);
225 pm_buffer_append_byte(buffer, 0);
230 pm_buffer_append_byte(buffer, 0);
235 pm_buffer_append_byte(buffer, 0);
240 pm_buffer_append_byte(buffer, 0);
245 pm_buffer_append_byte(buffer, 0);
247 pm_buffer_append_byte(buffer, 1);
248 pm_serialize_location(parser, &((
pm_begin_node_t *)node)->end_keyword_loc, buffer);
252 case PM_BLOCK_ARGUMENT_NODE: {
253 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
255 pm_buffer_append_byte(buffer, 0);
262 case PM_BLOCK_LOCAL_VARIABLE_NODE: {
263 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
267 case PM_BLOCK_NODE: {
268 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
269 uint32_t locals_size = pm_sizet_to_u32(((
pm_block_node_t *)node)->locals.size);
270 pm_buffer_append_varuint(buffer, locals_size);
271 for (uint32_t index = 0; index < locals_size; index++) {
272 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_block_node_t *)node)->locals.ids[index]));
275 pm_buffer_append_byte(buffer, 0);
280 pm_buffer_append_byte(buffer, 0);
284 pm_serialize_location(parser, &((
pm_block_node_t *)node)->opening_loc, buffer);
285 pm_serialize_location(parser, &((
pm_block_node_t *)node)->closing_loc, buffer);
288 case PM_BLOCK_PARAMETER_NODE: {
289 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
292 pm_buffer_append_byte(buffer, 0);
294 pm_buffer_append_byte(buffer, 1);
300 case PM_BLOCK_PARAMETERS_NODE: {
301 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
303 pm_buffer_append_byte(buffer, 0);
308 pm_buffer_append_varuint(buffer, locals_size);
309 for (uint32_t index = 0; index < locals_size; index++) {
313 pm_buffer_append_byte(buffer, 0);
315 pm_buffer_append_byte(buffer, 1);
319 pm_buffer_append_byte(buffer, 0);
321 pm_buffer_append_byte(buffer, 1);
326 case PM_BREAK_NODE: {
327 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
329 pm_buffer_append_byte(buffer, 0);
333 pm_serialize_location(parser, &((
pm_break_node_t *)node)->keyword_loc, buffer);
336 case PM_CALL_AND_WRITE_NODE: {
337 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
339 pm_buffer_append_byte(buffer, 0);
344 pm_buffer_append_byte(buffer, 0);
346 pm_buffer_append_byte(buffer, 1);
350 pm_buffer_append_byte(buffer, 0);
352 pm_buffer_append_byte(buffer, 1);
362 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
364 pm_buffer_append_byte(buffer, 0);
369 pm_buffer_append_byte(buffer, 0);
371 pm_buffer_append_byte(buffer, 1);
372 pm_serialize_location(parser, &((
pm_call_node_t *)node)->call_operator_loc, buffer);
374 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_call_node_t *)node)->name));
376 pm_buffer_append_byte(buffer, 0);
378 pm_buffer_append_byte(buffer, 1);
379 pm_serialize_location(parser, &((
pm_call_node_t *)node)->message_loc, buffer);
382 pm_buffer_append_byte(buffer, 0);
384 pm_buffer_append_byte(buffer, 1);
385 pm_serialize_location(parser, &((
pm_call_node_t *)node)->opening_loc, buffer);
388 pm_buffer_append_byte(buffer, 0);
393 pm_buffer_append_byte(buffer, 0);
395 pm_buffer_append_byte(buffer, 1);
396 pm_serialize_location(parser, &((
pm_call_node_t *)node)->closing_loc, buffer);
399 pm_buffer_append_byte(buffer, 0);
401 pm_buffer_append_byte(buffer, 1);
402 pm_serialize_location(parser, &((
pm_call_node_t *)node)->equal_loc, buffer);
405 pm_buffer_append_byte(buffer, 0);
411 case PM_CALL_OPERATOR_WRITE_NODE: {
412 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
414 pm_buffer_append_byte(buffer, 0);
419 pm_buffer_append_byte(buffer, 0);
421 pm_buffer_append_byte(buffer, 1);
425 pm_buffer_append_byte(buffer, 0);
427 pm_buffer_append_byte(buffer, 1);
437 case PM_CALL_OR_WRITE_NODE: {
438 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
440 pm_buffer_append_byte(buffer, 0);
445 pm_buffer_append_byte(buffer, 0);
447 pm_buffer_append_byte(buffer, 1);
451 pm_buffer_append_byte(buffer, 0);
453 pm_buffer_append_byte(buffer, 1);
462 case PM_CALL_TARGET_NODE: {
463 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
470 case PM_CAPTURE_PATTERN_NODE: {
471 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
477 case PM_CASE_MATCH_NODE: {
478 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
480 pm_buffer_append_byte(buffer, 0);
485 pm_buffer_append_varuint(buffer, conditions_size);
486 for (uint32_t index = 0; index < conditions_size; index++) {
490 pm_buffer_append_byte(buffer, 0);
499 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
501 pm_buffer_append_byte(buffer, 0);
505 uint32_t conditions_size = pm_sizet_to_u32(((
pm_case_node_t *)node)->conditions.size);
506 pm_buffer_append_varuint(buffer, conditions_size);
507 for (uint32_t index = 0; index < conditions_size; index++) {
511 pm_buffer_append_byte(buffer, 0);
515 pm_serialize_location(parser, &((
pm_case_node_t *)node)->case_keyword_loc, buffer);
516 pm_serialize_location(parser, &((
pm_case_node_t *)node)->end_keyword_loc, buffer);
519 case PM_CLASS_NODE: {
520 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
521 uint32_t locals_size = pm_sizet_to_u32(((
pm_class_node_t *)node)->locals.size);
522 pm_buffer_append_varuint(buffer, locals_size);
523 for (uint32_t index = 0; index < locals_size; index++) {
524 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_class_node_t *)node)->locals.ids[index]));
526 pm_serialize_location(parser, &((
pm_class_node_t *)node)->class_keyword_loc, buffer);
528 if (((
pm_class_node_t *)node)->inheritance_operator_loc.start == NULL) {
529 pm_buffer_append_byte(buffer, 0);
531 pm_buffer_append_byte(buffer, 1);
532 pm_serialize_location(parser, &((
pm_class_node_t *)node)->inheritance_operator_loc, buffer);
535 pm_buffer_append_byte(buffer, 0);
540 pm_buffer_append_byte(buffer, 0);
544 pm_serialize_location(parser, &((
pm_class_node_t *)node)->end_keyword_loc, buffer);
545 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_class_node_t *)node)->name));
548 case PM_CLASS_VARIABLE_AND_WRITE_NODE: {
549 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
556 case PM_CLASS_VARIABLE_OPERATOR_WRITE_NODE: {
557 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
565 case PM_CLASS_VARIABLE_OR_WRITE_NODE: {
566 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
573 case PM_CLASS_VARIABLE_READ_NODE: {
574 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
578 case PM_CLASS_VARIABLE_TARGET_NODE: {
579 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
583 case PM_CLASS_VARIABLE_WRITE_NODE: {
584 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
591 case PM_CONSTANT_AND_WRITE_NODE: {
592 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
599 case PM_CONSTANT_OPERATOR_WRITE_NODE: {
600 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
608 case PM_CONSTANT_OR_WRITE_NODE: {
609 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
616 case PM_CONSTANT_PATH_AND_WRITE_NODE: {
617 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
623 case PM_CONSTANT_PATH_NODE: {
624 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
626 pm_buffer_append_byte(buffer, 0);
635 case PM_CONSTANT_PATH_OPERATOR_WRITE_NODE: {
636 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
643 case PM_CONSTANT_PATH_OR_WRITE_NODE: {
644 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
650 case PM_CONSTANT_PATH_TARGET_NODE: {
651 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
653 pm_buffer_append_byte(buffer, 0);
662 case PM_CONSTANT_PATH_WRITE_NODE: {
663 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
669 case PM_CONSTANT_READ_NODE: {
670 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
674 case PM_CONSTANT_TARGET_NODE: {
675 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
679 case PM_CONSTANT_WRITE_NODE: {
680 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
690 size_t length_offset = buffer->
length;
691 pm_buffer_append_string(buffer,
"\0\0\0\0", 4);
692 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
693 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_def_node_t *)node)->name));
694 pm_serialize_location(parser, &((
pm_def_node_t *)node)->name_loc, buffer);
696 pm_buffer_append_byte(buffer, 0);
701 pm_buffer_append_byte(buffer, 0);
706 pm_buffer_append_byte(buffer, 0);
710 uint32_t locals_size = pm_sizet_to_u32(((
pm_def_node_t *)node)->locals.size);
711 pm_buffer_append_varuint(buffer, locals_size);
712 for (uint32_t index = 0; index < locals_size; index++) {
713 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_def_node_t *)node)->locals.ids[index]));
715 pm_serialize_location(parser, &((
pm_def_node_t *)node)->def_keyword_loc, buffer);
717 pm_buffer_append_byte(buffer, 0);
719 pm_buffer_append_byte(buffer, 1);
720 pm_serialize_location(parser, &((
pm_def_node_t *)node)->operator_loc, buffer);
723 pm_buffer_append_byte(buffer, 0);
725 pm_buffer_append_byte(buffer, 1);
726 pm_serialize_location(parser, &((
pm_def_node_t *)node)->lparen_loc, buffer);
729 pm_buffer_append_byte(buffer, 0);
731 pm_buffer_append_byte(buffer, 1);
732 pm_serialize_location(parser, &((
pm_def_node_t *)node)->rparen_loc, buffer);
735 pm_buffer_append_byte(buffer, 0);
737 pm_buffer_append_byte(buffer, 1);
738 pm_serialize_location(parser, &((
pm_def_node_t *)node)->equal_loc, buffer);
740 if (((
pm_def_node_t *)node)->end_keyword_loc.start == NULL) {
741 pm_buffer_append_byte(buffer, 0);
743 pm_buffer_append_byte(buffer, 1);
744 pm_serialize_location(parser, &((
pm_def_node_t *)node)->end_keyword_loc, buffer);
747 uint32_t length = pm_sizet_to_u32(buffer->
length - offset -
sizeof(uint32_t));
748 memcpy(buffer->
value + length_offset, &length,
sizeof(uint32_t));
751 case PM_DEFINED_NODE: {
752 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
754 pm_buffer_append_byte(buffer, 0);
756 pm_buffer_append_byte(buffer, 1);
761 pm_buffer_append_byte(buffer, 0);
763 pm_buffer_append_byte(buffer, 1);
766 pm_serialize_location(parser, &((
pm_defined_node_t *)node)->keyword_loc, buffer);
770 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
771 pm_serialize_location(parser, &((
pm_else_node_t *)node)->else_keyword_loc, buffer);
773 pm_buffer_append_byte(buffer, 0);
778 pm_buffer_append_byte(buffer, 0);
780 pm_buffer_append_byte(buffer, 1);
781 pm_serialize_location(parser, &((
pm_else_node_t *)node)->end_keyword_loc, buffer);
785 case PM_EMBEDDED_STATEMENTS_NODE: {
786 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
789 pm_buffer_append_byte(buffer, 0);
796 case PM_EMBEDDED_VARIABLE_NODE: {
797 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
802 case PM_ENSURE_NODE: {
803 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
804 pm_serialize_location(parser, &((
pm_ensure_node_t *)node)->ensure_keyword_loc, buffer);
806 pm_buffer_append_byte(buffer, 0);
810 pm_serialize_location(parser, &((
pm_ensure_node_t *)node)->end_keyword_loc, buffer);
813 case PM_FALSE_NODE: {
814 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
817 case PM_FIND_PATTERN_NODE: {
818 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
820 pm_buffer_append_byte(buffer, 0);
826 pm_buffer_append_varuint(buffer, requireds_size);
827 for (uint32_t index = 0; index < requireds_size; index++) {
832 pm_buffer_append_byte(buffer, 0);
834 pm_buffer_append_byte(buffer, 1);
838 pm_buffer_append_byte(buffer, 0);
840 pm_buffer_append_byte(buffer, 1);
845 case PM_FLIP_FLOP_NODE: {
846 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
848 pm_buffer_append_byte(buffer, 0);
853 pm_buffer_append_byte(buffer, 0);
860 case PM_FLOAT_NODE: {
861 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
866 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
870 pm_buffer_append_byte(buffer, 0);
874 pm_serialize_location(parser, &((
pm_for_node_t *)node)->for_keyword_loc, buffer);
875 pm_serialize_location(parser, &((
pm_for_node_t *)node)->in_keyword_loc, buffer);
877 pm_buffer_append_byte(buffer, 0);
879 pm_buffer_append_byte(buffer, 1);
880 pm_serialize_location(parser, &((
pm_for_node_t *)node)->do_keyword_loc, buffer);
882 pm_serialize_location(parser, &((
pm_for_node_t *)node)->end_keyword_loc, buffer);
885 case PM_FORWARDING_ARGUMENTS_NODE: {
886 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
889 case PM_FORWARDING_PARAMETER_NODE: {
890 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
893 case PM_FORWARDING_SUPER_NODE: {
894 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
896 pm_buffer_append_byte(buffer, 0);
902 case PM_GLOBAL_VARIABLE_AND_WRITE_NODE: {
903 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
910 case PM_GLOBAL_VARIABLE_OPERATOR_WRITE_NODE: {
911 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
919 case PM_GLOBAL_VARIABLE_OR_WRITE_NODE: {
920 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
927 case PM_GLOBAL_VARIABLE_READ_NODE: {
928 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
932 case PM_GLOBAL_VARIABLE_TARGET_NODE: {
933 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
937 case PM_GLOBAL_VARIABLE_WRITE_NODE: {
938 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
946 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
947 pm_serialize_location(parser, &((
pm_hash_node_t *)node)->opening_loc, buffer);
948 uint32_t elements_size = pm_sizet_to_u32(((
pm_hash_node_t *)node)->elements.size);
949 pm_buffer_append_varuint(buffer, elements_size);
950 for (uint32_t index = 0; index < elements_size; index++) {
953 pm_serialize_location(parser, &((
pm_hash_node_t *)node)->closing_loc, buffer);
956 case PM_HASH_PATTERN_NODE: {
957 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
959 pm_buffer_append_byte(buffer, 0);
964 pm_buffer_append_varuint(buffer, elements_size);
965 for (uint32_t index = 0; index < elements_size; index++) {
969 pm_buffer_append_byte(buffer, 0);
974 pm_buffer_append_byte(buffer, 0);
976 pm_buffer_append_byte(buffer, 1);
980 pm_buffer_append_byte(buffer, 0);
982 pm_buffer_append_byte(buffer, 1);
988 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
989 if (((
pm_if_node_t *)node)->if_keyword_loc.start == NULL) {
990 pm_buffer_append_byte(buffer, 0);
992 pm_buffer_append_byte(buffer, 1);
993 pm_serialize_location(parser, &((
pm_if_node_t *)node)->if_keyword_loc, buffer);
996 if (((
pm_if_node_t *)node)->then_keyword_loc.start == NULL) {
997 pm_buffer_append_byte(buffer, 0);
999 pm_buffer_append_byte(buffer, 1);
1000 pm_serialize_location(parser, &((
pm_if_node_t *)node)->then_keyword_loc, buffer);
1003 pm_buffer_append_byte(buffer, 0);
1008 pm_buffer_append_byte(buffer, 0);
1012 if (((
pm_if_node_t *)node)->end_keyword_loc.start == NULL) {
1013 pm_buffer_append_byte(buffer, 0);
1015 pm_buffer_append_byte(buffer, 1);
1016 pm_serialize_location(parser, &((
pm_if_node_t *)node)->end_keyword_loc, buffer);
1020 case PM_IMAGINARY_NODE: {
1021 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1025 case PM_IMPLICIT_NODE: {
1026 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1030 case PM_IMPLICIT_REST_NODE: {
1031 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1035 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1038 pm_buffer_append_byte(buffer, 0);
1042 pm_serialize_location(parser, &((
pm_in_node_t *)node)->in_loc, buffer);
1044 pm_buffer_append_byte(buffer, 0);
1046 pm_buffer_append_byte(buffer, 1);
1047 pm_serialize_location(parser, &((
pm_in_node_t *)node)->then_loc, buffer);
1051 case PM_INDEX_AND_WRITE_NODE: {
1052 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1054 pm_buffer_append_byte(buffer, 0);
1059 pm_buffer_append_byte(buffer, 0);
1061 pm_buffer_append_byte(buffer, 1);
1066 pm_buffer_append_byte(buffer, 0);
1072 pm_buffer_append_byte(buffer, 0);
1080 case PM_INDEX_OPERATOR_WRITE_NODE: {
1081 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1083 pm_buffer_append_byte(buffer, 0);
1088 pm_buffer_append_byte(buffer, 0);
1090 pm_buffer_append_byte(buffer, 1);
1095 pm_buffer_append_byte(buffer, 0);
1101 pm_buffer_append_byte(buffer, 0);
1110 case PM_INDEX_OR_WRITE_NODE: {
1111 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1113 pm_buffer_append_byte(buffer, 0);
1118 pm_buffer_append_byte(buffer, 0);
1120 pm_buffer_append_byte(buffer, 1);
1125 pm_buffer_append_byte(buffer, 0);
1131 pm_buffer_append_byte(buffer, 0);
1139 case PM_INDEX_TARGET_NODE: {
1140 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1144 pm_buffer_append_byte(buffer, 0);
1150 pm_buffer_append_byte(buffer, 0);
1156 case PM_INSTANCE_VARIABLE_AND_WRITE_NODE: {
1157 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1164 case PM_INSTANCE_VARIABLE_OPERATOR_WRITE_NODE: {
1165 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1173 case PM_INSTANCE_VARIABLE_OR_WRITE_NODE: {
1174 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1181 case PM_INSTANCE_VARIABLE_READ_NODE: {
1182 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1186 case PM_INSTANCE_VARIABLE_TARGET_NODE: {
1187 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1191 case PM_INSTANCE_VARIABLE_WRITE_NODE: {
1192 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1199 case PM_INTEGER_NODE: {
1200 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1204 case PM_INTERPOLATED_MATCH_LAST_LINE_NODE: {
1205 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1208 pm_buffer_append_varuint(buffer, parts_size);
1209 for (uint32_t index = 0; index < parts_size; index++) {
1215 case PM_INTERPOLATED_REGULAR_EXPRESSION_NODE: {
1216 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1219 pm_buffer_append_varuint(buffer, parts_size);
1220 for (uint32_t index = 0; index < parts_size; index++) {
1226 case PM_INTERPOLATED_STRING_NODE: {
1227 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1229 pm_buffer_append_byte(buffer, 0);
1231 pm_buffer_append_byte(buffer, 1);
1235 pm_buffer_append_varuint(buffer, parts_size);
1236 for (uint32_t index = 0; index < parts_size; index++) {
1240 pm_buffer_append_byte(buffer, 0);
1242 pm_buffer_append_byte(buffer, 1);
1247 case PM_INTERPOLATED_SYMBOL_NODE: {
1248 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1250 pm_buffer_append_byte(buffer, 0);
1252 pm_buffer_append_byte(buffer, 1);
1256 pm_buffer_append_varuint(buffer, parts_size);
1257 for (uint32_t index = 0; index < parts_size; index++) {
1261 pm_buffer_append_byte(buffer, 0);
1263 pm_buffer_append_byte(buffer, 1);
1268 case PM_INTERPOLATED_X_STRING_NODE: {
1269 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1272 pm_buffer_append_varuint(buffer, parts_size);
1273 for (uint32_t index = 0; index < parts_size; index++) {
1279 case PM_IT_LOCAL_VARIABLE_READ_NODE: {
1280 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1283 case PM_IT_PARAMETERS_NODE: {
1284 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1287 case PM_KEYWORD_HASH_NODE: {
1288 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1290 pm_buffer_append_varuint(buffer, elements_size);
1291 for (uint32_t index = 0; index < elements_size; index++) {
1296 case PM_KEYWORD_REST_PARAMETER_NODE: {
1297 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1300 pm_buffer_append_byte(buffer, 0);
1302 pm_buffer_append_byte(buffer, 1);
1308 case PM_LAMBDA_NODE: {
1309 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1310 uint32_t locals_size = pm_sizet_to_u32(((
pm_lambda_node_t *)node)->locals.size);
1311 pm_buffer_append_varuint(buffer, locals_size);
1312 for (uint32_t index = 0; index < locals_size; index++) {
1313 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_lambda_node_t *)node)->locals.ids[index]));
1315 pm_serialize_location(parser, &((
pm_lambda_node_t *)node)->operator_loc, buffer);
1316 pm_serialize_location(parser, &((
pm_lambda_node_t *)node)->opening_loc, buffer);
1317 pm_serialize_location(parser, &((
pm_lambda_node_t *)node)->closing_loc, buffer);
1319 pm_buffer_append_byte(buffer, 0);
1324 pm_buffer_append_byte(buffer, 0);
1330 case PM_LOCAL_VARIABLE_AND_WRITE_NODE: {
1331 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1339 case PM_LOCAL_VARIABLE_OPERATOR_WRITE_NODE: {
1340 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1349 case PM_LOCAL_VARIABLE_OR_WRITE_NODE: {
1350 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1358 case PM_LOCAL_VARIABLE_READ_NODE: {
1359 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1364 case PM_LOCAL_VARIABLE_TARGET_NODE: {
1365 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1370 case PM_LOCAL_VARIABLE_WRITE_NODE: {
1371 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1379 case PM_MATCH_LAST_LINE_NODE: {
1380 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1387 case PM_MATCH_PREDICATE_NODE: {
1388 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1394 case PM_MATCH_REQUIRED_NODE: {
1395 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1401 case PM_MATCH_WRITE_NODE: {
1402 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1405 pm_buffer_append_varuint(buffer, targets_size);
1406 for (uint32_t index = 0; index < targets_size; index++) {
1411 case PM_MISSING_NODE: {
1412 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1415 case PM_MODULE_NODE: {
1416 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1417 uint32_t locals_size = pm_sizet_to_u32(((
pm_module_node_t *)node)->locals.size);
1418 pm_buffer_append_varuint(buffer, locals_size);
1419 for (uint32_t index = 0; index < locals_size; index++) {
1420 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_module_node_t *)node)->locals.ids[index]));
1422 pm_serialize_location(parser, &((
pm_module_node_t *)node)->module_keyword_loc, buffer);
1425 pm_buffer_append_byte(buffer, 0);
1429 pm_serialize_location(parser, &((
pm_module_node_t *)node)->end_keyword_loc, buffer);
1430 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_module_node_t *)node)->name));
1433 case PM_MULTI_TARGET_NODE: {
1434 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1436 pm_buffer_append_varuint(buffer, lefts_size);
1437 for (uint32_t index = 0; index < lefts_size; index++) {
1441 pm_buffer_append_byte(buffer, 0);
1446 pm_buffer_append_varuint(buffer, rights_size);
1447 for (uint32_t index = 0; index < rights_size; index++) {
1451 pm_buffer_append_byte(buffer, 0);
1453 pm_buffer_append_byte(buffer, 1);
1457 pm_buffer_append_byte(buffer, 0);
1459 pm_buffer_append_byte(buffer, 1);
1464 case PM_MULTI_WRITE_NODE: {
1465 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1467 pm_buffer_append_varuint(buffer, lefts_size);
1468 for (uint32_t index = 0; index < lefts_size; index++) {
1472 pm_buffer_append_byte(buffer, 0);
1477 pm_buffer_append_varuint(buffer, rights_size);
1478 for (uint32_t index = 0; index < rights_size; index++) {
1482 pm_buffer_append_byte(buffer, 0);
1484 pm_buffer_append_byte(buffer, 1);
1488 pm_buffer_append_byte(buffer, 0);
1490 pm_buffer_append_byte(buffer, 1);
1497 case PM_NEXT_NODE: {
1498 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1500 pm_buffer_append_byte(buffer, 0);
1504 pm_serialize_location(parser, &((
pm_next_node_t *)node)->keyword_loc, buffer);
1508 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1511 case PM_NO_KEYWORDS_PARAMETER_NODE: {
1512 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1517 case PM_NUMBERED_PARAMETERS_NODE: {
1518 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1522 case PM_NUMBERED_REFERENCE_READ_NODE: {
1523 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1527 case PM_OPTIONAL_KEYWORD_PARAMETER_NODE: {
1528 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1534 case PM_OPTIONAL_PARAMETER_NODE: {
1535 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1543 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1546 pm_serialize_location(parser, &((
pm_or_node_t *)node)->operator_loc, buffer);
1549 case PM_PARAMETERS_NODE: {
1550 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1552 pm_buffer_append_varuint(buffer, requireds_size);
1553 for (uint32_t index = 0; index < requireds_size; index++) {
1557 pm_buffer_append_varuint(buffer, optionals_size);
1558 for (uint32_t index = 0; index < optionals_size; index++) {
1562 pm_buffer_append_byte(buffer, 0);
1567 pm_buffer_append_varuint(buffer, posts_size);
1568 for (uint32_t index = 0; index < posts_size; index++) {
1572 pm_buffer_append_varuint(buffer, keywords_size);
1573 for (uint32_t index = 0; index < keywords_size; index++) {
1577 pm_buffer_append_byte(buffer, 0);
1582 pm_buffer_append_byte(buffer, 0);
1588 case PM_PARENTHESES_NODE: {
1589 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1591 pm_buffer_append_byte(buffer, 0);
1599 case PM_PINNED_EXPRESSION_NODE: {
1600 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1607 case PM_PINNED_VARIABLE_NODE: {
1608 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1613 case PM_POST_EXECUTION_NODE: {
1614 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1616 pm_buffer_append_byte(buffer, 0);
1625 case PM_PRE_EXECUTION_NODE: {
1626 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1628 pm_buffer_append_byte(buffer, 0);
1637 case PM_PROGRAM_NODE: {
1638 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1639 uint32_t locals_size = pm_sizet_to_u32(((
pm_program_node_t *)node)->locals.size);
1640 pm_buffer_append_varuint(buffer, locals_size);
1641 for (uint32_t index = 0; index < locals_size; index++) {
1642 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(((
pm_program_node_t *)node)->locals.ids[index]));
1647 case PM_RANGE_NODE: {
1648 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1650 pm_buffer_append_byte(buffer, 0);
1655 pm_buffer_append_byte(buffer, 0);
1659 pm_serialize_location(parser, &((
pm_range_node_t *)node)->operator_loc, buffer);
1662 case PM_RATIONAL_NODE: {
1663 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1668 case PM_REDO_NODE: {
1669 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1672 case PM_REGULAR_EXPRESSION_NODE: {
1673 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1680 case PM_REQUIRED_KEYWORD_PARAMETER_NODE: {
1681 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1686 case PM_REQUIRED_PARAMETER_NODE: {
1687 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1691 case PM_RESCUE_MODIFIER_NODE: {
1692 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1698 case PM_RESCUE_NODE: {
1699 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1700 pm_serialize_location(parser, &((
pm_rescue_node_t *)node)->keyword_loc, buffer);
1701 uint32_t exceptions_size = pm_sizet_to_u32(((
pm_rescue_node_t *)node)->exceptions.size);
1702 pm_buffer_append_varuint(buffer, exceptions_size);
1703 for (uint32_t index = 0; index < exceptions_size; index++) {
1707 pm_buffer_append_byte(buffer, 0);
1709 pm_buffer_append_byte(buffer, 1);
1710 pm_serialize_location(parser, &((
pm_rescue_node_t *)node)->operator_loc, buffer);
1713 pm_buffer_append_byte(buffer, 0);
1718 pm_buffer_append_byte(buffer, 0);
1720 pm_buffer_append_byte(buffer, 1);
1721 pm_serialize_location(parser, &((
pm_rescue_node_t *)node)->then_keyword_loc, buffer);
1724 pm_buffer_append_byte(buffer, 0);
1729 pm_buffer_append_byte(buffer, 0);
1735 case PM_REST_PARAMETER_NODE: {
1736 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1739 pm_buffer_append_byte(buffer, 0);
1741 pm_buffer_append_byte(buffer, 1);
1747 case PM_RETRY_NODE: {
1748 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1751 case PM_RETURN_NODE: {
1752 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1753 pm_serialize_location(parser, &((
pm_return_node_t *)node)->keyword_loc, buffer);
1755 pm_buffer_append_byte(buffer, 0);
1761 case PM_SELF_NODE: {
1762 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1765 case PM_SHAREABLE_CONSTANT_NODE: {
1766 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1770 case PM_SINGLETON_CLASS_NODE: {
1771 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1773 pm_buffer_append_varuint(buffer, locals_size);
1774 for (uint32_t index = 0; index < locals_size; index++) {
1781 pm_buffer_append_byte(buffer, 0);
1788 case PM_SOURCE_ENCODING_NODE: {
1789 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1792 case PM_SOURCE_FILE_NODE: {
1793 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1797 case PM_SOURCE_LINE_NODE: {
1798 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1801 case PM_SPLAT_NODE: {
1802 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1803 pm_serialize_location(parser, &((
pm_splat_node_t *)node)->operator_loc, buffer);
1805 pm_buffer_append_byte(buffer, 0);
1811 case PM_STATEMENTS_NODE: {
1812 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1814 pm_buffer_append_varuint(buffer, body_size);
1815 for (uint32_t index = 0; index < body_size; index++) {
1820 case PM_STRING_NODE: {
1821 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1823 pm_buffer_append_byte(buffer, 0);
1825 pm_buffer_append_byte(buffer, 1);
1826 pm_serialize_location(parser, &((
pm_string_node_t *)node)->opening_loc, buffer);
1828 pm_serialize_location(parser, &((
pm_string_node_t *)node)->content_loc, buffer);
1830 pm_buffer_append_byte(buffer, 0);
1832 pm_buffer_append_byte(buffer, 1);
1833 pm_serialize_location(parser, &((
pm_string_node_t *)node)->closing_loc, buffer);
1835 pm_serialize_string(parser, &((
pm_string_node_t *)node)->unescaped, buffer);
1838 case PM_SUPER_NODE: {
1839 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1840 pm_serialize_location(parser, &((
pm_super_node_t *)node)->keyword_loc, buffer);
1842 pm_buffer_append_byte(buffer, 0);
1844 pm_buffer_append_byte(buffer, 1);
1845 pm_serialize_location(parser, &((
pm_super_node_t *)node)->lparen_loc, buffer);
1848 pm_buffer_append_byte(buffer, 0);
1853 pm_buffer_append_byte(buffer, 0);
1855 pm_buffer_append_byte(buffer, 1);
1856 pm_serialize_location(parser, &((
pm_super_node_t *)node)->rparen_loc, buffer);
1859 pm_buffer_append_byte(buffer, 0);
1865 case PM_SYMBOL_NODE: {
1866 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1868 pm_buffer_append_byte(buffer, 0);
1870 pm_buffer_append_byte(buffer, 1);
1871 pm_serialize_location(parser, &((
pm_symbol_node_t *)node)->opening_loc, buffer);
1874 pm_buffer_append_byte(buffer, 0);
1876 pm_buffer_append_byte(buffer, 1);
1877 pm_serialize_location(parser, &((
pm_symbol_node_t *)node)->value_loc, buffer);
1880 pm_buffer_append_byte(buffer, 0);
1882 pm_buffer_append_byte(buffer, 1);
1883 pm_serialize_location(parser, &((
pm_symbol_node_t *)node)->closing_loc, buffer);
1885 pm_serialize_string(parser, &((
pm_symbol_node_t *)node)->unescaped, buffer);
1888 case PM_TRUE_NODE: {
1889 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1892 case PM_UNDEF_NODE: {
1893 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1894 uint32_t names_size = pm_sizet_to_u32(((
pm_undef_node_t *)node)->names.size);
1895 pm_buffer_append_varuint(buffer, names_size);
1896 for (uint32_t index = 0; index < names_size; index++) {
1899 pm_serialize_location(parser, &((
pm_undef_node_t *)node)->keyword_loc, buffer);
1902 case PM_UNLESS_NODE: {
1903 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1904 pm_serialize_location(parser, &((
pm_unless_node_t *)node)->keyword_loc, buffer);
1907 pm_buffer_append_byte(buffer, 0);
1909 pm_buffer_append_byte(buffer, 1);
1910 pm_serialize_location(parser, &((
pm_unless_node_t *)node)->then_keyword_loc, buffer);
1913 pm_buffer_append_byte(buffer, 0);
1918 pm_buffer_append_byte(buffer, 0);
1923 pm_buffer_append_byte(buffer, 0);
1925 pm_buffer_append_byte(buffer, 1);
1926 pm_serialize_location(parser, &((
pm_unless_node_t *)node)->end_keyword_loc, buffer);
1930 case PM_UNTIL_NODE: {
1931 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1932 pm_serialize_location(parser, &((
pm_until_node_t *)node)->keyword_loc, buffer);
1934 pm_buffer_append_byte(buffer, 0);
1936 pm_buffer_append_byte(buffer, 1);
1937 pm_serialize_location(parser, &((
pm_until_node_t *)node)->do_keyword_loc, buffer);
1940 pm_buffer_append_byte(buffer, 0);
1942 pm_buffer_append_byte(buffer, 1);
1943 pm_serialize_location(parser, &((
pm_until_node_t *)node)->closing_loc, buffer);
1947 pm_buffer_append_byte(buffer, 0);
1953 case PM_WHEN_NODE: {
1954 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1955 pm_serialize_location(parser, &((
pm_when_node_t *)node)->keyword_loc, buffer);
1956 uint32_t conditions_size = pm_sizet_to_u32(((
pm_when_node_t *)node)->conditions.size);
1957 pm_buffer_append_varuint(buffer, conditions_size);
1958 for (uint32_t index = 0; index < conditions_size; index++) {
1962 pm_buffer_append_byte(buffer, 0);
1964 pm_buffer_append_byte(buffer, 1);
1965 pm_serialize_location(parser, &((
pm_when_node_t *)node)->then_keyword_loc, buffer);
1968 pm_buffer_append_byte(buffer, 0);
1974 case PM_WHILE_NODE: {
1975 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
1976 pm_serialize_location(parser, &((
pm_while_node_t *)node)->keyword_loc, buffer);
1978 pm_buffer_append_byte(buffer, 0);
1980 pm_buffer_append_byte(buffer, 1);
1981 pm_serialize_location(parser, &((
pm_while_node_t *)node)->do_keyword_loc, buffer);
1984 pm_buffer_append_byte(buffer, 0);
1986 pm_buffer_append_byte(buffer, 1);
1987 pm_serialize_location(parser, &((
pm_while_node_t *)node)->closing_loc, buffer);
1991 pm_buffer_append_byte(buffer, 0);
1997 case PM_X_STRING_NODE: {
1998 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
2005 case PM_YIELD_NODE: {
2006 pm_buffer_append_varuint(buffer, (uint32_t) node->
flags);
2007 pm_serialize_location(parser, &((
pm_yield_node_t *)node)->keyword_loc, buffer);
2009 pm_buffer_append_byte(buffer, 0);
2011 pm_buffer_append_byte(buffer, 1);
2012 pm_serialize_location(parser, &((
pm_yield_node_t *)node)->lparen_loc, buffer);
2015 pm_buffer_append_byte(buffer, 0);
2020 pm_buffer_append_byte(buffer, 0);
2022 pm_buffer_append_byte(buffer, 1);
2023 pm_serialize_location(parser, &((
pm_yield_node_t *)node)->rparen_loc, buffer);
2032 uint32_t size = pm_sizet_to_u32(list->
size);
2033 pm_buffer_append_varuint(buffer, size);
2035 for (uint32_t i = 0; i < size; i++) {
2036 uint32_t offset = pm_sizet_to_u32(list->
offsets[i]);
2037 pm_buffer_append_varuint(buffer, offset);
2044 pm_buffer_append_byte(buffer, (uint8_t) comment->
type);
2047 pm_serialize_location(parser, &comment->
location, buffer);
2055 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(
pm_list_size(list)));
2059 pm_serialize_comment(parser, comment, buffer);
2066 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(
magic_comment->key_start - parser->
start));
2067 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(
magic_comment->key_length));
2070 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(
magic_comment->value_start - parser->
start));
2071 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(
magic_comment->value_length));
2076 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(
pm_list_size(list)));
2087 pm_buffer_append_byte(buffer, 0);
2089 pm_buffer_append_byte(buffer, 1);
2090 pm_serialize_location(parser, &parser->
data_loc, buffer);
2097 pm_buffer_append_varuint(buffer, (uint32_t) diagnostic->
diag_id);
2100 size_t message_length = strlen(diagnostic->
message);
2101 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(message_length));
2102 pm_buffer_append_string(buffer, diagnostic->
message, message_length);
2105 pm_serialize_location(parser, &diagnostic->
location, buffer);
2107 pm_buffer_append_byte(buffer, diagnostic->
level);
2112 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(
pm_list_size(list)));
2116 pm_serialize_diagnostic(parser, diagnostic, buffer);
2125 size_t encoding_length = strlen(encoding->
name);
2126 pm_buffer_append_varuint(buffer, pm_sizet_to_u32(encoding_length));
2127 pm_buffer_append_string(buffer, encoding->
name, encoding_length);
2133 pm_buffer_append_varsint(buffer, parser->
start_line);
2134 pm_serialize_newline_list(&parser->
newline_list, buffer);
2137 pm_serialize_data_loc(parser, buffer);
2138 pm_serialize_diagnostic_list(parser, &parser->
error_list, buffer);
2139 pm_serialize_diagnostic_list(parser, &parser->
warning_list, buffer);
2142#line 275 "prism/templates/src/serialize.c.erb"
2148 pm_serialize_metadata(parser, buffer);
2152 size_t offset = buffer->
length;
2153 pm_buffer_append_zeroes(buffer, 4);
2159 pm_serialize_node(parser, node, buffer);
2163 uint32_t length = pm_sizet_to_u32(buffer->
length);
2164 memcpy(buffer->
value + offset, &length,
sizeof(uint32_t));
2175 if (bucket->
id != 0) {
2177 size_t buffer_offset = offset + ((((size_t)bucket->
id) - 1) * 8);
2185 uint32_t content_offset = pm_sizet_to_u32(buffer->
length);
2186 uint32_t owned_mask = (uint32_t) (1 << 31);
2188 assert(content_offset < owned_mask);
2189 content_offset |= owned_mask;
2191 memcpy(buffer->
value + buffer_offset, &content_offset, 4);
2192 pm_buffer_append_bytes(buffer, constant->
start, constant->
length);
2196 uint32_t source_offset = pm_ptrdifft_to_u32(constant->
start - parser->
start);
2197 memcpy(buffer->
value + buffer_offset, &source_offset, 4);
2201 uint32_t constant_length = pm_sizet_to_u32(constant->
length);
2202 memcpy(buffer->
value + buffer_offset + 4, &constant_length, 4);
2211 pm_buffer_append_varuint(buffer, token->type);
2212 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(token->start - parser->
start));
2213 pm_buffer_append_varuint(buffer, pm_ptrdifft_to_u32(token->end - token->start));
2214 pm_buffer_append_varuint(buffer, parser->
lex_state);
2223 pm_options_read(&options, data);
2229 .
data = (
void *) buffer,
2230 .callback = serialize_token,
2237 pm_buffer_append_byte(buffer, 0);
2239 pm_serialize_metadata(&parser, buffer);
2241 pm_node_destroy(&parser, node);
2253 pm_options_read(&options, data);
2259 .
data = (
void *) buffer,
2260 .callback = serialize_token,
2266 pm_buffer_append_byte(buffer, 0);
2267 pm_serialize(&parser, node, buffer);
2269 pm_node_destroy(&parser, node);
PRISM_EXPORTED_FUNCTION void pm_options_free(pm_options_t *options)
Free the internal memory associated with the options.
static const pm_constant_pool_bucket_type_t PM_CONSTANT_POOL_BUCKET_OWNED
An owned constant is one for which memory has been allocated.
static const pm_constant_pool_bucket_type_t PM_CONSTANT_POOL_BUCKET_CONSTANT
A constant constant is known at compile time.
PRISM_EXPORTED_FUNCTION size_t pm_list_size(pm_list_t *list)
Returns the size of the list.
PRISM_EXPORTED_FUNCTION size_t pm_string_length(const pm_string_t *string)
Returns the length associated with the string.
PRISM_EXPORTED_FUNCTION const uint8_t * pm_string_source(const pm_string_t *string)
Returns the start pointer associated with the string.
#define PRISM_EXPORTED_FUNCTION
By default, we compile with -fvisibility=hidden.
PRISM_EXPORTED_FUNCTION pm_node_t * pm_parse(pm_parser_t *parser)
Parse the Ruby source associated with the given parser and return the tree.
PRISM_EXPORTED_FUNCTION void pm_parser_free(pm_parser_t *parser)
Free any memory associated with the given parser.
PRISM_EXPORTED_FUNCTION void pm_parser_init(pm_parser_t *parser, const uint8_t *source, size_t size, const pm_options_t *options)
Initialize a parser with the given start and end pointers.
The main header file for the prism parser.
PRISM_EXPORTED_FUNCTION void pm_serialize_lex(pm_buffer_t *buffer, const uint8_t *source, size_t size, const char *data)
Lex the given source and serialize to the given buffer.
void pm_serialize_content(pm_parser_t *parser, pm_node_t *node, pm_buffer_t *buffer)
Serialize the encoding, metadata, nodes, and constant pool.
PRISM_EXPORTED_FUNCTION void pm_serialize_parse_lex(pm_buffer_t *buffer, const uint8_t *source, size_t size, const char *data)
Parse and serialize both the AST and the tokens represented by the given source to the given buffer.
void pm_serialize_encoding(const pm_encoding_t *encoding, pm_buffer_t *buffer)
Serialize the name of the encoding to the buffer.
void pm_serialize_comment_list(pm_parser_t *parser, pm_list_t *list, pm_buffer_t *buffer)
Serialize the given list of comments to the given buffer.
A pm_buffer_t is a simple memory buffer that stores data in a contiguous block of memory.
size_t length
The length of the buffer in bytes.
char * value
A pointer to the start of the buffer.
ClassVariableAndWriteNode.
ClassVariableOperatorWriteNode.
ClassVariableOrWriteNode.
ConstantOperatorWriteNode.
ConstantPathAndWriteNode.
ConstantPathOperatorWriteNode.
A bucket in the hash map.
unsigned int id
The incremental ID used for indexing back into the pool.
pm_constant_pool_bucket_type_t type
The type of the bucket, which determines how to free it.
uint32_t capacity
The number of buckets that have been allocated in the hash map.
pm_constant_pool_bucket_t * buckets
The buckets in the hash map.
uint32_t size
The number of buckets in the hash map.
pm_constant_t * constants
The constants that are stored in the buckets.
A constant in the pool which effectively stores a string.
size_t length
The length of the string.
const uint8_t * start
A pointer to the start of the string.
This struct represents a diagnostic generated during parsing.
pm_location_t location
The location of the diagnostic in the source.
const char * message
The message associated with the diagnostic.
pm_list_node_t node
The embedded base node.
pm_diagnostic_id_t diag_id
The ID of the diagnostic.
uint8_t level
The level of the diagnostic, see pm_error_level_t and pm_warning_level_t for possible values.
This struct defines the functions necessary to implement the encoding interface so we can determine h...
const char * name
The name of the encoding.
GlobalVariableAndWriteNode.
GlobalVariableOperatorWriteNode.
GlobalVariableOrWriteNode.
GlobalVariableTargetNode.
InstanceVariableAndWriteNode.
InstanceVariableOperatorWriteNode.
InstanceVariableOrWriteNode.
InstanceVariableReadNode.
InstanceVariableTargetNode.
InstanceVariableWriteNode.
A structure represents an arbitrary-sized integer.
size_t length
The number of allocated values.
uint32_t value
Embedded value for small integer.
uint32_t * values
List of 32-bit integers.
bool negative
Whether or not the integer is negative.
InterpolatedMatchLastLineNode.
InterpolatedRegularExpressionNode.
KeywordRestParameterNode.
When you are lexing through a file, the lexer needs all of the information that the parser additional...
void * data
This opaque pointer is used to provide whatever information the user deemed necessary to the callback...
struct pm_list_node * next
A pointer to the next node in the list.
This represents the overall linked list.
pm_list_node_t * head
A pointer to the head of the list.
LocalVariableAndWriteNode.
LocalVariableOperatorWriteNode.
LocalVariableOrWriteNode.
This represents a range of bytes in the source string to which a node or token corresponds.
const uint8_t * start
A pointer to the start location of the range in the source.
const uint8_t * end
A pointer to the end location of the range in the source.
A list of offsets of newlines in a string.
size_t * offsets
The list of offsets.
size_t size
The number of offsets in the list.
This is the base structure that represents a node in the syntax tree.
uint32_t node_id
The unique identifier for this node, which is deterministic based on the source.
pm_node_flags_t flags
This represents any flags on the node.
pm_location_t location
This is the location of the node in the source.
NumberedReferenceReadNode.
OptionalKeywordParameterNode.
The options that can be passed to the parser.
This struct represents the overall parser.
pm_lex_state_t lex_state
The current state of the lexer.
const pm_encoding_t * encoding
The encoding functions for the current file is attached to the parser as it's parsing so that it can ...
pm_constant_pool_t constant_pool
This constant pool keeps all of the constants defined throughout the file so that we can reference th...
pm_list_t magic_comment_list
The list of magic comments that have been found while parsing.
pm_lex_callback_t * lex_callback
This is an optional callback that can be attached to the parser that will be called whenever a new to...
pm_location_t data_loc
An optional location that represents the location of the END marker and the rest of the content of th...
const uint8_t * start
The pointer to the start of the source.
pm_list_t error_list
The list of errors that have been found while parsing.
pm_list_t warning_list
The list of warnings that have been found while parsing.
int32_t start_line
The line number at the start of the parse.
pm_list_t comment_list
The list of comments that have been found while parsing.
pm_newline_list_t newline_list
This is the list of newline offsets in the source file.
RequiredKeywordParameterNode.
A generic string type that can have various ownership semantics.
enum pm_string_t::@102 type
The type of the string.
This struct represents a token in the Ruby source.