jruby-prism-parser 0.23.0.pre.SNAPSHOT-java

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (110) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +401 -0
  3. data/CODE_OF_CONDUCT.md +76 -0
  4. data/CONTRIBUTING.md +62 -0
  5. data/LICENSE.md +7 -0
  6. data/Makefile +101 -0
  7. data/README.md +98 -0
  8. data/config.yml +2902 -0
  9. data/docs/build_system.md +91 -0
  10. data/docs/configuration.md +64 -0
  11. data/docs/cruby_compilation.md +27 -0
  12. data/docs/design.md +53 -0
  13. data/docs/encoding.md +121 -0
  14. data/docs/fuzzing.md +88 -0
  15. data/docs/heredocs.md +36 -0
  16. data/docs/javascript.md +118 -0
  17. data/docs/local_variable_depth.md +229 -0
  18. data/docs/mapping.md +117 -0
  19. data/docs/parser_translation.md +34 -0
  20. data/docs/parsing_rules.md +19 -0
  21. data/docs/releasing.md +98 -0
  22. data/docs/ripper.md +36 -0
  23. data/docs/ruby_api.md +43 -0
  24. data/docs/ruby_parser_translation.md +19 -0
  25. data/docs/serialization.md +209 -0
  26. data/docs/testing.md +55 -0
  27. data/ext/prism/api_node.c +5098 -0
  28. data/ext/prism/api_pack.c +267 -0
  29. data/ext/prism/extconf.rb +110 -0
  30. data/ext/prism/extension.c +1155 -0
  31. data/ext/prism/extension.h +18 -0
  32. data/include/prism/ast.h +5807 -0
  33. data/include/prism/defines.h +102 -0
  34. data/include/prism/diagnostic.h +339 -0
  35. data/include/prism/encoding.h +265 -0
  36. data/include/prism/node.h +57 -0
  37. data/include/prism/options.h +230 -0
  38. data/include/prism/pack.h +152 -0
  39. data/include/prism/parser.h +732 -0
  40. data/include/prism/prettyprint.h +26 -0
  41. data/include/prism/regexp.h +33 -0
  42. data/include/prism/util/pm_buffer.h +155 -0
  43. data/include/prism/util/pm_char.h +205 -0
  44. data/include/prism/util/pm_constant_pool.h +209 -0
  45. data/include/prism/util/pm_list.h +97 -0
  46. data/include/prism/util/pm_memchr.h +29 -0
  47. data/include/prism/util/pm_newline_list.h +93 -0
  48. data/include/prism/util/pm_state_stack.h +42 -0
  49. data/include/prism/util/pm_string.h +150 -0
  50. data/include/prism/util/pm_string_list.h +44 -0
  51. data/include/prism/util/pm_strncasecmp.h +32 -0
  52. data/include/prism/util/pm_strpbrk.h +46 -0
  53. data/include/prism/version.h +29 -0
  54. data/include/prism.h +289 -0
  55. data/jruby-prism.jar +0 -0
  56. data/lib/prism/compiler.rb +486 -0
  57. data/lib/prism/debug.rb +206 -0
  58. data/lib/prism/desugar_compiler.rb +207 -0
  59. data/lib/prism/dispatcher.rb +2150 -0
  60. data/lib/prism/dot_visitor.rb +4634 -0
  61. data/lib/prism/dsl.rb +785 -0
  62. data/lib/prism/ffi.rb +346 -0
  63. data/lib/prism/lex_compat.rb +908 -0
  64. data/lib/prism/mutation_compiler.rb +753 -0
  65. data/lib/prism/node.rb +17864 -0
  66. data/lib/prism/node_ext.rb +212 -0
  67. data/lib/prism/node_inspector.rb +68 -0
  68. data/lib/prism/pack.rb +224 -0
  69. data/lib/prism/parse_result/comments.rb +177 -0
  70. data/lib/prism/parse_result/newlines.rb +64 -0
  71. data/lib/prism/parse_result.rb +498 -0
  72. data/lib/prism/pattern.rb +250 -0
  73. data/lib/prism/serialize.rb +1354 -0
  74. data/lib/prism/translation/parser/compiler.rb +1838 -0
  75. data/lib/prism/translation/parser/lexer.rb +335 -0
  76. data/lib/prism/translation/parser/rubocop.rb +37 -0
  77. data/lib/prism/translation/parser.rb +178 -0
  78. data/lib/prism/translation/ripper.rb +577 -0
  79. data/lib/prism/translation/ruby_parser.rb +1521 -0
  80. data/lib/prism/translation.rb +11 -0
  81. data/lib/prism/version.rb +3 -0
  82. data/lib/prism/visitor.rb +495 -0
  83. data/lib/prism.rb +99 -0
  84. data/prism.gemspec +135 -0
  85. data/rbi/prism.rbi +7767 -0
  86. data/rbi/prism_static.rbi +207 -0
  87. data/sig/prism.rbs +4773 -0
  88. data/sig/prism_static.rbs +201 -0
  89. data/src/diagnostic.c +400 -0
  90. data/src/encoding.c +5132 -0
  91. data/src/node.c +2786 -0
  92. data/src/options.c +213 -0
  93. data/src/pack.c +493 -0
  94. data/src/prettyprint.c +8881 -0
  95. data/src/prism.c +18406 -0
  96. data/src/regexp.c +638 -0
  97. data/src/serialize.c +1554 -0
  98. data/src/token_type.c +700 -0
  99. data/src/util/pm_buffer.c +190 -0
  100. data/src/util/pm_char.c +318 -0
  101. data/src/util/pm_constant_pool.c +322 -0
  102. data/src/util/pm_list.c +49 -0
  103. data/src/util/pm_memchr.c +35 -0
  104. data/src/util/pm_newline_list.c +84 -0
  105. data/src/util/pm_state_stack.c +25 -0
  106. data/src/util/pm_string.c +203 -0
  107. data/src/util/pm_string_list.c +28 -0
  108. data/src/util/pm_strncasecmp.c +24 -0
  109. data/src/util/pm_strpbrk.c +180 -0
  110. metadata +156 -0
@@ -0,0 +1,203 @@
1
+ #include "prism/util/pm_string.h"
2
+
3
+ /**
4
+ * Returns the size of the pm_string_t struct. This is necessary to allocate the
5
+ * correct amount of memory in the FFI backend.
6
+ */
7
+ PRISM_EXPORTED_FUNCTION size_t
8
+ pm_string_sizeof(void) {
9
+ return sizeof(pm_string_t);
10
+ }
11
+
12
+ /**
13
+ * Initialize a shared string that is based on initial input.
14
+ */
15
+ void
16
+ pm_string_shared_init(pm_string_t *string, const uint8_t *start, const uint8_t *end) {
17
+ assert(start <= end);
18
+
19
+ *string = (pm_string_t) {
20
+ .type = PM_STRING_SHARED,
21
+ .source = start,
22
+ .length = (size_t) (end - start)
23
+ };
24
+ }
25
+
26
+ /**
27
+ * Initialize an owned string that is responsible for freeing allocated memory.
28
+ */
29
+ void
30
+ pm_string_owned_init(pm_string_t *string, uint8_t *source, size_t length) {
31
+ *string = (pm_string_t) {
32
+ .type = PM_STRING_OWNED,
33
+ .source = source,
34
+ .length = length
35
+ };
36
+ }
37
+
38
+ /**
39
+ * Initialize a constant string that doesn't own its memory source.
40
+ */
41
+ void
42
+ pm_string_constant_init(pm_string_t *string, const char *source, size_t length) {
43
+ *string = (pm_string_t) {
44
+ .type = PM_STRING_CONSTANT,
45
+ .source = (const uint8_t *) source,
46
+ .length = length
47
+ };
48
+ }
49
+
50
+ /**
51
+ * Read the file indicated by the filepath parameter into source and load its
52
+ * contents and size into the given `pm_string_t`. The given `pm_string_t`
53
+ * should be freed using `pm_string_free` when it is no longer used.
54
+ *
55
+ * We want to use demand paging as much as possible in order to avoid having to
56
+ * read the entire file into memory (which could be detrimental to performance
57
+ * for large files). This means that if we're on windows we'll use
58
+ * `MapViewOfFile`, on POSIX systems that have access to `mmap` we'll use
59
+ * `mmap`, and on other POSIX systems we'll use `read`.
60
+ */
61
+ bool
62
+ pm_string_mapped_init(pm_string_t *string, const char *filepath) {
63
+ #ifdef _WIN32
64
+ // Open the file for reading.
65
+ HANDLE file = CreateFile(filepath, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
66
+
67
+ if (file == INVALID_HANDLE_VALUE) {
68
+ return false;
69
+ }
70
+
71
+ // Get the file size.
72
+ DWORD file_size = GetFileSize(file, NULL);
73
+ if (file_size == INVALID_FILE_SIZE) {
74
+ CloseHandle(file);
75
+ return false;
76
+ }
77
+
78
+ // If the file is empty, then we don't need to do anything else, we'll set
79
+ // the source to a constant empty string and return.
80
+ if (file_size == 0) {
81
+ CloseHandle(file);
82
+ const uint8_t source[] = "";
83
+ *string = (pm_string_t) { .type = PM_STRING_CONSTANT, .source = source, .length = 0 };
84
+ return true;
85
+ }
86
+
87
+ // Create a mapping of the file.
88
+ HANDLE mapping = CreateFileMapping(file, NULL, PAGE_READONLY, 0, 0, NULL);
89
+ if (mapping == NULL) {
90
+ CloseHandle(file);
91
+ return false;
92
+ }
93
+
94
+ // Map the file into memory.
95
+ uint8_t *source = (uint8_t *) MapViewOfFile(mapping, FILE_MAP_READ, 0, 0, 0);
96
+ CloseHandle(mapping);
97
+ CloseHandle(file);
98
+
99
+ if (source == NULL) {
100
+ return false;
101
+ }
102
+
103
+ *string = (pm_string_t) { .type = PM_STRING_MAPPED, .source = source, .length = (size_t) file_size };
104
+ return true;
105
+ #else
106
+ // Open the file for reading
107
+ int fd = open(filepath, O_RDONLY);
108
+ if (fd == -1) {
109
+ return false;
110
+ }
111
+
112
+ // Stat the file to get the file size
113
+ struct stat sb;
114
+ if (fstat(fd, &sb) == -1) {
115
+ close(fd);
116
+ return false;
117
+ }
118
+
119
+ // mmap the file descriptor to virtually get the contents
120
+ size_t size = (size_t) sb.st_size;
121
+ uint8_t *source = NULL;
122
+
123
+ if (size == 0) {
124
+ close(fd);
125
+ const uint8_t source[] = "";
126
+ *string = (pm_string_t) { .type = PM_STRING_CONSTANT, .source = source, .length = 0 };
127
+ return true;
128
+ }
129
+
130
+ source = mmap(NULL, size, PROT_READ, MAP_PRIVATE, fd, 0);
131
+ if (source == MAP_FAILED) {
132
+ return false;
133
+ }
134
+
135
+ close(fd);
136
+ *string = (pm_string_t) { .type = PM_STRING_MAPPED, .source = source, .length = size };
137
+ return true;
138
+ #endif
139
+ }
140
+
141
+ /**
142
+ * Returns the memory size associated with the string.
143
+ */
144
+ size_t
145
+ pm_string_memsize(const pm_string_t *string) {
146
+ size_t size = sizeof(pm_string_t);
147
+ if (string->type == PM_STRING_OWNED) {
148
+ size += string->length;
149
+ }
150
+ return size;
151
+ }
152
+
153
+ /**
154
+ * Ensure the string is owned. If it is not, then reinitialize it as owned and
155
+ * copy over the previous source.
156
+ */
157
+ void
158
+ pm_string_ensure_owned(pm_string_t *string) {
159
+ if (string->type == PM_STRING_OWNED) return;
160
+
161
+ size_t length = pm_string_length(string);
162
+ const uint8_t *source = pm_string_source(string);
163
+
164
+ uint8_t *memory = malloc(length);
165
+ if (!memory) return;
166
+
167
+ pm_string_owned_init(string, memory, length);
168
+ memcpy((void *) string->source, source, length);
169
+ }
170
+
171
+ /**
172
+ * Returns the length associated with the string.
173
+ */
174
+ PRISM_EXPORTED_FUNCTION size_t
175
+ pm_string_length(const pm_string_t *string) {
176
+ return string->length;
177
+ }
178
+
179
+ /**
180
+ * Returns the start pointer associated with the string.
181
+ */
182
+ PRISM_EXPORTED_FUNCTION const uint8_t *
183
+ pm_string_source(const pm_string_t *string) {
184
+ return string->source;
185
+ }
186
+
187
+ /**
188
+ * Free the associated memory of the given string.
189
+ */
190
+ PRISM_EXPORTED_FUNCTION void
191
+ pm_string_free(pm_string_t *string) {
192
+ void *memory = (void *) string->source;
193
+
194
+ if (string->type == PM_STRING_OWNED) {
195
+ free(memory);
196
+ } else if (string->type == PM_STRING_MAPPED && string->length) {
197
+ #if defined(_WIN32)
198
+ UnmapViewOfFile(memory);
199
+ #else
200
+ munmap(memory, string->length);
201
+ #endif
202
+ }
203
+ }
@@ -0,0 +1,28 @@
1
+ #include "prism/util/pm_string_list.h"
2
+
3
+ /**
4
+ * Append a pm_string_t to the given string list.
5
+ */
6
+ void
7
+ pm_string_list_append(pm_string_list_t *string_list, pm_string_t *string) {
8
+ if (string_list->length + 1 > string_list->capacity) {
9
+ if (string_list->capacity == 0) {
10
+ string_list->capacity = 1;
11
+ } else {
12
+ string_list->capacity *= 2;
13
+ }
14
+
15
+ string_list->strings = realloc(string_list->strings, string_list->capacity * sizeof(pm_string_t));
16
+ if (string_list->strings == NULL) abort();
17
+ }
18
+
19
+ string_list->strings[string_list->length++] = *string;
20
+ }
21
+
22
+ /**
23
+ * Free the memory associated with the string list
24
+ */
25
+ void
26
+ pm_string_list_free(pm_string_list_t *string_list) {
27
+ free(string_list->strings);
28
+ }
@@ -0,0 +1,24 @@
1
+ #include "prism/util/pm_strncasecmp.h"
2
+
3
+ /**
4
+ * Compare two strings, ignoring case, up to the given length. Returns 0 if the
5
+ * strings are equal, a negative number if string1 is less than string2, or a
6
+ * positive number if string1 is greater than string2.
7
+ *
8
+ * Note that this is effectively our own implementation of strncasecmp, but it's
9
+ * not available on all of the platforms we want to support so we're rolling it
10
+ * here.
11
+ */
12
+ int
13
+ pm_strncasecmp(const uint8_t *string1, const uint8_t *string2, size_t length) {
14
+ size_t offset = 0;
15
+ int difference = 0;
16
+
17
+ while (offset < length && string1[offset] != '\0') {
18
+ if (string2[offset] == '\0') return string1[offset];
19
+ if ((difference = tolower(string1[offset]) - tolower(string2[offset])) != 0) return difference;
20
+ offset++;
21
+ }
22
+
23
+ return difference;
24
+ }
@@ -0,0 +1,180 @@
1
+ #include "prism/util/pm_strpbrk.h"
2
+
3
+ /**
4
+ * Add an invalid multibyte character error to the parser.
5
+ */
6
+ static inline void
7
+ pm_strpbrk_invalid_multibyte_character(pm_parser_t *parser, const uint8_t *start, const uint8_t *end) {
8
+ pm_diagnostic_list_append_format(&parser->error_list, start, end, PM_ERR_INVALID_MULTIBYTE_CHARACTER, *start);
9
+ }
10
+
11
+ /**
12
+ * This is the default path.
13
+ */
14
+ static inline const uint8_t *
15
+ pm_strpbrk_utf8(pm_parser_t *parser, const uint8_t *source, const uint8_t *charset, size_t maximum, bool validate) {
16
+ size_t index = 0;
17
+
18
+ while (index < maximum) {
19
+ if (strchr((const char *) charset, source[index]) != NULL) {
20
+ return source + index;
21
+ }
22
+
23
+ if (source[index] < 0x80) {
24
+ index++;
25
+ } else {
26
+ size_t width = pm_encoding_utf_8_char_width(source + index, (ptrdiff_t) (maximum - index));
27
+
28
+ if (width > 0) {
29
+ index += width;
30
+ } else if (!validate) {
31
+ index++;
32
+ } else {
33
+ // At this point we know we have an invalid multibyte character.
34
+ // We'll walk forward as far as we can until we find the next
35
+ // valid character so that we don't spam the user with a ton of
36
+ // the same kind of error.
37
+ const size_t start = index;
38
+
39
+ do {
40
+ index++;
41
+ } while (index < maximum && pm_encoding_utf_8_char_width(source + index, (ptrdiff_t) (maximum - index)) == 0);
42
+
43
+ pm_strpbrk_invalid_multibyte_character(parser, source + start, source + index);
44
+ }
45
+ }
46
+ }
47
+
48
+ return NULL;
49
+ }
50
+
51
+ /**
52
+ * This is the path when the encoding is ASCII-8BIT.
53
+ */
54
+ static inline const uint8_t *
55
+ pm_strpbrk_ascii_8bit(const uint8_t *source, const uint8_t *charset, size_t maximum) {
56
+ size_t index = 0;
57
+
58
+ while (index < maximum) {
59
+ if (strchr((const char *) charset, source[index]) != NULL) {
60
+ return source + index;
61
+ }
62
+
63
+ index++;
64
+ }
65
+
66
+ return NULL;
67
+ }
68
+
69
+ /**
70
+ * This is the slow path that does care about the encoding.
71
+ */
72
+ static inline const uint8_t *
73
+ pm_strpbrk_multi_byte(pm_parser_t *parser, const uint8_t *source, const uint8_t *charset, size_t maximum, bool validate) {
74
+ size_t index = 0;
75
+
76
+ while (index < maximum) {
77
+ if (strchr((const char *) charset, source[index]) != NULL) {
78
+ return source + index;
79
+ }
80
+
81
+ if (source[index] < 0x80) {
82
+ index++;
83
+ } else {
84
+ size_t width = parser->encoding->char_width(source + index, (ptrdiff_t) (maximum - index));
85
+
86
+ if (width > 0) {
87
+ index += width;
88
+ } else if (!validate) {
89
+ index++;
90
+ } else {
91
+ // At this point we know we have an invalid multibyte character.
92
+ // We'll walk forward as far as we can until we find the next
93
+ // valid character so that we don't spam the user with a ton of
94
+ // the same kind of error.
95
+ const size_t start = index;
96
+
97
+ do {
98
+ index++;
99
+ } while (index < maximum && parser->encoding->char_width(source + index, (ptrdiff_t) (maximum - index)) == 0);
100
+
101
+ pm_strpbrk_invalid_multibyte_character(parser, source + start, source + index);
102
+ }
103
+ }
104
+ }
105
+
106
+ return NULL;
107
+ }
108
+
109
+ /**
110
+ * This is the fast path that does not care about the encoding because we know
111
+ * the encoding only supports single-byte characters.
112
+ */
113
+ static inline const uint8_t *
114
+ pm_strpbrk_single_byte(pm_parser_t *parser, const uint8_t *source, const uint8_t *charset, size_t maximum, bool validate) {
115
+ size_t index = 0;
116
+
117
+ while (index < maximum) {
118
+ if (strchr((const char *) charset, source[index]) != NULL) {
119
+ return source + index;
120
+ }
121
+
122
+ if (source[index] < 0x80 || !validate) {
123
+ index++;
124
+ } else {
125
+ size_t width = parser->encoding->char_width(source + index, (ptrdiff_t) (maximum - index));
126
+
127
+ if (width > 0) {
128
+ index += width;
129
+ } else {
130
+ // At this point we know we have an invalid multibyte character.
131
+ // We'll walk forward as far as we can until we find the next
132
+ // valid character so that we don't spam the user with a ton of
133
+ // the same kind of error.
134
+ const size_t start = index;
135
+
136
+ do {
137
+ index++;
138
+ } while (index < maximum && parser->encoding->char_width(source + index, (ptrdiff_t) (maximum - index)) == 0);
139
+
140
+ pm_strpbrk_invalid_multibyte_character(parser, source + start, source + index);
141
+ }
142
+ }
143
+ }
144
+
145
+ return NULL;
146
+ }
147
+
148
+ /**
149
+ * Here we have rolled our own version of strpbrk. The standard library strpbrk
150
+ * has undefined behavior when the source string is not null-terminated. We want
151
+ * to support strings that are not null-terminated because pm_parse does not
152
+ * have the contract that the string is null-terminated. (This is desirable
153
+ * because it means the extension can call pm_parse with the result of a call to
154
+ * mmap).
155
+ *
156
+ * The standard library strpbrk also does not support passing a maximum length
157
+ * to search. We want to support this for the reason mentioned above, but we
158
+ * also don't want it to stop on null bytes. Ruby actually allows null bytes
159
+ * within strings, comments, regular expressions, etc. So we need to be able to
160
+ * skip past them.
161
+ *
162
+ * Finally, we want to support encodings wherein the charset could contain
163
+ * characters that are trailing bytes of multi-byte characters. For example, in
164
+ * Shift_JIS, the backslash character can be a trailing byte. In that case we
165
+ * need to take a slower path and iterate one multi-byte character at a time.
166
+ */
167
+ const uint8_t *
168
+ pm_strpbrk(pm_parser_t *parser, const uint8_t *source, const uint8_t *charset, ptrdiff_t length, bool validate) {
169
+ if (length <= 0) {
170
+ return NULL;
171
+ } else if (!parser->encoding_changed) {
172
+ return pm_strpbrk_utf8(parser, source, charset, (size_t) length, validate);
173
+ } else if (parser->encoding == PM_ENCODING_ASCII_8BIT_ENTRY) {
174
+ return pm_strpbrk_ascii_8bit(source, charset, (size_t) length);
175
+ } else if (parser->encoding->multibyte) {
176
+ return pm_strpbrk_multi_byte(parser, source, charset, (size_t) length, validate);
177
+ } else {
178
+ return pm_strpbrk_single_byte(parser, source, charset, (size_t) length, validate);
179
+ }
180
+ }
metadata ADDED
@@ -0,0 +1,156 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: jruby-prism-parser
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.23.0.pre.SNAPSHOT
5
+ platform: java
6
+ authors:
7
+ - JRuby Team
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2024-02-16 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description:
14
+ email:
15
+ - admin@jruby.org
16
+ executables: []
17
+ extensions:
18
+ - ext/prism/extconf.rb
19
+ extra_rdoc_files: []
20
+ files:
21
+ - CHANGELOG.md
22
+ - CODE_OF_CONDUCT.md
23
+ - CONTRIBUTING.md
24
+ - LICENSE.md
25
+ - Makefile
26
+ - README.md
27
+ - config.yml
28
+ - docs/build_system.md
29
+ - docs/configuration.md
30
+ - docs/cruby_compilation.md
31
+ - docs/design.md
32
+ - docs/encoding.md
33
+ - docs/fuzzing.md
34
+ - docs/heredocs.md
35
+ - docs/javascript.md
36
+ - docs/local_variable_depth.md
37
+ - docs/mapping.md
38
+ - docs/parser_translation.md
39
+ - docs/parsing_rules.md
40
+ - docs/releasing.md
41
+ - docs/ripper.md
42
+ - docs/ruby_api.md
43
+ - docs/ruby_parser_translation.md
44
+ - docs/serialization.md
45
+ - docs/testing.md
46
+ - ext/prism/api_node.c
47
+ - ext/prism/api_pack.c
48
+ - ext/prism/extconf.rb
49
+ - ext/prism/extension.c
50
+ - ext/prism/extension.h
51
+ - include/prism.h
52
+ - include/prism/ast.h
53
+ - include/prism/defines.h
54
+ - include/prism/diagnostic.h
55
+ - include/prism/encoding.h
56
+ - include/prism/node.h
57
+ - include/prism/options.h
58
+ - include/prism/pack.h
59
+ - include/prism/parser.h
60
+ - include/prism/prettyprint.h
61
+ - include/prism/regexp.h
62
+ - include/prism/util/pm_buffer.h
63
+ - include/prism/util/pm_char.h
64
+ - include/prism/util/pm_constant_pool.h
65
+ - include/prism/util/pm_list.h
66
+ - include/prism/util/pm_memchr.h
67
+ - include/prism/util/pm_newline_list.h
68
+ - include/prism/util/pm_state_stack.h
69
+ - include/prism/util/pm_string.h
70
+ - include/prism/util/pm_string_list.h
71
+ - include/prism/util/pm_strncasecmp.h
72
+ - include/prism/util/pm_strpbrk.h
73
+ - include/prism/version.h
74
+ - jruby-prism.jar
75
+ - lib/prism.rb
76
+ - lib/prism/compiler.rb
77
+ - lib/prism/debug.rb
78
+ - lib/prism/desugar_compiler.rb
79
+ - lib/prism/dispatcher.rb
80
+ - lib/prism/dot_visitor.rb
81
+ - lib/prism/dsl.rb
82
+ - lib/prism/ffi.rb
83
+ - lib/prism/lex_compat.rb
84
+ - lib/prism/mutation_compiler.rb
85
+ - lib/prism/node.rb
86
+ - lib/prism/node_ext.rb
87
+ - lib/prism/node_inspector.rb
88
+ - lib/prism/pack.rb
89
+ - lib/prism/parse_result.rb
90
+ - lib/prism/parse_result/comments.rb
91
+ - lib/prism/parse_result/newlines.rb
92
+ - lib/prism/pattern.rb
93
+ - lib/prism/serialize.rb
94
+ - lib/prism/translation.rb
95
+ - lib/prism/translation/parser.rb
96
+ - lib/prism/translation/parser/compiler.rb
97
+ - lib/prism/translation/parser/lexer.rb
98
+ - lib/prism/translation/parser/rubocop.rb
99
+ - lib/prism/translation/ripper.rb
100
+ - lib/prism/translation/ruby_parser.rb
101
+ - lib/prism/version.rb
102
+ - lib/prism/visitor.rb
103
+ - prism.gemspec
104
+ - rbi/prism.rbi
105
+ - rbi/prism_static.rbi
106
+ - sig/prism.rbs
107
+ - sig/prism_static.rbs
108
+ - src/diagnostic.c
109
+ - src/encoding.c
110
+ - src/node.c
111
+ - src/options.c
112
+ - src/pack.c
113
+ - src/prettyprint.c
114
+ - src/prism.c
115
+ - src/regexp.c
116
+ - src/serialize.c
117
+ - src/token_type.c
118
+ - src/util/pm_buffer.c
119
+ - src/util/pm_char.c
120
+ - src/util/pm_constant_pool.c
121
+ - src/util/pm_list.c
122
+ - src/util/pm_memchr.c
123
+ - src/util/pm_newline_list.c
124
+ - src/util/pm_state_stack.c
125
+ - src/util/pm_string.c
126
+ - src/util/pm_string_list.c
127
+ - src/util/pm_strncasecmp.c
128
+ - src/util/pm_strpbrk.c
129
+ homepage: https://github.com/jruby/jruby-prism
130
+ licenses:
131
+ - MIT
132
+ metadata:
133
+ allowed_push_host: https://rubygems.org
134
+ source_code_uri: https://github.com/ruby/prism
135
+ changelog_uri: https://github.com/ruby/prism/blob/main/CHANGELOG.md
136
+ post_install_message:
137
+ rdoc_options: []
138
+ require_paths:
139
+ - lib
140
+ required_ruby_version: !ruby/object:Gem::Requirement
141
+ requirements:
142
+ - - ">="
143
+ - !ruby/object:Gem::Version
144
+ version: 2.7.0
145
+ required_rubygems_version: !ruby/object:Gem::Requirement
146
+ requirements:
147
+ - - ">"
148
+ - !ruby/object:Gem::Version
149
+ version: 1.3.1
150
+ requirements:
151
+ - jar org.jruby, jruby-prism, 0.23.0-SNAPSHOT, :scope => :runtime
152
+ rubygems_version: 3.3.26
153
+ signing_key:
154
+ specification_version: 4
155
+ summary: Prism JRuby Parser Support
156
+ test_files: []