efront 4.25.1 → 4.25.2

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.
@@ -38,7 +38,7 @@ i18n.getIndex = function () {
38
38
  };
39
39
  i18n.setIndex = function (index) {
40
40
  languageIndex = +index;
41
- localStorage.setItem('language-index', index);
41
+ if (localStorage) localStorage.setItem('language-index', index);
42
42
  supports = [];
43
43
  i18n.supports = supports;
44
44
  i18n.reload();
@@ -62,7 +62,8 @@ i18n.removeReloader = function () {
62
62
  }
63
63
  };
64
64
  if (this.navigator) i18n.setLanguage(this.navigator.language);
65
- var i = +localStorage.getItem('language-index');
65
+ var { localStorage } = this;
66
+ var i = +localStorage?.getItem('language-index');
66
67
  if (i >= 0) i18n.setIndex(i);
67
68
  else i18n.setIndex(languageIndex);
68
69
  var supports;
@@ -551,7 +551,7 @@ var createScoped = function (parsed, wash) {
551
551
  var isCatch = false;
552
552
  var isFunction = false;
553
553
  var isScope = false;
554
- var isArrow = false;
554
+ var isArraw = false;
555
555
  var isClass = false;
556
556
  var isAsync = false;
557
557
  var isAster = false;
@@ -616,7 +616,7 @@ var createScoped = function (parsed, wash) {
616
616
  }
617
617
  if (o.next && o.next.type === STAMP && o.next.text === "=>") {
618
618
  isScope = true;
619
- isArrow = true;
619
+ isArraw = true;
620
620
  isAsync = o.prev?.type === STRAP && o.prev.text === 'async';
621
621
  }
622
622
  else {
@@ -739,7 +739,7 @@ var createScoped = function (parsed, wash) {
739
739
  if (o.entry === "(") {
740
740
  var prev = o.prev;
741
741
  if (o.next && o.next.type === STAMP && o.next.text === "=>") {
742
- isArrow = true;
742
+ isArraw = true;
743
743
  isScope = true;
744
744
  if (prev?.type === STRAP && prev.text === 'async') {
745
745
  isAsync = true;
@@ -783,7 +783,7 @@ var createScoped = function (parsed, wash) {
783
783
  scoped = [];
784
784
  var isExpress = o.isExpress;
785
785
 
786
- if (isFunction || isArrow) {
786
+ if (isFunction || isArraw) {
787
787
  scoped.used = used;
788
788
  scoped.vars = vars;
789
789
  lets = vars;
@@ -809,7 +809,7 @@ var createScoped = function (parsed, wash) {
809
809
  thisscope = scoped;
810
810
  }
811
811
  }
812
- if (isArrow);
812
+ if (isArraw);
813
813
  else while (o && (o.type !== SCOPED || o.entry === '[')) {
814
814
  o = o.next;
815
815
  if (o && o.type === EXPRESS) {
@@ -850,7 +850,7 @@ var createScoped = function (parsed, wash) {
850
850
  if (!o);
851
851
  else if (o.type === STAMP && o.text === "=>") o = o.next;
852
852
  }
853
- else if (isArrow) {
853
+ else if (isArraw) {
854
854
  vars[o.text] = true;
855
855
  o.kind = 'argument';
856
856
  saveTo(used, o.text, o);
@@ -862,7 +862,7 @@ var createScoped = function (parsed, wash) {
862
862
  o.scoped = scoped;
863
863
  o.isExpress = isExpress;
864
864
  run(o.first);
865
- if (isArrow && id >= 0 && o) o = o.next;
865
+ if (isArraw && id >= 0 && o) o = o.next;
866
866
  if (wash && isFunction) {
867
867
  var e = o.next;
868
868
  if (e && e.type === EXPRESS && /^[\.\[]/.test(e.text) || e && e.type === SCOPED && e.entry === "[") {
@@ -877,7 +877,7 @@ var createScoped = function (parsed, wash) {
877
877
  }
878
878
  }
879
879
  }
880
- else if (isArrow) {
880
+ else if (isArraw) {
881
881
  var next = skipAssignment(o);
882
882
  scoped.arraw = o;
883
883
  var u = o;
@@ -907,7 +907,7 @@ var createScoped = function (parsed, wash) {
907
907
  } while (o);
908
908
  }
909
909
  var map = isFunction ? vars : lets;
910
- var keepscope = !!scoped.body || !!scoped.head || isArrow;
910
+ var keepscope = !!scoped.body || !!scoped.head;
911
911
  if (!keepscope) for (var k in map) {
912
912
  keepscope = true;
913
913
  break;
@@ -934,8 +934,8 @@ var createScoped = function (parsed, wash) {
934
934
  mergeTo(_used, used);
935
935
  if (scoped.length) _scoped.push(scoped);
936
936
  }
937
- if (isArrow) {
938
- scoped.isArrow = true;
937
+ if (isArraw) {
938
+ scoped.isArraw = true;
939
939
  if (!thisscope.insett && used.this) thisscope.insett = true;
940
940
  if (!argscope.inseta && used.arguments) argscope.inseta = true;
941
941
  }
@@ -943,7 +943,7 @@ var createScoped = function (parsed, wash) {
943
943
  if (isFunction) {
944
944
  funcbody = _funcbody;
945
945
  labelused = _labelused;
946
- if (!isArrow) {
946
+ if (!isArraw) {
947
947
  delete vars.this;
948
948
  delete vars.arguments;
949
949
  thisscope = _thisscope;
@@ -1260,21 +1260,27 @@ var needBreakBetween = function (prev, next) {
1260
1260
  if (hasBreakBetween(prev, next)) return;
1261
1261
  return getSemicolonBetween(prev, next) === ';' ? ';' : '';
1262
1262
  };
1263
- var relink = function (list) {
1264
- var pi = 0, p = null;
1265
- list.first = p;
1263
+ var rolink = function (list) {
1264
+ return link(list, list[0]?.prev, list[list.length - 1]?.next);
1265
+ };
1266
+ var link = function (list, p, n) {
1267
+ var pi = 0, f = null;
1268
+ list.first = null;
1266
1269
  for (var cx = 0, dx = list.length; cx < dx; cx++) {
1267
1270
  var o = list[cx];
1268
1271
  o.prev = p;
1269
1272
  if (o.type & (COMMENT | SPACE)) continue;
1270
- if (!p) list.first = o;
1273
+ if (!f) list.first = o;
1271
1274
  while (pi < cx) list[pi++].next = o;
1272
- p = o;
1275
+ f = p = o;
1273
1276
  }
1274
- while (pi < cx) list[pi++].next = null;
1275
- list.last = p;
1277
+ while (pi < cx) list[pi++].next = n;
1278
+ list.last = f;
1276
1279
  return list;
1277
1280
  };
1281
+ var relink = function (list) {
1282
+ return link(list, null, null);
1283
+ };
1278
1284
  var rehead = function (list) {
1279
1285
  for (var cx = 0, dx = list.length; cx < dx; cx++) {
1280
1286
  var o = list[cx];
@@ -1901,6 +1907,7 @@ module.exports = {
1901
1907
  isEval,
1902
1908
  rename,
1903
1909
  relink,
1910
+ rolink,
1904
1911
  rehead,
1905
1912
  createSeeker,
1906
1913
  setqueue,
@@ -1,7 +1,7 @@
1
1
  var scanner2 = require("./scanner2");
2
2
  var strings = require("../basic/strings");
3
3
  var Program = scanner2.Program;
4
- var { STAMP, SCOPED, STRAP, EXPRESS, pickAssignment, COMMENT, SPACE, PROPERTY, VALUE, LABEL, QUOTED, snapExpressFoot, isEval, canbeTemp, rename, isHalfSentence, skipFunction, getDeclared, skipAssignment, skipSentenceQueue, createScoped, createString, splice, relink, pickSentence, snapExpressHead, needBreakBetween } = require("./common");
4
+ var { STAMP, SCOPED, STRAP, EXPRESS, pickAssignment, COMMENT, SPACE, PROPERTY, VALUE, LABEL, QUOTED, snapExpressFoot, isEval, canbeTemp, rename, isHalfSentence, skipFunction, getDeclared, skipAssignment, skipSentenceQueue, createScoped, createString, splice, relink, rolink, pickSentence, snapExpressHead, needBreakBetween } = require("./common");
5
5
  var splice2 = function (q, from, to, ...a) {
6
6
  var cx = q.indexOf(from);
7
7
  if (cx < 0) throw console.log(splice2.caller, console.format(`\r\n<red2>${i18n`自`}</red2>`), from && createString([from]), console.format(`\r\n<yellow>${i18n`至`}</yellow>`), to && createString([to]), console.format(`\r\n<cyan>${i18n`码列`}</cyan>`), createString(pickSentence(from))), i18n`结构异常`;
@@ -1009,6 +1009,7 @@ var killobj = function (body, getobjname, getletname, getname_, letname_, deep =
1009
1009
  break;
1010
1010
  case "async":
1011
1011
  splice(body, i, 1);
1012
+ if (o.next) o.next.async = true;
1012
1013
  break;
1013
1014
  case "new":
1014
1015
  if (o.next?.needle) {
@@ -1068,7 +1069,7 @@ var killobj = function (body, getobjname, getletname, getname_, letname_, deep =
1068
1069
  }
1069
1070
  else if (o.type === STAMP) {
1070
1071
  if (o.text === "=>") {
1071
- i = unarrow(body, i, deepkill, letname_);
1072
+ i = unarrow(body, i);
1072
1073
  continue;
1073
1074
  }
1074
1075
  else i = newpunc(body, i, _getnewname);
@@ -1255,7 +1256,7 @@ var unforof = function (o, getnewname, used, killobj) {
1255
1256
  splice(tf[1], 0, 0, ...splice2(r.queue, r, n, ...tf));
1256
1257
  }
1257
1258
  };
1258
- var unarrow = function (body, i, killobj, letname_) {
1259
+ var unarrow = function (body, i) {
1259
1260
  var o = body[i];
1260
1261
  var p = o.prev;
1261
1262
  var n = o.next;
@@ -1273,12 +1274,19 @@ var unarrow = function (body, i, killobj, letname_) {
1273
1274
  if (n.type !== SCOPED || !n.brace) {
1274
1275
  var nni = skipAssignment(body, ni);
1275
1276
  b = scanner2('{}')[0];
1276
- splice(b, 0, 0, { type: STRAP, transive: true, text: "return" }, ...splice(body, ni, nni - ni, b));
1277
- killarg(h, b, letname_);
1278
- killobj(b);
1277
+ var q = splice(body, ni, nni - ni, b);
1278
+ if (q.length === 1 && q.entry === '(') {
1279
+ q = q[0];
1280
+ }
1281
+ splice(b, 0, 0, { type: STRAP, transive: true, text: "return" }, ...q);
1282
+ relink(b);
1279
1283
  nni = indexof(body, b, ni) + 1;
1280
1284
  }
1281
1285
  else nni = ni + 1;
1286
+ var bd = body.slice(pi, nni);
1287
+ if (p?.async) bd.unshift({ type: STRAP, text: 'async' });
1288
+ relink(bd);
1289
+ down(createScoped(bd));
1282
1290
  return nni;
1283
1291
  };
1284
1292
  var getname = function (vars, envs, k) {
@@ -1653,8 +1661,8 @@ var newpunc = function (body, i, newname) {
1653
1661
  }
1654
1662
  return hi;
1655
1663
  }
1656
-
1657
1664
  var down = function (scoped) {
1665
+ if (scoped.isArraw) return;
1658
1666
  var inAsync = scoped.async;
1659
1667
  var inAster = scoped.yield;
1660
1668
  var funcMark = [, "aster", "async", "asyncAster"][inAsync << 1 | inAster];
@@ -1787,13 +1795,13 @@ var down = function (scoped) {
1787
1795
  };
1788
1796
 
1789
1797
  var markcodes = [];
1790
- if (scoped.isfunc && scoped.caps.this && (funcMark && !scoped.isArrow || scoped.insett)) {
1798
+ if (scoped.isfunc && scoped.caps.this && (funcMark || scoped.insett)) {
1791
1799
  let tn = _getname("this_");
1792
1800
  rename(scoped.caps, "this", tn);
1793
1801
  scoped.caps.this.forEach(o => o.origin = 'this');
1794
1802
  markcodes.push(`${tn}=this`);
1795
1803
  }
1796
- if (scoped.isfunc && scoped.caps.arguments && (funcMark && !scoped.isArrow || scoped.inseta)) {
1804
+ if (scoped.isfunc && scoped.caps.arguments && (funcMark || scoped.inseta)) {
1797
1805
  let an = _getname("arguments_");
1798
1806
  scoped.caps.arguments.forEach(o => o.origin = 'arguments');
1799
1807
  rename(scoped.caps, "arguments", an);
@@ -1803,7 +1811,7 @@ var down = function (scoped) {
1803
1811
  var _killobj = function (_getlocal, o) {
1804
1812
  return killobj(o, gettmpname, getletname, _getlocal, _letname);
1805
1813
  };
1806
- var kill = function (scoped, _, parentScope) {
1814
+ var kill = function (scoped) {
1807
1815
  if (scoped.isfunc) return down(scoped);
1808
1816
  killlet(scoped);
1809
1817
  var saveddeep = fordeep;
@@ -160,16 +160,15 @@ textSpan: highlightSpan.textSpan,
160
160
  isWriteAccess: highlightSpan.kind === "writtenReference" /* writtenReference */ }, highlightSpan.isInString && { isInString: true }, highlightSpan.contextSpan && { contextSpan: highlightSpan.contextSpan })) }`);
161
161
  assert(downLevel(`async()=>({ [argitem.sort ? argitem.sort : 'date']: "desc" })`), `function () { return &async(
162
162
  function () {
163
- _ = {}; if (!argitem.sort) return [1, 0]; _1 = argitem.sort; return [2, 0]
163
+ _ = {}; if (!argitem.sort) return [1, 0]; _2 = argitem.sort; return [2, 0]
164
164
  },
165
165
  function () {
166
- _1 = 'date'; return [1, 0]
166
+ _2 = 'date'; return [1, 0]
167
167
  },
168
168
  function () {
169
- _[_1] = "desc"; _0 = _; return [_0, 2]
169
+ _[_2] = "desc"; _1 = _; return [_1, 2]
170
170
  })
171
- var _0, _1 }
172
- var _`);
171
+ var _, _1, _2 }`);
173
172
  assert(downLevel(`={...{a:1}}`), `= &extend({}, { a: 1 })`);
174
173
  assert(downLevel(`={...a,...c}`), `= &extend({}, a, c)`);
175
174
  assert(downLevel(`={a:a,...b,c}`), `= (_ = &extend({ a: a }, b),\r\n_.c = c, _)\r\nvar _`);
@@ -451,11 +450,14 @@ function (_) {
451
450
  _0 = _; _0 = _0.a; a = _0
452
451
  })
453
452
  var a, _0`)
454
- assert(downLevel(`async a=>await a`), `function (a) { return return &async(
453
+ assert(downLevel(`async a=>await a`), `function (a) { return &async(
455
454
  function () {
456
455
  _0 = a; return [_0, 1]
456
+ },
457
+ function (_) {
458
+ _0 = _; return [_0, 2]
457
459
  })
458
- var a, _0 }`)
460
+ var _0 }`)
459
461
  assert(downLevel(`function(a=b=>b,c){c}`), 'function (a, c) { if (a === undefined) a = function (b) { return b }; c }')
460
462
  assert(downLevel(`Object.defineProperty(dis, f.key, {get() {}, set(v) {}})`), `Object.defineProperty(dis, f.key, (_ = {},
461
463
  _.get = function () {},
@@ -533,4 +535,6 @@ return cls0 }(function () {})`);
533
535
  assert(downLevel(`a=class{ static{[...a]}}`), `var &slice = Array["prototype"]["slice"];
534
536
  a = function (cls0) { (function () { &slice["call"](a) }())
535
537
  return cls0 }(function () {})`);
536
-
538
+ assert(downLevel(`geta=()=>({[a]:1})`), `geta = function () { return ((_ = {},
539
+ _[a] = 1, _))
540
+ var _ }`);
@@ -163,6 +163,7 @@ function translate([imap, supports], code) {
163
163
  var a = scanner2(`[]`);
164
164
  v.map(function (o) {
165
165
  var name = o.name;
166
+ if (!name) return o;
166
167
  if (!name) return scanner2(`(${JSON.stringify(o)})`)[0];
167
168
  delete o.name;
168
169
  name = ctn('i18n' + getm(name, t.nodup, t.warn), t);
@@ -181,7 +182,7 @@ function translate([imap, supports], code) {
181
182
  v = a;
182
183
  }
183
184
  }
184
- else if (/^(name|holder|comment)$/.test(k)) v = ctn('i18n' + getm(v, t.nodup, t.warn), t);
185
+ else if (/^(name|holder|comment)$/.test(k)) v = v ? ctn('i18n' + getm(v, t.nodup, t.warn), t) : [{ type: QUOTED, text: `""` }];
185
186
  else v = scanner2(`(${JSON.stringify(v)})`)[0];
186
187
  o.push({
187
188
  type: PROPERTY,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "efront",
3
- "version": "4.25.1",
3
+ "version": "4.25.2",
4
4
  "description": "一个开发环境,提供一种自由的前端开发模式,也可作为辅助工具使用。",
5
5
  "main": "public/efront.js",
6
6
  "directories": {