jsgui3-server 0.0.121 → 0.0.122
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 +248 -248
- package/examples/box/2) twenty square boxes/css flex wrap/server.js +112 -112
- 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 +320 -320
- package/examples/controls/10) window, mirrored text inputs/server.js +117 -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 +435 -452
- package/examples/controls/12) window, Select_Options control/server.js +117 -117
- 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 +204 -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 +247 -209
- package/examples/controls/8) window, checkbox/server.js +117 -117
- package/examples/controls/9) window, date picker/client.js +303 -303
- package/examples/controls/9) window, date picker/server.js +117 -117
- package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +398 -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/15) window, text field/server.js +0 -39
- 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,414 +1,414 @@
|
|
|
1
|
-
const {each, tof} = require('lang-tools');
|
|
2
|
-
const JS_File_JS_AST_Node = require('./JS_File_3-JS_AST_Node');
|
|
3
|
-
|
|
4
|
-
const JS_File_Import_References = require('./JS_File_Import_References');
|
|
5
|
-
|
|
6
|
-
// Index prior to this?
|
|
7
|
-
// Or just within JS_File?
|
|
8
|
-
// Would actually make sense here, as some AST trees could be long and worth working on in some ways, or reading info from.
|
|
9
|
-
|
|
10
|
-
// identifier_name_occurrance_index
|
|
11
|
-
// and provides a reference to each place that identifier name has been used within the scope.
|
|
12
|
-
// then building up an identifier name occurrance index could be done recursively where each node gets its child nodes to calculate their occurrance indexes first.
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
//const { default: JS_File_JS_AST_Node } = require('./JS_File_2-JS_AST_Node');
|
|
20
|
-
//const { default: Import_References } = require('./JS_File_Import_References');
|
|
21
|
-
// Will extract relevant AST code functionality. Files often import things at the beginning, then have declarations, then export what was declared at the end.
|
|
22
|
-
|
|
23
|
-
// Understanding the import declarations so they could be localised.
|
|
24
|
-
// So we can refer to the ast of them, because we have recognised them elsewhere.
|
|
25
|
-
|
|
26
|
-
// Can build the functions into a js file.
|
|
27
|
-
// Later on - renaming local variables within a scope.
|
|
28
|
-
|
|
29
|
-
// JS_File_Writable too...
|
|
30
|
-
// .imports = ... or requires
|
|
31
|
-
// .add_platform?
|
|
32
|
-
|
|
33
|
-
// Or better to create the platform objects out of the functions which have been comprehended from various files.
|
|
34
|
-
// JS_File_Platform?
|
|
35
|
-
// This will be more about understanding the js file. Basic structure will have already been obtained.
|
|
36
|
-
|
|
37
|
-
// Maybe a Babel level below?
|
|
38
|
-
|
|
39
|
-
class JS_File_Comprehension extends JS_File_JS_AST_Node {
|
|
40
|
-
constructor(spec) {
|
|
41
|
-
super(spec);
|
|
42
|
-
|
|
43
|
-
const body = this.body = {};
|
|
44
|
-
|
|
45
|
-
//const {body} = this;
|
|
46
|
-
|
|
47
|
-
//const {each_root_node} = this;
|
|
48
|
-
|
|
49
|
-
let bn;
|
|
50
|
-
|
|
51
|
-
this.on('parsed-node_body', e_parsed => {
|
|
52
|
-
bn = body.node = e_parsed.value;
|
|
53
|
-
|
|
54
|
-
body.each = bn.each;
|
|
55
|
-
body.filter = bn.filter;
|
|
56
|
-
body.collect = bn.collect;
|
|
57
|
-
body.select = bn.select;
|
|
58
|
-
body.find = bn.find;
|
|
59
|
-
|
|
60
|
-
// body.child.declaration.name
|
|
61
|
-
// // needs a verb?
|
|
62
|
-
// or will be a shorthand for collect?
|
|
63
|
-
|
|
64
|
-
// body.each.child.declaration
|
|
65
|
-
// body.filter.child.declaration
|
|
66
|
-
// body.collect...
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
//const each_root_node = (callback) => bn.each.child(callback);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
//body.each = cb => bn.each(cb);
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
//body.filter = cb => {
|
|
83
|
-
// throw 'NYI'
|
|
84
|
-
//}
|
|
85
|
-
//body.each.child = (cb) => each_root_node(cb);
|
|
86
|
-
|
|
87
|
-
/*
|
|
88
|
-
const each_filtered_child_node = (fn, cb) => {
|
|
89
|
-
each_root_node(node => {if (fn(node)) cb(node)})
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
body.filter.child = (fn, cb) => each_filtered_child_node(fn, cb);
|
|
93
|
-
|
|
94
|
-
body.each.child.expression_statement = (cb) => each_filtered_child_node(node => node.type === 'ExpressionStatement', cb);
|
|
95
|
-
body.each.child.declaration = (cb) => each_filtered_child_node(node => node.is_declaration, cb);
|
|
96
|
-
*/
|
|
97
|
-
|
|
98
|
-
const deep_iterate = body.each;
|
|
99
|
-
|
|
100
|
-
const each_root_declaration = callback => {
|
|
101
|
-
filter_each_root_node(node => node.is_declaration, callback);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// .collect.root.declaration.name
|
|
105
|
-
// this.collect.root.declaration.name
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
const define_old_grdns_fn = () => {
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
this.get_root_declaration_names = () => {
|
|
113
|
-
|
|
114
|
-
//throw 'Will be replaced with this.collect.root.declaration.name'
|
|
115
|
-
|
|
116
|
-
console.log('!!!Will be replaced with this.collect.root.declaration.name!!!')
|
|
117
|
-
|
|
118
|
-
//console.log('get_root_declaration_names');
|
|
119
|
-
|
|
120
|
-
// can only do this when it's ready, it its been recieved and parsed.
|
|
121
|
-
const all_body_dec_names = [], map_all_body_dec_names = {};
|
|
122
|
-
|
|
123
|
-
//console.log('this', this);
|
|
124
|
-
//console.log('this.body', this.body);
|
|
125
|
-
//console.log('this.body.child_nodes.length', this.body.child_nodes.length);
|
|
126
|
-
|
|
127
|
-
this.body.each.child(js_ast_node => {
|
|
128
|
-
|
|
129
|
-
//console.log('js_ast_node', js_ast_node);
|
|
130
|
-
// Then a function to search the node for all declaration names.
|
|
131
|
-
// .get_identifier_names
|
|
132
|
-
|
|
133
|
-
//const identifier_names = js_ast_node.get_identifier_names();
|
|
134
|
-
|
|
135
|
-
//console.log('js_ast_node.type', js_ast_node.type);
|
|
136
|
-
//throw 'stop';
|
|
137
|
-
|
|
138
|
-
const body_node = js_ast_node.babel.node;
|
|
139
|
-
//console.log('body_node', body_node);
|
|
140
|
-
const arr_body_node_declarator_names = [], map_body_node_declarator_names = {};
|
|
141
|
-
|
|
142
|
-
if (js_ast_node.type === 'VariableDeclaration') {
|
|
143
|
-
//console.log('body_node', body_node);
|
|
144
|
-
|
|
145
|
-
each(body_node.declarations, declaration => {
|
|
146
|
-
//console.log('declaration', declaration);
|
|
147
|
-
|
|
148
|
-
if (declaration.type === 'VariableDeclarator') {
|
|
149
|
-
const name = declaration.id.name;
|
|
150
|
-
//console.log('name', name);
|
|
151
|
-
|
|
152
|
-
if (!map_body_node_declarator_names[name]) { // also want the declarator names that are for classes.
|
|
153
|
-
arr_body_node_declarator_names.push(name);
|
|
154
|
-
map_body_node_declarator_names[name] = true;
|
|
155
|
-
}
|
|
156
|
-
} else {
|
|
157
|
-
throw 'stop';
|
|
158
|
-
}
|
|
159
|
-
})
|
|
160
|
-
}
|
|
161
|
-
if (js_ast_node.type === 'ClassDeclaration') {
|
|
162
|
-
//console.log('body_node', body_node);
|
|
163
|
-
const name = body_node.id.name;
|
|
164
|
-
|
|
165
|
-
if (!map_body_node_declarator_names[name]) { // also want the declarator names that are for classes.
|
|
166
|
-
arr_body_node_declarator_names.push(name);
|
|
167
|
-
map_body_node_declarator_names[name] = true;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
//const variable_names = js_ast_node.get_variable_names();
|
|
171
|
-
//console.log('variable_names', variable_names);
|
|
172
|
-
|
|
173
|
-
//const identifier_names = js_ast_node.get_identifier_names();
|
|
174
|
-
//if (identifier_names.length > 0) console.log('identifier_names', identifier_names);
|
|
175
|
-
let arr_bod_dec_name;
|
|
176
|
-
if (arr_body_node_declarator_names.length > 1) {
|
|
177
|
-
//console.log('arr_body_node_declarator_names', arr_body_node_declarator_names);
|
|
178
|
-
// Can have multiple identifiers in a node.
|
|
179
|
-
// {a, b, c}
|
|
180
|
-
arr_bod_dec_name = arr_body_node_declarator_names;
|
|
181
|
-
//throw 'stop'
|
|
182
|
-
} else if (arr_body_node_declarator_names.length === 1) {
|
|
183
|
-
arr_bod_dec_name = arr_body_node_declarator_names[0];
|
|
184
|
-
}
|
|
185
|
-
if (arr_bod_dec_name) {
|
|
186
|
-
//console.log('arr_bod_dec_name', arr_bod_dec_name);
|
|
187
|
-
const t = tof(arr_bod_dec_name);
|
|
188
|
-
if (t === 'string') {
|
|
189
|
-
if (!map_all_body_dec_names[arr_bod_dec_name]) {
|
|
190
|
-
all_body_dec_names.push(arr_bod_dec_name);
|
|
191
|
-
}
|
|
192
|
-
} else if (t === 'array') {
|
|
193
|
-
each(arr_bod_dec_name, name => {
|
|
194
|
-
if (!map_all_body_dec_names[name]) {
|
|
195
|
-
all_body_dec_names.push(name);
|
|
196
|
-
}
|
|
197
|
-
})
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
})
|
|
201
|
-
return all_body_dec_names;
|
|
202
|
-
}
|
|
203
|
-
// declaration_details
|
|
204
|
-
// is it all inline?
|
|
205
|
-
// can we get a compressed version of it?
|
|
206
|
-
// where does it refer?
|
|
207
|
-
// eg, do we need the whole of lang-mini, or can we just extract 'each'.
|
|
208
|
-
|
|
209
|
-
// For the moment, focus more on lang-mini and a few tools that use it and some functions it has.
|
|
210
|
-
|
|
211
|
-
// Maybe another layer 4.1
|
|
212
|
-
// specific queries to find features.
|
|
213
|
-
// and get information on those features.
|
|
214
|
-
|
|
215
|
-
// Loading things into a platform object makes a lot of sense.
|
|
216
|
-
// Possibly use Platform within Module (and vice-versa?) Or Module extends Platform?
|
|
217
|
-
//
|
|
218
|
-
|
|
219
|
-
// also will be replaced.
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
let root_declared_names;
|
|
223
|
-
Object.defineProperty(this, 'root_declared_names', {
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
// Using shorthand method names (ES2015 feature).
|
|
227
|
-
// This is equivalent to:
|
|
228
|
-
// get: function() { return bValue; },
|
|
229
|
-
|
|
230
|
-
get() {
|
|
231
|
-
throw 'To be removed';
|
|
232
|
-
if (!root_declared_names) {
|
|
233
|
-
root_declared_names = this.get_root_declaration_names();
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
return root_declared_names;
|
|
237
|
-
},
|
|
238
|
-
//set(newValue) { bValue = newValue; },
|
|
239
|
-
enumerable: true,
|
|
240
|
-
configurable: false
|
|
241
|
-
});
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
// each_root_assignment_expression
|
|
252
|
-
//const each_root_assignment_expression = (callback) => each_root_node(node => node.type === 'AssignmentExpression', callback);
|
|
253
|
-
//this.each_root_node = each_root_node;
|
|
254
|
-
//this.each_root_declaration = each_root_declaration;
|
|
255
|
-
//this.each_root_assignment_expression = each_root_assignment_expression;
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
const collect_callbacks = function(fn) {
|
|
259
|
-
const a = arguments;
|
|
260
|
-
|
|
261
|
-
const apply_args = [];
|
|
262
|
-
for (let c = 1, l = a.length; c < l; c++) {
|
|
263
|
-
apply_args.push(a[c]);
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
const res = [];
|
|
267
|
-
const callback = item => {
|
|
268
|
-
res.push(item);
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
apply_args.push(callback);
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
// May need to apply / call the function with arguments given.
|
|
276
|
-
|
|
277
|
-
fn.apply(this, apply_args);
|
|
278
|
-
|
|
279
|
-
//fn(item => res.push(item));
|
|
280
|
-
return res;
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
const collect_root_nodes = () => {
|
|
284
|
-
const res = [];
|
|
285
|
-
bn.each.child(rn => {
|
|
286
|
-
res.push(rn);
|
|
287
|
-
})
|
|
288
|
-
return res;
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
const select_root_nodes = (fn_select) => {
|
|
292
|
-
const res = [];
|
|
293
|
-
bn.each.child(rn => {
|
|
294
|
-
if (fn_select(rn)) res.push(rn);
|
|
295
|
-
})
|
|
296
|
-
return res;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
//const select_root_declarations = (fn_select) => collect_callbacks(each_root_declaration, fn_select);
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
// .each .root
|
|
304
|
-
|
|
305
|
-
//const collect
|
|
306
|
-
|
|
307
|
-
// this.each_babel_root_node
|
|
308
|
-
|
|
309
|
-
Object.assign(this, {
|
|
310
|
-
each: body.each,
|
|
311
|
-
collect: body.collect,
|
|
312
|
-
filter: body.filter,
|
|
313
|
-
select: body.select,
|
|
314
|
-
find: body.find
|
|
315
|
-
})
|
|
316
|
-
|
|
317
|
-
/*
|
|
318
|
-
Object.assign(this, {
|
|
319
|
-
each: cb => deep_iterate(cb),
|
|
320
|
-
collect: {
|
|
321
|
-
root: () => collect_root_nodes()
|
|
322
|
-
},
|
|
323
|
-
filter: {
|
|
324
|
-
root: (fn_filter, callback) => filter_each_root_node(fn_filter, callback)
|
|
325
|
-
},
|
|
326
|
-
select: {
|
|
327
|
-
root: (fn_select) => select_root_nodes(fn_select)
|
|
328
|
-
}
|
|
329
|
-
})
|
|
330
|
-
|
|
331
|
-
Object.assign(this.each, {
|
|
332
|
-
root: (callback) => each_root_node(callback)
|
|
333
|
-
})
|
|
334
|
-
*/
|
|
335
|
-
|
|
336
|
-
//
|
|
337
|
-
|
|
338
|
-
// .each.child(...)
|
|
339
|
-
// .each.child.declaration(...)
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
//const each_root = this.each.child;
|
|
344
|
-
|
|
345
|
-
/*
|
|
346
|
-
Object.assign(each_root, {
|
|
347
|
-
declaration: callback => each_root_declaration(callback)
|
|
348
|
-
});
|
|
349
|
-
*/
|
|
350
|
-
// //const collect_root_declarations = () => collect_callbacks(each_root_declaration);
|
|
351
|
-
|
|
352
|
-
/*
|
|
353
|
-
const collect_root = this.collect.root;
|
|
354
|
-
Object.assign(collect_root, {
|
|
355
|
-
declaration: () => collect_callbacks(each_root_declaration)
|
|
356
|
-
});
|
|
357
|
-
|
|
358
|
-
const select_root = this.select.root;
|
|
359
|
-
Object.assign(select_root, {
|
|
360
|
-
declaration: select_root_declarations
|
|
361
|
-
});
|
|
362
|
-
|
|
363
|
-
const filter_root = this.filter.root;
|
|
364
|
-
|
|
365
|
-
*/
|
|
366
|
-
|
|
367
|
-
//.declaration = each_root_declaration;
|
|
368
|
-
//.declaration = collect_root_declarations;
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
// the query objects
|
|
373
|
-
|
|
374
|
-
// Think we can have reasonably concise and logical use syntax with these dotted paths.
|
|
375
|
-
// Later see about compressing property names to just a two or three characters.
|
|
376
|
-
// (or just one, could be easy and save a lot of app size)
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
// .collect
|
|
380
|
-
// .each
|
|
381
|
-
// .select
|
|
382
|
-
// .filter
|
|
383
|
-
|
|
384
|
-
// A function call map would make a lot of sense.
|
|
385
|
-
// Which functions are being called
|
|
386
|
-
|
|
387
|
-
// map function calls by name
|
|
388
|
-
|
|
389
|
-
// .each.deep.function_call.name
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
// collect.root.declaration.name
|
|
393
|
-
// collect.deep.call.require ???
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
});
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
}
|
|
409
|
-
}
|
|
410
|
-
JS_File_Comprehension.load_from_stream = (rs, path) => {
|
|
411
|
-
const res = new JS_File_Comprehension({rs: rs, path: path});
|
|
412
|
-
return res;
|
|
413
|
-
}
|
|
1
|
+
const {each, tof} = require('lang-tools');
|
|
2
|
+
const JS_File_JS_AST_Node = require('./JS_File_3-JS_AST_Node');
|
|
3
|
+
|
|
4
|
+
const JS_File_Import_References = require('./JS_File_Import_References');
|
|
5
|
+
|
|
6
|
+
// Index prior to this?
|
|
7
|
+
// Or just within JS_File?
|
|
8
|
+
// Would actually make sense here, as some AST trees could be long and worth working on in some ways, or reading info from.
|
|
9
|
+
|
|
10
|
+
// identifier_name_occurrance_index
|
|
11
|
+
// and provides a reference to each place that identifier name has been used within the scope.
|
|
12
|
+
// then building up an identifier name occurrance index could be done recursively where each node gets its child nodes to calculate their occurrance indexes first.
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
//const { default: JS_File_JS_AST_Node } = require('./JS_File_2-JS_AST_Node');
|
|
20
|
+
//const { default: Import_References } = require('./JS_File_Import_References');
|
|
21
|
+
// Will extract relevant AST code functionality. Files often import things at the beginning, then have declarations, then export what was declared at the end.
|
|
22
|
+
|
|
23
|
+
// Understanding the import declarations so they could be localised.
|
|
24
|
+
// So we can refer to the ast of them, because we have recognised them elsewhere.
|
|
25
|
+
|
|
26
|
+
// Can build the functions into a js file.
|
|
27
|
+
// Later on - renaming local variables within a scope.
|
|
28
|
+
|
|
29
|
+
// JS_File_Writable too...
|
|
30
|
+
// .imports = ... or requires
|
|
31
|
+
// .add_platform?
|
|
32
|
+
|
|
33
|
+
// Or better to create the platform objects out of the functions which have been comprehended from various files.
|
|
34
|
+
// JS_File_Platform?
|
|
35
|
+
// This will be more about understanding the js file. Basic structure will have already been obtained.
|
|
36
|
+
|
|
37
|
+
// Maybe a Babel level below?
|
|
38
|
+
|
|
39
|
+
class JS_File_Comprehension extends JS_File_JS_AST_Node {
|
|
40
|
+
constructor(spec) {
|
|
41
|
+
super(spec);
|
|
42
|
+
|
|
43
|
+
const body = this.body = {};
|
|
44
|
+
|
|
45
|
+
//const {body} = this;
|
|
46
|
+
|
|
47
|
+
//const {each_root_node} = this;
|
|
48
|
+
|
|
49
|
+
let bn;
|
|
50
|
+
|
|
51
|
+
this.on('parsed-node_body', e_parsed => {
|
|
52
|
+
bn = body.node = e_parsed.value;
|
|
53
|
+
|
|
54
|
+
body.each = bn.each;
|
|
55
|
+
body.filter = bn.filter;
|
|
56
|
+
body.collect = bn.collect;
|
|
57
|
+
body.select = bn.select;
|
|
58
|
+
body.find = bn.find;
|
|
59
|
+
|
|
60
|
+
// body.child.declaration.name
|
|
61
|
+
// // needs a verb?
|
|
62
|
+
// or will be a shorthand for collect?
|
|
63
|
+
|
|
64
|
+
// body.each.child.declaration
|
|
65
|
+
// body.filter.child.declaration
|
|
66
|
+
// body.collect...
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
//const each_root_node = (callback) => bn.each.child(callback);
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
//body.each = cb => bn.each(cb);
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
//body.filter = cb => {
|
|
83
|
+
// throw 'NYI'
|
|
84
|
+
//}
|
|
85
|
+
//body.each.child = (cb) => each_root_node(cb);
|
|
86
|
+
|
|
87
|
+
/*
|
|
88
|
+
const each_filtered_child_node = (fn, cb) => {
|
|
89
|
+
each_root_node(node => {if (fn(node)) cb(node)})
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
body.filter.child = (fn, cb) => each_filtered_child_node(fn, cb);
|
|
93
|
+
|
|
94
|
+
body.each.child.expression_statement = (cb) => each_filtered_child_node(node => node.type === 'ExpressionStatement', cb);
|
|
95
|
+
body.each.child.declaration = (cb) => each_filtered_child_node(node => node.is_declaration, cb);
|
|
96
|
+
*/
|
|
97
|
+
|
|
98
|
+
const deep_iterate = body.each;
|
|
99
|
+
|
|
100
|
+
const each_root_declaration = callback => {
|
|
101
|
+
filter_each_root_node(node => node.is_declaration, callback);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// .collect.root.declaration.name
|
|
105
|
+
// this.collect.root.declaration.name
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
const define_old_grdns_fn = () => {
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
this.get_root_declaration_names = () => {
|
|
113
|
+
|
|
114
|
+
//throw 'Will be replaced with this.collect.root.declaration.name'
|
|
115
|
+
|
|
116
|
+
console.log('!!!Will be replaced with this.collect.root.declaration.name!!!')
|
|
117
|
+
|
|
118
|
+
//console.log('get_root_declaration_names');
|
|
119
|
+
|
|
120
|
+
// can only do this when it's ready, it its been recieved and parsed.
|
|
121
|
+
const all_body_dec_names = [], map_all_body_dec_names = {};
|
|
122
|
+
|
|
123
|
+
//console.log('this', this);
|
|
124
|
+
//console.log('this.body', this.body);
|
|
125
|
+
//console.log('this.body.child_nodes.length', this.body.child_nodes.length);
|
|
126
|
+
|
|
127
|
+
this.body.each.child(js_ast_node => {
|
|
128
|
+
|
|
129
|
+
//console.log('js_ast_node', js_ast_node);
|
|
130
|
+
// Then a function to search the node for all declaration names.
|
|
131
|
+
// .get_identifier_names
|
|
132
|
+
|
|
133
|
+
//const identifier_names = js_ast_node.get_identifier_names();
|
|
134
|
+
|
|
135
|
+
//console.log('js_ast_node.type', js_ast_node.type);
|
|
136
|
+
//throw 'stop';
|
|
137
|
+
|
|
138
|
+
const body_node = js_ast_node.babel.node;
|
|
139
|
+
//console.log('body_node', body_node);
|
|
140
|
+
const arr_body_node_declarator_names = [], map_body_node_declarator_names = {};
|
|
141
|
+
|
|
142
|
+
if (js_ast_node.type === 'VariableDeclaration') {
|
|
143
|
+
//console.log('body_node', body_node);
|
|
144
|
+
|
|
145
|
+
each(body_node.declarations, declaration => {
|
|
146
|
+
//console.log('declaration', declaration);
|
|
147
|
+
|
|
148
|
+
if (declaration.type === 'VariableDeclarator') {
|
|
149
|
+
const name = declaration.id.name;
|
|
150
|
+
//console.log('name', name);
|
|
151
|
+
|
|
152
|
+
if (!map_body_node_declarator_names[name]) { // also want the declarator names that are for classes.
|
|
153
|
+
arr_body_node_declarator_names.push(name);
|
|
154
|
+
map_body_node_declarator_names[name] = true;
|
|
155
|
+
}
|
|
156
|
+
} else {
|
|
157
|
+
throw 'stop';
|
|
158
|
+
}
|
|
159
|
+
})
|
|
160
|
+
}
|
|
161
|
+
if (js_ast_node.type === 'ClassDeclaration') {
|
|
162
|
+
//console.log('body_node', body_node);
|
|
163
|
+
const name = body_node.id.name;
|
|
164
|
+
|
|
165
|
+
if (!map_body_node_declarator_names[name]) { // also want the declarator names that are for classes.
|
|
166
|
+
arr_body_node_declarator_names.push(name);
|
|
167
|
+
map_body_node_declarator_names[name] = true;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
//const variable_names = js_ast_node.get_variable_names();
|
|
171
|
+
//console.log('variable_names', variable_names);
|
|
172
|
+
|
|
173
|
+
//const identifier_names = js_ast_node.get_identifier_names();
|
|
174
|
+
//if (identifier_names.length > 0) console.log('identifier_names', identifier_names);
|
|
175
|
+
let arr_bod_dec_name;
|
|
176
|
+
if (arr_body_node_declarator_names.length > 1) {
|
|
177
|
+
//console.log('arr_body_node_declarator_names', arr_body_node_declarator_names);
|
|
178
|
+
// Can have multiple identifiers in a node.
|
|
179
|
+
// {a, b, c}
|
|
180
|
+
arr_bod_dec_name = arr_body_node_declarator_names;
|
|
181
|
+
//throw 'stop'
|
|
182
|
+
} else if (arr_body_node_declarator_names.length === 1) {
|
|
183
|
+
arr_bod_dec_name = arr_body_node_declarator_names[0];
|
|
184
|
+
}
|
|
185
|
+
if (arr_bod_dec_name) {
|
|
186
|
+
//console.log('arr_bod_dec_name', arr_bod_dec_name);
|
|
187
|
+
const t = tof(arr_bod_dec_name);
|
|
188
|
+
if (t === 'string') {
|
|
189
|
+
if (!map_all_body_dec_names[arr_bod_dec_name]) {
|
|
190
|
+
all_body_dec_names.push(arr_bod_dec_name);
|
|
191
|
+
}
|
|
192
|
+
} else if (t === 'array') {
|
|
193
|
+
each(arr_bod_dec_name, name => {
|
|
194
|
+
if (!map_all_body_dec_names[name]) {
|
|
195
|
+
all_body_dec_names.push(name);
|
|
196
|
+
}
|
|
197
|
+
})
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
})
|
|
201
|
+
return all_body_dec_names;
|
|
202
|
+
}
|
|
203
|
+
// declaration_details
|
|
204
|
+
// is it all inline?
|
|
205
|
+
// can we get a compressed version of it?
|
|
206
|
+
// where does it refer?
|
|
207
|
+
// eg, do we need the whole of lang-mini, or can we just extract 'each'.
|
|
208
|
+
|
|
209
|
+
// For the moment, focus more on lang-mini and a few tools that use it and some functions it has.
|
|
210
|
+
|
|
211
|
+
// Maybe another layer 4.1
|
|
212
|
+
// specific queries to find features.
|
|
213
|
+
// and get information on those features.
|
|
214
|
+
|
|
215
|
+
// Loading things into a platform object makes a lot of sense.
|
|
216
|
+
// Possibly use Platform within Module (and vice-versa?) Or Module extends Platform?
|
|
217
|
+
//
|
|
218
|
+
|
|
219
|
+
// also will be replaced.
|
|
220
|
+
|
|
221
|
+
|
|
222
|
+
let root_declared_names;
|
|
223
|
+
Object.defineProperty(this, 'root_declared_names', {
|
|
224
|
+
|
|
225
|
+
|
|
226
|
+
// Using shorthand method names (ES2015 feature).
|
|
227
|
+
// This is equivalent to:
|
|
228
|
+
// get: function() { return bValue; },
|
|
229
|
+
|
|
230
|
+
get() {
|
|
231
|
+
throw 'To be removed';
|
|
232
|
+
if (!root_declared_names) {
|
|
233
|
+
root_declared_names = this.get_root_declaration_names();
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
return root_declared_names;
|
|
237
|
+
},
|
|
238
|
+
//set(newValue) { bValue = newValue; },
|
|
239
|
+
enumerable: true,
|
|
240
|
+
configurable: false
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
|
|
244
|
+
|
|
245
|
+
|
|
246
|
+
|
|
247
|
+
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
|
|
251
|
+
// each_root_assignment_expression
|
|
252
|
+
//const each_root_assignment_expression = (callback) => each_root_node(node => node.type === 'AssignmentExpression', callback);
|
|
253
|
+
//this.each_root_node = each_root_node;
|
|
254
|
+
//this.each_root_declaration = each_root_declaration;
|
|
255
|
+
//this.each_root_assignment_expression = each_root_assignment_expression;
|
|
256
|
+
|
|
257
|
+
|
|
258
|
+
const collect_callbacks = function(fn) {
|
|
259
|
+
const a = arguments;
|
|
260
|
+
|
|
261
|
+
const apply_args = [];
|
|
262
|
+
for (let c = 1, l = a.length; c < l; c++) {
|
|
263
|
+
apply_args.push(a[c]);
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
const res = [];
|
|
267
|
+
const callback = item => {
|
|
268
|
+
res.push(item);
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
apply_args.push(callback);
|
|
272
|
+
|
|
273
|
+
|
|
274
|
+
|
|
275
|
+
// May need to apply / call the function with arguments given.
|
|
276
|
+
|
|
277
|
+
fn.apply(this, apply_args);
|
|
278
|
+
|
|
279
|
+
//fn(item => res.push(item));
|
|
280
|
+
return res;
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
const collect_root_nodes = () => {
|
|
284
|
+
const res = [];
|
|
285
|
+
bn.each.child(rn => {
|
|
286
|
+
res.push(rn);
|
|
287
|
+
})
|
|
288
|
+
return res;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
const select_root_nodes = (fn_select) => {
|
|
292
|
+
const res = [];
|
|
293
|
+
bn.each.child(rn => {
|
|
294
|
+
if (fn_select(rn)) res.push(rn);
|
|
295
|
+
})
|
|
296
|
+
return res;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
//const select_root_declarations = (fn_select) => collect_callbacks(each_root_declaration, fn_select);
|
|
301
|
+
|
|
302
|
+
|
|
303
|
+
// .each .root
|
|
304
|
+
|
|
305
|
+
//const collect
|
|
306
|
+
|
|
307
|
+
// this.each_babel_root_node
|
|
308
|
+
|
|
309
|
+
Object.assign(this, {
|
|
310
|
+
each: body.each,
|
|
311
|
+
collect: body.collect,
|
|
312
|
+
filter: body.filter,
|
|
313
|
+
select: body.select,
|
|
314
|
+
find: body.find
|
|
315
|
+
})
|
|
316
|
+
|
|
317
|
+
/*
|
|
318
|
+
Object.assign(this, {
|
|
319
|
+
each: cb => deep_iterate(cb),
|
|
320
|
+
collect: {
|
|
321
|
+
root: () => collect_root_nodes()
|
|
322
|
+
},
|
|
323
|
+
filter: {
|
|
324
|
+
root: (fn_filter, callback) => filter_each_root_node(fn_filter, callback)
|
|
325
|
+
},
|
|
326
|
+
select: {
|
|
327
|
+
root: (fn_select) => select_root_nodes(fn_select)
|
|
328
|
+
}
|
|
329
|
+
})
|
|
330
|
+
|
|
331
|
+
Object.assign(this.each, {
|
|
332
|
+
root: (callback) => each_root_node(callback)
|
|
333
|
+
})
|
|
334
|
+
*/
|
|
335
|
+
|
|
336
|
+
//
|
|
337
|
+
|
|
338
|
+
// .each.child(...)
|
|
339
|
+
// .each.child.declaration(...)
|
|
340
|
+
|
|
341
|
+
|
|
342
|
+
|
|
343
|
+
//const each_root = this.each.child;
|
|
344
|
+
|
|
345
|
+
/*
|
|
346
|
+
Object.assign(each_root, {
|
|
347
|
+
declaration: callback => each_root_declaration(callback)
|
|
348
|
+
});
|
|
349
|
+
*/
|
|
350
|
+
// //const collect_root_declarations = () => collect_callbacks(each_root_declaration);
|
|
351
|
+
|
|
352
|
+
/*
|
|
353
|
+
const collect_root = this.collect.root;
|
|
354
|
+
Object.assign(collect_root, {
|
|
355
|
+
declaration: () => collect_callbacks(each_root_declaration)
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
const select_root = this.select.root;
|
|
359
|
+
Object.assign(select_root, {
|
|
360
|
+
declaration: select_root_declarations
|
|
361
|
+
});
|
|
362
|
+
|
|
363
|
+
const filter_root = this.filter.root;
|
|
364
|
+
|
|
365
|
+
*/
|
|
366
|
+
|
|
367
|
+
//.declaration = each_root_declaration;
|
|
368
|
+
//.declaration = collect_root_declarations;
|
|
369
|
+
|
|
370
|
+
|
|
371
|
+
|
|
372
|
+
// the query objects
|
|
373
|
+
|
|
374
|
+
// Think we can have reasonably concise and logical use syntax with these dotted paths.
|
|
375
|
+
// Later see about compressing property names to just a two or three characters.
|
|
376
|
+
// (or just one, could be easy and save a lot of app size)
|
|
377
|
+
|
|
378
|
+
|
|
379
|
+
// .collect
|
|
380
|
+
// .each
|
|
381
|
+
// .select
|
|
382
|
+
// .filter
|
|
383
|
+
|
|
384
|
+
// A function call map would make a lot of sense.
|
|
385
|
+
// Which functions are being called
|
|
386
|
+
|
|
387
|
+
// map function calls by name
|
|
388
|
+
|
|
389
|
+
// .each.deep.function_call.name
|
|
390
|
+
|
|
391
|
+
|
|
392
|
+
// collect.root.declaration.name
|
|
393
|
+
// collect.deep.call.require ???
|
|
394
|
+
|
|
395
|
+
|
|
396
|
+
|
|
397
|
+
|
|
398
|
+
});
|
|
399
|
+
|
|
400
|
+
|
|
401
|
+
|
|
402
|
+
|
|
403
|
+
|
|
404
|
+
|
|
405
|
+
|
|
406
|
+
|
|
407
|
+
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
JS_File_Comprehension.load_from_stream = (rs, path) => {
|
|
411
|
+
const res = new JS_File_Comprehension({rs: rs, path: path});
|
|
412
|
+
return res;
|
|
413
|
+
}
|
|
414
414
|
module.exports = JS_File_Comprehension;
|