nodexh 3.2.0 → 4.0.1

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.
Files changed (3) hide show
  1. package/lib/main.js +12 -192
  2. package/package.json +2 -4
  3. package/src/main.coffee +8 -145
package/lib/main.js CHANGED
@@ -1,202 +1,23 @@
1
1
  (function() {
2
2
  'use strict';
3
- var FS, GUY, PATH, _exit_handler, _get_context, alert, blue, bold, cyan, debug, echo, exit_handler, fetch_mapped_location, get_context, get_error_callsites, gold, green, grey, inspect, lime, load_source_map, log, modules_path_color, orange, outside_path_color, own_path_color, plum, red, reverse, rpr, show_error_with_source_context, steel, underline, white, write_to_stderr, yellow;
3
+ var SFMODULES, exit_handler, format_stack, write_to_stderr;
4
4
 
5
5
  //###########################################################################################################
6
- GUY = require('guy');
6
+ // blue # Слава Україні
7
+ // yellow # Слава Україні
8
+ SFMODULES = require('bricabrac-single-file-modules');
7
9
 
8
- ({alert, debug} = GUY.trm.get_loggers('NODEXH'));
9
-
10
- ({rpr, inspect, echo, log} = GUY.trm);
11
-
12
- get_error_callsites = require('error-callsites');
13
-
14
- load_source_map = (require('util')).promisify(require('load-source-map'));
15
-
16
- FS = require('fs');
17
-
18
- PATH = require('path');
19
-
20
- ({red, green, steel, cyan, bold, lime, gold, white, plum, orange, blue, yellow, reverse, underline, bold} = GUY.trm); // Слава Україні // Слава Україні
21
-
22
- grey = GUY.trm.BASE1;
23
-
24
- //-----------------------------------------------------------------------------------------------------------
25
- modules_path_color = function(...P) {
26
- return reverse(bold(orange('', ...P, '')));
27
- };
28
-
29
- outside_path_color = function(...P) {
30
- return reverse(bold(plum('', ...P, '')));
31
- };
32
-
33
- own_path_color = function(...P) {
34
- return reverse(bold(lime('', ...P, '')));
35
- };
10
+ ({format_stack} = SFMODULES.unstable.require_format_stack());
36
11
 
37
12
  //-----------------------------------------------------------------------------------------------------------
38
- write_to_stderr = function(...P) {
39
- return process.stderr.write(' ' + (GUY.trm.pen(...P)) + '\n');
40
- };
41
-
42
- //-----------------------------------------------------------------------------------------------------------
43
- fetch_mapped_location = async function(path, linenr, colnr) {
44
- var error, mapped_path, smp, sourcemap;
45
- try {
46
- sourcemap = (await load_source_map(path));
47
- smp = sourcemap.originalPositionFor({
48
- line: linenr,
49
- column: colnr
50
- });
51
- } catch (error1) {
52
- error = error1;
53
- return {path, linenr, colnr};
54
- }
55
- //.........................................................................................................
56
- if ((smp != null) && (smp.source != null) && (smp.source !== '') && (smp.line != null) && (smp.column != null)) {
57
- mapped_path = PATH.join(PATH.dirname(path), smp.source);
58
- return {
59
- path: mapped_path,
60
- linenr: smp.line,
61
- colnr: smp.column
62
- };
63
- }
64
- //.........................................................................................................
65
- return {path, linenr, colnr};
66
- };
67
-
68
- //-----------------------------------------------------------------------------------------------------------
69
- get_context = function(path, linenr, colnr, width) {
70
- var error;
71
- try {
72
- return _get_context(path, linenr, colnr, width);
73
- } catch (error1) {
74
- error = error1;
75
- if (error.code !== 'ENOENT') {
76
- throw error;
77
- }
78
- }
79
- return [];
80
- };
81
-
82
- //-----------------------------------------------------------------------------------------------------------
83
- _get_context = function(path, linenr, colnr, width) {
84
- /* TAINT perform line length adjustment, hiliting in dedicated method */
85
- var R, c0, c1, coldelta, delta, effect, first_idx, hilite, i, idx, last_idx, len, line, lines, ref, this_linenr, this_linenr_txt, width2;
86
- lines = (FS.readFileSync(path, {
87
- encoding: 'utf-8'
88
- })).split('\n');
89
- delta = 1;
90
- coldelta = 5;
91
- effect = reverse;
92
- first_idx = Math.max(0, linenr - 1 - delta);
93
- last_idx = Math.min(lines.length - 1, linenr - 1 + delta);
94
- R = [];
95
- ref = lines.slice(first_idx, +last_idx + 1 || 9e9);
96
- for (idx = i = 0, len = ref.length; i < len; idx = ++i) {
97
- line = ref[idx];
98
- this_linenr = first_idx + idx + 1;
99
- this_linenr_txt = (this_linenr.toString().padStart(4)) + '│ ';
100
- if (this_linenr !== linenr) {
101
- /* TAINT should adjust overlong context lines as well */
102
- R.push(`${grey(this_linenr_txt)}${grey(line)}`);
103
- continue;
104
- }
105
- c0 = colnr - 1;
106
- c1 = colnr + coldelta;
107
- hilite = effect(line.slice(c0, c1));
108
- line = line.slice(0, c0) + hilite + line.slice(c1);
109
- if (c1 > width) {
110
- width2 = Math.floor(width / 2);
111
- line = '... ' + line.slice(c1 - width2, +(c1 + hilite.length - (c1 - c0) + width2) + 1 || 9e9) + ' ...';
112
- } else {
113
- line = line.slice(0, +width + 1 || 9e9);
114
- }
115
- R.push(`${grey(this_linenr_txt)}${cyan(line)}`);
116
- }
117
- return R;
118
- };
119
-
120
- //-----------------------------------------------------------------------------------------------------------
121
- show_error_with_source_context = async function(error, headline) {
122
- /* TAINT use proper methods to format with multiple colors */
123
- var arrowhead, arrowshaft, callsite, callsites, colnr, context_line, fname, fname_txt, i, j, len, len1, linenr, path, path_color, ref, ref1, ref2, relpath, width, width1;
124
- alert('^77765-1^', reverse(bold(headline)));
125
- arrowhead = white('▲');
126
- arrowshaft = white('│');
127
- width = process.stdout.columns;
128
- callsites = get_error_callsites(error);
129
- //.........................................................................................................
130
- if ((callsites == null) || (callsites.length === 0)) {
131
- write_to_stderr(red(reverse("^455756^ error has no associated callsites:")));
132
- write_to_stderr(red(reverse(rpr(error))));
133
- return null;
134
- }
135
- //.........................................................................................................
136
- callsites.reverse();
137
- //.........................................................................................................
138
- for (i = 0, len = callsites.length; i < len; i++) {
139
- callsite = callsites[i];
140
- path = callsite.getFileName();
141
- //.......................................................................................................
142
- if (path == null) {
143
- write_to_stderr(grey('—'.repeat(108)));
144
- continue;
145
- }
146
- //.......................................................................................................
147
- linenr = callsite.getLineNumber();
148
- colnr = callsite.getColumnNumber();
149
- //.......................................................................................................
150
- if ((path.startsWith('node:')) || (path.startsWith('internal/'))) {
151
- write_to_stderr(arrowhead, grey(`${path} @ ${linenr},${colnr}`));
152
- continue;
153
- }
154
- //.......................................................................................................
155
- fname = (ref = (ref1 = callsite.getFunctionName()) != null ? ref1 : callsite.getMethodName()) != null ? ref : null;
156
- ({path, linenr, colnr} = (await fetch_mapped_location(path, linenr, colnr)));
157
- relpath = PATH.relative(process.cwd(), path);
158
- //.......................................................................................................
159
- switch (true) {
160
- case /\/node_modules\//.test(path):
161
- path_color = modules_path_color;
162
- break;
163
- case relpath.startsWith('../'):
164
- path_color = outside_path_color;
165
- break;
166
- default:
167
- path_color = own_path_color;
168
- }
169
- //.......................................................................................................
170
- if (fname != null) {
171
- fname_txt = steel(fname);
172
- width1 = width + (fname_txt.length - fname.length);
173
- write_to_stderr(arrowhead, path_color(`${relpath} @ ${linenr},${colnr}: ${fname_txt}() \x1b[38;05;234m`.padEnd(width1, '—')));
174
- } else {
175
- write_to_stderr(arrowhead, path_color(`${relpath} @ ${linenr},${colnr}: \x1b[38;05;234m`.padEnd(width, '—')));
176
- }
177
- ref2 = (await get_context(path, linenr, colnr, width));
178
- for (j = 0, len1 = ref2.length; j < len1; j++) {
179
- context_line = ref2[j];
180
- write_to_stderr(arrowshaft, context_line);
181
- }
182
- }
183
- alert('^77765-2^', reverse(bold(headline)));
184
- return null;
185
- };
186
-
187
- //-----------------------------------------------------------------------------------------------------------
188
- _exit_handler = async function(error, origin) {
189
- /* TAINT origin never used */
190
- var message, ref, ref1, ref2, type;
191
- type = (ref = (ref1 = error.code) != null ? ref1 : error.name) != null ? ref : 'EXCEPTION';
192
- message = ` ${type}: ` + ((ref2 = error != null ? error.message : void 0) != null ? ref2 : "an unrecoverable condition occurred");
193
- await show_error_with_source_context(error, message);
194
- return null;
13
+ write_to_stderr = function(text) {
14
+ return process.stderr.write(text + '\n');
195
15
  };
196
16
 
197
17
  //-----------------------------------------------------------------------------------------------------------
198
- exit_handler = async function(error, origin) {
199
- await _exit_handler(error, origin);
18
+ exit_handler = function(error, origin) {
19
+ // _exit_handler error, origin
20
+ write_to_stderr(format_stack(error));
200
21
  setImmediate((function() {
201
22
  return process.exit(111);
202
23
  }));
@@ -212,9 +33,8 @@
212
33
  }
213
34
 
214
35
  //###########################################################################################################
215
- module.exports = {exit_handler, _exit_handler};
36
+ module.exports = {exit_handler};
216
37
 
217
38
  }).call(this);
218
39
 
219
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":["../src/main.coffee"],"names":[],"mappings":"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","sourcesContent":["\n'use strict'\n\n\n############################################################################################################\nGUY                       = require 'guy'\n{ alert\n  debug   }               = GUY.trm.get_loggers 'NODEXH'\n{ rpr\n  inspect\n  echo\n  log     }               = GUY.trm\nget_error_callsites       = require 'error-callsites'\nload_source_map           = ( require 'util' ).promisify ( require 'load-source-map' )\nFS                        = require 'fs'\nPATH                      = require 'path'\n{ red\n  green\n  steel\n  cyan\n  bold\n  lime\n  gold\n  white\n  plum\n  orange\n  blue    # Слава Україні\n  yellow  # Слава Україні\n  reverse\n  underline\n  bold }                  = GUY.trm\ngrey                      = GUY.trm.BASE1\n\n\n#-----------------------------------------------------------------------------------------------------------\nmodules_path_color  = ( P... ) -> reverse bold orange '', P..., ''\noutside_path_color  = ( P... ) -> reverse bold plum   '', P..., ''\nown_path_color      = ( P... ) -> reverse bold lime   '', P..., ''\n\n#-----------------------------------------------------------------------------------------------------------\nwrite_to_stderr = ( P... ) -> process.stderr.write ' ' + ( GUY.trm.pen P... ) + '\\n'\n\n#-----------------------------------------------------------------------------------------------------------\nfetch_mapped_location = ( path, linenr, colnr ) ->\n  try\n    sourcemap = await load_source_map path\n    smp       = sourcemap.originalPositionFor { line: linenr, column: colnr, }\n  catch error\n    return { path, linenr, colnr, }\n  #.........................................................................................................\n  if ( smp? ) and ( smp.source? ) and ( smp.source isnt '' ) and ( smp.line? ) and ( smp.column? )\n    mapped_path = PATH.join ( PATH.dirname path ), smp.source\n    return { path: mapped_path, linenr: smp.line, colnr: smp.column, }\n  #.........................................................................................................\n  return { path, linenr, colnr, }\n\n#-----------------------------------------------------------------------------------------------------------\nget_context = ( path, linenr, colnr, width ) ->\n  try return ( _get_context path, linenr, colnr, width ) catch error\n    throw error unless error.code is 'ENOENT'\n  return []\n\n#-----------------------------------------------------------------------------------------------------------\n_get_context = ( path, linenr, colnr, width ) ->\n  lines     = ( FS.readFileSync path, { encoding: 'utf-8' } ).split '\\n'\n  delta     = 1\n  coldelta  = 5\n  effect    = reverse\n  first_idx = Math.max 0, linenr - 1 - delta\n  last_idx  = Math.min lines.length - 1, linenr - 1 + delta\n  R         = []\n  for line, idx in lines[ first_idx .. last_idx ]\n    this_linenr     = first_idx + idx + 1\n    this_linenr_txt = ( this_linenr.toString().padStart 4 ) + '│ '\n    if this_linenr isnt linenr\n      ### TAINT should adjust overlong context lines as well ###\n      R.push  \"#{grey this_linenr_txt}#{grey line}\"\n      continue\n    ### TAINT perform line length adjustment, hiliting in dedicated method ###\n    c0      = colnr - 1\n    c1      = colnr + coldelta\n    hilite  = effect line[ c0 ... c1 ]\n    line    = line[ ... c0 ] + hilite + line[ c1 .. ]\n    if c1 > width\n      width2  = Math.floor width / 2\n      line    = '... ' + line[ c1 - width2 .. c1 + hilite.length - ( c1 - c0 ) + width2 ] + ' ...'\n    else\n      line  = line[ .. width ]\n    R.push  \"#{grey this_linenr_txt}#{cyan line}\"\n  return R\n\n#-----------------------------------------------------------------------------------------------------------\nshow_error_with_source_context = ( error, headline ) ->\n  alert '^77765-1^', reverse bold headline\n  arrowhead   = white '▲'\n  arrowshaft  = white '│'\n  width       = process.stdout.columns\n  callsites   = get_error_callsites error\n  #.........................................................................................................\n  if ( not callsites? ) or ( callsites.length is 0 )\n    write_to_stderr red reverse \"^455756^ error has no associated callsites:\"\n    write_to_stderr red reverse rpr error\n    return null\n  #.........................................................................................................\n  callsites.reverse()\n  #.........................................................................................................\n  for callsite in callsites\n    path = callsite.getFileName()\n    #.......................................................................................................\n    unless path?\n      write_to_stderr grey '—'.repeat 108\n      continue\n    #.......................................................................................................\n    linenr      = callsite.getLineNumber()\n    colnr       = callsite.getColumnNumber()\n    #.......................................................................................................\n    if ( path.startsWith 'node:' ) or ( path.startsWith 'internal/' )\n      write_to_stderr arrowhead, grey \"#{path} @ #{linenr},#{colnr}\"\n      continue\n    #.......................................................................................................\n    fname = callsite.getFunctionName() ? callsite.getMethodName() ? null\n    { path\n      linenr\n      colnr   } = await fetch_mapped_location path, linenr, colnr\n    relpath     = PATH.relative process.cwd(), path\n    #.......................................................................................................\n    switch true\n      when ( /\\/node_modules\\//.test path ) then  path_color = modules_path_color\n      when ( relpath.startsWith '../'     ) then  path_color = outside_path_color\n      else                                        path_color = own_path_color\n    #.......................................................................................................\n    if fname?\n      ### TAINT use proper methods to format with multiple colors ###\n      fname_txt = steel fname\n      width1    = width + ( fname_txt.length - fname.length )\n      write_to_stderr arrowhead, path_color ( \"#{relpath} @ #{linenr},#{colnr}: #{fname_txt}() \\x1b[38;05;234m\".padEnd width1, '—' )\n    else\n      write_to_stderr arrowhead, path_color ( \"#{relpath} @ #{linenr},#{colnr}: \\x1b[38;05;234m\".padEnd width, '—' )\n    for context_line in await get_context path, linenr, colnr, width\n      write_to_stderr arrowshaft, context_line\n  alert '^77765-2^', reverse bold headline\n  return null\n\n#-----------------------------------------------------------------------------------------------------------\n_exit_handler = ( error, origin ) ->\n  ### TAINT origin never used ###\n  type    = error.code ? error.name ? 'EXCEPTION'\n  message = \" #{type}: \" + ( error?.message ? \"an unrecoverable condition occurred\" )\n  await show_error_with_source_context error, message\n  return null\n\n#-----------------------------------------------------------------------------------------------------------\nexit_handler = ( error, origin ) ->\n  await _exit_handler error, origin\n  setImmediate ( -> process.exit 111 )\n  return null\n\n\n\n############################################################################################################\nunless global[ Symbol.for 'cnd-exception-handler' ]?\n  null\n  global[ Symbol.for 'cnd-exception-handler' ] = true\n  process.once 'uncaughtException',  exit_handler\n  process.once 'unhandledRejection', exit_handler\n\n\n############################################################################################################\nmodule.exports = { exit_handler, _exit_handler, }\n\n"]}
220
- //# sourceURL=../src/main.coffee
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL21haW4uY29mZmVlIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBO0VBQUE7QUFBQSxNQUFBLFNBQUEsRUFBQSxZQUFBLEVBQUEsWUFBQSxFQUFBLGVBQUE7Ozs7O0VBTUEsU0FBQSxHQUE0QixPQUFBLENBQVEsK0JBQVI7O0VBQzVCLENBQUEsQ0FBRSxZQUFGLENBQUEsR0FBNEIsU0FBUyxDQUFDLFFBQVEsQ0FBQyxvQkFBbkIsQ0FBQSxDQUE1QixFQVBBOzs7RUFVQSxlQUFBLEdBQWtCLFFBQUEsQ0FBRSxJQUFGLENBQUE7V0FBWSxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQWYsQ0FBcUIsSUFBQSxHQUFPLElBQTVCO0VBQVosRUFWbEI7OztFQWFBLFlBQUEsR0FBZSxRQUFBLENBQUUsS0FBRixFQUFTLE1BQVQsQ0FBQSxFQUFBOztJQUViLGVBQUEsQ0FBZ0IsWUFBQSxDQUFhLEtBQWIsQ0FBaEI7SUFDQSxZQUFBLENBQWEsQ0FBRSxRQUFBLENBQUEsQ0FBQTthQUFHLE9BQU8sQ0FBQyxJQUFSLENBQWEsR0FBYjtJQUFILENBQUYsQ0FBYjtBQUNBLFdBQU87RUFKTSxFQWJmOzs7RUFzQkEsSUFBTyxtREFBUDtJQUNFO0lBQ0EsTUFBTSxDQUFFLE1BQU0sQ0FBQyxHQUFQLENBQVcsdUJBQVgsQ0FBRixDQUFOLEdBQStDO0lBQy9DLE9BQU8sQ0FBQyxJQUFSLENBQWEsbUJBQWIsRUFBbUMsWUFBbkM7SUFDQSxPQUFPLENBQUMsSUFBUixDQUFhLG9CQUFiLEVBQW1DLFlBQW5DLEVBSkY7R0F0QkE7OztFQThCQSxNQUFNLENBQUMsT0FBUCxHQUFpQixDQUFFLFlBQUY7QUE5QmpCIiwic291cmNlc0NvbnRlbnQiOlsiXG4ndXNlIHN0cmljdCdcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgYmx1ZSAgICAjINCh0LvQsNCy0LAg0KPQutGA0LDRl9C90ZZcbiMgeWVsbG93ICAjINCh0LvQsNCy0LAg0KPQutGA0LDRl9C90ZZcblNGTU9EVUxFUyAgICAgICAgICAgICAgICAgPSByZXF1aXJlICdicmljYWJyYWMtc2luZ2xlLWZpbGUtbW9kdWxlcydcbnsgZm9ybWF0X3N0YWNrLCAgICAgICAgIH0gPSBTRk1PRFVMRVMudW5zdGFibGUucmVxdWlyZV9mb3JtYXRfc3RhY2soKVxuXG4jLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbndyaXRlX3RvX3N0ZGVyciA9ICggdGV4dCApIC0+IHByb2Nlc3Muc3RkZXJyLndyaXRlIHRleHQgKyAnXFxuJ1xuXG4jLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbmV4aXRfaGFuZGxlciA9ICggZXJyb3IsIG9yaWdpbiApIC0+XG4gICMgX2V4aXRfaGFuZGxlciBlcnJvciwgb3JpZ2luXG4gIHdyaXRlX3RvX3N0ZGVyciBmb3JtYXRfc3RhY2sgZXJyb3JcbiAgc2V0SW1tZWRpYXRlICggLT4gcHJvY2Vzcy5leGl0IDExMSApXG4gIHJldHVybiBudWxsXG5cblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbnVubGVzcyBnbG9iYWxbIFN5bWJvbC5mb3IgJ2NuZC1leGNlcHRpb24taGFuZGxlcicgXT9cbiAgbnVsbFxuICBnbG9iYWxbIFN5bWJvbC5mb3IgJ2NuZC1leGNlcHRpb24taGFuZGxlcicgXSA9IHRydWVcbiAgcHJvY2Vzcy5vbmNlICd1bmNhdWdodEV4Y2VwdGlvbicsICBleGl0X2hhbmRsZXJcbiAgcHJvY2Vzcy5vbmNlICd1bmhhbmRsZWRSZWplY3Rpb24nLCBleGl0X2hhbmRsZXJcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbm1vZHVsZS5leHBvcnRzID0geyBleGl0X2hhbmRsZXIsIH1cblxuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nodexh",
3
- "version": "3.2.0",
3
+ "version": "4.0.1",
4
4
  "description": "a wrapper around the `node` executable for better stacktraces with sourcemaps, sourcecode excerpts",
5
5
  "main": "lib/main.js",
6
6
  "bin": {
@@ -23,9 +23,7 @@
23
23
  },
24
24
  "homepage": "https://github.com/loveencounterflow/nodexh",
25
25
  "dependencies": {
26
- "error-callsites": "^2.0.3",
27
- "guy": "^13.7.1",
28
- "load-source-map": "3.0.1"
26
+ "bricabrac-single-file-modules": "^0.6.0"
29
27
  },
30
28
  "scripts": {
31
29
  "build": "coffee --map -o lib -c src"
package/src/main.coffee CHANGED
@@ -3,155 +3,18 @@
3
3
 
4
4
 
5
5
  ############################################################################################################
6
- GUY = require 'guy'
7
- { alert
8
- debug } = GUY.trm.get_loggers 'NODEXH'
9
- { rpr
10
- inspect
11
- echo
12
- log } = GUY.trm
13
- get_error_callsites = require 'error-callsites'
14
- load_source_map = ( require 'util' ).promisify ( require 'load-source-map' )
15
- FS = require 'fs'
16
- PATH = require 'path'
17
- { red
18
- green
19
- steel
20
- cyan
21
- bold
22
- lime
23
- gold
24
- white
25
- plum
26
- orange
27
- blue # Слава Україні
28
- yellow # Слава Україні
29
- reverse
30
- underline
31
- bold } = GUY.trm
32
- grey = GUY.trm.BASE1
33
-
34
-
35
- #-----------------------------------------------------------------------------------------------------------
36
- modules_path_color = ( P... ) -> reverse bold orange '', P..., ''
37
- outside_path_color = ( P... ) -> reverse bold plum '', P..., ''
38
- own_path_color = ( P... ) -> reverse bold lime '', P..., ''
39
-
40
- #-----------------------------------------------------------------------------------------------------------
41
- write_to_stderr = ( P... ) -> process.stderr.write ' ' + ( GUY.trm.pen P... ) + '\n'
42
-
43
- #-----------------------------------------------------------------------------------------------------------
44
- fetch_mapped_location = ( path, linenr, colnr ) ->
45
- try
46
- sourcemap = await load_source_map path
47
- smp = sourcemap.originalPositionFor { line: linenr, column: colnr, }
48
- catch error
49
- return { path, linenr, colnr, }
50
- #.........................................................................................................
51
- if ( smp? ) and ( smp.source? ) and ( smp.source isnt '' ) and ( smp.line? ) and ( smp.column? )
52
- mapped_path = PATH.join ( PATH.dirname path ), smp.source
53
- return { path: mapped_path, linenr: smp.line, colnr: smp.column, }
54
- #.........................................................................................................
55
- return { path, linenr, colnr, }
6
+ # blue # Слава Україні
7
+ # yellow # Слава Україні
8
+ SFMODULES = require 'bricabrac-single-file-modules'
9
+ { format_stack, } = SFMODULES.unstable.require_format_stack()
56
10
 
57
11
  #-----------------------------------------------------------------------------------------------------------
58
- get_context = ( path, linenr, colnr, width ) ->
59
- try return ( _get_context path, linenr, colnr, width ) catch error
60
- throw error unless error.code is 'ENOENT'
61
- return []
62
-
63
- #-----------------------------------------------------------------------------------------------------------
64
- _get_context = ( path, linenr, colnr, width ) ->
65
- lines = ( FS.readFileSync path, { encoding: 'utf-8' } ).split '\n'
66
- delta = 1
67
- coldelta = 5
68
- effect = reverse
69
- first_idx = Math.max 0, linenr - 1 - delta
70
- last_idx = Math.min lines.length - 1, linenr - 1 + delta
71
- R = []
72
- for line, idx in lines[ first_idx .. last_idx ]
73
- this_linenr = first_idx + idx + 1
74
- this_linenr_txt = ( this_linenr.toString().padStart 4 ) + '│ '
75
- if this_linenr isnt linenr
76
- ### TAINT should adjust overlong context lines as well ###
77
- R.push "#{grey this_linenr_txt}#{grey line}"
78
- continue
79
- ### TAINT perform line length adjustment, hiliting in dedicated method ###
80
- c0 = colnr - 1
81
- c1 = colnr + coldelta
82
- hilite = effect line[ c0 ... c1 ]
83
- line = line[ ... c0 ] + hilite + line[ c1 .. ]
84
- if c1 > width
85
- width2 = Math.floor width / 2
86
- line = '... ' + line[ c1 - width2 .. c1 + hilite.length - ( c1 - c0 ) + width2 ] + ' ...'
87
- else
88
- line = line[ .. width ]
89
- R.push "#{grey this_linenr_txt}#{cyan line}"
90
- return R
91
-
92
- #-----------------------------------------------------------------------------------------------------------
93
- show_error_with_source_context = ( error, headline ) ->
94
- alert '^77765-1^', reverse bold headline
95
- arrowhead = white '▲'
96
- arrowshaft = white '│'
97
- width = process.stdout.columns
98
- callsites = get_error_callsites error
99
- #.........................................................................................................
100
- if ( not callsites? ) or ( callsites.length is 0 )
101
- write_to_stderr red reverse "^455756^ error has no associated callsites:"
102
- write_to_stderr red reverse rpr error
103
- return null
104
- #.........................................................................................................
105
- callsites.reverse()
106
- #.........................................................................................................
107
- for callsite in callsites
108
- path = callsite.getFileName()
109
- #.......................................................................................................
110
- unless path?
111
- write_to_stderr grey '—'.repeat 108
112
- continue
113
- #.......................................................................................................
114
- linenr = callsite.getLineNumber()
115
- colnr = callsite.getColumnNumber()
116
- #.......................................................................................................
117
- if ( path.startsWith 'node:' ) or ( path.startsWith 'internal/' )
118
- write_to_stderr arrowhead, grey "#{path} @ #{linenr},#{colnr}"
119
- continue
120
- #.......................................................................................................
121
- fname = callsite.getFunctionName() ? callsite.getMethodName() ? null
122
- { path
123
- linenr
124
- colnr } = await fetch_mapped_location path, linenr, colnr
125
- relpath = PATH.relative process.cwd(), path
126
- #.......................................................................................................
127
- switch true
128
- when ( /\/node_modules\//.test path ) then path_color = modules_path_color
129
- when ( relpath.startsWith '../' ) then path_color = outside_path_color
130
- else path_color = own_path_color
131
- #.......................................................................................................
132
- if fname?
133
- ### TAINT use proper methods to format with multiple colors ###
134
- fname_txt = steel fname
135
- width1 = width + ( fname_txt.length - fname.length )
136
- write_to_stderr arrowhead, path_color ( "#{relpath} @ #{linenr},#{colnr}: #{fname_txt}() \x1b[38;05;234m".padEnd width1, '—' )
137
- else
138
- write_to_stderr arrowhead, path_color ( "#{relpath} @ #{linenr},#{colnr}: \x1b[38;05;234m".padEnd width, '—' )
139
- for context_line in await get_context path, linenr, colnr, width
140
- write_to_stderr arrowshaft, context_line
141
- alert '^77765-2^', reverse bold headline
142
- return null
143
-
144
- #-----------------------------------------------------------------------------------------------------------
145
- _exit_handler = ( error, origin ) ->
146
- ### TAINT origin never used ###
147
- type = error.code ? error.name ? 'EXCEPTION'
148
- message = " #{type}: " + ( error?.message ? "an unrecoverable condition occurred" )
149
- await show_error_with_source_context error, message
150
- return null
12
+ write_to_stderr = ( text ) -> process.stderr.write text + '\n'
151
13
 
152
14
  #-----------------------------------------------------------------------------------------------------------
153
15
  exit_handler = ( error, origin ) ->
154
- await _exit_handler error, origin
16
+ # _exit_handler error, origin
17
+ write_to_stderr format_stack error
155
18
  setImmediate ( -> process.exit 111 )
156
19
  return null
157
20
 
@@ -166,5 +29,5 @@ unless global[ Symbol.for 'cnd-exception-handler' ]?
166
29
 
167
30
 
168
31
  ############################################################################################################
169
- module.exports = { exit_handler, _exit_handler, }
32
+ module.exports = { exit_handler, }
170
33