jsgui3-server 0.0.75 → 0.0.77
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.
- package/examples/client-side-popup-menu-button.html +93 -93
- package/examples/controls/_html-server-color-palette.js +114 -114
- package/examples/controls/html-server-combo-box.js +104 -104
- package/examples/controls/html-server-list.js +98 -98
- package/examples/controls/html-server-popup-menu-button.js +114 -114
- package/examples/controls/html-server-start-stop-toggle-button.js +146 -146
- package/examples/controls/scs-arrow-button.js +36 -36
- package/examples/controls/scs-date-picker.js +157 -157
- package/examples/controls/scs-file-browser.js +82 -82
- package/examples/controls/scs-item.js +159 -159
- package/examples/controls/scs-month-arrow-selector.js +126 -126
- package/examples/controls/scs-month-view.js +95 -95
- package/examples/controls/scs-start-stop-toggle-button.js +40 -40
- package/examples/controls/scs-tree.js +49 -49
- package/examples/controls/scs-year-arrow-selector.js +127 -127
- package/examples/demos/date-picker.js +119 -119
- package/examples/demos/explain-encapsulation.js +9 -9
- package/examples/demos/resizing.js +35 -35
- package/examples/demos/server_time.js +6 -6
- package/examples/demos/square_box.js +324 -324
- package/examples/html-rendering.js +20 -20
- package/examples/html-server.js +100 -100
- package/fs2.js +1836 -1836
- package/module.js +21 -21
- package/old/single-control-server.js +418 -418
- package/package.json +44 -42
- package/publishing/function-publisher.js +202 -202
- package/publishing/notes.md +5 -5
- package/publishing/observable-publisher.js +118 -118
- package/publishing/resource-publisher.js +306 -306
- package/resources/data-resource.js +104 -104
- package/resources/fs-resource.js +148 -148
- package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -0
- package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +43 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +62 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +42 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +62 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node.js +94 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +228 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +338 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +40 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +97 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +38 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +62 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +44 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +73 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +93 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +160 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +179 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +88 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +92 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +137 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +74 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +40 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +86 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +43 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +41 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +55 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +46 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +344 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +39 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +31 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +29 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +27 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +9 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +44 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +22 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +87 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +9 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +28 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +29 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +737 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +65 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +32 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +306 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +78 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +249 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +139 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +101 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +61 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +180 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +32 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +38 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +40 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +201 -0
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +44 -0
- package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +77 -0
- package/resources/jsbuilder/JS_AST/query/all.js +0 -0
- package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +228 -0
- package/resources/jsbuilder/JS_AST/query/find_object_keys.js +405 -0
- package/resources/jsbuilder/JS_AST/query/node_queries.js +9 -0
- package/resources/jsbuilder/JS_AST/query/root_queries.js +0 -0
- package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +12 -0
- package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +86 -0
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +124 -0
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +88 -0
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +11 -0
- package/resources/jsbuilder/JS_Builder.js +10 -36
- package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +32 -0
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +26 -0
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +79 -0
- package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +18 -0
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +26 -0
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +9 -0
- package/resources/jsbuilder/JS_File/JS_File.js +12 -0
- package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -0
- package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -0
- package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -0
- package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -0
- package/resources/jsbuilder/JS_File/JS_File_4-Query.js +414 -0
- package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +415 -0
- package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -0
- package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -0
- package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -0
- package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +24 -0
- package/resources/jsbuilder/JS_File/JS_File_Import_References.js +32 -0
- package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -0
- package/resources/jsbuilder/JS_File/JS_Files.js +16 -0
- package/resources/jsbuilder/Module.js +14 -0
- package/resources/jsbuilder/Platform.js +13 -53
- package/resources/jsbuilder/Platforms.js +69 -15
- package/resources/jsbuilder/Project.js +109 -0
- package/resources/jsbuilder/Reference.js +1 -1
- package/resources/jsbuilder/Reference_Sequence.js +16 -7
- package/resources/jsbuilder/Scope.js +30 -0
- package/resources/jsbuilder/Variable_Name_Provider.js +43 -0
- package/resources/jsbuilder/_JS_File.js +226 -0
- package/resources/jsbuilder/ast_query.js +21 -0
- package/resources/jsbuilder/babel/babel_consts.js +150 -0
- package/resources/jsbuilder/babel/babel_node_tools.js +542 -0
- package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +604 -0
- package/resources/jsbuilder/build.js +16 -0
- package/resources/jsbuilder/platform_notes.md +66 -0
- package/resources/jsbuilder/test/test_ast_node.js +451 -0
- package/resources/jsbuilder/test/test_js_file.js +303 -11
- package/resources/jsbuilder/test/test_project.js +157 -0
- package/resources/local-server-info-resource.js +78 -78
- package/resources/process-js.js +537 -537
- package/resources/server-resource-pool.js +84 -84
- package/resources/website-css-resource.js +411 -411
- package/resources/website-javascript-resource.js +761 -751
- package/resources/website-resource.js +390 -390
- package/resources/website-static-html-resource.js +196 -196
- package/server.js +170 -170
- package/single-control-server.js +398 -398
- package/single-page-app.js +129 -129
- package/resources/jsbuilder/Declaration.js +0 -15
- package/resources/jsbuilder/Declaration_Sequence.js +0 -15
- package/resources/jsbuilder/JS_File.js +0 -77
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
const {each} = require('lang-mini');
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
// Doesn't use the index - at least not yet.
|
|
5
|
+
// Maybe the indexing system of nodes will be of use here.
|
|
6
|
+
|
|
7
|
+
const check_object_declaration_by_name = (node, name) => {
|
|
8
|
+
// not deep
|
|
9
|
+
let res = false;
|
|
10
|
+
if (node.is_declaration) {
|
|
11
|
+
const keys = node.declaration.keys;
|
|
12
|
+
//console.log('keys', keys);
|
|
13
|
+
|
|
14
|
+
if (keys.length === 1) {
|
|
15
|
+
const key = keys[0];
|
|
16
|
+
if (key === name) {
|
|
17
|
+
res = node;
|
|
18
|
+
}
|
|
19
|
+
} else {
|
|
20
|
+
throw 'NYI';
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
//throw 'NYI'
|
|
24
|
+
} else {
|
|
25
|
+
// do nothing
|
|
26
|
+
}
|
|
27
|
+
return res;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const find_object_declaration_by_name = (node_operation_root, name) => {
|
|
31
|
+
|
|
32
|
+
let res;
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
each(node_operation_root.child_nodes, (cn, idx, stop) => {
|
|
36
|
+
const checked_for_declaration_name = check_object_declaration_by_name(cn, name);
|
|
37
|
+
//console.log('checked_for_declaration_name', checked_for_declaration_name);
|
|
38
|
+
|
|
39
|
+
if (checked_for_declaration_name) {
|
|
40
|
+
res = checked_for_declaration_name;
|
|
41
|
+
stop();
|
|
42
|
+
}
|
|
43
|
+
})
|
|
44
|
+
|
|
45
|
+
//throw 'stop';
|
|
46
|
+
return res;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
const find_program_node = node => {
|
|
50
|
+
if (node.type === 'Program') return node;
|
|
51
|
+
if (node.parent_node) {
|
|
52
|
+
return find_program_node(node.parent_node);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
// So far set up to run on the program as a whole.
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
// An improved query system could better specify what's being looked for.
|
|
62
|
+
// Maybe extending the system from bottom-up to be able to .query an object's keys makes sense.
|
|
63
|
+
|
|
64
|
+
// Also, should focus more on the inner keys properties?
|
|
65
|
+
// Or just reading the keys from the specifically relevant AST nodes.
|
|
66
|
+
// And improved query would help to find them better.
|
|
67
|
+
|
|
68
|
+
// find_object_keys looks a bit confused in what it's looking at and doing.
|
|
69
|
+
// possibly smaller functions would work better?
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
const find_object_keys = (node) => {
|
|
78
|
+
|
|
79
|
+
// find the program node to start with.
|
|
80
|
+
// will search that only in this function.
|
|
81
|
+
// may need to rename this fn, but searching the program node is what this fn is about.
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
//const keys = [];
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
//console.log('');
|
|
91
|
+
//console.log('find_object_keys node', node);
|
|
92
|
+
//console.log('find_object_keys node.source', node.source);
|
|
93
|
+
//console.log('find_object_keys node.name', node.name);
|
|
94
|
+
//console.log('find_object_keys node.path', node.path);
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
let exported_obj_name = node.name;
|
|
101
|
+
|
|
102
|
+
console.log('exported_obj_name', exported_obj_name);
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
//throw 'stop';
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
if (!exported_obj_name) {
|
|
110
|
+
let name;
|
|
111
|
+
node.deep_iterate((n, i, other, stop) => {
|
|
112
|
+
//console.log('n', n);
|
|
113
|
+
if (n.is_identifier) {
|
|
114
|
+
if (!name) name = n.name;
|
|
115
|
+
//console.log('name', name);
|
|
116
|
+
stop(); //does not seem to work
|
|
117
|
+
}
|
|
118
|
+
})
|
|
119
|
+
if (name) {
|
|
120
|
+
exported_obj_name = name;
|
|
121
|
+
//console.log('exported_obj_name', exported_obj_name);
|
|
122
|
+
//throw 'stop';
|
|
123
|
+
} else {
|
|
124
|
+
throw 'stop';
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
//console.log('node.source', node.source);
|
|
132
|
+
// The declaration node for the object.
|
|
133
|
+
|
|
134
|
+
//console.log('node.parent.node', node.parent.node);
|
|
135
|
+
//console.log('node.gparent.node', node.gparent.node);
|
|
136
|
+
//console.log('node.ggparent.node', node.ggparent.node);
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
// not necessarily....
|
|
140
|
+
const module_exports_statement = node.gparent.node;
|
|
141
|
+
console.log('module_exports_statement', module_exports_statement);
|
|
142
|
+
console.log('module_exports_statement.index', module_exports_statement.index);
|
|
143
|
+
|
|
144
|
+
|
|
145
|
+
|
|
146
|
+
//const program = module_exports_statement.parent.node;
|
|
147
|
+
const program = find_program_node(node);
|
|
148
|
+
|
|
149
|
+
const res = [];
|
|
150
|
+
|
|
151
|
+
const handle_key = key => res.push(key);
|
|
152
|
+
|
|
153
|
+
console.log('module_exports_statement', module_exports_statement);
|
|
154
|
+
//throw 'stop';
|
|
155
|
+
|
|
156
|
+
if (program.type === 'Program') {
|
|
157
|
+
|
|
158
|
+
const prev_nodes = program.child_nodes.slice(0, module_exports_statement.index);
|
|
159
|
+
let exported_object_declaration_node;
|
|
160
|
+
let exported_object_further_assignment_object_name;
|
|
161
|
+
let exported_object_further_assignment_object_declaration;
|
|
162
|
+
|
|
163
|
+
console.log('prev_nodes.length', prev_nodes.length);
|
|
164
|
+
//throw 'stop';
|
|
165
|
+
|
|
166
|
+
each(prev_nodes, prev_node => {
|
|
167
|
+
if (prev_node.is_declaration) {
|
|
168
|
+
//console.log('prev_node.declaration.keys', prev_node.declaration.keys);
|
|
169
|
+
|
|
170
|
+
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
if (prev_node.declaration.keys.length === 1) {
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
if (prev_node.declaration.keys[0] === exported_obj_name) {
|
|
178
|
+
exported_object_declaration_node = prev_node;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
} else {
|
|
182
|
+
|
|
183
|
+
// do any of these keys contain the name we are looking for?
|
|
184
|
+
|
|
185
|
+
if (prev_node.declaration.keys.includes(exported_obj_name)) {
|
|
186
|
+
throw 'NYI';
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
//console.log('prev_node', prev_node);
|
|
190
|
+
//console.log('prev_node.source', prev_node.source);
|
|
191
|
+
//throw 'NYI';
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
} else {
|
|
195
|
+
//console.log('');
|
|
196
|
+
//console.log('prev_node', prev_node);
|
|
197
|
+
//console.log('prev_node.source', prev_node.source);
|
|
198
|
+
//console.log('prev_node.signature', prev_node.signature);
|
|
199
|
+
|
|
200
|
+
// also need to check for
|
|
201
|
+
|
|
202
|
+
if (prev_node.signature === 'ES(AsE(ME(ID,ID),ID))') {
|
|
203
|
+
//console.log('exported_obj_name', exported_obj_name);
|
|
204
|
+
// can we do collect identifiers?
|
|
205
|
+
const ids = [];
|
|
206
|
+
prev_node.deep_iterate(node => {
|
|
207
|
+
if (node.is_identifier) ids.push(node);
|
|
208
|
+
});
|
|
209
|
+
//console.log('ids', ids);
|
|
210
|
+
|
|
211
|
+
const [obj_name, prop_name, value_name] = ids.map(id => id.name);
|
|
212
|
+
//console.log('[obj_name, prop_name, value_name]', [obj_name, prop_name, value_name]);
|
|
213
|
+
|
|
214
|
+
if (obj_name === exported_obj_name) {
|
|
215
|
+
|
|
216
|
+
|
|
217
|
+
//console.log('prop_name', prop_name);
|
|
218
|
+
|
|
219
|
+
handle_key(prop_name);
|
|
220
|
+
|
|
221
|
+
//throw 'NYI';
|
|
222
|
+
}
|
|
223
|
+
//throw 'NYI';
|
|
224
|
+
}
|
|
225
|
+
//
|
|
226
|
+
if (prev_node.signature === 'ES(CE(ME(ID,ID),ID,ID))') { // object.assign
|
|
227
|
+
// eg Object.assign(ec, lang_mini);
|
|
228
|
+
|
|
229
|
+
const me = prev_node.child_nodes[0].child_nodes[0];
|
|
230
|
+
//console.log('me', me);
|
|
231
|
+
const [id1, id2] = me.child_nodes;
|
|
232
|
+
const [name1, name2] = [id1.name, id2.name];
|
|
233
|
+
//console.log('[name1, name2]', [name1, name2]);
|
|
234
|
+
|
|
235
|
+
if (name1 === 'Object' && name2 === 'assign') {
|
|
236
|
+
const assign_target = prev_node.child_nodes[0].child_nodes[1];
|
|
237
|
+
//console.log('assign_target.name', assign_target.name);
|
|
238
|
+
|
|
239
|
+
if (assign_target.name === exported_obj_name) {
|
|
240
|
+
// have found a point where object.assign is used to assign properties to the value that is being exported.
|
|
241
|
+
|
|
242
|
+
const assignment_object = prev_node.child_nodes[0].child_nodes[2];
|
|
243
|
+
|
|
244
|
+
|
|
245
|
+
//console.log('assignment_object.source', assignment_object.source);
|
|
246
|
+
|
|
247
|
+
exported_object_further_assignment_object_name = assignment_object.name;
|
|
248
|
+
|
|
249
|
+
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
|
|
257
|
+
|
|
258
|
+
// Could be assigning something to the object we want?
|
|
259
|
+
|
|
260
|
+
// Want to be on the lookout for Object.assign(exported_object, ...)
|
|
261
|
+
|
|
262
|
+
|
|
263
|
+
|
|
264
|
+
// Does it assign anything (any keys?) to the exported object?
|
|
265
|
+
//throw 'NYI';
|
|
266
|
+
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
|
|
271
|
+
console.log('exported_object_declaration_node', exported_object_declaration_node);
|
|
272
|
+
|
|
273
|
+
//const keys_eodn = find_object_keys(exported_object_declaration_node);
|
|
274
|
+
//console.log('keys_eodn', keys_eodn);
|
|
275
|
+
if (exported_object_declaration_node) console.log('exported_object_declaration_node.declaration.keys', exported_object_declaration_node.declaration.keys);
|
|
276
|
+
|
|
277
|
+
// .internal_keys
|
|
278
|
+
// .
|
|
279
|
+
|
|
280
|
+
console.log('exported_object_further_assignment_object_name', exported_object_further_assignment_object_name);
|
|
281
|
+
//throw 'stop';
|
|
282
|
+
|
|
283
|
+
if (exported_object_further_assignment_object_name && !exported_object_further_assignment_object_declaration) {
|
|
284
|
+
//console.log('exported_object_further_assignment_object_name', exported_object_further_assignment_object_name);
|
|
285
|
+
|
|
286
|
+
// find the node where that exported_object_further_assignment_object was defined.
|
|
287
|
+
|
|
288
|
+
exported_object_further_assignment_object_declaration = find_object_declaration_by_name(program, exported_object_further_assignment_object_name);
|
|
289
|
+
//console.log('exported_object_further_assignment_object_declaration', exported_object_further_assignment_object_declaration);
|
|
290
|
+
|
|
291
|
+
|
|
292
|
+
// The more advanced query system could be really good for looking up these keys.
|
|
293
|
+
// But it's worth seeing what can be found without it for the moment.
|
|
294
|
+
|
|
295
|
+
|
|
296
|
+
|
|
297
|
+
|
|
298
|
+
// Want to find out what is being assigned to the object with that name.
|
|
299
|
+
|
|
300
|
+
// .parent.node.select.child
|
|
301
|
+
|
|
302
|
+
// .parent.filter.child.declaration(declaration => declaration.has_name(exported_object_further_assignment_object_name))
|
|
303
|
+
|
|
304
|
+
// Seems like we need a bit more on the querying, can run tests that just query single nodes for a bit longer.
|
|
305
|
+
|
|
306
|
+
// .parent.find.child.declaration.keys
|
|
307
|
+
|
|
308
|
+
// .parent.collect.child.declaration.keys
|
|
309
|
+
// can have some nice syntax, and tests.
|
|
310
|
+
// worth writing out pieces of nice syntax, and working on the implementation.
|
|
311
|
+
|
|
312
|
+
// Probably worth making a Query class that gets returned a lot.
|
|
313
|
+
|
|
314
|
+
// Or maybe work on a new API, .query
|
|
315
|
+
// and then when .query is working well, see if we can set up shortcuts to it.
|
|
316
|
+
|
|
317
|
+
// .query looks like a good place to set up queries and specifically use a query object abstraction.
|
|
318
|
+
// this will just be for describing the queries, when we have the query description, other code would be used to execute that query.
|
|
319
|
+
|
|
320
|
+
// const pn = node.parent.node;
|
|
321
|
+
// const q = pn.query.collect.child.declaration.keys;
|
|
322
|
+
// const qres = pn.exequery(q);
|
|
323
|
+
|
|
324
|
+
// If all these things happen within the initial query object, and are properties of it, then it can make a consistent API.
|
|
325
|
+
// Everything returned will be a query object.
|
|
326
|
+
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
|
|
330
|
+
|
|
331
|
+
|
|
332
|
+
|
|
333
|
+
|
|
334
|
+
|
|
335
|
+
// Lookup the history of that object...
|
|
336
|
+
|
|
337
|
+
// lookup_object_keys
|
|
338
|
+
// seems like a possible piece of external functionality on top of the main class structure.
|
|
339
|
+
// as in, makes use of it, but is a query that is more application-level, and defined in a way in which it can be self-contained.
|
|
340
|
+
// it's not so formulaic, so it seems. The query directory could be put to use now.
|
|
341
|
+
|
|
342
|
+
// see what assignments are made to lang_mini
|
|
343
|
+
|
|
344
|
+
// find_object_keys_by_name
|
|
345
|
+
// only within the root makes sense.
|
|
346
|
+
|
|
347
|
+
// find_object_assignments_made
|
|
348
|
+
|
|
349
|
+
// and a recursive version?
|
|
350
|
+
// could see about that later on, but querying / reading what gets exported from various jsgui files such as lang.js will be what we need for this stage of the building.
|
|
351
|
+
|
|
352
|
+
// for the moment, want good queries on the files as a preparatory stage for the transformations and building.
|
|
353
|
+
|
|
354
|
+
|
|
355
|
+
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
|
|
359
|
+
|
|
360
|
+
|
|
361
|
+
//console.trace();
|
|
362
|
+
//throw 'NYI';
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
if (exported_object_further_assignment_object_declaration) {
|
|
366
|
+
// go looking at the keys that get assigned to that.
|
|
367
|
+
|
|
368
|
+
|
|
369
|
+
//console.log('exported_object_further_assignment_object_declaration', exported_object_further_assignment_object_declaration);
|
|
370
|
+
//console.log('exported_object_further_assignment_object_declaration.parent.node', exported_object_further_assignment_object_declaration.parent.node);
|
|
371
|
+
//console.log('exported_object_further_assignment_object_declaration.gparent.node', exported_object_further_assignment_object_declaration.gparent.node);
|
|
372
|
+
const eofad_keys = find_object_keys(exported_object_further_assignment_object_declaration);
|
|
373
|
+
each(eofad_keys, key => res.push(key));
|
|
374
|
+
|
|
375
|
+
|
|
376
|
+
|
|
377
|
+
//console.log('eofad_keys', eofad_keys);
|
|
378
|
+
//throw 'NYI';
|
|
379
|
+
|
|
380
|
+
//
|
|
381
|
+
//
|
|
382
|
+
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
} else {
|
|
386
|
+
throw 'stop';
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
// then look through previous siblings for declarations
|
|
390
|
+
|
|
391
|
+
//console.log('node', node);
|
|
392
|
+
//console.log('node.source', node.source);
|
|
393
|
+
|
|
394
|
+
|
|
395
|
+
//console.log('exported_obj_name', exported_obj_name);
|
|
396
|
+
|
|
397
|
+
|
|
398
|
+
return res;
|
|
399
|
+
|
|
400
|
+
//throw 'NYI';
|
|
401
|
+
|
|
402
|
+
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
module.exports = find_object_keys;
|
|
File without changes
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/*
|
|
2
|
+
|
|
3
|
+
Identify what features a module has
|
|
4
|
+
|
|
5
|
+
See if there are places where specific exctraction functions can run to get specific information.
|
|
6
|
+
|
|
7
|
+
This root node query can identify things to be queried lower down.
|
|
8
|
+
|
|
9
|
+
Some queries used here would be useful in other places, not just the root.
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
*/
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
const JS_AST_Node = require('../JS_AST/JS_AST_Node');
|
|
2
|
+
const JS_AST_Node_Babel = require('../JS_AST/JS_AST_Node');
|
|
3
|
+
|
|
4
|
+
class JSGUI_Singular_Declaration extends JS_AST_Node {
|
|
5
|
+
constructor(spec) {
|
|
6
|
+
|
|
7
|
+
// Will be one of the simpler features to recognise.
|
|
8
|
+
|
|
9
|
+
// A declaration where only one thing gets declared.
|
|
10
|
+
// Makes sense as an abstraction to use.
|
|
11
|
+
// Declarations may wind up joined together as output.
|
|
12
|
+
// They also may be taken apart as input.
|
|
13
|
+
|
|
14
|
+
// Lots of singular declarations can be extracted from lang-mini
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
// Signature of:
|
|
22
|
+
// VDn(VDr(ID,x))
|
|
23
|
+
// x means that anything inside can change, ie it's an expression of some sort.
|
|
24
|
+
|
|
25
|
+
// how about .is_expression property?
|
|
26
|
+
// would depend on the type I expect.
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
// These could be found and extracted from JS files.
|
|
31
|
+
// Maybe Structure_Pattern would be better.
|
|
32
|
+
// Then extract data from specific and easy to reference parts of it.
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
// Won't be compatable with all AST nodes.
|
|
37
|
+
|
|
38
|
+
// If it's with an incompatable node, switch the JSGUI declaration specific functionality off.
|
|
39
|
+
|
|
40
|
+
// Needs to have a single item being declared...?
|
|
41
|
+
// Though how about arrays.
|
|
42
|
+
|
|
43
|
+
// Some relatively simple rules and queries to see if something is a declaration.
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
super(spec);
|
|
52
|
+
|
|
53
|
+
// Name property will work differently...?
|
|
54
|
+
|
|
55
|
+
Object.defineProperty(this, 'name', {
|
|
56
|
+
get() { return 'JV'; },
|
|
57
|
+
//set(newValue) { bValue = newValue; },
|
|
58
|
+
enumerable: true,
|
|
59
|
+
configurable: false
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// Would be useful to get right elsewhere.
|
|
65
|
+
// Or outputting what would go into the constructor of the next one.
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
// Method to see if a JS_AST_Node is JSGUI_Declaration compatable.
|
|
69
|
+
// Declatations will essentially be for a single item.
|
|
70
|
+
// eg lang-mini will contain lots of declarations.
|
|
71
|
+
|
|
72
|
+
// Declarations will need to be in the right order in many situations.
|
|
73
|
+
// There will be a lot more in local scope, more things brought local within a large application.
|
|
74
|
+
// Classes that do very different things. Maybe even with the same original names, but will have to be renamed to different things if in the same scope.
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
JSGUI_Singular_Declaration.from_js_ast_node = (js_ast_node) => {
|
|
80
|
+
// Would be in a different context / no context when it gets made.
|
|
81
|
+
|
|
82
|
+
throw 'NYI';
|
|
83
|
+
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
module.exports = JSGUI_Singular_Declaration;
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
//const JS_AST_Node = require('../JS_AST/JS_AST_Node');
|
|
2
|
+
const {each} = require('lang-mini');
|
|
3
|
+
const JS_AST_Node_Extended_Core = require('./JS_AST_Node_Extended_0-Core');
|
|
4
|
+
|
|
5
|
+
class JS_AST_Node_Declaration extends JS_AST_Node_Extended_Core {
|
|
6
|
+
constructor(spec) {
|
|
7
|
+
super(spec);
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
// the type must be declaration.
|
|
11
|
+
|
|
12
|
+
if (!this.is_declaration) {
|
|
13
|
+
throw 'stop';
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// Have tools for extracting specific information from declarations.
|
|
17
|
+
// Possibly for making a compressed version.
|
|
18
|
+
|
|
19
|
+
// get own names.
|
|
20
|
+
|
|
21
|
+
const get_declared_names = () => {
|
|
22
|
+
if (this.is_declaration === true) {
|
|
23
|
+
const cns = this.child_nodes;
|
|
24
|
+
const map_names = {}, arr_names = [];
|
|
25
|
+
const handle_name = (name) => {
|
|
26
|
+
if (!map_names[name]) {
|
|
27
|
+
map_names[name] = true;
|
|
28
|
+
arr_names.push(name);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (this.type === 'VariableDeclaration') {
|
|
33
|
+
|
|
34
|
+
each (cns, cn => {
|
|
35
|
+
//const tcn = ;
|
|
36
|
+
if (cn.type === 'VariableDeclarator') {
|
|
37
|
+
const gfc = cn.child_nodes[0];
|
|
38
|
+
console.log('gfc', gfc);
|
|
39
|
+
if (gfc.type === 'Identifier') {
|
|
40
|
+
console.log('gfc.name', gfc.name);
|
|
41
|
+
handle_name(gfc.name);
|
|
42
|
+
} else if (gfc.type === 'ArrayPattern') {
|
|
43
|
+
// each child, should be an identifier
|
|
44
|
+
each (gfc.child_nodes, ggc => {
|
|
45
|
+
if (ggc.type === 'Identifier') {
|
|
46
|
+
//console.log('ggc.name', ggc.name);
|
|
47
|
+
handle_name(ggc.name);
|
|
48
|
+
} else {
|
|
49
|
+
throw 'stop';
|
|
50
|
+
}
|
|
51
|
+
})
|
|
52
|
+
} else {
|
|
53
|
+
throw 'stop';
|
|
54
|
+
}
|
|
55
|
+
} else {
|
|
56
|
+
|
|
57
|
+
console.log('cn.type', cn.type);
|
|
58
|
+
console.log('this', this);
|
|
59
|
+
throw 'stop';
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
}
|
|
66
|
+
})
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
} else {
|
|
70
|
+
//console.log('this.type', this.type);
|
|
71
|
+
//console.log('this', this);
|
|
72
|
+
|
|
73
|
+
if (this.type === 'ClassDeclaration') {
|
|
74
|
+
const dec_id = this.child_nodes[0];
|
|
75
|
+
//console.log('dec_id', dec_id);
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
if (dec_id.type === 'Identifier') {
|
|
79
|
+
//console.log('dec_id.name', dec_id.name);
|
|
80
|
+
handle_name(dec_id.name);
|
|
81
|
+
} else {
|
|
82
|
+
throw 'stop';
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
} else {
|
|
86
|
+
throw 'stop';
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
//if (this.type === 'ClassDeclaration') {
|
|
91
|
+
// const gnc0 = this.child_nodes[0];
|
|
92
|
+
// console.log('gcn0', gcn0);
|
|
93
|
+
//} else {
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
// }
|
|
100
|
+
//throw 'stop';
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
//console.log('arr_names', arr_names);
|
|
105
|
+
return arr_names;
|
|
106
|
+
} else {
|
|
107
|
+
throw 'stop';
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
this.get_declared_names = get_declared_names;
|
|
112
|
+
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
/*
|
|
117
|
+
JS_AST_Node_Declaration.from_js_ast_node = (js_ast_node) => {
|
|
118
|
+
// Would be in a different context / no context when it gets made.
|
|
119
|
+
|
|
120
|
+
throw 'NYI';
|
|
121
|
+
|
|
122
|
+
}
|
|
123
|
+
*/
|
|
124
|
+
module.exports = JS_AST_Node_Declaration;
|