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,304 +1,304 @@
|
|
|
1
|
-
// Load a JS file into an OO structure
|
|
2
|
-
// Short term goals:
|
|
3
|
-
|
|
4
|
-
// Answering questions on the level of the file.
|
|
5
|
-
// Questions that are useful for finding out how to link the js files together.
|
|
6
|
-
// Don't want each file to be given it's own scope - want them to share local variable references to the the necessary things.
|
|
7
|
-
// Then those variable names won't be reused in inner scopes unless their replacement there is fine (ie they are otherwise unused).
|
|
8
|
-
|
|
9
|
-
// This will assemble somewhat detailed information about what happens inside a JavaScript file.
|
|
10
|
-
// The aim is to carry out and represent different kinds of analysis, but at the moment focusing of finding features.
|
|
11
|
-
|
|
12
|
-
// Root features
|
|
13
|
-
|
|
14
|
-
// Declaration features
|
|
15
|
-
// Object features
|
|
16
|
-
|
|
17
|
-
// Let's make it so that any node can be tagged as having / representing / being part of a feature of some kind.
|
|
18
|
-
// To begin with focus on what variables are being declared and used.
|
|
19
|
-
|
|
20
|
-
// Will be great to load in a whole load of JSGUI projects in such a way that the system / platform understands the ordering and
|
|
21
|
-
// recomposes them into a flat system where many / all declarations are local rather than using any import
|
|
22
|
-
|
|
23
|
-
// jsgui-lang
|
|
24
|
-
// ----------
|
|
25
|
-
|
|
26
|
-
// Recognise the basic / general signature of the full document.
|
|
27
|
-
// Recognise that the declarations are all within the root
|
|
28
|
-
// Recognise the exports object at the end exports an object that is composed from same-name references to items declared within lang-mini
|
|
29
|
-
// and only items declared within jsgui
|
|
30
|
-
// that it has no external references
|
|
31
|
-
|
|
32
|
-
// JSGUI_JS_File?
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
const JS_File = require('../JS_File/JS_File');
|
|
37
|
-
//const JS_File_Comprehension = require('../JS_File_Comprehension');
|
|
38
|
-
const path = require('path');
|
|
39
|
-
const fs = require('fs');
|
|
40
|
-
const Project = require('../Project');
|
|
41
|
-
const {each} = require('lang-tools');
|
|
42
|
-
|
|
43
|
-
const JS_AST_Node = require('../JS_AST_Node_Extended/JS_AST_Node_Extended');
|
|
44
|
-
|
|
45
|
-
const test_js_file = () => {
|
|
46
|
-
// Worth working with a lower level part of jsgui, such as lang-mini.
|
|
47
|
-
// lang-mini itself has an external reference.
|
|
48
|
-
// stream the file in.
|
|
49
|
-
const lm_path = '../../../../../tools/lang-mini/lang-mini.js'
|
|
50
|
-
const lt_path = '../../../../../tools/lang-tools/lang.js'
|
|
51
|
-
const fnl_path = require.resolve('fnl');
|
|
52
|
-
const filecomp_path = '../JS_File_Comprehension.js';
|
|
53
|
-
const jsfile_path = '../JS_File/JS_File.js';
|
|
54
|
-
const jsbuilder_path = '../JS_Builder.js';
|
|
55
|
-
//const file_path = '../JS_File.js';
|
|
56
|
-
const file_path = fnl_path;
|
|
57
|
-
// path of lang mini...
|
|
58
|
-
|
|
59
|
-
// Write and test a simple and convenient way for analysing JS files and recompiling them.
|
|
60
|
-
// To start with, find the ways to arrange parts of the JS into 'platforms'.
|
|
61
|
-
// How to then build platforms into JS files.
|
|
62
|
-
// Will be about closures and sequences.
|
|
63
|
-
// A lot about unique naming, closures, and getting the sequence of definitions correct.
|
|
64
|
-
// ObjectPattern
|
|
65
|
-
const resolved_path = path.resolve(file_path);
|
|
66
|
-
//console.log('resolved_path', resolved_path);
|
|
67
|
-
|
|
68
|
-
const fstream = fs.createReadStream(resolved_path);
|
|
69
|
-
|
|
70
|
-
const jsf = JS_File.load_from_stream(fstream, file_path);
|
|
71
|
-
jsf.on('ready', () => {
|
|
72
|
-
const {js_ast_node_file} = jsf;
|
|
73
|
-
const body_child_node_identifier_names = [];
|
|
74
|
-
const map_bcnidns = {};
|
|
75
|
-
|
|
76
|
-
// If it can resolve imports to find out more about what keys are there, that would help.
|
|
77
|
-
// May be useful to have a way to indicate that a file / module adds keys to what it imports.
|
|
78
|
-
|
|
79
|
-
// The improved querying system is the next thing.
|
|
80
|
-
// Query must be after index.
|
|
81
|
-
|
|
82
|
-
//console.log('jsf.root.constructor', jsf.root.constructor);
|
|
83
|
-
console.log('jsf.node_root.constructor', jsf.node_root.constructor);
|
|
84
|
-
|
|
85
|
-
const root = jsf.node_root;
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
console.log('root.exports', root.exports);
|
|
90
|
-
console.log('root.exports.exported', root.exports.exported);
|
|
91
|
-
console.log('root.exports.exported.node', root.exports.exported.node);
|
|
92
|
-
console.log('root.exports.exported.node.type', root.exports.exported.node.type);
|
|
93
|
-
//console.log('root.exports.exported.node.source', root.exports.exported.node.source);
|
|
94
|
-
|
|
95
|
-
// then consult the index of root...
|
|
96
|
-
//root.setup_node_index
|
|
97
|
-
|
|
98
|
-
//const exported_decs = root.get_indexed_nodes_by_key('identifiers_by_name', root.exports.exported.node.source.name);
|
|
99
|
-
//console.log('exported_decs', exported_decs);
|
|
100
|
-
|
|
101
|
-
const working_find_exported_keys = () => {
|
|
102
|
-
const root_exported_node = root.exports.exported.node;
|
|
103
|
-
const exports_keys = [];
|
|
104
|
-
const program = root.child_nodes[0];
|
|
105
|
-
const exported_node_name = root.exports.exported.node.name;
|
|
106
|
-
if (exported_node_name === undefined) {
|
|
107
|
-
// some more capabilities will be within ObjectExpression
|
|
108
|
-
|
|
109
|
-
if (root_exported_node.type === 'ObjectExpression') {
|
|
110
|
-
each(root_exported_node.child_nodes, opr => {
|
|
111
|
-
if (opr.child_nodes[0].type === 'StringLiteral') {
|
|
112
|
-
const key = opr.child_nodes[0].source.split('"').join('').split('\'').join('');
|
|
113
|
-
//console.log('key', key);
|
|
114
|
-
exports_keys.push(key);
|
|
115
|
-
} else {
|
|
116
|
-
throw 'NYI';
|
|
117
|
-
}
|
|
118
|
-
//const key = opr.child_nodes[0].
|
|
119
|
-
})
|
|
120
|
-
} else {
|
|
121
|
-
throw 'NYI';
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
//throw 'NYI';
|
|
125
|
-
} else {
|
|
126
|
-
|
|
127
|
-
//console.log('exported_node_name', exported_node_name);
|
|
128
|
-
|
|
129
|
-
let exported_object_declaration_node;
|
|
130
|
-
|
|
131
|
-
const expn = program.query.collect.child.variabledeclaration.exe().query.select.node.by.first.child.first.child.name.exe(exported_node_name);
|
|
132
|
-
// .collect.node.where.first.child.first.child.name ???
|
|
133
|
-
|
|
134
|
-
// select the node with the matching name too...?
|
|
135
|
-
|
|
136
|
-
//console.log('expn', expn);
|
|
137
|
-
//console.log('expn.length', expn.length);
|
|
138
|
-
|
|
139
|
-
if (expn.length === 1) {
|
|
140
|
-
exported_object_declaration_node = expn[0];
|
|
141
|
-
} else {
|
|
142
|
-
throw 'stop';
|
|
143
|
-
}
|
|
144
|
-
//console.log('program.child.count', root.child.count);
|
|
145
|
-
//console.log('root.exports.exported.name', root.exports.exported.name);
|
|
146
|
-
//console.log('root.exports.exported.node.name', root.exports.exported.node.name);
|
|
147
|
-
|
|
148
|
-
console.log('exported_object_declaration_node.signature', exported_object_declaration_node.signature);
|
|
149
|
-
|
|
150
|
-
// Want to algorithmically extract nodes from signatures.
|
|
151
|
-
// Meaning pattern matching, and we specify we want specific nodes from there.
|
|
152
|
-
// Better pattern matching will be one way the foundation side of the code can better support required operations.
|
|
153
|
-
|
|
154
|
-
if (exported_object_declaration_node) {
|
|
155
|
-
//const oe = exported_object_declaration_node.all.find(node => node.type === 'ObjectExpression');
|
|
156
|
-
//console.log('oe', oe);
|
|
157
|
-
//console.log('exported_object_declaration_node.child.count', exported_object_declaration_node.child.count);
|
|
158
|
-
|
|
159
|
-
if (exported_object_declaration_node.child.count === 1) {
|
|
160
|
-
const vdr = exported_object_declaration_node.child_nodes[0];
|
|
161
|
-
//console.log('vdr', vdr);
|
|
162
|
-
//console.log('vdr.child.count', vdr.child.count);
|
|
163
|
-
//console.log('vdr.child_nodes[1].type', vdr.child_nodes[1].type);
|
|
164
|
-
|
|
165
|
-
if (vdr.child_nodes[1].type === 'ObjectExpression') {
|
|
166
|
-
const oe = vdr.child_nodes[1];
|
|
167
|
-
//console.log('oe.child.count', oe.child.count);
|
|
168
|
-
//console.log('oe.child.shared.type', oe.child.shared.type);
|
|
169
|
-
|
|
170
|
-
if (oe.child.shared.type === 'ObjectProperty') {
|
|
171
|
-
oe.query.each.child.exe(cn => {
|
|
172
|
-
//console.log('cn', cn);
|
|
173
|
-
//console.log('cn.source', cn.source);
|
|
174
|
-
|
|
175
|
-
if (cn.child_nodes[0].type === 'StringLiteral') {
|
|
176
|
-
const key = cn.child_nodes[0].source.split('\'').join('').split(',').join(''); // though will change this to .value I expect.
|
|
177
|
-
exports_keys.push(key);
|
|
178
|
-
} else {
|
|
179
|
-
throw 'NYI';
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
})
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
const assignment_source_names = [];
|
|
189
|
-
|
|
190
|
-
if (exports_keys.length === 0) {
|
|
191
|
-
if (root.exports.exported.node.name) {
|
|
192
|
-
program.query.filter.each.child.node.by.signature.exe('ES(CE(ME(ID,ID),ID,ID))', cn => {
|
|
193
|
-
const call_names = cn.query.find.by.type.exe('MemberExpression').query.collect.child.name.exe();
|
|
194
|
-
if (call_names[0] === 'Object' && call_names[1] === 'assign') {
|
|
195
|
-
const target_name = cn.child_nodes[0].child_nodes[1].name;
|
|
196
|
-
if (target_name === root.exports.exported.node.name) {
|
|
197
|
-
//console.log('found assignment to exported object');
|
|
198
|
-
const assignment_source_name = cn.child_nodes[0].child_nodes[2].name;
|
|
199
|
-
//console.log('assignment_source_name', assignment_source_name);
|
|
200
|
-
assignment_source_names.push(assignment_source_name);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
});
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
let assignment_source_declaration_node, assignment_source_name;
|
|
207
|
-
|
|
208
|
-
if (assignment_source_names.length > 0) {
|
|
209
|
-
if (assignment_source_names.length === 1) {
|
|
210
|
-
//console.log('assignment_source_names', assignment_source_names);
|
|
211
|
-
assignment_source_name = assignment_source_names[0];
|
|
212
|
-
|
|
213
|
-
program.query.each.child.declaration.exe(node => {
|
|
214
|
-
//if (node.is_declaration) {
|
|
215
|
-
//console.log('');
|
|
216
|
-
//console.log('node', node);
|
|
217
|
-
//console.log('node.source', node.source);
|
|
218
|
-
|
|
219
|
-
if (node.signature === 'VDn(VDr(ID,CE(ID,SL)))') {
|
|
220
|
-
// var lang_mini = require('lang-tools');
|
|
221
|
-
|
|
222
|
-
// could spot that it's a require call here.
|
|
223
|
-
// basically this code is going to be re-worked in some ways to make use of improved queries.
|
|
224
|
-
// would be nice to get this code down to a much smaller amount of statements where the overall logic is clear in a few lines
|
|
225
|
-
// what the procedure is looking for and returning.
|
|
226
|
-
|
|
227
|
-
const obj_name = node.child_nodes[0].child_nodes[0].name;
|
|
228
|
-
const fn_call_name = node.child_nodes[0].child_nodes[1].child_nodes[0].name;
|
|
229
|
-
if (fn_call_name === 'require') {
|
|
230
|
-
const required_path = node.child_nodes[0].child_nodes[1].child_nodes[1].source.split('\'').join('').split('"').join('').split('`').join('');
|
|
231
|
-
//console.log('required_path', required_path);
|
|
232
|
-
|
|
233
|
-
if (obj_name === assignment_source_name) {
|
|
234
|
-
assignment_source_declaration_node = node;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
// so can find the initial declaration of assignment_source_names
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
if (node.signature === 'VDn(VDr(ID,ME(ID,ID)))') {
|
|
242
|
-
// var Evented_Class = lang_mini.Evented_Class;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
//}
|
|
246
|
-
|
|
247
|
-
})
|
|
248
|
-
|
|
249
|
-
} else {
|
|
250
|
-
throw 'NYI';
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
//console.log('assignment_source_declaration_node', assignment_source_declaration_node);
|
|
254
|
-
|
|
255
|
-
if (assignment_source_declaration_node) {
|
|
256
|
-
// query.callmap.child.signature.exe(map_sigs_handlers, default_handler);
|
|
257
|
-
|
|
258
|
-
program.query.each.child.exe(node => {
|
|
259
|
-
if (node.signature === 'ES(AsE(ME(ID,ID),ID))') {
|
|
260
|
-
const ase = node.child_nodes[0];
|
|
261
|
-
const me = ase.child_nodes[0];
|
|
262
|
-
const obj_name = me.child_nodes[0].name;
|
|
263
|
-
const obj_property_name = me.child_nodes[1].name;
|
|
264
|
-
|
|
265
|
-
//console.log('[obj_name, obj_property_name]', [obj_name, obj_property_name]);
|
|
266
|
-
|
|
267
|
-
if (obj_name === assignment_source_name) {
|
|
268
|
-
// looks like another key.
|
|
269
|
-
exports_keys.push(obj_property_name);
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
//console.log('exports_keys', exports_keys);
|
|
276
|
-
return exports_keys;
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
//const exports_keys = find_exported_keys();
|
|
280
|
-
//console.log('exports_keys', exports_keys);
|
|
281
|
-
|
|
282
|
-
// Hard work now already done for this.
|
|
283
|
-
const try_identifier_mapping = () => {
|
|
284
|
-
jsf.body.node.each.child(cn => {
|
|
285
|
-
const idbns = cn.map.identifier.name;
|
|
286
|
-
//console.log('idbns', idbns);
|
|
287
|
-
//// map_names_to_declarations
|
|
288
|
-
// maps the declaration nodes by the names that occurs in their identifiers.
|
|
289
|
-
|
|
290
|
-
//// .map.declaration.identifier.name
|
|
291
|
-
|
|
292
|
-
const idtodecs = cn.map.declaration.identifier.name;
|
|
293
|
-
//console.log('');
|
|
294
|
-
//console.log('idtodecs.size', idtodecs.size);
|
|
295
|
-
//console.log('idtodecs.keys()', idtodecs.keys());
|
|
296
|
-
});
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
//try_identifier_mapping();
|
|
300
|
-
|
|
301
|
-
});
|
|
302
|
-
}
|
|
303
|
-
|
|
1
|
+
// Load a JS file into an OO structure
|
|
2
|
+
// Short term goals:
|
|
3
|
+
|
|
4
|
+
// Answering questions on the level of the file.
|
|
5
|
+
// Questions that are useful for finding out how to link the js files together.
|
|
6
|
+
// Don't want each file to be given it's own scope - want them to share local variable references to the the necessary things.
|
|
7
|
+
// Then those variable names won't be reused in inner scopes unless their replacement there is fine (ie they are otherwise unused).
|
|
8
|
+
|
|
9
|
+
// This will assemble somewhat detailed information about what happens inside a JavaScript file.
|
|
10
|
+
// The aim is to carry out and represent different kinds of analysis, but at the moment focusing of finding features.
|
|
11
|
+
|
|
12
|
+
// Root features
|
|
13
|
+
|
|
14
|
+
// Declaration features
|
|
15
|
+
// Object features
|
|
16
|
+
|
|
17
|
+
// Let's make it so that any node can be tagged as having / representing / being part of a feature of some kind.
|
|
18
|
+
// To begin with focus on what variables are being declared and used.
|
|
19
|
+
|
|
20
|
+
// Will be great to load in a whole load of JSGUI projects in such a way that the system / platform understands the ordering and
|
|
21
|
+
// recomposes them into a flat system where many / all declarations are local rather than using any import
|
|
22
|
+
|
|
23
|
+
// jsgui-lang
|
|
24
|
+
// ----------
|
|
25
|
+
|
|
26
|
+
// Recognise the basic / general signature of the full document.
|
|
27
|
+
// Recognise that the declarations are all within the root
|
|
28
|
+
// Recognise the exports object at the end exports an object that is composed from same-name references to items declared within lang-mini
|
|
29
|
+
// and only items declared within jsgui
|
|
30
|
+
// that it has no external references
|
|
31
|
+
|
|
32
|
+
// JSGUI_JS_File?
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
const JS_File = require('../JS_File/JS_File');
|
|
37
|
+
//const JS_File_Comprehension = require('../JS_File_Comprehension');
|
|
38
|
+
const path = require('path');
|
|
39
|
+
const fs = require('fs');
|
|
40
|
+
const Project = require('../Project');
|
|
41
|
+
const {each} = require('lang-tools');
|
|
42
|
+
|
|
43
|
+
const JS_AST_Node = require('../JS_AST_Node_Extended/JS_AST_Node_Extended');
|
|
44
|
+
|
|
45
|
+
const test_js_file = () => {
|
|
46
|
+
// Worth working with a lower level part of jsgui, such as lang-mini.
|
|
47
|
+
// lang-mini itself has an external reference.
|
|
48
|
+
// stream the file in.
|
|
49
|
+
const lm_path = '../../../../../tools/lang-mini/lang-mini.js'
|
|
50
|
+
const lt_path = '../../../../../tools/lang-tools/lang.js'
|
|
51
|
+
const fnl_path = require.resolve('fnl');
|
|
52
|
+
const filecomp_path = '../JS_File_Comprehension.js';
|
|
53
|
+
const jsfile_path = '../JS_File/JS_File.js';
|
|
54
|
+
const jsbuilder_path = '../JS_Builder.js';
|
|
55
|
+
//const file_path = '../JS_File.js';
|
|
56
|
+
const file_path = fnl_path;
|
|
57
|
+
// path of lang mini...
|
|
58
|
+
|
|
59
|
+
// Write and test a simple and convenient way for analysing JS files and recompiling them.
|
|
60
|
+
// To start with, find the ways to arrange parts of the JS into 'platforms'.
|
|
61
|
+
// How to then build platforms into JS files.
|
|
62
|
+
// Will be about closures and sequences.
|
|
63
|
+
// A lot about unique naming, closures, and getting the sequence of definitions correct.
|
|
64
|
+
// ObjectPattern
|
|
65
|
+
const resolved_path = path.resolve(file_path);
|
|
66
|
+
//console.log('resolved_path', resolved_path);
|
|
67
|
+
|
|
68
|
+
const fstream = fs.createReadStream(resolved_path);
|
|
69
|
+
|
|
70
|
+
const jsf = JS_File.load_from_stream(fstream, file_path);
|
|
71
|
+
jsf.on('ready', () => {
|
|
72
|
+
const {js_ast_node_file} = jsf;
|
|
73
|
+
const body_child_node_identifier_names = [];
|
|
74
|
+
const map_bcnidns = {};
|
|
75
|
+
|
|
76
|
+
// If it can resolve imports to find out more about what keys are there, that would help.
|
|
77
|
+
// May be useful to have a way to indicate that a file / module adds keys to what it imports.
|
|
78
|
+
|
|
79
|
+
// The improved querying system is the next thing.
|
|
80
|
+
// Query must be after index.
|
|
81
|
+
|
|
82
|
+
//console.log('jsf.root.constructor', jsf.root.constructor);
|
|
83
|
+
console.log('jsf.node_root.constructor', jsf.node_root.constructor);
|
|
84
|
+
|
|
85
|
+
const root = jsf.node_root;
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
console.log('root.exports', root.exports);
|
|
90
|
+
console.log('root.exports.exported', root.exports.exported);
|
|
91
|
+
console.log('root.exports.exported.node', root.exports.exported.node);
|
|
92
|
+
console.log('root.exports.exported.node.type', root.exports.exported.node.type);
|
|
93
|
+
//console.log('root.exports.exported.node.source', root.exports.exported.node.source);
|
|
94
|
+
|
|
95
|
+
// then consult the index of root...
|
|
96
|
+
//root.setup_node_index
|
|
97
|
+
|
|
98
|
+
//const exported_decs = root.get_indexed_nodes_by_key('identifiers_by_name', root.exports.exported.node.source.name);
|
|
99
|
+
//console.log('exported_decs', exported_decs);
|
|
100
|
+
|
|
101
|
+
const working_find_exported_keys = () => {
|
|
102
|
+
const root_exported_node = root.exports.exported.node;
|
|
103
|
+
const exports_keys = [];
|
|
104
|
+
const program = root.child_nodes[0];
|
|
105
|
+
const exported_node_name = root.exports.exported.node.name;
|
|
106
|
+
if (exported_node_name === undefined) {
|
|
107
|
+
// some more capabilities will be within ObjectExpression
|
|
108
|
+
|
|
109
|
+
if (root_exported_node.type === 'ObjectExpression') {
|
|
110
|
+
each(root_exported_node.child_nodes, opr => {
|
|
111
|
+
if (opr.child_nodes[0].type === 'StringLiteral') {
|
|
112
|
+
const key = opr.child_nodes[0].source.split('"').join('').split('\'').join('');
|
|
113
|
+
//console.log('key', key);
|
|
114
|
+
exports_keys.push(key);
|
|
115
|
+
} else {
|
|
116
|
+
throw 'NYI';
|
|
117
|
+
}
|
|
118
|
+
//const key = opr.child_nodes[0].
|
|
119
|
+
})
|
|
120
|
+
} else {
|
|
121
|
+
throw 'NYI';
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
//throw 'NYI';
|
|
125
|
+
} else {
|
|
126
|
+
|
|
127
|
+
//console.log('exported_node_name', exported_node_name);
|
|
128
|
+
|
|
129
|
+
let exported_object_declaration_node;
|
|
130
|
+
|
|
131
|
+
const expn = program.query.collect.child.variabledeclaration.exe().query.select.node.by.first.child.first.child.name.exe(exported_node_name);
|
|
132
|
+
// .collect.node.where.first.child.first.child.name ???
|
|
133
|
+
|
|
134
|
+
// select the node with the matching name too...?
|
|
135
|
+
|
|
136
|
+
//console.log('expn', expn);
|
|
137
|
+
//console.log('expn.length', expn.length);
|
|
138
|
+
|
|
139
|
+
if (expn.length === 1) {
|
|
140
|
+
exported_object_declaration_node = expn[0];
|
|
141
|
+
} else {
|
|
142
|
+
throw 'stop';
|
|
143
|
+
}
|
|
144
|
+
//console.log('program.child.count', root.child.count);
|
|
145
|
+
//console.log('root.exports.exported.name', root.exports.exported.name);
|
|
146
|
+
//console.log('root.exports.exported.node.name', root.exports.exported.node.name);
|
|
147
|
+
|
|
148
|
+
console.log('exported_object_declaration_node.signature', exported_object_declaration_node.signature);
|
|
149
|
+
|
|
150
|
+
// Want to algorithmically extract nodes from signatures.
|
|
151
|
+
// Meaning pattern matching, and we specify we want specific nodes from there.
|
|
152
|
+
// Better pattern matching will be one way the foundation side of the code can better support required operations.
|
|
153
|
+
|
|
154
|
+
if (exported_object_declaration_node) {
|
|
155
|
+
//const oe = exported_object_declaration_node.all.find(node => node.type === 'ObjectExpression');
|
|
156
|
+
//console.log('oe', oe);
|
|
157
|
+
//console.log('exported_object_declaration_node.child.count', exported_object_declaration_node.child.count);
|
|
158
|
+
|
|
159
|
+
if (exported_object_declaration_node.child.count === 1) {
|
|
160
|
+
const vdr = exported_object_declaration_node.child_nodes[0];
|
|
161
|
+
//console.log('vdr', vdr);
|
|
162
|
+
//console.log('vdr.child.count', vdr.child.count);
|
|
163
|
+
//console.log('vdr.child_nodes[1].type', vdr.child_nodes[1].type);
|
|
164
|
+
|
|
165
|
+
if (vdr.child_nodes[1].type === 'ObjectExpression') {
|
|
166
|
+
const oe = vdr.child_nodes[1];
|
|
167
|
+
//console.log('oe.child.count', oe.child.count);
|
|
168
|
+
//console.log('oe.child.shared.type', oe.child.shared.type);
|
|
169
|
+
|
|
170
|
+
if (oe.child.shared.type === 'ObjectProperty') {
|
|
171
|
+
oe.query.each.child.exe(cn => {
|
|
172
|
+
//console.log('cn', cn);
|
|
173
|
+
//console.log('cn.source', cn.source);
|
|
174
|
+
|
|
175
|
+
if (cn.child_nodes[0].type === 'StringLiteral') {
|
|
176
|
+
const key = cn.child_nodes[0].source.split('\'').join('').split(',').join(''); // though will change this to .value I expect.
|
|
177
|
+
exports_keys.push(key);
|
|
178
|
+
} else {
|
|
179
|
+
throw 'NYI';
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
})
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
const assignment_source_names = [];
|
|
189
|
+
|
|
190
|
+
if (exports_keys.length === 0) {
|
|
191
|
+
if (root.exports.exported.node.name) {
|
|
192
|
+
program.query.filter.each.child.node.by.signature.exe('ES(CE(ME(ID,ID),ID,ID))', cn => {
|
|
193
|
+
const call_names = cn.query.find.by.type.exe('MemberExpression').query.collect.child.name.exe();
|
|
194
|
+
if (call_names[0] === 'Object' && call_names[1] === 'assign') {
|
|
195
|
+
const target_name = cn.child_nodes[0].child_nodes[1].name;
|
|
196
|
+
if (target_name === root.exports.exported.node.name) {
|
|
197
|
+
//console.log('found assignment to exported object');
|
|
198
|
+
const assignment_source_name = cn.child_nodes[0].child_nodes[2].name;
|
|
199
|
+
//console.log('assignment_source_name', assignment_source_name);
|
|
200
|
+
assignment_source_names.push(assignment_source_name);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
let assignment_source_declaration_node, assignment_source_name;
|
|
207
|
+
|
|
208
|
+
if (assignment_source_names.length > 0) {
|
|
209
|
+
if (assignment_source_names.length === 1) {
|
|
210
|
+
//console.log('assignment_source_names', assignment_source_names);
|
|
211
|
+
assignment_source_name = assignment_source_names[0];
|
|
212
|
+
|
|
213
|
+
program.query.each.child.declaration.exe(node => {
|
|
214
|
+
//if (node.is_declaration) {
|
|
215
|
+
//console.log('');
|
|
216
|
+
//console.log('node', node);
|
|
217
|
+
//console.log('node.source', node.source);
|
|
218
|
+
|
|
219
|
+
if (node.signature === 'VDn(VDr(ID,CE(ID,SL)))') {
|
|
220
|
+
// var lang_mini = require('lang-tools');
|
|
221
|
+
|
|
222
|
+
// could spot that it's a require call here.
|
|
223
|
+
// basically this code is going to be re-worked in some ways to make use of improved queries.
|
|
224
|
+
// would be nice to get this code down to a much smaller amount of statements where the overall logic is clear in a few lines
|
|
225
|
+
// what the procedure is looking for and returning.
|
|
226
|
+
|
|
227
|
+
const obj_name = node.child_nodes[0].child_nodes[0].name;
|
|
228
|
+
const fn_call_name = node.child_nodes[0].child_nodes[1].child_nodes[0].name;
|
|
229
|
+
if (fn_call_name === 'require') {
|
|
230
|
+
const required_path = node.child_nodes[0].child_nodes[1].child_nodes[1].source.split('\'').join('').split('"').join('').split('`').join('');
|
|
231
|
+
//console.log('required_path', required_path);
|
|
232
|
+
|
|
233
|
+
if (obj_name === assignment_source_name) {
|
|
234
|
+
assignment_source_declaration_node = node;
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
// so can find the initial declaration of assignment_source_names
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
if (node.signature === 'VDn(VDr(ID,ME(ID,ID)))') {
|
|
242
|
+
// var Evented_Class = lang_mini.Evented_Class;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
//}
|
|
246
|
+
|
|
247
|
+
})
|
|
248
|
+
|
|
249
|
+
} else {
|
|
250
|
+
throw 'NYI';
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
//console.log('assignment_source_declaration_node', assignment_source_declaration_node);
|
|
254
|
+
|
|
255
|
+
if (assignment_source_declaration_node) {
|
|
256
|
+
// query.callmap.child.signature.exe(map_sigs_handlers, default_handler);
|
|
257
|
+
|
|
258
|
+
program.query.each.child.exe(node => {
|
|
259
|
+
if (node.signature === 'ES(AsE(ME(ID,ID),ID))') {
|
|
260
|
+
const ase = node.child_nodes[0];
|
|
261
|
+
const me = ase.child_nodes[0];
|
|
262
|
+
const obj_name = me.child_nodes[0].name;
|
|
263
|
+
const obj_property_name = me.child_nodes[1].name;
|
|
264
|
+
|
|
265
|
+
//console.log('[obj_name, obj_property_name]', [obj_name, obj_property_name]);
|
|
266
|
+
|
|
267
|
+
if (obj_name === assignment_source_name) {
|
|
268
|
+
// looks like another key.
|
|
269
|
+
exports_keys.push(obj_property_name);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
//console.log('exports_keys', exports_keys);
|
|
276
|
+
return exports_keys;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
//const exports_keys = find_exported_keys();
|
|
280
|
+
//console.log('exports_keys', exports_keys);
|
|
281
|
+
|
|
282
|
+
// Hard work now already done for this.
|
|
283
|
+
const try_identifier_mapping = () => {
|
|
284
|
+
jsf.body.node.each.child(cn => {
|
|
285
|
+
const idbns = cn.map.identifier.name;
|
|
286
|
+
//console.log('idbns', idbns);
|
|
287
|
+
//// map_names_to_declarations
|
|
288
|
+
// maps the declaration nodes by the names that occurs in their identifiers.
|
|
289
|
+
|
|
290
|
+
//// .map.declaration.identifier.name
|
|
291
|
+
|
|
292
|
+
const idtodecs = cn.map.declaration.identifier.name;
|
|
293
|
+
//console.log('');
|
|
294
|
+
//console.log('idtodecs.size', idtodecs.size);
|
|
295
|
+
//console.log('idtodecs.keys()', idtodecs.keys());
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
//try_identifier_mapping();
|
|
300
|
+
|
|
301
|
+
});
|
|
302
|
+
}
|
|
303
|
+
|
|
304
304
|
test_js_file();
|