jsgui3-server 0.0.121 → 0.0.123
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/.vscode/settings.json +6 -0
- package/README.md +10 -10
- package/controls/Active_HTML_Document.js +116 -116
- package/controls/README.md +7 -7
- package/controls/page/admin.js +74 -74
- package/controls/panel/admin.js +11 -11
- package/examples/_css/basic.css +913 -913
- package/examples/_css/database-control.css +51 -51
- package/examples/_css/jsgui.css +66 -66
- package/examples/_css/multi-layout.css +23 -23
- package/examples/_css/style.css +1669 -1669
- package/examples/_css/top-and-bottom-bars.css +54 -54
- package/examples/box/1) square box/client.js +188 -188
- package/examples/box/1) square box/server.js +112 -112
- package/examples/box/2) twenty square boxes/css flex wrap/client.js +112 -248
- package/examples/box/2) twenty square boxes/css flex wrap/server.js +39 -112
- package/examples/box/3) twenty selectable square boxes/css flex wrap/client.js +129 -0
- package/examples/{controls/15) window, text field → box/3) twenty selectable square boxes/css flex wrap}/server.js +38 -38
- package/examples/boxes/square_boxes.js +45 -48
- package/examples/boxes/square_boxes_client.js +132 -136
- package/examples/client-side-popup-menu-button.html +93 -93
- package/examples/color_palette.js +51 -51
- package/examples/color_palette_client.js +95 -95
- package/examples/controls/1) window/client.js +186 -186
- package/examples/controls/1) window/server.js +117 -117
- package/examples/controls/10) window, mirrored text inputs/client.js +118 -320
- package/examples/controls/10) window, mirrored text inputs/server.js +37 -117
- package/examples/controls/11) window, mirrored text fields/client.js +493 -251
- package/examples/controls/11) window, mirrored text fields/server.js +117 -117
- package/examples/controls/11b) window, shared Data_Object model mirrored text fields/client.js +613 -331
- package/examples/controls/11b) window, shared Data_Object model mirrored text fields/server.js +117 -117
- package/examples/controls/11c) window, shared Data_Value model mirrored text fields/client.js +617 -617
- package/examples/controls/11c) window, shared Data_Value model mirrored text fields/server.js +117 -117
- package/examples/controls/11d) window, shared model mirrored integer text fields/client.js +611 -280
- package/examples/controls/11d) window, shared model mirrored integer text fields/server.js +134 -22
- package/examples/controls/12) window, Select_Options control/client.js +66 -452
- package/examples/controls/12) window, Select_Options control/server.js +19 -117
- package/examples/controls/13) window, Dropdown_Menu control/client.js +66 -0
- package/examples/controls/13) window, Dropdown_Menu control/server.js +20 -0
- package/examples/controls/2) two windows/client.js +193 -193
- package/examples/controls/2) two windows/server.js +113 -113
- package/examples/controls/3) five windows/client.js +217 -217
- package/examples/controls/3) five windows/server.js +116 -115
- package/examples/controls/4) window, tabbed panel/client.js +54 -225
- package/examples/controls/4) window, tabbed panel/server.js +17 -117
- package/examples/controls/5) window, grid/client.js +204 -484
- package/examples/controls/5) window, grid/server.js +117 -119
- package/examples/controls/6) window, color_palette/client.js +68 -204
- package/examples/controls/6) window, color_palette/server.js +117 -117
- package/examples/controls/7) window, month_view/client.js +40 -231
- package/examples/controls/7) window, month_view/server.js +117 -117
- package/examples/controls/8) window, checkbox/client.js +33 -209
- package/examples/controls/8) window, checkbox/server.js +117 -117
- package/examples/controls/9) window, date picker/client.js +76 -303
- package/examples/controls/9) window, date picker/server.js +117 -117
- package/examples/controls/9b) window, shared data.model mirrored date pickers/README.md +51 -0
- package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +83 -398
- package/examples/controls/9b) window, shared data.model mirrored date pickers/server.js +117 -117
- package/examples/controls/__old/_html-server-color-palette.js +114 -114
- package/examples/controls/__old/html-server-combo-box.js +104 -104
- package/examples/controls/__old/html-server-list.js +98 -98
- package/examples/controls/__old/html-server-popup-menu-button.js +114 -114
- package/examples/controls/__old/html-server-start-stop-toggle-button.js +146 -146
- package/examples/controls/__old/scs-arrow-button.js +36 -36
- package/examples/controls/__old/scs-date-picker.js +157 -157
- package/examples/controls/__old/scs-file-browser.js +82 -82
- package/examples/controls/__old/scs-item.js +159 -159
- package/examples/controls/__old/scs-month-arrow-selector.js +126 -126
- package/examples/controls/__old/scs-month-view.js +94 -94
- package/examples/controls/__old/scs-start-stop-toggle-button.js +40 -40
- package/examples/controls/__old/scs-tree.js +49 -49
- package/examples/controls/__old/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/grids/grid_1.js +45 -45
- package/examples/grids/grid_1_client.js +329 -329
- package/examples/html-rendering.js +20 -20
- package/examples/html-server.js +105 -105
- package/examples/introducing jsgui3/server.js +110 -110
- package/examples/mx_display/mx_display_1.js +45 -45
- package/examples/mx_display/mx_display_1_client.js +444 -444
- package/fs2.js +1836 -1836
- package/http/responders/HTTP_Responder.js +15 -15
- package/http/responders/static/Static_Route_HTTP_Responder.js +105 -105
- package/module.js +34 -34
- package/old/_single-control-server.js +418 -418
- package/old/single-control-server.js +368 -368
- package/old/single-page-app.js +131 -131
- package/package.json +42 -42
- package/page-context.js +92 -92
- package/publishers/helpers/assigners/Assigner.js +10 -10
- package/publishers/helpers/assigners/static-compressed-response-buffers/Single_Control_Webpage_Server_Static_Compressed_Response_Buffers_Assigner.js +150 -150
- package/publishers/helpers/assigners/static-headers/Single_Control_Webpage_Server_Static_Headers_Assigner.js +109 -109
- package/publishers/helpers/assigners/static-routes/Single_Control_Webpage_Server_Static_Routes_Assigner.js +91 -91
- package/publishers/helpers/assigners/static-uncompressed-response-buffers/Single_Control_Webpage_Server_Static_Uncompressed_Response_Buffers_Assigner.js +104 -104
- package/publishers/helpers/preparers/static/bundle/Ready_To_Serve_Preparer.js +18 -18
- package/publishers/helpers/preparers/static/bundle/Static_Routes_Responses_Webpage_Bundle_Preparer.js +44 -44
- package/publishers/http-function-publisher.js +212 -212
- package/publishers/http-html-page-publisher.js +5 -5
- package/publishers/http-html-publisher.js +24 -24
- package/publishers/http-js-publisher.js +135 -135
- package/publishers/http-observable-publisher.js +124 -124
- package/publishers/http-publisher.js +53 -53
- package/publishers/http-resource-publisher.js +325 -325
- package/publishers/http-webpage-publisher.js +659 -658
- package/publishers/http-webpageorsite-publisher.js +343 -343
- package/publishers/http-website-publisher.js +640 -640
- package/publishers/notes.md +9 -9
- package/resources/README.md +16 -16
- package/resources/_old_website-javascript-resource.js +994 -994
- package/resources/_old_website-resource.js +507 -507
- package/resources/compile/server-resource-compilation.js +43 -43
- package/resources/data-resource.js +118 -118
- package/resources/fs-resource.js +146 -146
- package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -105
- package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +42 -42
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +41 -41
- package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Node.js +93 -93
- package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +253 -253
- package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +337 -337
- package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +96 -96
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +37 -37
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +72 -72
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +92 -92
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -29
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -116
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +159 -159
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +178 -178
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +87 -87
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +91 -91
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +136 -136
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +73 -73
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +85 -85
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +42 -42
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +40 -40
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +54 -54
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +45 -45
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +343 -343
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +38 -38
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +30 -30
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +28 -28
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +26 -26
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +8 -8
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +21 -21
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +89 -89
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +8 -8
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +27 -27
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +28 -28
- package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +736 -736
- package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +64 -64
- package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +31 -31
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -15
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +305 -305
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +77 -77
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +248 -248
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +138 -138
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -10
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +100 -100
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +60 -60
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +179 -179
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -12
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -35
- package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -11
- package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +31 -31
- package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +37 -37
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -25
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +200 -200
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +43 -43
- package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +76 -76
- package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +227 -227
- package/resources/jsbuilder/JS_AST/query/find_object_keys.js +404 -404
- package/resources/jsbuilder/JS_AST/query/node_queries.js +8 -8
- package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +11 -11
- package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +85 -85
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +123 -123
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +87 -87
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +10 -10
- package/resources/jsbuilder/JS_Builder.js +10 -10
- package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +31 -31
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +25 -25
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +78 -78
- package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +17 -17
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +25 -25
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +8 -8
- package/resources/jsbuilder/JS_File/JS_File.js +12 -12
- package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -202
- package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -175
- package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -81
- package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -86
- package/resources/jsbuilder/JS_File/JS_File_4-Query.js +413 -413
- package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +414 -414
- package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -59
- package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -24
- package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -12
- package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +23 -23
- package/resources/jsbuilder/JS_File/JS_File_Import_References.js +31 -31
- package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -16
- package/resources/jsbuilder/JS_File/JS_Files.js +15 -15
- package/resources/jsbuilder/Module.js +14 -14
- package/resources/jsbuilder/Platform.js +13 -13
- package/resources/jsbuilder/Platforms.js +69 -69
- package/resources/jsbuilder/Project.js +109 -109
- package/resources/jsbuilder/Reference.js +1 -1
- package/resources/jsbuilder/Reference_Sequence.js +16 -16
- package/resources/jsbuilder/Scope.js +29 -29
- package/resources/jsbuilder/Variable_Name_Provider.js +42 -42
- package/resources/jsbuilder/_JS_File.js +225 -225
- package/resources/jsbuilder/ast_query.js +20 -20
- package/resources/jsbuilder/babel/babel_consts.js +162 -162
- package/resources/jsbuilder/babel/babel_node_tools.js +541 -541
- package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +923 -904
- package/resources/jsbuilder/build.js +16 -16
- package/resources/jsbuilder/platform_notes.md +66 -66
- package/resources/jsbuilder/test/test_ast_node.js +381 -381
- package/resources/jsbuilder/test/test_js_file.js +303 -303
- package/resources/jsbuilder/test/test_project.js +157 -157
- package/resources/local-server-info-resource.js +96 -96
- package/resources/notes.txt +10 -10
- package/resources/old/website-image-resource.js +1185 -1185
- package/resources/process-js.js +498 -498
- package/resources/processors/bundlers/bundle.js +29 -29
- package/resources/processors/bundlers/bundler.js +23 -23
- package/resources/processors/bundlers/css-bundler.js +234 -234
- package/resources/processors/bundlers/js/JS_Bundler.js +51 -51
- package/resources/processors/bundlers/js/esbuild/Advanced_JS_Bundler_Using_ESBuild.js +388 -391
- package/resources/processors/bundlers/js/esbuild/Bundler_Using_ESBuild.js +8 -8
- package/resources/processors/bundlers/js/esbuild/Core_JS_Non_Minifying_Bundler_Using_ESBuild.js +188 -188
- package/resources/processors/bundlers/js/esbuild/Core_JS_Single_File_Minifying_Bundler_Using_ESBuild.js +191 -192
- package/resources/processors/bundlers/js/esbuild/_Old_CSS_Extractor.js +239 -239
- package/resources/processors/bundlers/js-bundler.js +263 -263
- package/resources/processors/bundlers/test_ast.js +73 -73
- package/resources/processors/bundlers/webpage-bundler.js +404 -404
- package/resources/processors/bundlers/website-bundler.js +22 -22
- package/resources/processors/extractors/Extractor.js +9 -11
- package/resources/processors/extractors/js/css_and_js/AST_Node/CSS_And_JS_From_JS_String_Using_AST_Node_Extractor.js +239 -254
- package/resources/processors/extractors/js/css_and_js/CSS_And_JS_From_JS_String_Extractor.js +3 -3
- package/resources/processors/extractors/string/Pos_Span_String_Extractor.js +93 -93
- package/resources/server-installed-tools.js +28 -28
- package/resources/server-resource-pool.js +41 -41
- package/resources/website-audio-resource.js +735 -735
- package/resources/website-css-resource.js +411 -411
- package/resources/website-image-resource.js +412 -412
- package/resources/website-javascript-resource-processor.js +908 -908
- package/resources/website-javascript-resource.js +874 -874
- package/resources/website-resource-processor.js +10 -10
- package/resources/website-resource.js +164 -164
- package/resources/website-static-html-resource.js +199 -199
- package/resources/website-template-html-resource.js +231 -231
- package/roadmap.md +75 -75
- package/server.js +609 -573
- package/static-page-context.js +13 -13
- package/website/webpage.js +81 -81
- package/website/website-group.js +15 -15
- package/website/website.js +260 -260
- package/examples/controls/11d) window, shared model mirrored integer text fields/both.js +0 -17
- package/examples/controls/13) window, shared model mirrored lat_long/client.js +0 -933
- package/examples/controls/13) window, shared model mirrored lat_long/server.js +0 -50
- package/examples/controls/14) window, control compositional model/client.js +0 -328
- package/examples/controls/14) window, control compositional model/server.js +0 -118
- package/examples/controls/14a) window, control spec has compositional model/client.js +0 -440
- package/examples/controls/14a) window, control spec has compositional model/server.js +0 -118
- package/examples/controls/15) window, text field/client.js +0 -256
- package/examples/controls/16) Window([Text_Input])/client.js +0 -266
- package/examples/controls/16) Window([Text_Input])/server.js +0 -109
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/client.js +0 -494
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/isomorphic.js +0 -24
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/server.js +0 -73
- package/examples/controls/2b) two window, context menus/client.js +0 -193
- package/examples/controls/2b) two window, context menus/server.js +0 -114
- package/examples/controls/4a) window, tabbed panel with various controls inside/client.js +0 -233
- package/examples/controls/4a) window, tabbed panel with various controls inside/server.js +0 -118
|
@@ -1,405 +1,405 @@
|
|
|
1
|
-
const {each} = require('lang-tools');
|
|
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
|
-
|
|
1
|
+
const {each} = require('lang-tools');
|
|
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
405
|
module.exports = find_object_keys;
|