herb 0.8.10-arm-linux-gnu → 0.9.0-arm-linux-gnu
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.
- checksums.yaml +4 -4
- data/Makefile +11 -3
- data/README.md +64 -34
- data/Rakefile +48 -40
- data/config.yml +317 -34
- data/ext/herb/error_helpers.c +367 -140
- data/ext/herb/error_helpers.h +1 -0
- data/ext/herb/extconf.rb +67 -28
- data/ext/herb/extension.c +317 -51
- data/ext/herb/extension.h +1 -0
- data/ext/herb/extension_helpers.c +23 -14
- data/ext/herb/extension_helpers.h +2 -2
- data/ext/herb/nodes.c +537 -270
- data/ext/herb/nodes.h +1 -0
- data/herb.gemspec +3 -2
- data/lib/herb/3.0/herb.so +0 -0
- data/lib/herb/3.1/herb.so +0 -0
- data/lib/herb/3.2/herb.so +0 -0
- data/lib/herb/3.3/herb.so +0 -0
- data/lib/herb/3.4/herb.so +0 -0
- data/lib/herb/4.0/herb.so +0 -0
- data/lib/herb/ast/helpers.rb +3 -3
- data/lib/herb/ast/node.rb +15 -2
- data/lib/herb/ast/nodes.rb +1132 -157
- data/lib/herb/bootstrap.rb +87 -0
- data/lib/herb/cli.rb +341 -31
- data/lib/herb/configuration.rb +248 -0
- data/lib/herb/defaults.yml +32 -0
- data/lib/herb/engine/compiler.rb +78 -11
- data/lib/herb/engine/debug_visitor.rb +13 -3
- data/lib/herb/engine/error_formatter.rb +13 -9
- data/lib/herb/engine/parser_error_overlay.rb +10 -6
- data/lib/herb/engine/validator.rb +8 -3
- data/lib/herb/engine/validators/nesting_validator.rb +2 -2
- data/lib/herb/engine.rb +82 -35
- data/lib/herb/errors.rb +563 -88
- data/lib/herb/lex_result.rb +1 -0
- data/lib/herb/location.rb +7 -3
- data/lib/herb/parse_result.rb +12 -2
- data/lib/herb/parser_options.rb +57 -0
- data/lib/herb/position.rb +1 -0
- data/lib/herb/prism_inspect.rb +116 -0
- data/lib/herb/project.rb +923 -331
- data/lib/herb/range.rb +1 -0
- data/lib/herb/token.rb +7 -1
- data/lib/herb/version.rb +1 -1
- data/lib/herb/visitor.rb +37 -2
- data/lib/herb/warnings.rb +6 -1
- data/lib/herb.rb +35 -3
- data/sig/herb/ast/helpers.rbs +2 -2
- data/sig/herb/ast/node.rbs +12 -2
- data/sig/herb/ast/nodes.rbs +641 -128
- data/sig/herb/bootstrap.rbs +31 -0
- data/sig/herb/configuration.rbs +89 -0
- data/sig/herb/engine/compiler.rbs +9 -1
- data/sig/herb/engine/debug_visitor.rbs +2 -0
- data/sig/herb/engine/validator.rbs +5 -1
- data/sig/herb/engine.rbs +17 -3
- data/sig/herb/errors.rbs +258 -63
- data/sig/herb/location.rbs +4 -0
- data/sig/herb/parse_result.rbs +4 -2
- data/sig/herb/parser_options.rbs +42 -0
- data/sig/herb/position.rbs +1 -0
- data/sig/herb/prism_inspect.rbs +28 -0
- data/sig/herb/range.rbs +1 -0
- data/sig/herb/token.rbs +6 -0
- data/sig/herb/visitor.rbs +25 -4
- data/sig/herb/warnings.rbs +6 -1
- data/sig/herb.rbs +14 -0
- data/sig/herb_c_extension.rbs +5 -2
- data/sig/serialized_ast_errors.rbs +54 -6
- data/sig/serialized_ast_nodes.rbs +60 -6
- data/src/analyze/action_view/attribute_extraction_helpers.c +290 -0
- data/src/analyze/action_view/content_tag.c +70 -0
- data/src/analyze/action_view/link_to.c +143 -0
- data/src/analyze/action_view/registry.c +60 -0
- data/src/analyze/action_view/tag.c +64 -0
- data/src/analyze/action_view/tag_helper_node_builders.c +305 -0
- data/src/analyze/action_view/tag_helpers.c +748 -0
- data/src/analyze/action_view/turbo_frame_tag.c +88 -0
- data/src/analyze/analyze.c +882 -0
- data/src/{analyzed_ruby.c → analyze/analyzed_ruby.c} +13 -11
- data/src/analyze/builders.c +343 -0
- data/src/analyze/conditional_elements.c +594 -0
- data/src/analyze/conditional_open_tags.c +640 -0
- data/src/analyze/control_type.c +250 -0
- data/src/{analyze_helpers.c → analyze/helpers.c} +48 -23
- data/src/analyze/invalid_structures.c +193 -0
- data/src/{analyze_missing_end.c → analyze/missing_end.c} +33 -22
- data/src/analyze/parse_errors.c +84 -0
- data/src/analyze/prism_annotate.c +397 -0
- data/src/{analyze_transform.c → analyze/transform.c} +17 -3
- data/src/ast_node.c +17 -7
- data/src/ast_nodes.c +662 -387
- data/src/ast_pretty_print.c +190 -6
- data/src/errors.c +1076 -520
- data/src/extract.c +145 -49
- data/src/herb.c +52 -34
- data/src/html_util.c +241 -12
- data/src/include/analyze/action_view/attribute_extraction_helpers.h +36 -0
- data/src/include/analyze/action_view/tag_helper_handler.h +41 -0
- data/src/include/analyze/action_view/tag_helper_node_builders.h +70 -0
- data/src/include/analyze/action_view/tag_helpers.h +38 -0
- data/src/include/{analyze.h → analyze/analyze.h} +14 -4
- data/src/include/{analyzed_ruby.h → analyze/analyzed_ruby.h} +3 -3
- data/src/include/analyze/builders.h +27 -0
- data/src/include/analyze/conditional_elements.h +9 -0
- data/src/include/analyze/conditional_open_tags.h +9 -0
- data/src/include/analyze/control_type.h +14 -0
- data/src/include/{analyze_helpers.h → analyze/helpers.h} +4 -2
- data/src/include/analyze/invalid_structures.h +11 -0
- data/src/include/analyze/prism_annotate.h +16 -0
- data/src/include/ast_node.h +11 -5
- data/src/include/ast_nodes.h +117 -38
- data/src/include/ast_pretty_print.h +5 -0
- data/src/include/element_source.h +3 -8
- data/src/include/errors.h +148 -55
- data/src/include/extract.h +21 -5
- data/src/include/herb.h +18 -6
- data/src/include/herb_prism_node.h +13 -0
- data/src/include/html_util.h +7 -2
- data/src/include/io.h +3 -1
- data/src/include/lex_helpers.h +29 -0
- data/src/include/lexer.h +1 -1
- data/src/include/lexer_peek_helpers.h +87 -13
- data/src/include/lexer_struct.h +2 -0
- data/src/include/location.h +2 -1
- data/src/include/parser.h +27 -2
- data/src/include/parser_helpers.h +19 -3
- data/src/include/pretty_print.h +10 -5
- data/src/include/prism_context.h +45 -0
- data/src/include/prism_helpers.h +10 -7
- data/src/include/prism_serialized.h +12 -0
- data/src/include/token.h +16 -4
- data/src/include/token_struct.h +10 -3
- data/src/include/utf8.h +2 -1
- data/src/include/util/hb_allocator.h +78 -0
- data/src/include/util/hb_arena.h +6 -1
- data/src/include/util/hb_arena_debug.h +12 -1
- data/src/include/util/hb_array.h +7 -3
- data/src/include/util/hb_buffer.h +6 -4
- data/src/include/util/hb_foreach.h +79 -0
- data/src/include/util/hb_narray.h +8 -4
- data/src/include/util/hb_string.h +56 -9
- data/src/include/util.h +6 -3
- data/src/include/version.h +1 -1
- data/src/io.c +3 -2
- data/src/lexer.c +42 -30
- data/src/lexer_peek_helpers.c +12 -74
- data/src/location.c +2 -2
- data/src/main.c +53 -28
- data/src/parser.c +783 -247
- data/src/parser_helpers.c +110 -23
- data/src/parser_match_tags.c +109 -48
- data/src/pretty_print.c +29 -24
- data/src/prism_helpers.c +30 -27
- data/src/ruby_parser.c +2 -0
- data/src/token.c +151 -66
- data/src/token_matchers.c +0 -1
- data/src/utf8.c +7 -6
- data/src/util/hb_allocator.c +341 -0
- data/src/util/hb_arena.c +81 -56
- data/src/util/hb_arena_debug.c +32 -17
- data/src/util/hb_array.c +30 -15
- data/src/util/hb_buffer.c +17 -21
- data/src/util/hb_narray.c +22 -7
- data/src/util/hb_string.c +49 -35
- data/src/util.c +21 -11
- data/src/visitor.c +47 -0
- data/templates/ext/herb/error_helpers.c.erb +24 -11
- data/templates/ext/herb/error_helpers.h.erb +1 -0
- data/templates/ext/herb/nodes.c.erb +50 -16
- data/templates/ext/herb/nodes.h.erb +1 -0
- data/templates/java/error_helpers.c.erb +1 -1
- data/templates/java/nodes.c.erb +30 -8
- data/templates/java/org/herb/ast/Errors.java.erb +24 -1
- data/templates/java/org/herb/ast/Nodes.java.erb +80 -21
- data/templates/javascript/packages/core/src/errors.ts.erb +16 -3
- data/templates/javascript/packages/core/src/node-type-guards.ts.erb +3 -1
- data/templates/javascript/packages/core/src/nodes.ts.erb +109 -32
- data/templates/javascript/packages/node/extension/error_helpers.cpp.erb +13 -4
- data/templates/javascript/packages/node/extension/nodes.cpp.erb +43 -4
- data/templates/lib/herb/ast/nodes.rb.erb +88 -31
- data/templates/lib/herb/errors.rb.erb +15 -3
- data/templates/lib/herb/visitor.rb.erb +2 -2
- data/templates/rust/src/ast/nodes.rs.erb +97 -44
- data/templates/rust/src/errors.rs.erb +2 -1
- data/templates/rust/src/nodes.rs.erb +167 -15
- data/templates/rust/src/union_types.rs.erb +60 -0
- data/templates/rust/src/visitor.rs.erb +81 -0
- data/templates/src/{analyze_missing_end.c.erb → analyze/missing_end.c.erb} +9 -6
- data/templates/src/{analyze_transform.c.erb → analyze/transform.c.erb} +2 -2
- data/templates/src/ast_nodes.c.erb +34 -26
- data/templates/src/ast_pretty_print.c.erb +24 -5
- data/templates/src/errors.c.erb +60 -54
- data/templates/src/include/ast_nodes.h.erb +6 -2
- data/templates/src/include/ast_pretty_print.h.erb +5 -0
- data/templates/src/include/errors.h.erb +15 -11
- data/templates/src/include/util/hb_foreach.h.erb +20 -0
- data/templates/src/parser_match_tags.c.erb +10 -4
- data/templates/src/visitor.c.erb +2 -2
- data/templates/template.rb +204 -29
- data/templates/wasm/error_helpers.cpp.erb +9 -5
- data/templates/wasm/nodes.cpp.erb +41 -4
- metadata +57 -16
- data/src/analyze.c +0 -1608
- data/src/element_source.c +0 -12
- data/src/include/util/hb_system.h +0 -9
- data/src/util/hb_system.c +0 -30
|
@@ -18,7 +18,7 @@ jobject <%= error.name %>FromCStruct(JNIEnv* env, <%= error.struct_type %>* <%=
|
|
|
18
18
|
|
|
19
19
|
jstring jtype = (*env)->NewStringUTF(env, "<%= error.name %>");
|
|
20
20
|
jobject location = CreateLocation(env, <%= error.human %>->base.location);
|
|
21
|
-
jstring jmessage = (
|
|
21
|
+
jstring jmessage = CreateStringFromHbString(env, <%= error.human %>->base.message);
|
|
22
22
|
|
|
23
23
|
return (*env)->NewObject(env, errorClass, constructor, jtype, location, jmessage);
|
|
24
24
|
}
|
data/templates/java/nodes.c.erb
CHANGED
|
@@ -25,30 +25,52 @@ jobject <%= node.name %>FromCStruct(JNIEnv* env, <%= node.struct_type %>* <%= no
|
|
|
25
25
|
|
|
26
26
|
<%- node.fields.each do |field| -%>
|
|
27
27
|
<%- if field.is_a?(Herb::Template::StringField) -%>
|
|
28
|
-
jstring <%= field.name %> = (
|
|
28
|
+
jstring <%= field.name %> = CreateStringFromHbString(env, <%= node.human %>-><%= field.name %>);
|
|
29
29
|
<%- elsif field.is_a?(Herb::Template::TokenField) -%>
|
|
30
30
|
jobject <%= field.name %> = <%= node.human %>-><%= field.name %> ? CreateToken(env, <%= node.human %>-><%= field.name %>) : NULL;
|
|
31
31
|
<%- elsif field.is_a?(Herb::Template::BooleanField) -%>
|
|
32
32
|
jboolean <%= field.name %> = <%= node.human %>-><%= field.name %> ? JNI_TRUE : JNI_FALSE;
|
|
33
33
|
<%- elsif field.is_a?(Herb::Template::ArrayField) -%>
|
|
34
34
|
jobject <%= field.name %> = NodesArrayFromCArray(env, <%= node.human %>-><%= field.name %>);
|
|
35
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
35
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
36
36
|
jobject <%= field.name %> = <%= node.human %>-><%= field.name %> ? NodeFromCStruct(env, (AST_NODE_T*) <%= node.human %>-><%= field.name %>) : NULL;
|
|
37
37
|
<%- elsif field.is_a?(Herb::Template::ElementSourceField) -%>
|
|
38
|
-
|
|
39
|
-
jstring <%= field.name %> = (*env)->NewStringUTF(env, "");
|
|
38
|
+
jstring <%= field.name %> = <%= node.human %>-><%= field.name %>.data ? (*env)->NewStringUTF(env, <%= node.human %>-><%= field.name %>.data) : NULL;
|
|
40
39
|
<%- elsif field.is_a?(Herb::Template::LocationField) -%>
|
|
41
40
|
jobject <%= field.name %> = <%= node.human %>-><%= field.name %> ? CreateLocation(env, *<%= node.human %>-><%= field.name %>) : NULL;
|
|
42
|
-
<%- elsif field.is_a?(Herb::Template::
|
|
43
|
-
|
|
41
|
+
<%- elsif field.is_a?(Herb::Template::PrismSerializedField) -%>
|
|
42
|
+
jbyteArray <%= field.name %>;
|
|
43
|
+
if (<%= node.human %>-><%= field.name %>.data != NULL && <%= node.human %>-><%= field.name %>.length > 0) {
|
|
44
|
+
<%= field.name %> = (*env)->NewByteArray(env, (jsize)<%= node.human %>-><%= field.name %>.length);
|
|
45
|
+
(*env)->SetByteArrayRegion(env, <%= field.name %>, 0, (jsize)<%= node.human %>-><%= field.name %>.length, (const jbyte*)<%= node.human %>-><%= field.name %>.data);
|
|
46
|
+
} else {
|
|
47
|
+
<%= field.name %> = NULL;
|
|
48
|
+
}
|
|
49
|
+
<%- elsif field.is_a?(Herb::Template::PrismNodeField) -%>
|
|
50
|
+
jbyteArray <%= field.name %>;
|
|
51
|
+
if (<%= node.human %>-><%= field.name %>.node != NULL && <%= node.human %>-><%= field.name %>.parser != NULL) {
|
|
52
|
+
pm_buffer_t pm_buffer = { 0 };
|
|
53
|
+
pm_serialize(<%= node.human %>-><%= field.name %>.parser, <%= node.human %>-><%= field.name %>.node, &pm_buffer);
|
|
54
|
+
if (pm_buffer.length > 0) {
|
|
55
|
+
<%= field.name %> = (*env)->NewByteArray(env, (jsize)pm_buffer.length);
|
|
56
|
+
(*env)->SetByteArrayRegion(env, <%= field.name %>, 0, (jsize)pm_buffer.length, (const jbyte*)pm_buffer.value);
|
|
57
|
+
} else {
|
|
58
|
+
<%= field.name %> = NULL;
|
|
59
|
+
}
|
|
60
|
+
pm_buffer_free(&pm_buffer);
|
|
61
|
+
} else {
|
|
62
|
+
<%= field.name %> = NULL;
|
|
63
|
+
}
|
|
64
|
+
<%- elsif field.is_a?(Herb::Template::AnalyzedRubyField) || field.is_a?(Herb::Template::PrismContextField) -%>
|
|
65
|
+
// Skip <%= field.name %> (<%= field.class.name.split('::').last %>) - internal parser state
|
|
44
66
|
<%- end -%>
|
|
45
67
|
<%- end -%>
|
|
46
68
|
|
|
47
|
-
const char* signature = "(Ljava/lang/String;Lorg/herb/Location;Ljava/util/List;<%- node.fields.each do |f| -%><%- unless f.is_a?(Herb::Template::AnalyzedRubyField) || f.is_a?(Herb::Template::
|
|
69
|
+
const char* signature = "(Ljava/lang/String;Lorg/herb/Location;Ljava/util/List;<%- node.fields.each do |f| -%><%- unless f.is_a?(Herb::Template::AnalyzedRubyField) || f.is_a?(Herb::Template::PrismContextField) -%><%- if f.is_a?(Herb::Template::StringField) -%>Ljava/lang/String;<%- elsif f.is_a?(Herb::Template::TokenField) -%>Lorg/herb/Token;<%- elsif f.is_a?(Herb::Template::BooleanField) -%>Z<%- elsif f.is_a?(Herb::Template::ArrayField) -%>Ljava/util/List;<%- elsif f.is_a?(Herb::Template::NodeField) -%>Lorg/herb/ast/<%= f.specific_kind || 'Node' %>;<%- elsif f.is_a?(Herb::Template::ElementSourceField) -%>Ljava/lang/String;<%- elsif f.is_a?(Herb::Template::LocationField) -%>Lorg/herb/Location;<%- elsif f.is_a?(Herb::Template::PrismSerializedField) || f.is_a?(Herb::Template::PrismNodeField) -%>[B<%- end -%><%- end -%><%- end -%>)V";
|
|
48
70
|
jmethodID constructor = (*env)->GetMethodID(env, nodeClass, "<init>", signature);
|
|
49
71
|
if (!constructor) { return NULL; }
|
|
50
72
|
|
|
51
|
-
jobject result = (*env)->NewObject(env, nodeClass, constructor, type, location, errors<%- node.fields.each do |field| -%><%- unless field.is_a?(Herb::Template::AnalyzedRubyField) || field.is_a?(Herb::Template::
|
|
73
|
+
jobject result = (*env)->NewObject(env, nodeClass, constructor, type, location, errors<%- node.fields.each do |field| -%><%- unless field.is_a?(Herb::Template::AnalyzedRubyField) || field.is_a?(Herb::Template::PrismContextField) -%>, <%= field.name %><%- end -%><%- end -%>);
|
|
52
74
|
|
|
53
75
|
return result;
|
|
54
76
|
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
package org.herb.ast;
|
|
2
2
|
|
|
3
3
|
import org.herb.Location;
|
|
4
|
+
import org.herb.Position;
|
|
4
5
|
import org.herb.Token;
|
|
5
6
|
|
|
6
7
|
/**
|
|
@@ -58,12 +59,16 @@ class <%= error.name %> extends HerbError {
|
|
|
58
59
|
private final Token <%= field.name %>;
|
|
59
60
|
<%- when Herb::Template::TokenTypeField -%>
|
|
60
61
|
private final String <%= field.name %>;
|
|
62
|
+
<%- when Herb::Template::PositionField -%>
|
|
63
|
+
private final Position <%= field.name %>;
|
|
64
|
+
<%- when Herb::Template::SizeTField -%>
|
|
65
|
+
private final long <%= field.name %>;
|
|
61
66
|
<%- else -%>
|
|
62
67
|
// Unsupported field type: <%= field.class %>
|
|
63
68
|
<%- end -%>
|
|
64
69
|
<%- end -%>
|
|
65
70
|
|
|
66
|
-
public <%= error.name %>(String type, String message, Location location<%- error.fields.each do |field| -%><%- case field -%><%- when Herb::Template::StringField -%>, String <%= field.name %><%- when Herb::Template::TokenField -%>, Token <%= field.name %><%- when Herb::Template::TokenTypeField -%>, String <%= field.name %><%- end -%><%- end -%>) {
|
|
71
|
+
public <%= error.name %>(String type, String message, Location location<%- error.fields.each do |field| -%><%- case field -%><%- when Herb::Template::StringField -%>, String <%= field.name %><%- when Herb::Template::TokenField -%>, Token <%= field.name %><%- when Herb::Template::TokenTypeField -%>, String <%= field.name %><%- when Herb::Template::PositionField -%>, Position <%= field.name %><%- when Herb::Template::SizeTField -%>, long <%= field.name %><%- end -%><%- end -%>) {
|
|
67
72
|
super(type, message, location);
|
|
68
73
|
<%- error.fields.each do |field| -%>
|
|
69
74
|
this.<%= field.name %> = <%= field.name %>;
|
|
@@ -87,6 +92,16 @@ class <%= error.name %> extends HerbError {
|
|
|
87
92
|
return <%= field.name %>;
|
|
88
93
|
}
|
|
89
94
|
|
|
95
|
+
<%- when Herb::Template::PositionField -%>
|
|
96
|
+
public Position get<%= field.name.capitalize %>() {
|
|
97
|
+
return <%= field.name %>;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
<%- when Herb::Template::SizeTField -%>
|
|
101
|
+
public long get<%= field.name.capitalize %>() {
|
|
102
|
+
return <%= field.name %>;
|
|
103
|
+
}
|
|
104
|
+
|
|
90
105
|
<%- end -%>
|
|
91
106
|
<%- end -%>
|
|
92
107
|
@Override
|
|
@@ -111,6 +126,14 @@ class <%= error.name %> extends HerbError {
|
|
|
111
126
|
output.append("<%= symbol %> <%= field.name %>: ");
|
|
112
127
|
output.append(<%= field.name %> != null ? <%= field.name %>.inspect() : "∅");
|
|
113
128
|
output.append("\n");
|
|
129
|
+
<%- when Herb::Template::PositionField -%>
|
|
130
|
+
output.append("<%= symbol %> <%= field.name %>: ");
|
|
131
|
+
output.append(<%= field.name %> != null ? <%= field.name %>.toString() : "∅");
|
|
132
|
+
output.append("\n");
|
|
133
|
+
<%- when Herb::Template::SizeTField -%>
|
|
134
|
+
output.append("<%= symbol %> <%= field.name %>: ");
|
|
135
|
+
output.append(<%= field.name %>);
|
|
136
|
+
output.append("\n");
|
|
114
137
|
<%- end -%>
|
|
115
138
|
<%- end -%>
|
|
116
139
|
|
|
@@ -18,7 +18,7 @@ class <%= node.name %> extends BaseNode {
|
|
|
18
18
|
private final boolean <%= field.name %>;
|
|
19
19
|
<%- elsif field.is_a?(Herb::Template::ArrayField) -%>
|
|
20
20
|
private final List<Node> <%= field.name %>;
|
|
21
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
21
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
22
22
|
<%- if field.specific_kind -%>
|
|
23
23
|
private final <%= field.specific_kind %> <%= field.name %>;
|
|
24
24
|
<%- else -%>
|
|
@@ -28,6 +28,8 @@ class <%= node.name %> extends BaseNode {
|
|
|
28
28
|
private final String <%= field.name %>;
|
|
29
29
|
<%- elsif field.is_a?(Herb::Template::LocationField) -%>
|
|
30
30
|
private final Location <%= field.name %>;
|
|
31
|
+
<%- elsif field.is_a?(Herb::Template::PrismSerializedField) || field.is_a?(Herb::Template::PrismNodeField) -%>
|
|
32
|
+
private final byte[] <%= field.name %>;
|
|
31
33
|
<%- else -%>
|
|
32
34
|
// private final Object <%= field.name %>;
|
|
33
35
|
<%- end -%>
|
|
@@ -48,12 +50,14 @@ class <%= node.name %> extends BaseNode {
|
|
|
48
50
|
boolean <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
49
51
|
<%- elsif field.is_a?(Herb::Template::ArrayField) -%>
|
|
50
52
|
List<Node> <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
51
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
53
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
52
54
|
<%= field.specific_kind || 'Node' %> <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
53
55
|
<%- elsif field.is_a?(Herb::Template::ElementSourceField) -%>
|
|
54
56
|
String <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
55
57
|
<%- elsif field.is_a?(Herb::Template::LocationField) -%>
|
|
56
58
|
Location <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
59
|
+
<%- elsif field.is_a?(Herb::Template::PrismSerializedField) || field.is_a?(Herb::Template::PrismNodeField) -%>
|
|
60
|
+
byte[] <%= field.name %><%- if node.fields.last != field %>,<% end %>
|
|
57
61
|
<%- else -%>
|
|
58
62
|
// <%= field.c_type %> <%= field.name %>
|
|
59
63
|
<%- end -%>
|
|
@@ -64,7 +68,7 @@ class <%= node.name %> extends BaseNode {
|
|
|
64
68
|
|
|
65
69
|
<%- if node.fields.any? -%>
|
|
66
70
|
<%- node.fields.each do |field| -%>
|
|
67
|
-
<%- unless field.is_a?(Herb::Template::AnalyzedRubyField) || field.is_a?(Herb::Template::
|
|
71
|
+
<%- unless field.is_a?(Herb::Template::AnalyzedRubyField) || field.is_a?(Herb::Template::PrismContextField) -%>
|
|
68
72
|
this.<%= field.name %> = <%= field.name %>;
|
|
69
73
|
<%- else -%>
|
|
70
74
|
// this.<%= field.name %> = <%= field.name %>;
|
|
@@ -95,7 +99,7 @@ class <%= node.name %> extends BaseNode {
|
|
|
95
99
|
return <%= field.name %>;
|
|
96
100
|
}
|
|
97
101
|
|
|
98
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
102
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
99
103
|
public <%= field.specific_kind || 'Node' %> get<%= field.name.split('_').map(&:capitalize).join %>() {
|
|
100
104
|
return <%= field.name %>;
|
|
101
105
|
}
|
|
@@ -110,6 +114,11 @@ class <%= node.name %> extends BaseNode {
|
|
|
110
114
|
return <%= field.name %>;
|
|
111
115
|
}
|
|
112
116
|
|
|
117
|
+
<%- elsif field.is_a?(Herb::Template::PrismSerializedField) || field.is_a?(Herb::Template::PrismNodeField) -%>
|
|
118
|
+
public byte[] get<%= field.name.split('_').map(&:capitalize).join %>() {
|
|
119
|
+
return <%= field.name %>;
|
|
120
|
+
}
|
|
121
|
+
|
|
113
122
|
<%- else -%>
|
|
114
123
|
/*
|
|
115
124
|
public Object get<%= field.name.split('_').map(&:capitalize).join %>() {
|
|
@@ -135,7 +144,7 @@ class <%= node.name %> extends BaseNode {
|
|
|
135
144
|
}
|
|
136
145
|
}
|
|
137
146
|
|
|
138
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
147
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
139
148
|
if (<%= field.name %> != null) <%= field.name %>.accept(visitor, context);
|
|
140
149
|
|
|
141
150
|
<%- end -%>
|
|
@@ -147,6 +156,10 @@ class <%= node.name %> extends BaseNode {
|
|
|
147
156
|
|
|
148
157
|
@Override
|
|
149
158
|
public String inspect() {
|
|
159
|
+
return inspect(null);
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
public String inspect(String source) {
|
|
150
163
|
StringBuilder output = new StringBuilder();
|
|
151
164
|
|
|
152
165
|
output.append("@ <%= node.name %> ").append(location != null ? "(location: " + location.toString() + ")" : "no-location").append("\n");
|
|
@@ -156,32 +169,78 @@ class <%= node.name %> extends BaseNode {
|
|
|
156
169
|
output.append(inspectErrors(" "));
|
|
157
170
|
<%- end -%>
|
|
158
171
|
<%- if node.fields.any? -%>
|
|
159
|
-
<%- node.
|
|
160
|
-
<%-
|
|
161
|
-
<%-
|
|
162
|
-
<%-
|
|
172
|
+
<%- node.field_visibilities.each do |visibility| -%>
|
|
173
|
+
<%- field = visibility.field -%>
|
|
174
|
+
<%- next if field.always_invisible? -%>
|
|
175
|
+
<%- if field.conditionally_invisible? -%>
|
|
176
|
+
if (<%= field.name %> != null) {
|
|
177
|
+
output.append("└── <%= field.name %>: ").append("(").append(<%= field.name %>.length).append(" bytes)").append("\n");
|
|
178
|
+
}
|
|
179
|
+
<%- else -%>
|
|
180
|
+
<%- if visibility.dynamic_last? -%>
|
|
181
|
+
{
|
|
182
|
+
boolean isLast = <%= visibility.prism_field_name %> == null;
|
|
183
|
+
String symbol = isLast ? "└── " : "├── ";
|
|
184
|
+
<%- end -%>
|
|
163
185
|
<%- if field.is_a?(Herb::Template::StringField) || field.is_a?(Herb::Template::ElementSourceField) -%>
|
|
164
|
-
|
|
186
|
+
<%- if visibility.dynamic_last? -%>
|
|
187
|
+
output.append(symbol).append("<%= field.name %>: ").append(<%= field.name %> != null ? "\"" + <%= field.name %>.replace("\\", "\\\\").replace("\n", "\\n").replace("\r", "\\r").replace("\t", "\\t").replace("\"", "\\\"") + "\"" : "∅").append("\n");
|
|
188
|
+
<%- else -%>
|
|
189
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ").append(<%= field.name %> != null ? "\"" + <%= field.name %>.replace("\\", "\\\\").replace("\n", "\\n").replace("\r", "\\r").replace("\t", "\\t").replace("\"", "\\\"") + "\"" : "∅").append("\n");
|
|
190
|
+
<%- end -%>
|
|
165
191
|
<%- elsif field.is_a?(Herb::Template::TokenField) -%>
|
|
166
|
-
|
|
192
|
+
<%- if visibility.dynamic_last? -%>
|
|
193
|
+
output.append(symbol).append("<%= field.name %>: ").append(<%= field.name %> != null ? <%= field.name %>.treeInspect() : "∅").append("\n");
|
|
194
|
+
<%- else -%>
|
|
195
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ").append(<%= field.name %> != null ? <%= field.name %>.treeInspect() : "∅").append("\n");
|
|
196
|
+
<%- end -%>
|
|
167
197
|
<%- elsif field.is_a?(Herb::Template::BooleanField) -%>
|
|
168
|
-
|
|
198
|
+
<%- if visibility.dynamic_last? -%>
|
|
199
|
+
output.append(symbol).append("<%= field.name %>: ").append(<%= field.name %>).append("\n");
|
|
200
|
+
<%- else -%>
|
|
201
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ").append(<%= field.name %>).append("\n");
|
|
202
|
+
<%- end -%>
|
|
169
203
|
<%- elsif field.is_a?(Herb::Template::LocationField) -%>
|
|
170
|
-
|
|
204
|
+
<%- if visibility.dynamic_last? -%>
|
|
205
|
+
output.append(symbol).append("<%= field.name %>: ").append(<%= field.name %> != null ? "(location: " + <%= field.name %>.treeInspect() + ")" : "∅").append("\n");
|
|
206
|
+
<%- else -%>
|
|
207
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ").append(<%= field.name %> != null ? "(location: " + <%= field.name %>.treeInspect() + ")" : "∅").append("\n");
|
|
208
|
+
<%- end -%>
|
|
171
209
|
<%- elsif field.is_a?(Herb::Template::ArrayField) -%>
|
|
172
|
-
|
|
173
|
-
|
|
210
|
+
<%- if visibility.dynamic_last? -%>
|
|
211
|
+
String childPrefix = isLast ? " " : "│ ";
|
|
212
|
+
output.append(symbol).append("<%= field.name %>: ").append(inspectArray(<%= field.name %>, childPrefix, source));
|
|
213
|
+
<%- else -%>
|
|
214
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ").append(inspectArray(<%= field.name %>, "<%= visibility.prefix %>", source));
|
|
215
|
+
<%- end -%>
|
|
216
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
217
|
+
<%- if visibility.dynamic_last? -%>
|
|
218
|
+
String childPrefix = isLast ? " " : "│ ";
|
|
219
|
+
if (<%= field.name %> != null) {
|
|
220
|
+
output.append(symbol).append("<%= field.name %>:\n");
|
|
221
|
+
output.append(childPrefix).append(inspectNode(<%= field.name %>, childPrefix, source));
|
|
222
|
+
} else {
|
|
223
|
+
output.append(symbol).append("<%= field.name %>: ∅\n");
|
|
224
|
+
}
|
|
225
|
+
<%- else -%>
|
|
174
226
|
if (<%= field.name %> != null) {
|
|
175
|
-
output.append("<%= symbol %><%= field.name %>:\n");
|
|
176
|
-
output.append("<%= prefix %>").append(inspectNode(<%= field.name %>, "<%= prefix %>"));
|
|
177
|
-
<%- unless
|
|
178
|
-
output.append("<%= prefix %>").append("\n");
|
|
227
|
+
output.append("<%= visibility.symbol %><%= field.name %>:\n");
|
|
228
|
+
output.append("<%= visibility.prefix %>").append(inspectNode(<%= field.name %>, "<%= visibility.prefix %>", source));
|
|
229
|
+
<%- unless visibility.static_last? -%>
|
|
230
|
+
output.append("<%= visibility.prefix %>").append("\n");
|
|
179
231
|
<%- end -%>
|
|
180
232
|
} else {
|
|
181
|
-
output.append("<%= symbol %><%= field.name %>: ∅\n");
|
|
233
|
+
output.append("<%= visibility.symbol %><%= field.name %>: ∅\n");
|
|
234
|
+
}
|
|
235
|
+
<%- end -%>
|
|
236
|
+
<%- else -%>
|
|
237
|
+
<% raise "Unhandled class #{field.class}" %>
|
|
238
|
+
<%- end -%>
|
|
239
|
+
<%- if visibility.dynamic_last? -%>
|
|
182
240
|
}
|
|
183
241
|
<%- end -%>
|
|
184
242
|
<%- end -%>
|
|
243
|
+
<%- end -%>
|
|
185
244
|
<%- else -%>
|
|
186
245
|
output.append("└── (no fields)\n");
|
|
187
246
|
<%- end -%>
|
|
@@ -209,7 +268,7 @@ class <%= node.name %> extends BaseNode {
|
|
|
209
268
|
}
|
|
210
269
|
}
|
|
211
270
|
|
|
212
|
-
<%- elsif field.is_a?(Herb::Template::NodeField) -%>
|
|
271
|
+
<%- elsif field.is_a?(Herb::Template::NodeField) || field.is_a?(Herb::Template::BorrowedNodeField) -%>
|
|
213
272
|
if (<%= field.name %> != null) {
|
|
214
273
|
result.addAll(<%= field.name %>.recursiveErrors());
|
|
215
274
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Location, SerializedLocation } from "./location.js"
|
|
2
|
+
import { Position, SerializedPosition } from "./position.js"
|
|
2
3
|
import { Token, SerializedToken } from "./token.js"
|
|
3
4
|
import { Diagnostic, MonacoDiagnostic } from "./diagnostic.js"
|
|
4
5
|
|
|
@@ -64,6 +65,8 @@ export interface Serialized<%= error.name %> {
|
|
|
64
65
|
<%= field.name %>: SerializedToken | null;
|
|
65
66
|
<%- when Herb::Template::TokenTypeField -%>
|
|
66
67
|
<%= field.name %>: string | null;
|
|
68
|
+
<%- when Herb::Template::PositionField -%>
|
|
69
|
+
<%= field.name %>: SerializedPosition;
|
|
67
70
|
<%- else -%>
|
|
68
71
|
<%= field.name %>: any; // <%= field.inspect %>
|
|
69
72
|
<%- end -%>
|
|
@@ -82,6 +85,8 @@ export interface <%= error.name %>Props {
|
|
|
82
85
|
<%= field.name %>: Token | null;
|
|
83
86
|
<%- when Herb::Template::TokenTypeField -%>
|
|
84
87
|
<%= field.name %>: string | null;
|
|
88
|
+
<%- when Herb::Template::PositionField -%>
|
|
89
|
+
<%= field.name %>: Position;
|
|
85
90
|
<%- else -%>
|
|
86
91
|
<%= field.name %>: any; // <%= field.inspect %>
|
|
87
92
|
<%- end -%>
|
|
@@ -97,6 +102,8 @@ export class <%= error.name %> extends HerbError {
|
|
|
97
102
|
readonly <%= field.name %>: Token | null;
|
|
98
103
|
<%- when Herb::Template::TokenTypeField -%>
|
|
99
104
|
readonly <%= field.name %>: string | null;
|
|
105
|
+
<%- when Herb::Template::PositionField -%>
|
|
106
|
+
readonly <%= field.name %>: Position;
|
|
100
107
|
<%- else -%>
|
|
101
108
|
readonly <%= field.name %>: any;
|
|
102
109
|
<%- end -%>
|
|
@@ -113,8 +120,10 @@ export class <%= error.name %> extends HerbError {
|
|
|
113
120
|
<%= field.name %>: data.<%= field.name %>,
|
|
114
121
|
<%- when Herb::Template::TokenField -%>
|
|
115
122
|
<%= field.name %>: data.<%= field.name %> ? Token.from(data.<%= field.name %>) : null,
|
|
123
|
+
<%- when Herb::Template::PositionField -%>
|
|
124
|
+
<%= field.name %>: Position.from(data.<%= field.name %>),
|
|
116
125
|
<%- else -%>
|
|
117
|
-
<% raise "
|
|
126
|
+
<% raise "Unexpected type: #{field.class}" %>
|
|
118
127
|
<%- end -%>
|
|
119
128
|
<%- end -%>
|
|
120
129
|
})
|
|
@@ -138,8 +147,10 @@ export class <%= error.name %> extends HerbError {
|
|
|
138
147
|
<%= field.name %>: this.<%= field.name %>,
|
|
139
148
|
<%- when Herb::Template::TokenField -%>
|
|
140
149
|
<%= field.name %>: this.<%= field.name %> ? this.<%= field.name %>.toJSON() : null,
|
|
150
|
+
<%- when Herb::Template::PositionField -%>
|
|
151
|
+
<%= field.name %>: this.<%= field.name %>.toJSON(),
|
|
141
152
|
<%- else -%>
|
|
142
|
-
<% raise "
|
|
153
|
+
<% raise "Unexpected type: #{field.class}" %>
|
|
143
154
|
<%- end -%>
|
|
144
155
|
<%- end -%>
|
|
145
156
|
};
|
|
@@ -170,8 +181,10 @@ export class <%= error.name %> extends HerbError {
|
|
|
170
181
|
output += `<%= name %>${JSON.stringify(this.<%= field.name %>)}\n`;
|
|
171
182
|
<%- when Herb::Template::TokenField -%>
|
|
172
183
|
output += `<%= name %>${this.<%= field.name %> ? this.<%= field.name %>.treeInspect() : "∅"}\n`;
|
|
184
|
+
<%- when Herb::Template::PositionField -%>
|
|
185
|
+
output += `<%= name %>(${this.<%= field.name %>.line}:${this.<%= field.name %>.column})\n`;
|
|
173
186
|
<%- else -%>
|
|
174
|
-
<% raise "
|
|
187
|
+
<% raise "Unexpected type: #{field.class}" %>
|
|
175
188
|
<%- end -%>
|
|
176
189
|
<%- end -%>
|
|
177
190
|
|
|
@@ -20,7 +20,9 @@ import {
|
|
|
20
20
|
/**
|
|
21
21
|
* Checks if a node is a <%= node.name %>
|
|
22
22
|
*/
|
|
23
|
-
export function is<%= node.name %>(node: Node): node is <%= node.name %> {
|
|
23
|
+
export function is<%= node.name %>(node: Node | null | undefined): node is <%= node.name %> {
|
|
24
|
+
if (!node) return false
|
|
25
|
+
|
|
24
26
|
return node instanceof <%= node.name %> || node.type === "<%= node.type %>" || (node.constructor as any).type === "<%= node.type %>"
|
|
25
27
|
}
|
|
26
28
|
|