@wyw-in-js/transform 2.0.1 → 2.1.0
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/esm/index.js.map +1 -1
- package/esm/transform/Entrypoint.types.js.map +1 -1
- package/esm/transform/generators/processImports.js +1 -1
- package/esm/transform/generators/processImports.js.map +1 -1
- package/esm/transform/generators/resolveImports.js +24 -2
- package/esm/transform/generators/resolveImports.js.map +1 -1
- package/esm/transform/helpers/withDefaultServices.js +2 -1
- package/esm/transform/helpers/withDefaultServices.js.map +1 -1
- package/esm/transform/types.js.map +1 -1
- package/esm/transform.js +3 -2
- package/esm/transform.js.map +1 -1
- package/esm/types.js.map +1 -1
- package/esm/utils/applyOxcProcessors/applyOxcProcessors.js.map +1 -1
- package/esm/utils/applyOxcProcessors/processorFactory.js.map +1 -1
- package/esm/utils/collectOxcRuntime/normalizeRuntimeCode.js +2 -12
- package/esm/utils/collectOxcRuntime/normalizeRuntimeCode.js.map +1 -1
- package/esm/utils/collectOxcRuntime/types.js.map +1 -1
- package/esm/utils/collectOxcTemplateDependencies/staticEvaluator.js +51 -0
- package/esm/utils/collectOxcTemplateDependencies/staticEvaluator.js.map +1 -1
- package/esm/utils/oxcPreevalStage/types.js.map +1 -1
- package/esm/utils/parseOxc.js +16 -2
- package/esm/utils/parseOxc.js.map +1 -1
- package/package.json +6 -6
- package/types/index.d.ts +1 -1
- package/types/transform/Entrypoint.types.d.ts +1 -0
- package/types/transform/generators/processImports.js +3 -1
- package/types/transform/generators/resolveImports.js +27 -2
- package/types/transform/helpers/withDefaultServices.d.ts +1 -1
- package/types/transform/helpers/withDefaultServices.js +2 -1
- package/types/transform/types.d.ts +2 -0
- package/types/transform.js +3 -2
- package/types/types.d.ts +4 -3
- package/types/utils/applyOxcProcessors/applyOxcProcessors.d.ts +1 -1
- package/types/utils/applyOxcProcessors/processorFactory.d.ts +1 -1
- package/types/utils/collectOxcRuntime/normalizeRuntimeCode.js +2 -11
- package/types/utils/collectOxcRuntime/types.d.ts +1 -1
- package/types/utils/collectOxcTemplateDependencies/staticEvaluator.js +59 -0
- package/types/utils/oxcPreevalStage/types.d.ts +1 -1
- package/types/utils/parseOxc.js +17 -2
|
@@ -42,6 +42,53 @@ const getObjectMember = (objectValue, property) => {
|
|
|
42
42
|
}
|
|
43
43
|
return objectValue[property];
|
|
44
44
|
};
|
|
45
|
+
const staticObjectPropertyKey = (property, ctx, env, stack) => {
|
|
46
|
+
if (!property.key) {
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
let key;
|
|
50
|
+
if (property.computed) {
|
|
51
|
+
key = evaluateStatic(property.key, ctx, env, stack);
|
|
52
|
+
} else if (property.key.type === "Identifier") {
|
|
53
|
+
key = property.key.name;
|
|
54
|
+
} else if (property.key.type === "Literal") {
|
|
55
|
+
key = property.key.value;
|
|
56
|
+
}
|
|
57
|
+
return typeof key === "string" || typeof key === "number" ? key : null;
|
|
58
|
+
};
|
|
59
|
+
const evaluateObjectExpressionMember = (expression, propertyKey, ctx, env, stack) => {
|
|
60
|
+
if (expression.type !== "ObjectExpression") {
|
|
61
|
+
return undefined;
|
|
62
|
+
}
|
|
63
|
+
for (let idx = expression.properties.length - 1; idx >= 0; idx -= 1) {
|
|
64
|
+
const property = expression.properties[idx];
|
|
65
|
+
if (property.type === "SpreadElement") {
|
|
66
|
+
return undefined;
|
|
67
|
+
}
|
|
68
|
+
const key = staticObjectPropertyKey(property, ctx, env, stack);
|
|
69
|
+
if (key === null) {
|
|
70
|
+
return undefined;
|
|
71
|
+
}
|
|
72
|
+
if (key === propertyKey) {
|
|
73
|
+
return evaluateStatic(property.value, ctx, env, stack);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return undefined;
|
|
77
|
+
};
|
|
78
|
+
const evaluateKnownObjectMember = (expression, propertyKey, ctx, env, stack) => {
|
|
79
|
+
const objectMember = evaluateObjectExpressionMember(expression, propertyKey, ctx, env, stack);
|
|
80
|
+
if (objectMember !== undefined) {
|
|
81
|
+
return objectMember;
|
|
82
|
+
}
|
|
83
|
+
if (expression.type !== "Identifier" || env.has(expression.name)) {
|
|
84
|
+
return undefined;
|
|
85
|
+
}
|
|
86
|
+
const binding = resolveBindingAt(ctx, expression.name, expression.start);
|
|
87
|
+
if (!binding || binding.kind === "param" || binding.importedFrom || binding.isRoot || stack.includes(binding.name) || !binding.declarator?.init || binding.declarator.id.type !== "Identifier") {
|
|
88
|
+
return undefined;
|
|
89
|
+
}
|
|
90
|
+
return evaluateKnownObjectMember(binding.declarator.init, propertyKey, ctx, env, [...stack, binding.name]);
|
|
91
|
+
};
|
|
45
92
|
const oxcStaticCallableValue = Symbol("wyw.oxc.staticCallableValue");
|
|
46
93
|
const isOxcStaticCallableValue = (value) => typeof value === "object" && value !== null && oxcStaticCallableValue in value;
|
|
47
94
|
const unwrapOxcStaticCallableValue = (value) => isOxcStaticCallableValue(value) ? value[oxcStaticCallableValue] : value;
|
|
@@ -440,6 +487,10 @@ export const evaluateStatic = (expression, ctx, env = new Map(), stack = []) =>
|
|
|
440
487
|
// ?? / || branch (or a runtime read) is more predictable.
|
|
441
488
|
return undefined;
|
|
442
489
|
}
|
|
490
|
+
const knownObjectMember = evaluateKnownObjectMember(expression.object, key, ctx, env, stack);
|
|
491
|
+
if (knownObjectMember !== undefined) {
|
|
492
|
+
return knownObjectMember;
|
|
493
|
+
}
|
|
443
494
|
const objectValue = evaluateStatic(expression.object, ctx, env, stack);
|
|
444
495
|
if (objectValue === undefined) {
|
|
445
496
|
return undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"AASA,SAAS,2BAA2B;AACpC,SAAS,wBAAwB;AAGjC,OAAO,MAAM,eAAe,UAAkC;AAC5D,KAAI,OAAO,UAAU,UAAU;AAC7B,SAAO,OAAO,SAAS,MAAM,GAAG,KAAK,UAAU,MAAM,GAAG;;AAG1D,KACE,UAAU,QACV,OAAO,UAAU,YACjB,OAAO,UAAU,WACjB;AACA,SAAO,KAAK,UAAU,MAAM;;AAG9B,KAAI,MAAM,QAAQ,MAAM,EAAE;AACxB,SAAO,KAAK,UAAU,MAAM;;AAG9B,KAAI,OAAO,UAAU,YAAY,UAAU,MAAM;AAC/C,SAAO,IAAI,KAAK,UAAU,MAAM,CAAC;;AAGnC,QAAO;;AAGT,OAAO,MAAM,6BAA6B,UACxC,YAAY,MAAM,KAAK;AAEzB,OAAO,MAAM,oBAAoB,UAA4B;AAC3D,KAAI,MAAM,QAAQ,MAAM,EAAE;AACxB,SAAO,MAAM,KAAK,SAAS,iBAAiB,KAAK,CAAC;;AAGpD,KAAI,OAAO,UAAU,YAAY,UAAU,MAAM;AAC/C,SAAO,OAAO,YACZ,OAAO,QAAQ,MAAM,CAAC,KAAK,CAAC,KAAK,UAAU,CAAC,KAAK,iBAAiB,KAAK,CAAC,CAAC,CAC1E;;AAGH,QAAO;;AAGT,MAAM,aAAa,KAAK;AACxB,MAAM,iBAAiB,KAAK;AAE5B,MAAM,WAAW,UAA0B;AACzC,KAAI,CAAC,OAAO,SAAS,MAAM,IAAI,UAAU,GAAG;AAC1C,SAAO;;CAGT,MAAM,UAAU,KAAK,KAAK,MAAM,GAAG,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC;CAC9D,MAAM,YAAa,UAAU,aAAc,cAAc;AAEzD,QAAO,YAAY,iBAAiB,WAAW,aAAa;;AAG9D,MAAM,cAAc,UAA0B,CAAC,QAAQ,MAAM,GAAG;AAEhE,MAAM,mBACJ,aACA,aACwB;AACxB,KACE,gBAAgB,QAChB,gBAAgB,aACf,OAAO,gBAAgB,YACtB,OAAO,gBAAgB,YACvB,OAAO,gBAAgB,YACvB,OAAO,gBAAgB,WACzB;AACA,SAAO;;AAGT,QAAQ,YAAiD;;AAK3D,MAAM,yBAAyB,OAAO,8BAA8B;AAMpE,MAAM,4BACJ,UAEA,OAAO,UAAU,YACjB,UAAU,QACV,0BAA0B;AAE5B,MAAM,gCAAgC,UACpC,yBAAyB,MAAM,GAAG,MAAM,0BAA0B;AAEpE,OAAO,MAAM,gCACX,WAC4B,GAC3B,yBAAyB,OAC3B;AAED,MAAM,sBACJ,SACA,OACA,KACA,KACA,UACY;AACZ,KAAI,QAAQ,SAAS,cAAc;AACjC,MAAI,IAAI,QAAQ,MAAM,MAAM;AAC5B,SAAO;;AAGT,KAAI,QAAQ,SAAS,qBAAqB;AACxC,SAAO,mBACL,QAAQ,MACR,UAAU,YACN,eAAe,QAAQ,OAAO,KAAK,KAAK,MAAM,GAC9C,OACJ,KACA,KACA,MACD;;AAGH,KAAI,QAAQ,SAAS,iBAAiB;AACpC,MAAI,OAAO,UAAU,YAAY,UAAU,MAAM;AAC/C,UAAO;;AAGT,SAAO,QAAQ,WAAW,OAAO,aAAa;AAC5C,OAAI,SAAS,SAAS,eAAe;AACnC,WAAO;;GAGT,IAAI;AACJ,OAAI,SAAS,UAAU;AACrB,UAAM,eAAe,SAAS,KAAmB,KAAK,KAAK,MAAM;cACxD,SAAS,IAAI,SAAS,cAAc;AAC7C,UAAM,SAAS,IAAI;cACV,SAAS,IAAI,SAAS,WAAW;AAC1C,UAAM,SAAS,IAAI;;AAErB,OAAI,QAAQ,aAAa,QAAQ,MAAM;AACrC,WAAO;;AAGT,UAAO,mBACL,SAAS,OACT,gBAAgB,OAAO,IAAuB,EAC9C,KACA,KACA,MACD;IACD;;AAGJ,KAAI,QAAQ,SAAS,gBAAgB;AACnC,MAAI,CAAC,MAAM,QAAQ,MAAM,EAAE;AACzB,UAAO;;AAGT,SAAO,QAAQ,SAAS,OAAO,SAAS,UACtC,UACI,mBAAmB,SAAS,MAAM,QAAQ,KAAK,KAAK,MAAM,GAC1D,KACL;;AAGH,QAAO;;AAGT,MAAM,qBACJ,aACA,WACA,UACA,KACA,KACA,UACwB;CACxB,MAAM,eAAe,SAAwD;AAC3E,MAAI,KAAK,SAAS,cAAc;AAC9B,UAAO,KAAK,SAAS,cAAc,EAAE,MAAM,EAAE,EAAE,GAAG;;AAGpD,MAAI,KAAK,SAAS,oBAAoB;AACpC,UAAO;;EAGT,MAAM,SAAS,YAAY,KAAK,OAAO;AACvC,MAAI,CAAC,QAAQ;AACX,UAAO;;EAGT,IAAI;AACJ,MAAI,KAAK,UAAU;AACjB,SAAM,eAAe,KAAK,UAAwB,KAAK,KAAK,MAAM;aACzD,KAAK,SAAS,SAAS,cAAc;AAC9C,SAAM,KAAK,SAAS;;AAEtB,MACE,QAAQ,aACR,QAAQ,QACP,OAAO,QAAQ,YAAY,OAAO,QAAQ,UAC3C;AACA,UAAO;;AAGT,SAAO,EACL,MAAM,CAAC,GAAG,OAAO,MAAM,IAAI,EAC5B;;CAGH,MAAM,WAAW,YACf,SAAS,SAAS,yBAAyB,SAAS,OAAO,SAAS,SACrE;AACD,KAAI,CAAC,UAAU;AACb,SAAO;;CAGT,MAAM,SAAS,iBAAiB,UAAU;AAC1C,KAAI,SAAS,KAAK,WAAW,GAAG;AAC9B,MAAI,SAAS,SAAS,wBAAwB;AAC5C,UAAO;;AAGT,SAAO,eAAe,SAAS,OAAO,KAAK,KAAK,MAAM;;CAGxD,IAAI,SAAS;AACb,MAAK,IAAI,MAAM,GAAG,MAAM,SAAS,KAAK,SAAS,GAAG,OAAO,GAAG;EAC1D,MAAM,MAAM,SAAS,KAAK;EAC1B,MAAM,OAAO,SAAS;AACtB,MAAI,OAAO,SAAS,YAAY,SAAS,MAAM;AAC7C,UAAO;;AAGT,WAAS;;CAGX,MAAM,UAAU,SAAS,KAAK,SAAS,KAAK,SAAS;AACrD,KAAI,SAAS,SAAS,wBAAwB;EAC5C,MAAM,YAAY,eAAe,SAAS,OAAO,KAAK,KAAK,MAAM;AACjE,MAAI,cAAc,WAAW;AAC3B,UAAO;;AAGT,SAAO,WAAW;AAClB,SAAO;;CAGT,MAAM,eAAe,OAAO;AAC5B,KAAI,OAAO,iBAAiB,UAAU;AACpC,SAAO;;AAGT,QAAO,WACL,SAAS,aAAa,OAAO,eAAe,IAAI,eAAe;AACjE,QAAO;;AAGT,MAAM,wBACJ,IACA,MACA,KACA,KACA,UACwB;AACxB,KAAI,GAAG,SAAS,CAAC,GAAG,MAAM;AACxB,SAAO;;CAGT,MAAM,WAAW,IAAI,IAAI,IAAI;AAC7B,MAAK,IAAI,MAAM,GAAG,MAAM,GAAG,OAAO,QAAQ,OAAO,GAAG;AAClD,MAAI,CAAC,mBAAmB,GAAG,OAAO,MAAM,KAAK,MAAM,KAAK,UAAU,MAAM,EAAE;AACxE,UAAO;;;AAIX,KAAI,GAAG,KAAK,SAAS,kBAAkB;AACrC,SAAO,eAAe,GAAG,MAAoB,KAAK,UAAU,MAAM;;AAGpE,MAAK,MAAM,aAAa,GAAG,KAAK,MAAM;AACpC,MAAI,UAAU,SAAS,uBAAuB;AAC5C,QAAK,MAAM,cAAc,UAAU,cAAc;IAC/C,MAAM,QAAQ,WAAW,OACrB,eAAe,WAAW,MAAM,KAAK,UAAU,MAAM,GACrD;AACJ,QAAI,CAAC,mBAAmB,WAAW,IAAI,OAAO,KAAK,UAAU,MAAM,EAAE;AACnE,YAAO;;;AAGX;;AAGF,MAAI,UAAU,SAAS,mBAAmB;AACxC,OAAI,CAAC,UAAU,UAAU;AACvB,WAAO;;AAGT,UAAO,eAAe,UAAU,UAAU,KAAK,UAAU,MAAM;;AAGjE,SAAO;;AAGT,QAAO;;AAGT,MAAM,sBAAsB,SAAwB;AAClD,KAAI,KAAK,SAAS,sBAAsB,KAAK,UAAU;AACrD,SAAO;;AAGT,KAAI,KAAK,SAAS,SAAS,gBAAgB,KAAK,SAAS,SAAS,OAAO;AACvE,SAAO;;AAGT,QAAO,KAAK,OAAO,SAAS,gBAAgB,KAAK,OAAO,SAAS;;AAGnE,MAAM,2BACJ,YACA,QAEA,WAAW,SAAS,sBACpB,mBAAmB,WAAW,OAAO,IACrC,CAAC,IAAI,IAAI,UAAU;AAErB,MAAM,sCACJ,YACA,KACA,QACY;AACZ,KAAI,wBAAwB,YAAY,IAAI,EAAE;AAC5C,SAAO;;AAGT,KAAI,WAAW,SAAS,qBAAqB,WAAW,aAAa,QAAQ;AAC3E,SAAO;;AAGT,QACE,WAAW,SAAS,gBACpB,WAAW,SAAS,eACpB,CAAC,iBAAiB,KAAK,WAAW,MAAM,WAAW,MAAM;;AAI7D,MAAM,kBACJ,YACA,KACA,MAAe,IAAI,KAAK,EACxB,QAAkB,EAAE,KACI;AACxB,KAAI,WAAW,SAAS,oBAAoB;AAC1C,SAAO;;CAGT,MAAM,OAAO,eAAe,WAAW,MAAoB,KAAK,KAAK,MAAM;CAC3E,MAAM,QAAQ,eAAe,WAAW,OAAqB,KAAK,KAAK,MAAM;CAE7E,MAAM,+BACJ,SAAS,aACT,mCAAmC,WAAW,MAAoB,KAAK,IAAI;CAC7E,MAAM,gCACJ,UAAU,aACV,mCACE,WAAW,OACX,KACA,IACD;AAEH,KACG,SAAS,aAAa,CAAC,gCACvB,UAAU,aAAa,CAAC,+BACzB;AACA,SAAO;;AAGT,SAAQ,WAAW,UAAnB;EACE,KAAK,MACH,QAAO,SAAS;EAClB,KAAK,MACH,QAAO,SAAS;EAClB,KAAK;;AAEH,SAAO,QAAQ;EACjB,KAAK;;AAEH,SAAO,QAAQ;EACjB,QACE;;AAGJ,KAAI,WAAW,aAAa,KAAK;AAC/B,MAAI,OAAO,SAAS,YAAY,OAAO,UAAU,UAAU;AACzD,UAAO,OAAO;;AAGhB,OACG,OAAO,SAAS,YAAY,OAAO,SAAS,cAC5C,OAAO,UAAU,YAAY,OAAO,UAAU,WAC/C;AACA,UAAO,GAAG,OAAO;;;AAIrB,KAAI,OAAO,SAAS,YAAY,OAAO,UAAU,UAAU;AACzD,UAAQ,WAAW,UAAnB;GACE,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,KACH,QAAO,QAAQ;GACjB,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,KACH,QAAO,QAAQ;GACjB,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,IACH,QAAO,OAAO;GAChB,KAAK,KACH,QAAO,QAAQ;GACjB,QACE;;;AAIN,QAAO;;AAGT,OAAO,MAAM,kBACX,YACA,KACA,MAAe,IAAI,KAAK,EACxB,QAAkB,EAAE,KACI;AACxB,KACE,WAAW,SAAS,oBACpB,WAAW,SAAS,2BACpB,WAAW,SAAS,yBACpB,WAAW,SAAS,+BACpB,WAAW,SAAS,qBACpB,WAAW,SAAS,2BACpB;AACA,SAAO,eAAe,WAAW,YAA0B,KAAK,KAAK,MAAM;;AAG7E,KAAI,WAAW,SAAS,WAAW;AACjC,SAAO,WAAW;;AAGpB,KAAI,WAAW,SAAS,mBAAmB;AACzC,MAAI,WAAW,aAAa,UAAU;GACpC,MAAM,wBAAwB,wBAC5B,WAAW,UACX,IACD;;;;;GAKD,MAAM,6BACJ,WAAW,SAAS,SAAS,gBAC7B,CAAC,iBACC,KACA,WAAW,SAAS,MACpB,WAAW,SAAS,MACrB;GACH,MAAM,MAAM,eACV,WAAW,UACX,KACA,KACA,MACD;AACD,OAAI,QAAQ,WAAW;AACrB,WAAO,yBAAyB,6BAC5B,cACA;;AAGN,UAAO,OAAO;;EAGhB,MAAM,MAAM,eACV,WAAW,UACX,KACA,KACA,MACD;AACD,MAAI,QAAQ,WAAW;AACrB,UAAO;;AAGT,UAAQ,WAAW,UAAnB;GACE,KAAK,IACH,QAAO,OAAO,QAAQ,WAAW,CAAC,MAAM;GAC1C,KAAK,IACH,QAAO,OAAO,QAAQ,WAAW,CAAC,MAAM;GAC1C,KAAK,IACH,QAAO,CAAC;GACV,KAAK,IACH,QAAO,OAAO,QAAQ,WAAW,WAAW,IAAI,GAAG;GACrD,KAAK,OACH,QAAO;GACT,QACE,QAAO;;;AAIb,KAAI,WAAW,SAAS,qBAAqB;EAC3C,MAAM,OAAO,eAAe,WAAW,MAAM,KAAK,KAAK,MAAM;;;;;EAK7D,MAAM,yBAAyB,wBAC7B,WAAW,MACX,IACD;AAED,MAAI,SAAS,aAAa,CAAC,wBAAwB;AACjD,UAAO;;AAGT,MAAI,WAAW,aAAa,MAAM;AAChC,UAAO,QAAQ,eAAe,WAAW,OAAO,KAAK,KAAK,MAAM;;AAGlE,MAAI,WAAW,aAAa,MAAM;AAChC,UAAO,QAAQ,eAAe,WAAW,OAAO,KAAK,KAAK,MAAM;;AAGlE,MAAI,WAAW,aAAa,MAAM;AAChC,UAAO,QAAQ,eAAe,WAAW,OAAO,KAAK,KAAK,MAAM;;AAGlE,SAAO;;AAGT,KAAI,WAAW,SAAS,yBAAyB;EAC/C,MAAM,OAAO,eAAe,WAAW,MAAM,KAAK,KAAK,MAAM;AAC7D,MAAI,SAAS,WAAW;AACtB,UAAO;;AAGT,SAAO,eACL,OAAO,WAAW,aAAa,WAAW,WAC1C,KACA,KACA,MACD;;AAGH,KAAI,WAAW,SAAS,mBAAmB;EACzC,IAAI,SAAS;AAEb,OAAK,IAAI,MAAM,GAAG,MAAM,WAAW,OAAO,QAAQ,OAAO,GAAG;AAC1D,aAAU,WAAW,OAAO,MAAM,MAAM,UAAU;GAElD,MAAM,iBAAiB,WAAW,YAAY;AAC9C,OAAI,CAAC,gBAAgB;AACnB;;GAGF,MAAM,QAAQ,eAAe,gBAAgB,KAAK,KAAK,MAAM;AAC7D,OACE,UAAU,aACT,OAAO,UAAU,YAAY,OAAO,UAAU,UAC/C;AACA,WAAO;;AAGT,aAAU,OAAO,MAAM;;AAGzB,SAAO;;AAGT,KAAI,WAAW,SAAS,cAAc;AACpC,MAAI,IAAI,IAAI,WAAW,KAAK,EAAE;AAC5B,UAAO,6BAA6B,IAAI,IAAI,WAAW,KAAK,CAAC;;EAG/D,MAAM,UAAU,iBAAiB,KAAK,WAAW,MAAM,WAAW,MAAM;AACxE,MAAI,SAAS,cAAc;;;;GAIzB,MAAM,WAAW,oBACf,IAAI,gBACJ,QAAQ,cACR,QAAQ,SACT;AACD,OAAI,SAAS,SAAS,OAAO,SAAS,UAAU,YAAY;AAC1D,WAAO,SAAS;;AAElB,UAAO;;AAET,MAAI,CAAC,SAAS;AACZ,UAAO;;AAGT,MAAI,QAAQ,SAAS,SAAS;AAC5B,UAAO;;AAGT,MAAI,MAAM,SAAS,QAAQ,KAAK,EAAE;AAChC,UAAO;;EAGT,IAAI;EACJ,MAAM,EAAE,eAAe;EACvB,MAAM,OAAO,YAAY;AACzB,MAAI,MAAM;AACR,OAAI,WAAW,GAAG,SAAS,cAAc;AACvC,WAAO;;AAGT,WAAQ,eAAe,MAAM,KAAK,KAAK,CAAC,GAAG,OAAO,QAAQ,KAAK,CAAC;aACvD,QAAQ,cAAc;AAC/B,WAAQ,QAAQ;;AAGlB,MACE,UAAU,aACV,QAAQ,UACR,OAAO,UAAU,YACjB,UAAU,QACV,CAAC,MAAM,QAAQ,MAAM,EACrB;GACA,MAAM,YAAY,IAAI,uBAAuB,IAAI,QAAQ,KAAK,IAAI,EAAE;GACpE,IAAI,YAAY,iBAAiB,MAAM;AACvC,QAAK,MAAM,YAAY,WAAW;AAChC,QAAI,SAAS,SAAS,IAAI,wBAAwB;AAChD;;IAGF,MAAM,UAAU,kBACd,QAAQ,MACR,WACA,UACA,KACA,KACA,CAAC,GAAG,OAAO,QAAQ,KAAK,CACzB;AACD,QAAI,YAAY,WAAW;AACzB,YAAO;;AAGT,gBAAY;;AAGd,UAAO;;AAGT,SAAO;;AAGT,KAAI,WAAW,SAAS,oBAAoB;EAC1C,MAAM,SAAkC,EAAE;AAE1C,OAAK,MAAM,YAAY,WAAW,YAAY;AAC5C,OAAI,SAAS,SAAS,iBAAiB;IACrC,MAAM,cAAc,eAAe,SAAS,UAAU,KAAK,KAAK,MAAM;AACtE,QAAI,OAAO,gBAAgB,YAAY,gBAAgB,MAAM;AAC3D,YAAO;;AAGT,WAAO,OAAO,QAAQ,YAAY;AAClC;;GAGF,IAAI;AACJ,OAAI,SAAS,UAAU;AACrB,UAAM,eAAe,SAAS,KAAmB,KAAK,KAAK,MAAM;cACxD,SAAS,IAAI,SAAS,cAAc;AAC7C,UAAM,SAAS,IAAI;cACV,SAAS,IAAI,SAAS,WAAW;AAC1C,UAAM,SAAS,IAAI;;AAErB,OACE,QAAQ,aACR,QAAQ,QACP,OAAO,QAAQ,YAAY,OAAO,QAAQ,UAC3C;AACA,WAAO;;GAGT,MAAM,QAAQ,eAAe,SAAS,OAAO,KAAK,KAAK,MAAM;AAC7D,OAAI,UAAU,WAAW;AACvB,WAAO;;AAGT,UAAO,OAAO;;AAGhB,SAAO;;AAGT,KAAI,WAAW,SAAS,mBAAmB;EACzC,MAAM,SAAoB,EAAE;AAE5B,OAAK,MAAM,WAAW,WAAW,UAAU;AACzC,OAAI,CAAC,SAAS;AACZ,WAAO;;AAGT,OAAI,QAAQ,SAAS,iBAAiB;IACpC,MAAM,cAAc,eAAe,QAAQ,UAAU,KAAK,KAAK,MAAM;AACrE,QAAI,CAAC,MAAM,QAAQ,YAAY,EAAE;AAC/B,YAAO;;AAGT,WAAO,KAAK,GAAG,YAAY;AAC3B;;GAGF,MAAM,QAAQ,eAAe,SAAS,KAAK,KAAK,MAAM;AACtD,OAAI,UAAU,WAAW;AACvB,WAAO;;AAGT,UAAO,KAAK,MAAM;;AAGpB,SAAO;;AAGT,KAAI,WAAW,SAAS,oBAAoB;EAC1C,IAAI;AACJ,MAAI,WAAW,UAAU;AACvB,SAAM,eAAe,WAAW,UAAwB,KAAK,KAAK,MAAM;aAC/D,WAAW,SAAS,SAAS,cAAc;AACpD,SAAM,WAAW,SAAS;;AAE5B,MACE,QAAQ,aACR,QAAQ,QACP,OAAO,QAAQ,YAAY,OAAO,QAAQ,UAC3C;AACA,UAAO;;AAGT,MAAI,wBAAwB,YAAY,IAAI,IAAI,OAAO,QAAQ,UAAU;;;;;AAKvE,UAAO;;EAGT,MAAM,cAAc,eAAe,WAAW,QAAQ,KAAK,KAAK,MAAM;AACtE,MAAI,gBAAgB,WAAW;AAC7B,UAAO;;AAGT,SAAO,gBAAgB,aAAa,IAAI;;AAG1C,KAAI,WAAW,SAAS,iBAAiB;AACvC,MACE,WAAW,OAAO,SAAS,gBAC3B,WAAW,UAAU,WAAW,GAChC;AACA,UAAO;;EAGT,MAAM,CAAC,YAAY,WAAW;AAC9B,MAAI,CAAC,YAAY,SAAS,SAAS,iBAAiB;AAClD,UAAO;;EAGT,MAAM,QAAQ,eAAe,UAAU,KAAK,KAAK,MAAM;AACvD,MAAI,UAAU,WAAW;AACvB,UAAO;;AAGT,MAAI,WAAW,OAAO,SAAS,UAAU;AACvC,UAAO,OAAO,MAAM;;AAGtB,MAAI,WAAW,OAAO,SAAS,UAAU;AACvC,UAAO,OAAO,MAAM;;AAGtB,MAAI,WAAW,OAAO,SAAS,WAAW;AACxC,UAAO,QAAQ,MAAM;;AAGvB,SAAO;;AAGT,KAAI,WAAW,SAAS,kBAAkB;AACxC,MAAI,WAAW,OAAO,SAAS,cAAc;GAC3C,MAAM,OAAO,WAAW,UAAU,KAAK,QACrC,IAAI,SAAS,kBACT,YACA,eAAe,KAAK,KAAK,KAAK,MAAM,CACzC;AACD,OAAI,KAAK,MAAM,UAAU,UAAU,UAAU,EAAE;AAC7C,WAAO;;GAGT,MAAM,iBAAiB,IAAI,IAAI,WAAW,OAAO,KAAK;AACtD,OACE,yBAAyB,eAAe,IACxC,WAAW,UAAU,WAAW,GAChC;AACA,WAAO,6BAA6B,eAAe;;;;AAKrD,OAAI,OAAO,mBAAmB,YAAY;AACxC,QAAI;AACF,YAAQ,eAAgD,GAAG,KAAK;YAC1D;AACN,YAAO;;;AAIX,OAAI,WAAW,OAAO,SAAS,YAAY,KAAK,WAAW,GAAG;AAC5D,WAAO,OAAO,KAAK,GAAG;;AAGxB,OAAI,WAAW,OAAO,SAAS,YAAY,KAAK,WAAW,GAAG;AAC5D,WAAO,OAAO,KAAK,GAAG;;AAGxB,OAAI,WAAW,OAAO,SAAS,aAAa,KAAK,WAAW,GAAG;AAC7D,WAAO,QAAQ,KAAK,GAAG;;GAGzB,MAAM,UAAU,iBACd,KACA,WAAW,OAAO,MAClB,WAAW,OAAO,MACnB;;;;;AAMD,OAAI,SAAS,cAAc;IACzB,MAAM,WAAW,oBACf,IAAI,gBACJ,QAAQ,cACR,QAAQ,SACT;AACD,QAAI,SAAS,SAAS,OAAO,SAAS,UAAU,YAAY;AAC1D,SAAI;AACF,aAAQ,SAAS,MAAuC,GAAG,KAAK;aAC1D;AACN,aAAO;;;;GAKb,MAAM,KAAK,SAAS,gBAAgB,SAAS,YAAY;AACzD,OACE,OACC,GAAG,SAAS,6BACX,GAAG,SAAS,yBACZ,GAAG,SAAS,uBACd;AACA,WAAO,qBAAqB,IAAI,MAAM,KAAK,KAAK,CAC9C,GAAG,OACH,WAAW,OAAO,KACnB,CAAC;;;AAIN,MAAI,WAAW,OAAO,SAAS,oBAAoB;GACjD,MAAM,cAAc,eAClB,WAAW,OAAO,QAClB,KACA,KACA,MACD;GACD,IAAI;AACJ,OAAI,WAAW,OAAO,UAAU;AAC9B,UAAM,eACJ,WAAW,OAAO,UAClB,KACA,KACA,MACD;cACQ,WAAW,OAAO,SAAS,SAAS,cAAc;AAC3D,UAAM,WAAW,OAAO,SAAS;;AAEnC,OAAI,OAAO,gBAAgB,UAAU;AACnC,QAAI,QAAQ,iBAAiB,WAAW,UAAU,WAAW,GAAG;AAC9D,YAAO,YAAY,aAAa;;AAGlC,QAAI,QAAQ,iBAAiB,WAAW,UAAU,WAAW,GAAG;AAC9D,YAAO,YAAY,aAAa;;;;;AAMxC,QAAO,eAAe,YAAY,KAAK,KAAK,MAAM","names":[],"sources":["../../../src/utils/collectOxcTemplateDependencies/staticEvaluator.ts"],"version":3,"sourcesContent":["/* eslint-disable no-restricted-syntax,no-continue,@typescript-eslint/no-use-before-define */\n\nimport type {\n AssignmentExpression,\n Expression,\n Node,\n UpdateExpression,\n} from 'oxc-parser';\n\nimport { lookupStaticBinding } from './staticBindings';\nimport { resolveBindingAt } from './scopeAnalysis';\nimport type { ExtractionContext, OxcFunctionLikeNode } from './types';\n\nexport const literalCode = (value: unknown): string | null => {\n if (typeof value === 'number') {\n return Number.isFinite(value) ? JSON.stringify(value) : null;\n }\n\n if (\n value === null ||\n typeof value === 'string' ||\n typeof value === 'boolean'\n ) {\n return JSON.stringify(value);\n }\n\n if (Array.isArray(value)) {\n return JSON.stringify(value);\n }\n\n if (typeof value === 'object' && value !== null) {\n return `(${JSON.stringify(value)})`;\n }\n\n return null;\n};\n\nexport const isStaticSerializableValue = (value: unknown): boolean =>\n literalCode(value) !== null;\n\nexport const cloneStaticValue = (value: unknown): unknown => {\n if (Array.isArray(value)) {\n return value.map((item) => cloneStaticValue(item));\n }\n\n if (typeof value === 'object' && value !== null) {\n return Object.fromEntries(\n Object.entries(value).map(([key, item]) => [key, cloneStaticValue(item)])\n );\n }\n\n return value;\n};\n\nconst INT32_SIZE = 2 ** 32;\nconst INT32_SIGN_BIT = 2 ** 31;\n\nconst toInt32 = (value: number): number => {\n if (!Number.isFinite(value) || value === 0) {\n return 0;\n }\n\n const integer = Math.sign(value) * Math.floor(Math.abs(value));\n const int32bit = ((integer % INT32_SIZE) + INT32_SIZE) % INT32_SIZE;\n\n return int32bit >= INT32_SIGN_BIT ? int32bit - INT32_SIZE : int32bit;\n};\n\nconst bitwiseNot = (value: number): number => -toInt32(value) - 1;\n\nconst getObjectMember = (\n objectValue: unknown,\n property: string | number\n): unknown | undefined => {\n if (\n objectValue === null ||\n objectValue === undefined ||\n (typeof objectValue !== 'object' &&\n typeof objectValue !== 'string' &&\n typeof objectValue !== 'number' &&\n typeof objectValue !== 'boolean')\n ) {\n return undefined;\n }\n\n return (objectValue as Record<string | number, unknown>)[property];\n};\n\ntype EvalEnv = Map<string, unknown>;\n\nconst oxcStaticCallableValue = Symbol('wyw.oxc.staticCallableValue');\n\ntype OxcStaticCallableValue = {\n [oxcStaticCallableValue]: unknown;\n};\n\nconst isOxcStaticCallableValue = (\n value: unknown\n): value is OxcStaticCallableValue =>\n typeof value === 'object' &&\n value !== null &&\n oxcStaticCallableValue in value;\n\nconst unwrapOxcStaticCallableValue = (value: unknown): unknown =>\n isOxcStaticCallableValue(value) ? value[oxcStaticCallableValue] : value;\n\nexport const createOxcStaticCallableValue = (\n value: unknown\n): OxcStaticCallableValue => ({\n [oxcStaticCallableValue]: value,\n});\n\nconst assignPatternValue = (\n pattern: Node,\n value: unknown,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): boolean => {\n if (pattern.type === 'Identifier') {\n env.set(pattern.name, value);\n return true;\n }\n\n if (pattern.type === 'AssignmentPattern') {\n return assignPatternValue(\n pattern.left,\n value === undefined\n ? evaluateStatic(pattern.right, ctx, env, stack)\n : value,\n ctx,\n env,\n stack\n );\n }\n\n if (pattern.type === 'ObjectPattern') {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n\n return pattern.properties.every((property) => {\n if (property.type === 'RestElement') {\n return false;\n }\n\n let key: unknown;\n if (property.computed) {\n key = evaluateStatic(property.key as Expression, ctx, env, stack);\n } else if (property.key.type === 'Identifier') {\n key = property.key.name;\n } else if (property.key.type === 'Literal') {\n key = property.key.value;\n }\n if (key === undefined || key === null) {\n return false;\n }\n\n return assignPatternValue(\n property.value,\n getObjectMember(value, key as string | number),\n ctx,\n env,\n stack\n );\n });\n }\n\n if (pattern.type === 'ArrayPattern') {\n if (!Array.isArray(value)) {\n return false;\n }\n\n return pattern.elements.every((element, index) =>\n element\n ? assignPatternValue(element, value[index], ctx, env, stack)\n : true\n );\n }\n\n return false;\n};\n\nconst applyRootMutation = (\n bindingName: string,\n baseValue: unknown,\n mutation: AssignmentExpression | UpdateExpression,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n const resolvePath = (node: Node): { path: Array<string | number> } | null => {\n if (node.type === 'Identifier') {\n return node.name === bindingName ? { path: [] } : null;\n }\n\n if (node.type !== 'MemberExpression') {\n return null;\n }\n\n const parent = resolvePath(node.object);\n if (!parent) {\n return null;\n }\n\n let key: unknown;\n if (node.computed) {\n key = evaluateStatic(node.property as Expression, ctx, env, stack);\n } else if (node.property.type === 'Identifier') {\n key = node.property.name;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return null;\n }\n\n return {\n path: [...parent.path, key],\n };\n };\n\n const pathInfo = resolvePath(\n mutation.type === 'AssignmentExpression' ? mutation.left : mutation.argument\n );\n if (!pathInfo) {\n return undefined;\n }\n\n const cloned = cloneStaticValue(baseValue);\n if (pathInfo.path.length === 0) {\n if (mutation.type !== 'AssignmentExpression') {\n return undefined;\n }\n\n return evaluateStatic(mutation.right, ctx, env, stack);\n }\n\n let target = cloned as Record<string | number, unknown>;\n for (let idx = 0; idx < pathInfo.path.length - 1; idx += 1) {\n const key = pathInfo.path[idx];\n const next = target?.[key];\n if (typeof next !== 'object' || next === null) {\n return undefined;\n }\n\n target = next as Record<string | number, unknown>;\n }\n\n const lastKey = pathInfo.path[pathInfo.path.length - 1]!;\n if (mutation.type === 'AssignmentExpression') {\n const nextValue = evaluateStatic(mutation.right, ctx, env, stack);\n if (nextValue === undefined) {\n return undefined;\n }\n\n target[lastKey] = nextValue;\n return cloned;\n }\n\n const currentValue = target[lastKey];\n if (typeof currentValue !== 'number') {\n return undefined;\n }\n\n target[lastKey] =\n mutation.operator === '++' ? currentValue + 1 : currentValue - 1;\n return cloned;\n};\n\nconst evaluateFunctionCall = (\n fn: OxcFunctionLikeNode,\n args: unknown[],\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n if (fn.async || !fn.body) {\n return undefined;\n }\n\n const localEnv = new Map(env);\n for (let idx = 0; idx < fn.params.length; idx += 1) {\n if (!assignPatternValue(fn.params[idx], args[idx], ctx, localEnv, stack)) {\n return undefined;\n }\n }\n\n if (fn.body.type !== 'BlockStatement') {\n return evaluateStatic(fn.body as Expression, ctx, localEnv, stack);\n }\n\n for (const statement of fn.body.body) {\n if (statement.type === 'VariableDeclaration') {\n for (const declarator of statement.declarations) {\n const value = declarator.init\n ? evaluateStatic(declarator.init, ctx, localEnv, stack)\n : undefined;\n if (!assignPatternValue(declarator.id, value, ctx, localEnv, stack)) {\n return undefined;\n }\n }\n continue;\n }\n\n if (statement.type === 'ReturnStatement') {\n if (!statement.argument) {\n return undefined;\n }\n\n return evaluateStatic(statement.argument, ctx, localEnv, stack);\n }\n\n return undefined;\n }\n\n return undefined;\n};\n\nconst isProcessEnvMember = (node: Node): boolean => {\n if (node.type !== 'MemberExpression' || node.computed) {\n return false;\n }\n\n if (node.property.type !== 'Identifier' || node.property.name !== 'env') {\n return false;\n }\n\n return node.object.type === 'Identifier' && node.object.name === 'process';\n};\n\nconst isProcessEnvValueAccess = (\n expression: Expression,\n env: EvalEnv\n): boolean =>\n expression.type === 'MemberExpression' &&\n isProcessEnvMember(expression.object) &&\n !env.has('process');\n\nconst isDeterministicUndefinedExpression = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv\n): boolean => {\n if (isProcessEnvValueAccess(expression, env)) {\n return true;\n }\n\n if (expression.type === 'UnaryExpression' && expression.operator === 'void') {\n return true;\n }\n\n return (\n expression.type === 'Identifier' &&\n expression.name === 'undefined' &&\n !resolveBindingAt(ctx, expression.name, expression.start)\n );\n};\n\nconst evaluateBinary = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv = new Map(),\n stack: string[] = []\n): unknown | undefined => {\n if (expression.type !== 'BinaryExpression') {\n return undefined;\n }\n\n const left = evaluateStatic(expression.left as Expression, ctx, env, stack);\n const right = evaluateStatic(expression.right as Expression, ctx, env, stack);\n\n const leftIsDeterministicUndefined =\n left === undefined &&\n isDeterministicUndefinedExpression(expression.left as Expression, ctx, env);\n const rightIsDeterministicUndefined =\n right === undefined &&\n isDeterministicUndefinedExpression(\n expression.right as Expression,\n ctx,\n env\n );\n\n if (\n (left === undefined && !leftIsDeterministicUndefined) ||\n (right === undefined && !rightIsDeterministicUndefined)\n ) {\n return undefined;\n }\n\n switch (expression.operator) {\n case '===':\n return left === right;\n case '!==':\n return left !== right;\n case '==':\n // eslint-disable-next-line eqeqeq\n return left == right;\n case '!=':\n // eslint-disable-next-line eqeqeq\n return left != right;\n default:\n break;\n }\n\n if (expression.operator === '+') {\n if (typeof left === 'number' && typeof right === 'number') {\n return left + right;\n }\n\n if (\n (typeof left === 'string' || typeof left === 'number') &&\n (typeof right === 'string' || typeof right === 'number')\n ) {\n return `${left}${right}`;\n }\n }\n\n if (typeof left === 'number' && typeof right === 'number') {\n switch (expression.operator) {\n case '<':\n return left < right;\n case '<=':\n return left <= right;\n case '>':\n return left > right;\n case '>=':\n return left >= right;\n case '-':\n return left - right;\n case '*':\n return left * right;\n case '/':\n return left / right;\n case '%':\n return left % right;\n case '**':\n return left ** right;\n default:\n break;\n }\n }\n\n return undefined;\n};\n\nexport const evaluateStatic = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv = new Map(),\n stack: string[] = []\n): unknown | undefined => {\n if (\n expression.type === 'TSAsExpression' ||\n expression.type === 'TSSatisfiesExpression' ||\n expression.type === 'TSNonNullExpression' ||\n expression.type === 'TSInstantiationExpression' ||\n expression.type === 'TSTypeAssertion' ||\n expression.type === 'ParenthesizedExpression'\n ) {\n return evaluateStatic(expression.expression as Expression, ctx, env, stack);\n }\n\n if (expression.type === 'Literal') {\n return expression.value;\n }\n\n if (expression.type === 'UnaryExpression') {\n if (expression.operator === 'typeof') {\n const argIsProcessEnvAccess = isProcessEnvValueAccess(\n expression.argument as Expression,\n env\n );\n // `typeof someIdentifier` is the canonical undeclared-global\n // probe — it returns 'undefined' regardless of whether the\n // symbol is declared. Only fold truly unbound identifiers: declared\n // but dynamic locals still have runtime values we cannot infer.\n const argIsUnboundBareIdentifier =\n expression.argument.type === 'Identifier' &&\n !resolveBindingAt(\n ctx,\n expression.argument.name,\n expression.argument.start\n );\n const arg = evaluateStatic(\n expression.argument as Expression,\n ctx,\n env,\n stack\n );\n if (arg === undefined) {\n return argIsProcessEnvAccess || argIsUnboundBareIdentifier\n ? 'undefined'\n : undefined;\n }\n\n return typeof arg;\n }\n\n const arg = evaluateStatic(\n expression.argument as Expression,\n ctx,\n env,\n stack\n );\n if (arg === undefined) {\n return undefined;\n }\n\n switch (expression.operator) {\n case '-':\n return typeof arg === 'number' ? -arg : undefined;\n case '+':\n return typeof arg === 'number' ? +arg : undefined;\n case '!':\n return !arg;\n case '~':\n return typeof arg === 'number' ? bitwiseNot(arg) : undefined;\n case 'void':\n return undefined;\n default:\n return undefined;\n }\n }\n\n if (expression.type === 'LogicalExpression') {\n const left = evaluateStatic(expression.left, ctx, env, stack);\n // process.env.X access is the only source we trust as \"deterministically\n // undefined\" — it's a build-time lookup we control. For everything else,\n // undefined means \"couldn't evaluate\" and we must bail to avoid inlining\n // a wrong fallback when the runtime value isn't actually nullish.\n const leftIsProcessEnvAccess = isProcessEnvValueAccess(\n expression.left,\n env\n );\n\n if (left === undefined && !leftIsProcessEnvAccess) {\n return undefined;\n }\n\n if (expression.operator === '||') {\n return left || evaluateStatic(expression.right, ctx, env, stack);\n }\n\n if (expression.operator === '??') {\n return left ?? evaluateStatic(expression.right, ctx, env, stack);\n }\n\n if (expression.operator === '&&') {\n return left && evaluateStatic(expression.right, ctx, env, stack);\n }\n\n return undefined;\n }\n\n if (expression.type === 'ConditionalExpression') {\n const test = evaluateStatic(expression.test, ctx, env, stack);\n if (test === undefined) {\n return undefined;\n }\n\n return evaluateStatic(\n test ? expression.consequent : expression.alternate,\n ctx,\n env,\n stack\n );\n }\n\n if (expression.type === 'TemplateLiteral') {\n let result = '';\n\n for (let idx = 0; idx < expression.quasis.length; idx += 1) {\n result += expression.quasis[idx]?.value.cooked ?? '';\n\n const nextExpression = expression.expressions[idx];\n if (!nextExpression) {\n continue;\n }\n\n const value = evaluateStatic(nextExpression, ctx, env, stack);\n if (\n value === undefined ||\n (typeof value !== 'string' && typeof value !== 'number')\n ) {\n return undefined;\n }\n\n result += String(value);\n }\n\n return result;\n }\n\n if (expression.type === 'Identifier') {\n if (env.has(expression.name)) {\n return unwrapOxcStaticCallableValue(env.get(expression.name));\n }\n\n const binding = resolveBindingAt(ctx, expression.name, expression.start);\n if (binding?.importedFrom) {\n // staticBindings can supply a literal value for an imported name,\n // bypassing whatever the source module would otherwise resolve to.\n // Function values are deferred to the CallExpression branch.\n const override = lookupStaticBinding(\n ctx.staticBindings,\n binding.importedFrom,\n binding.imported\n );\n if (override.found && typeof override.value !== 'function') {\n return override.value;\n }\n return undefined;\n }\n if (!binding) {\n return undefined;\n }\n\n if (binding.kind === 'param') {\n return undefined;\n }\n\n if (stack.includes(binding.name)) {\n return undefined;\n }\n\n let value: unknown | undefined;\n const { declarator } = binding;\n const init = declarator?.init;\n if (init) {\n if (declarator.id.type !== 'Identifier') {\n return undefined;\n }\n\n value = evaluateStatic(init, ctx, env, [...stack, binding.name]);\n } else if (binding.functionNode) {\n value = binding.functionNode;\n }\n\n if (\n value !== undefined &&\n binding.isRoot &&\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value)\n ) {\n const mutations = ctx.rootMutationsByBinding.get(binding.name) ?? [];\n let nextValue = cloneStaticValue(value);\n for (const mutation of mutations) {\n if (mutation.start >= ctx.currentExpressionStart) {\n break;\n }\n\n const applied = applyRootMutation(\n binding.name,\n nextValue,\n mutation,\n ctx,\n env,\n [...stack, binding.name]\n );\n if (applied === undefined) {\n return undefined;\n }\n\n nextValue = applied;\n }\n\n return nextValue;\n }\n\n return value;\n }\n\n if (expression.type === 'ObjectExpression') {\n const result: Record<string, unknown> = {};\n\n for (const property of expression.properties) {\n if (property.type === 'SpreadElement') {\n const spreadValue = evaluateStatic(property.argument, ctx, env, stack);\n if (typeof spreadValue !== 'object' || spreadValue === null) {\n return undefined;\n }\n\n Object.assign(result, spreadValue);\n continue;\n }\n\n let key: unknown;\n if (property.computed) {\n key = evaluateStatic(property.key as Expression, ctx, env, stack);\n } else if (property.key.type === 'Identifier') {\n key = property.key.name;\n } else if (property.key.type === 'Literal') {\n key = property.key.value;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return undefined;\n }\n\n const value = evaluateStatic(property.value, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n result[key] = value;\n }\n\n return result;\n }\n\n if (expression.type === 'ArrayExpression') {\n const result: unknown[] = [];\n\n for (const element of expression.elements) {\n if (!element) {\n return undefined;\n }\n\n if (element.type === 'SpreadElement') {\n const spreadValue = evaluateStatic(element.argument, ctx, env, stack);\n if (!Array.isArray(spreadValue)) {\n return undefined;\n }\n\n result.push(...spreadValue);\n continue;\n }\n\n const value = evaluateStatic(element, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n result.push(value);\n }\n\n return result;\n }\n\n if (expression.type === 'MemberExpression') {\n let key: unknown;\n if (expression.computed) {\n key = evaluateStatic(expression.property as Expression, ctx, env, stack);\n } else if (expression.property.type === 'Identifier') {\n key = expression.property.name;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return undefined;\n }\n\n if (isProcessEnvValueAccess(expression, env) && typeof key === 'string') {\n // Treat process.env.X as deterministically undefined at build time.\n // Reading from real process.env would couple the bundle to whatever\n // happens to be set on the build machine; falling back to the\n // ?? / || branch (or a runtime read) is more predictable.\n return undefined;\n }\n\n const objectValue = evaluateStatic(expression.object, ctx, env, stack);\n if (objectValue === undefined) {\n return undefined;\n }\n\n return getObjectMember(objectValue, key);\n }\n\n if (expression.type === 'NewExpression') {\n if (\n expression.callee.type !== 'Identifier' ||\n expression.arguments.length !== 1\n ) {\n return undefined;\n }\n\n const [argument] = expression.arguments;\n if (!argument || argument.type === 'SpreadElement') {\n return undefined;\n }\n\n const value = evaluateStatic(argument, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n if (expression.callee.name === 'String') {\n return String(value);\n }\n\n if (expression.callee.name === 'Number') {\n return Number(value);\n }\n\n if (expression.callee.name === 'Boolean') {\n return Boolean(value);\n }\n\n return undefined;\n }\n\n if (expression.type === 'CallExpression') {\n if (expression.callee.type === 'Identifier') {\n const args = expression.arguments.map((arg) =>\n arg.type === 'SpreadElement'\n ? undefined\n : evaluateStatic(arg, ctx, env, stack)\n );\n if (args.some((value) => value === undefined)) {\n return undefined;\n }\n\n const staticCallable = env.get(expression.callee.name);\n if (\n isOxcStaticCallableValue(staticCallable) &&\n expression.arguments.length === 0\n ) {\n return unwrapOxcStaticCallableValue(staticCallable);\n }\n\n // Plain function in env (e.g. supplied via staticBindings as a\n // pure helper). Invoke with already-evaluated args.\n if (typeof staticCallable === 'function') {\n try {\n return (staticCallable as (...a: unknown[]) => unknown)(...args);\n } catch {\n return undefined;\n }\n }\n\n if (expression.callee.name === 'String' && args.length === 1) {\n return String(args[0]);\n }\n\n if (expression.callee.name === 'Number' && args.length === 1) {\n return Number(args[0]);\n }\n\n if (expression.callee.name === 'Boolean' && args.length === 1) {\n return Boolean(args[0]);\n }\n\n const binding = resolveBindingAt(\n ctx,\n expression.callee.name,\n expression.callee.start\n );\n\n // staticBindings can register a pure helper for an imported name\n // (e.g. linaria's `cx` from '@linaria/core'). When the callee\n // resolves to such an import and every arg evaluated, invoke the\n // helper and return its result as a static value.\n if (binding?.importedFrom) {\n const override = lookupStaticBinding(\n ctx.staticBindings,\n binding.importedFrom,\n binding.imported\n );\n if (override.found && typeof override.value === 'function') {\n try {\n return (override.value as (...a: unknown[]) => unknown)(...args);\n } catch {\n return undefined;\n }\n }\n }\n\n const fn = binding?.functionNode ?? binding?.declarator?.init;\n if (\n fn &&\n (fn.type === 'ArrowFunctionExpression' ||\n fn.type === 'FunctionDeclaration' ||\n fn.type === 'FunctionExpression')\n ) {\n return evaluateFunctionCall(fn, args, ctx, env, [\n ...stack,\n expression.callee.name,\n ]);\n }\n }\n\n if (expression.callee.type === 'MemberExpression') {\n const objectValue = evaluateStatic(\n expression.callee.object,\n ctx,\n env,\n stack\n );\n let key: unknown;\n if (expression.callee.computed) {\n key = evaluateStatic(\n expression.callee.property as Expression,\n ctx,\n env,\n stack\n );\n } else if (expression.callee.property.type === 'Identifier') {\n key = expression.callee.property.name;\n }\n if (typeof objectValue === 'string') {\n if (key === 'toLowerCase' && expression.arguments.length === 0) {\n return objectValue.toLowerCase();\n }\n\n if (key === 'toUpperCase' && expression.arguments.length === 0) {\n return objectValue.toUpperCase();\n }\n }\n }\n }\n\n return evaluateBinary(expression, ctx, env, stack);\n};\n"],"file":"staticEvaluator.js"}
|
|
1
|
+
{"mappings":"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","names":[],"sources":["../../../src/utils/collectOxcTemplateDependencies/staticEvaluator.ts"],"version":3,"sourcesContent":["/* eslint-disable no-restricted-syntax,no-continue,@typescript-eslint/no-use-before-define */\n\nimport type {\n AssignmentExpression,\n Expression,\n Node,\n UpdateExpression,\n} from 'oxc-parser';\n\nimport { lookupStaticBinding } from './staticBindings';\nimport { resolveBindingAt } from './scopeAnalysis';\nimport type { ExtractionContext, OxcFunctionLikeNode } from './types';\n\nexport const literalCode = (value: unknown): string | null => {\n if (typeof value === 'number') {\n return Number.isFinite(value) ? JSON.stringify(value) : null;\n }\n\n if (\n value === null ||\n typeof value === 'string' ||\n typeof value === 'boolean'\n ) {\n return JSON.stringify(value);\n }\n\n if (Array.isArray(value)) {\n return JSON.stringify(value);\n }\n\n if (typeof value === 'object' && value !== null) {\n return `(${JSON.stringify(value)})`;\n }\n\n return null;\n};\n\nexport const isStaticSerializableValue = (value: unknown): boolean =>\n literalCode(value) !== null;\n\nexport const cloneStaticValue = (value: unknown): unknown => {\n if (Array.isArray(value)) {\n return value.map((item) => cloneStaticValue(item));\n }\n\n if (typeof value === 'object' && value !== null) {\n return Object.fromEntries(\n Object.entries(value).map(([key, item]) => [key, cloneStaticValue(item)])\n );\n }\n\n return value;\n};\n\nconst INT32_SIZE = 2 ** 32;\nconst INT32_SIGN_BIT = 2 ** 31;\n\nconst toInt32 = (value: number): number => {\n if (!Number.isFinite(value) || value === 0) {\n return 0;\n }\n\n const integer = Math.sign(value) * Math.floor(Math.abs(value));\n const int32bit = ((integer % INT32_SIZE) + INT32_SIZE) % INT32_SIZE;\n\n return int32bit >= INT32_SIGN_BIT ? int32bit - INT32_SIZE : int32bit;\n};\n\nconst bitwiseNot = (value: number): number => -toInt32(value) - 1;\n\nconst getObjectMember = (\n objectValue: unknown,\n property: string | number\n): unknown | undefined => {\n if (\n objectValue === null ||\n objectValue === undefined ||\n (typeof objectValue !== 'object' &&\n typeof objectValue !== 'string' &&\n typeof objectValue !== 'number' &&\n typeof objectValue !== 'boolean')\n ) {\n return undefined;\n }\n\n return (objectValue as Record<string | number, unknown>)[property];\n};\n\nconst staticObjectPropertyKey = (\n property: Node & { computed?: boolean; key?: Node },\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): string | number | null => {\n if (!property.key) {\n return null;\n }\n\n let key: unknown;\n if (property.computed) {\n key = evaluateStatic(property.key as Expression, ctx, env, stack);\n } else if (property.key.type === 'Identifier') {\n key = property.key.name;\n } else if (property.key.type === 'Literal') {\n key = property.key.value;\n }\n\n return typeof key === 'string' || typeof key === 'number' ? key : null;\n};\n\nconst evaluateObjectExpressionMember = (\n expression: Expression,\n propertyKey: string | number,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n if (expression.type !== 'ObjectExpression') {\n return undefined;\n }\n\n for (let idx = expression.properties.length - 1; idx >= 0; idx -= 1) {\n const property = expression.properties[idx]!;\n if (property.type === 'SpreadElement') {\n return undefined;\n }\n\n const key = staticObjectPropertyKey(property, ctx, env, stack);\n if (key === null) {\n return undefined;\n }\n\n if (key === propertyKey) {\n return evaluateStatic(property.value, ctx, env, stack);\n }\n }\n\n return undefined;\n};\n\nconst evaluateKnownObjectMember = (\n expression: Expression,\n propertyKey: string | number,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n const objectMember = evaluateObjectExpressionMember(\n expression,\n propertyKey,\n ctx,\n env,\n stack\n );\n if (objectMember !== undefined) {\n return objectMember;\n }\n\n if (expression.type !== 'Identifier' || env.has(expression.name)) {\n return undefined;\n }\n\n const binding = resolveBindingAt(ctx, expression.name, expression.start);\n if (\n !binding ||\n binding.kind === 'param' ||\n binding.importedFrom ||\n binding.isRoot ||\n stack.includes(binding.name) ||\n !binding.declarator?.init ||\n binding.declarator.id.type !== 'Identifier'\n ) {\n return undefined;\n }\n\n return evaluateKnownObjectMember(\n binding.declarator.init,\n propertyKey,\n ctx,\n env,\n [...stack, binding.name]\n );\n};\n\ntype EvalEnv = Map<string, unknown>;\n\nconst oxcStaticCallableValue = Symbol('wyw.oxc.staticCallableValue');\n\ntype OxcStaticCallableValue = {\n [oxcStaticCallableValue]: unknown;\n};\n\nconst isOxcStaticCallableValue = (\n value: unknown\n): value is OxcStaticCallableValue =>\n typeof value === 'object' &&\n value !== null &&\n oxcStaticCallableValue in value;\n\nconst unwrapOxcStaticCallableValue = (value: unknown): unknown =>\n isOxcStaticCallableValue(value) ? value[oxcStaticCallableValue] : value;\n\nexport const createOxcStaticCallableValue = (\n value: unknown\n): OxcStaticCallableValue => ({\n [oxcStaticCallableValue]: value,\n});\n\nconst assignPatternValue = (\n pattern: Node,\n value: unknown,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): boolean => {\n if (pattern.type === 'Identifier') {\n env.set(pattern.name, value);\n return true;\n }\n\n if (pattern.type === 'AssignmentPattern') {\n return assignPatternValue(\n pattern.left,\n value === undefined\n ? evaluateStatic(pattern.right, ctx, env, stack)\n : value,\n ctx,\n env,\n stack\n );\n }\n\n if (pattern.type === 'ObjectPattern') {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n\n return pattern.properties.every((property) => {\n if (property.type === 'RestElement') {\n return false;\n }\n\n let key: unknown;\n if (property.computed) {\n key = evaluateStatic(property.key as Expression, ctx, env, stack);\n } else if (property.key.type === 'Identifier') {\n key = property.key.name;\n } else if (property.key.type === 'Literal') {\n key = property.key.value;\n }\n if (key === undefined || key === null) {\n return false;\n }\n\n return assignPatternValue(\n property.value,\n getObjectMember(value, key as string | number),\n ctx,\n env,\n stack\n );\n });\n }\n\n if (pattern.type === 'ArrayPattern') {\n if (!Array.isArray(value)) {\n return false;\n }\n\n return pattern.elements.every((element, index) =>\n element\n ? assignPatternValue(element, value[index], ctx, env, stack)\n : true\n );\n }\n\n return false;\n};\n\nconst applyRootMutation = (\n bindingName: string,\n baseValue: unknown,\n mutation: AssignmentExpression | UpdateExpression,\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n const resolvePath = (node: Node): { path: Array<string | number> } | null => {\n if (node.type === 'Identifier') {\n return node.name === bindingName ? { path: [] } : null;\n }\n\n if (node.type !== 'MemberExpression') {\n return null;\n }\n\n const parent = resolvePath(node.object);\n if (!parent) {\n return null;\n }\n\n let key: unknown;\n if (node.computed) {\n key = evaluateStatic(node.property as Expression, ctx, env, stack);\n } else if (node.property.type === 'Identifier') {\n key = node.property.name;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return null;\n }\n\n return {\n path: [...parent.path, key],\n };\n };\n\n const pathInfo = resolvePath(\n mutation.type === 'AssignmentExpression' ? mutation.left : mutation.argument\n );\n if (!pathInfo) {\n return undefined;\n }\n\n const cloned = cloneStaticValue(baseValue);\n if (pathInfo.path.length === 0) {\n if (mutation.type !== 'AssignmentExpression') {\n return undefined;\n }\n\n return evaluateStatic(mutation.right, ctx, env, stack);\n }\n\n let target = cloned as Record<string | number, unknown>;\n for (let idx = 0; idx < pathInfo.path.length - 1; idx += 1) {\n const key = pathInfo.path[idx];\n const next = target?.[key];\n if (typeof next !== 'object' || next === null) {\n return undefined;\n }\n\n target = next as Record<string | number, unknown>;\n }\n\n const lastKey = pathInfo.path[pathInfo.path.length - 1]!;\n if (mutation.type === 'AssignmentExpression') {\n const nextValue = evaluateStatic(mutation.right, ctx, env, stack);\n if (nextValue === undefined) {\n return undefined;\n }\n\n target[lastKey] = nextValue;\n return cloned;\n }\n\n const currentValue = target[lastKey];\n if (typeof currentValue !== 'number') {\n return undefined;\n }\n\n target[lastKey] =\n mutation.operator === '++' ? currentValue + 1 : currentValue - 1;\n return cloned;\n};\n\nconst evaluateFunctionCall = (\n fn: OxcFunctionLikeNode,\n args: unknown[],\n ctx: ExtractionContext,\n env: EvalEnv,\n stack: string[]\n): unknown | undefined => {\n if (fn.async || !fn.body) {\n return undefined;\n }\n\n const localEnv = new Map(env);\n for (let idx = 0; idx < fn.params.length; idx += 1) {\n if (!assignPatternValue(fn.params[idx], args[idx], ctx, localEnv, stack)) {\n return undefined;\n }\n }\n\n if (fn.body.type !== 'BlockStatement') {\n return evaluateStatic(fn.body as Expression, ctx, localEnv, stack);\n }\n\n for (const statement of fn.body.body) {\n if (statement.type === 'VariableDeclaration') {\n for (const declarator of statement.declarations) {\n const value = declarator.init\n ? evaluateStatic(declarator.init, ctx, localEnv, stack)\n : undefined;\n if (!assignPatternValue(declarator.id, value, ctx, localEnv, stack)) {\n return undefined;\n }\n }\n continue;\n }\n\n if (statement.type === 'ReturnStatement') {\n if (!statement.argument) {\n return undefined;\n }\n\n return evaluateStatic(statement.argument, ctx, localEnv, stack);\n }\n\n return undefined;\n }\n\n return undefined;\n};\n\nconst isProcessEnvMember = (node: Node): boolean => {\n if (node.type !== 'MemberExpression' || node.computed) {\n return false;\n }\n\n if (node.property.type !== 'Identifier' || node.property.name !== 'env') {\n return false;\n }\n\n return node.object.type === 'Identifier' && node.object.name === 'process';\n};\n\nconst isProcessEnvValueAccess = (\n expression: Expression,\n env: EvalEnv\n): boolean =>\n expression.type === 'MemberExpression' &&\n isProcessEnvMember(expression.object) &&\n !env.has('process');\n\nconst isDeterministicUndefinedExpression = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv\n): boolean => {\n if (isProcessEnvValueAccess(expression, env)) {\n return true;\n }\n\n if (expression.type === 'UnaryExpression' && expression.operator === 'void') {\n return true;\n }\n\n return (\n expression.type === 'Identifier' &&\n expression.name === 'undefined' &&\n !resolveBindingAt(ctx, expression.name, expression.start)\n );\n};\n\nconst evaluateBinary = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv = new Map(),\n stack: string[] = []\n): unknown | undefined => {\n if (expression.type !== 'BinaryExpression') {\n return undefined;\n }\n\n const left = evaluateStatic(expression.left as Expression, ctx, env, stack);\n const right = evaluateStatic(expression.right as Expression, ctx, env, stack);\n\n const leftIsDeterministicUndefined =\n left === undefined &&\n isDeterministicUndefinedExpression(expression.left as Expression, ctx, env);\n const rightIsDeterministicUndefined =\n right === undefined &&\n isDeterministicUndefinedExpression(\n expression.right as Expression,\n ctx,\n env\n );\n\n if (\n (left === undefined && !leftIsDeterministicUndefined) ||\n (right === undefined && !rightIsDeterministicUndefined)\n ) {\n return undefined;\n }\n\n switch (expression.operator) {\n case '===':\n return left === right;\n case '!==':\n return left !== right;\n case '==':\n // eslint-disable-next-line eqeqeq\n return left == right;\n case '!=':\n // eslint-disable-next-line eqeqeq\n return left != right;\n default:\n break;\n }\n\n if (expression.operator === '+') {\n if (typeof left === 'number' && typeof right === 'number') {\n return left + right;\n }\n\n if (\n (typeof left === 'string' || typeof left === 'number') &&\n (typeof right === 'string' || typeof right === 'number')\n ) {\n return `${left}${right}`;\n }\n }\n\n if (typeof left === 'number' && typeof right === 'number') {\n switch (expression.operator) {\n case '<':\n return left < right;\n case '<=':\n return left <= right;\n case '>':\n return left > right;\n case '>=':\n return left >= right;\n case '-':\n return left - right;\n case '*':\n return left * right;\n case '/':\n return left / right;\n case '%':\n return left % right;\n case '**':\n return left ** right;\n default:\n break;\n }\n }\n\n return undefined;\n};\n\nexport const evaluateStatic = (\n expression: Expression,\n ctx: ExtractionContext,\n env: EvalEnv = new Map(),\n stack: string[] = []\n): unknown | undefined => {\n if (\n expression.type === 'TSAsExpression' ||\n expression.type === 'TSSatisfiesExpression' ||\n expression.type === 'TSNonNullExpression' ||\n expression.type === 'TSInstantiationExpression' ||\n expression.type === 'TSTypeAssertion' ||\n expression.type === 'ParenthesizedExpression'\n ) {\n return evaluateStatic(expression.expression as Expression, ctx, env, stack);\n }\n\n if (expression.type === 'Literal') {\n return expression.value;\n }\n\n if (expression.type === 'UnaryExpression') {\n if (expression.operator === 'typeof') {\n const argIsProcessEnvAccess = isProcessEnvValueAccess(\n expression.argument as Expression,\n env\n );\n // `typeof someIdentifier` is the canonical undeclared-global\n // probe — it returns 'undefined' regardless of whether the\n // symbol is declared. Only fold truly unbound identifiers: declared\n // but dynamic locals still have runtime values we cannot infer.\n const argIsUnboundBareIdentifier =\n expression.argument.type === 'Identifier' &&\n !resolveBindingAt(\n ctx,\n expression.argument.name,\n expression.argument.start\n );\n const arg = evaluateStatic(\n expression.argument as Expression,\n ctx,\n env,\n stack\n );\n if (arg === undefined) {\n return argIsProcessEnvAccess || argIsUnboundBareIdentifier\n ? 'undefined'\n : undefined;\n }\n\n return typeof arg;\n }\n\n const arg = evaluateStatic(\n expression.argument as Expression,\n ctx,\n env,\n stack\n );\n if (arg === undefined) {\n return undefined;\n }\n\n switch (expression.operator) {\n case '-':\n return typeof arg === 'number' ? -arg : undefined;\n case '+':\n return typeof arg === 'number' ? +arg : undefined;\n case '!':\n return !arg;\n case '~':\n return typeof arg === 'number' ? bitwiseNot(arg) : undefined;\n case 'void':\n return undefined;\n default:\n return undefined;\n }\n }\n\n if (expression.type === 'LogicalExpression') {\n const left = evaluateStatic(expression.left, ctx, env, stack);\n // process.env.X access is the only source we trust as \"deterministically\n // undefined\" — it's a build-time lookup we control. For everything else,\n // undefined means \"couldn't evaluate\" and we must bail to avoid inlining\n // a wrong fallback when the runtime value isn't actually nullish.\n const leftIsProcessEnvAccess = isProcessEnvValueAccess(\n expression.left,\n env\n );\n\n if (left === undefined && !leftIsProcessEnvAccess) {\n return undefined;\n }\n\n if (expression.operator === '||') {\n return left || evaluateStatic(expression.right, ctx, env, stack);\n }\n\n if (expression.operator === '??') {\n return left ?? evaluateStatic(expression.right, ctx, env, stack);\n }\n\n if (expression.operator === '&&') {\n return left && evaluateStatic(expression.right, ctx, env, stack);\n }\n\n return undefined;\n }\n\n if (expression.type === 'ConditionalExpression') {\n const test = evaluateStatic(expression.test, ctx, env, stack);\n if (test === undefined) {\n return undefined;\n }\n\n return evaluateStatic(\n test ? expression.consequent : expression.alternate,\n ctx,\n env,\n stack\n );\n }\n\n if (expression.type === 'TemplateLiteral') {\n let result = '';\n\n for (let idx = 0; idx < expression.quasis.length; idx += 1) {\n result += expression.quasis[idx]?.value.cooked ?? '';\n\n const nextExpression = expression.expressions[idx];\n if (!nextExpression) {\n continue;\n }\n\n const value = evaluateStatic(nextExpression, ctx, env, stack);\n if (\n value === undefined ||\n (typeof value !== 'string' && typeof value !== 'number')\n ) {\n return undefined;\n }\n\n result += String(value);\n }\n\n return result;\n }\n\n if (expression.type === 'Identifier') {\n if (env.has(expression.name)) {\n return unwrapOxcStaticCallableValue(env.get(expression.name));\n }\n\n const binding = resolveBindingAt(ctx, expression.name, expression.start);\n if (binding?.importedFrom) {\n // staticBindings can supply a literal value for an imported name,\n // bypassing whatever the source module would otherwise resolve to.\n // Function values are deferred to the CallExpression branch.\n const override = lookupStaticBinding(\n ctx.staticBindings,\n binding.importedFrom,\n binding.imported\n );\n if (override.found && typeof override.value !== 'function') {\n return override.value;\n }\n return undefined;\n }\n if (!binding) {\n return undefined;\n }\n\n if (binding.kind === 'param') {\n return undefined;\n }\n\n if (stack.includes(binding.name)) {\n return undefined;\n }\n\n let value: unknown | undefined;\n const { declarator } = binding;\n const init = declarator?.init;\n if (init) {\n if (declarator.id.type !== 'Identifier') {\n return undefined;\n }\n\n value = evaluateStatic(init, ctx, env, [...stack, binding.name]);\n } else if (binding.functionNode) {\n value = binding.functionNode;\n }\n\n if (\n value !== undefined &&\n binding.isRoot &&\n typeof value === 'object' &&\n value !== null &&\n !Array.isArray(value)\n ) {\n const mutations = ctx.rootMutationsByBinding.get(binding.name) ?? [];\n let nextValue = cloneStaticValue(value);\n for (const mutation of mutations) {\n if (mutation.start >= ctx.currentExpressionStart) {\n break;\n }\n\n const applied = applyRootMutation(\n binding.name,\n nextValue,\n mutation,\n ctx,\n env,\n [...stack, binding.name]\n );\n if (applied === undefined) {\n return undefined;\n }\n\n nextValue = applied;\n }\n\n return nextValue;\n }\n\n return value;\n }\n\n if (expression.type === 'ObjectExpression') {\n const result: Record<string, unknown> = {};\n\n for (const property of expression.properties) {\n if (property.type === 'SpreadElement') {\n const spreadValue = evaluateStatic(property.argument, ctx, env, stack);\n if (typeof spreadValue !== 'object' || spreadValue === null) {\n return undefined;\n }\n\n Object.assign(result, spreadValue);\n continue;\n }\n\n let key: unknown;\n if (property.computed) {\n key = evaluateStatic(property.key as Expression, ctx, env, stack);\n } else if (property.key.type === 'Identifier') {\n key = property.key.name;\n } else if (property.key.type === 'Literal') {\n key = property.key.value;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return undefined;\n }\n\n const value = evaluateStatic(property.value, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n result[key] = value;\n }\n\n return result;\n }\n\n if (expression.type === 'ArrayExpression') {\n const result: unknown[] = [];\n\n for (const element of expression.elements) {\n if (!element) {\n return undefined;\n }\n\n if (element.type === 'SpreadElement') {\n const spreadValue = evaluateStatic(element.argument, ctx, env, stack);\n if (!Array.isArray(spreadValue)) {\n return undefined;\n }\n\n result.push(...spreadValue);\n continue;\n }\n\n const value = evaluateStatic(element, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n result.push(value);\n }\n\n return result;\n }\n\n if (expression.type === 'MemberExpression') {\n let key: unknown;\n if (expression.computed) {\n key = evaluateStatic(expression.property as Expression, ctx, env, stack);\n } else if (expression.property.type === 'Identifier') {\n key = expression.property.name;\n }\n if (\n key === undefined ||\n key === null ||\n (typeof key !== 'string' && typeof key !== 'number')\n ) {\n return undefined;\n }\n\n if (isProcessEnvValueAccess(expression, env) && typeof key === 'string') {\n // Treat process.env.X as deterministically undefined at build time.\n // Reading from real process.env would couple the bundle to whatever\n // happens to be set on the build machine; falling back to the\n // ?? / || branch (or a runtime read) is more predictable.\n return undefined;\n }\n\n const knownObjectMember = evaluateKnownObjectMember(\n expression.object as Expression,\n key,\n ctx,\n env,\n stack\n );\n if (knownObjectMember !== undefined) {\n return knownObjectMember;\n }\n\n const objectValue = evaluateStatic(expression.object, ctx, env, stack);\n if (objectValue === undefined) {\n return undefined;\n }\n\n return getObjectMember(objectValue, key);\n }\n\n if (expression.type === 'NewExpression') {\n if (\n expression.callee.type !== 'Identifier' ||\n expression.arguments.length !== 1\n ) {\n return undefined;\n }\n\n const [argument] = expression.arguments;\n if (!argument || argument.type === 'SpreadElement') {\n return undefined;\n }\n\n const value = evaluateStatic(argument, ctx, env, stack);\n if (value === undefined) {\n return undefined;\n }\n\n if (expression.callee.name === 'String') {\n return String(value);\n }\n\n if (expression.callee.name === 'Number') {\n return Number(value);\n }\n\n if (expression.callee.name === 'Boolean') {\n return Boolean(value);\n }\n\n return undefined;\n }\n\n if (expression.type === 'CallExpression') {\n if (expression.callee.type === 'Identifier') {\n const args = expression.arguments.map((arg) =>\n arg.type === 'SpreadElement'\n ? undefined\n : evaluateStatic(arg, ctx, env, stack)\n );\n if (args.some((value) => value === undefined)) {\n return undefined;\n }\n\n const staticCallable = env.get(expression.callee.name);\n if (\n isOxcStaticCallableValue(staticCallable) &&\n expression.arguments.length === 0\n ) {\n return unwrapOxcStaticCallableValue(staticCallable);\n }\n\n // Plain function in env (e.g. supplied via staticBindings as a\n // pure helper). Invoke with already-evaluated args.\n if (typeof staticCallable === 'function') {\n try {\n return (staticCallable as (...a: unknown[]) => unknown)(...args);\n } catch {\n return undefined;\n }\n }\n\n if (expression.callee.name === 'String' && args.length === 1) {\n return String(args[0]);\n }\n\n if (expression.callee.name === 'Number' && args.length === 1) {\n return Number(args[0]);\n }\n\n if (expression.callee.name === 'Boolean' && args.length === 1) {\n return Boolean(args[0]);\n }\n\n const binding = resolveBindingAt(\n ctx,\n expression.callee.name,\n expression.callee.start\n );\n\n // staticBindings can register a pure helper for an imported name\n // (e.g. linaria's `cx` from '@linaria/core'). When the callee\n // resolves to such an import and every arg evaluated, invoke the\n // helper and return its result as a static value.\n if (binding?.importedFrom) {\n const override = lookupStaticBinding(\n ctx.staticBindings,\n binding.importedFrom,\n binding.imported\n );\n if (override.found && typeof override.value === 'function') {\n try {\n return (override.value as (...a: unknown[]) => unknown)(...args);\n } catch {\n return undefined;\n }\n }\n }\n\n const fn = binding?.functionNode ?? binding?.declarator?.init;\n if (\n fn &&\n (fn.type === 'ArrowFunctionExpression' ||\n fn.type === 'FunctionDeclaration' ||\n fn.type === 'FunctionExpression')\n ) {\n return evaluateFunctionCall(fn, args, ctx, env, [\n ...stack,\n expression.callee.name,\n ]);\n }\n }\n\n if (expression.callee.type === 'MemberExpression') {\n const objectValue = evaluateStatic(\n expression.callee.object,\n ctx,\n env,\n stack\n );\n let key: unknown;\n if (expression.callee.computed) {\n key = evaluateStatic(\n expression.callee.property as Expression,\n ctx,\n env,\n stack\n );\n } else if (expression.callee.property.type === 'Identifier') {\n key = expression.callee.property.name;\n }\n if (typeof objectValue === 'string') {\n if (key === 'toLowerCase' && expression.arguments.length === 0) {\n return objectValue.toLowerCase();\n }\n\n if (key === 'toUpperCase' && expression.arguments.length === 0) {\n return objectValue.toUpperCase();\n }\n }\n }\n }\n\n return evaluateBinary(expression, ctx, env, stack);\n};\n"],"file":"staticEvaluator.js"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"","names":[],"sources":["../../../src/utils/oxcPreevalStage/types.ts"],"version":3,"sourcesContent":["import type { StrictOptions } from '@wyw-in-js/shared';\n\nimport type { EventEmitter } from '../EventEmitter';\nimport type { WYWTransformMetadata } from '../TransformMetadata';\nimport type { OxcStaticValueCandidate } from '../collectOxcTemplateDependencies';\n\nexport type OxcPreevalOptions = Pick<\n StrictOptions,\n | 'classNameSlug'\n | 'codeRemover'\n | 'displayName'\n | 'eval'\n | 'extensions'\n | 'features'\n | 'staticBindings'\n | 'tagResolver'\n> & { eventEmitter?: EventEmitter };\n\nexport type OxcPreevalResult = {\n baseCode: string;\n code: string;\n dependencyNames: string[];\n metadata: WYWTransformMetadata | null;\n processorClassNames: Record<string, string>;\n staticDependencies: string[];\n staticValueCache: Map<string, unknown>;\n staticValueCandidates: OxcStaticValueCandidate[];\n};\n\nexport type StaticPreevalOverlay = {\n evalDependencyNames: string[];\n staticValueCache: Map<string, unknown>;\n staticValueCandidates: OxcStaticValueCandidate[];\n};\n"],"file":"types.js"}
|
|
1
|
+
{"mappings":"","names":[],"sources":["../../../src/utils/oxcPreevalStage/types.ts"],"version":3,"sourcesContent":["import type { StrictOptions } from '@wyw-in-js/shared';\n\nimport type { EventEmitter } from '../EventEmitter';\nimport type { WYWTransformMetadata } from '../TransformMetadata';\nimport type { OxcStaticValueCandidate } from '../collectOxcTemplateDependencies';\n\nexport type OxcPreevalOptions = Pick<\n StrictOptions,\n | 'classNameSlug'\n | 'codeRemover'\n | 'displayName'\n | 'eval'\n | 'extensions'\n | 'features'\n | 'processors'\n | 'staticBindings'\n | 'tagResolver'\n> & { eventEmitter?: EventEmitter };\n\nexport type OxcPreevalResult = {\n baseCode: string;\n code: string;\n dependencyNames: string[];\n metadata: WYWTransformMetadata | null;\n processorClassNames: Record<string, string>;\n staticDependencies: string[];\n staticValueCache: Map<string, unknown>;\n staticValueCandidates: OxcStaticValueCandidate[];\n};\n\nexport type StaticPreevalOverlay = {\n evalDependencyNames: string[];\n staticValueCache: Map<string, unknown>;\n staticValueCandidates: OxcStaticValueCandidate[];\n};\n"],"file":"types.js"}
|
package/esm/utils/parseOxc.js
CHANGED
|
@@ -7,6 +7,10 @@ import { parseSync } from "oxc-parser";
|
|
|
7
7
|
const MAX_PARSE_CACHE_ENTRIES = 1e3;
|
|
8
8
|
const parseCache = new Map();
|
|
9
9
|
const getAstType = (filename) => filename.endsWith(".ts") || filename.endsWith(".tsx") ? "ts" : "js";
|
|
10
|
+
const getJsxFallbackFilename = (filename) => {
|
|
11
|
+
if (filename.endsWith(".js")) return `${filename}x`;
|
|
12
|
+
return null;
|
|
13
|
+
};
|
|
10
14
|
const makeCacheKey = (filename, code, sourceType) => `${sourceType}\0${filename}\0${code}`;
|
|
11
15
|
const setCachedParse = (key, value) => {
|
|
12
16
|
parseCache.set(key, value);
|
|
@@ -24,12 +28,22 @@ export const parseOxcCached = (filename, code, sourceType) => {
|
|
|
24
28
|
if (cached) {
|
|
25
29
|
return cached;
|
|
26
30
|
}
|
|
27
|
-
|
|
31
|
+
let parsed = parseSync(filename, code, {
|
|
28
32
|
astType: getAstType(filename),
|
|
29
33
|
range: true,
|
|
30
34
|
sourceType
|
|
31
35
|
});
|
|
32
|
-
|
|
36
|
+
let fatalError = parsed.errors.find((error) => error.severity === "Error");
|
|
37
|
+
const jsxFallbackFilename = getJsxFallbackFilename(filename);
|
|
38
|
+
if (fatalError?.message.includes("JSX") && jsxFallbackFilename) {
|
|
39
|
+
// Some bundlers pass .js files with JSX to WyW before a later JSX transform.
|
|
40
|
+
parsed = parseSync(jsxFallbackFilename, code, {
|
|
41
|
+
astType: getAstType(jsxFallbackFilename),
|
|
42
|
+
range: true,
|
|
43
|
+
sourceType
|
|
44
|
+
});
|
|
45
|
+
fatalError = parsed.errors.find((error) => error.severity === "Error");
|
|
46
|
+
}
|
|
33
47
|
if (fatalError) {
|
|
34
48
|
throw new Error(fatalError.message);
|
|
35
49
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"AAAA,SAAS,iBAAiB;;;;;;AAiB1B,MAAM,0BAA0B;AAChC,MAAM,aAAa,IAAI,KAAwB;AAE/C,MAAM,cAAc,aAClB,SAAS,SAAS,MAAM,IAAI,SAAS,SAAS,OAAO,GAAG,OAAO;AAEjE,MAAM,gBACJ,UACA,MACA,eACW,GAAG,WAAW,IAAI,SAAS,IAAI;AAE5C,MAAM,kBAAkB,KAAa,UAAgC;AACnE,YAAW,IAAI,KAAK,MAAM;AAC1B,KAAI,WAAW,OAAO,yBAAyB;EAC7C,MAAM,YAAY,WAAW,MAAM,CAAC,MAAM,CAAC;AAC3C,MAAI,WAAW;AACb,cAAW,OAAO,UAAU;;;AAIhC,QAAO;;AAGT,OAAO,MAAM,kBACX,UACA,MACA,eACc;CACd,MAAM,WAAW,aAAa,UAAU,MAAM,WAAW;CACzD,MAAM,SAAS,WAAW,IAAI,SAAS;AACvC,KAAI,QAAQ;AACV,SAAO;;CAGT,
|
|
1
|
+
{"mappings":"AAAA,SAAS,iBAAiB;;;;;;AAiB1B,MAAM,0BAA0B;AAChC,MAAM,aAAa,IAAI,KAAwB;AAE/C,MAAM,cAAc,aAClB,SAAS,SAAS,MAAM,IAAI,SAAS,SAAS,OAAO,GAAG,OAAO;AAEjE,MAAM,0BAA0B,aAAoC;AAClE,KAAI,SAAS,SAAS,MAAM,CAAE,QAAO,GAAG,SAAS;AAEjD,QAAO;;AAGT,MAAM,gBACJ,UACA,MACA,eACW,GAAG,WAAW,IAAI,SAAS,IAAI;AAE5C,MAAM,kBAAkB,KAAa,UAAgC;AACnE,YAAW,IAAI,KAAK,MAAM;AAC1B,KAAI,WAAW,OAAO,yBAAyB;EAC7C,MAAM,YAAY,WAAW,MAAM,CAAC,MAAM,CAAC;AAC3C,MAAI,WAAW;AACb,cAAW,OAAO,UAAU;;;AAIhC,QAAO;;AAGT,OAAO,MAAM,kBACX,UACA,MACA,eACc;CACd,MAAM,WAAW,aAAa,UAAU,MAAM,WAAW;CACzD,MAAM,SAAS,WAAW,IAAI,SAAS;AACvC,KAAI,QAAQ;AACV,SAAO;;CAGT,IAAI,SAAS,UAAU,UAAU,MAAM;EACrC,SAAS,WAAW,SAAS;EAC7B,OAAO;EACP;EACD,CAAC;CACF,IAAI,aAAa,OAAO,OAAO,MAAM,UAAU,MAAM,aAAa,QAAQ;CAC1E,MAAM,sBAAsB,uBAAuB,SAAS;AAC5D,KAAI,YAAY,QAAQ,SAAS,MAAM,IAAI,qBAAqB;;AAE9D,WAAS,UAAU,qBAAqB,MAAM;GAC5C,SAAS,WAAW,oBAAoB;GACxC,OAAO;GACP;GACD,CAAC;AACF,eAAa,OAAO,OAAO,MAAM,UAAU,MAAM,aAAa,QAAQ;;AAGxE,KAAI,YAAY;AACd,QAAM,IAAI,MAAM,WAAW,QAAQ;;AAGrC,QAAO,eAAe,UAAU;EAC9B,QAAQ,EACN,iBAAiB,OAAO,OAAO,iBAChC;EACD,SAAS,OAAO;EACjB,CAAC;;AAGJ,OAAO,MAAM,yBACX,UACA,MACA,eACY,eAAe,UAAU,MAAM,WAAW,CAAC","names":[],"sources":["../../src/utils/parseOxc.ts"],"version":3,"sourcesContent":["import { parseSync } from 'oxc-parser';\nimport type { Program } from 'oxc-parser';\n\ntype OxcSourceType = 'module' | 'unambiguous';\n\ntype ParsedOxc = {\n module: {\n hasModuleSyntax: boolean;\n };\n program: Program;\n};\n\n// 200 evicts under sustained pressure on large monorepos — the\n// removeUnusedAfterReplacement cleanup loop reparses on every iteration\n// (new content -> new key) and applyOxcProcessors reparses after extraction.\n// 1000 is still bounded (~50-100 MB worst case for an enormous build) and\n// keeps every entry hot across the actions for a single file.\nconst MAX_PARSE_CACHE_ENTRIES = 1000;\nconst parseCache = new Map<string, ParsedOxc>();\n\nconst getAstType = (filename: string): 'js' | 'ts' =>\n filename.endsWith('.ts') || filename.endsWith('.tsx') ? 'ts' : 'js';\n\nconst getJsxFallbackFilename = (filename: string): string | null => {\n if (filename.endsWith('.js')) return `${filename}x`;\n\n return null;\n};\n\nconst makeCacheKey = (\n filename: string,\n code: string,\n sourceType: OxcSourceType\n): string => `${sourceType}\\0${filename}\\0${code}`;\n\nconst setCachedParse = (key: string, value: ParsedOxc): ParsedOxc => {\n parseCache.set(key, value);\n if (parseCache.size > MAX_PARSE_CACHE_ENTRIES) {\n const oldestKey = parseCache.keys().next().value;\n if (oldestKey) {\n parseCache.delete(oldestKey);\n }\n }\n\n return value;\n};\n\nexport const parseOxcCached = (\n filename: string,\n code: string,\n sourceType: OxcSourceType\n): ParsedOxc => {\n const cacheKey = makeCacheKey(filename, code, sourceType);\n const cached = parseCache.get(cacheKey);\n if (cached) {\n return cached;\n }\n\n let parsed = parseSync(filename, code, {\n astType: getAstType(filename),\n range: true,\n sourceType,\n });\n let fatalError = parsed.errors.find((error) => error.severity === 'Error');\n const jsxFallbackFilename = getJsxFallbackFilename(filename);\n if (fatalError?.message.includes('JSX') && jsxFallbackFilename) {\n // Some bundlers pass .js files with JSX to WyW before a later JSX transform.\n parsed = parseSync(jsxFallbackFilename, code, {\n astType: getAstType(jsxFallbackFilename),\n range: true,\n sourceType,\n });\n fatalError = parsed.errors.find((error) => error.severity === 'Error');\n }\n\n if (fatalError) {\n throw new Error(fatalError.message);\n }\n\n return setCachedParse(cacheKey, {\n module: {\n hasModuleSyntax: parsed.module.hasModuleSyntax,\n },\n program: parsed.program as Program,\n });\n};\n\nexport const parseOxcProgramCached = (\n filename: string,\n code: string,\n sourceType: OxcSourceType\n): Program => parseOxcCached(filename, code, sourceType).program;\n"],"file":"parseOxc.js"}
|
package/package.json
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wyw-in-js/transform",
|
|
3
|
-
"version": "2.0
|
|
3
|
+
"version": "2.1.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"dependencies": {
|
|
6
6
|
"@jridgewell/remapping": "^2.3.5",
|
|
7
|
-
"@wyw-in-js/processor-utils": "2.
|
|
8
|
-
"@wyw-in-js/shared": "2.
|
|
7
|
+
"@wyw-in-js/processor-utils": "2.1.0",
|
|
8
|
+
"@wyw-in-js/shared": "2.1.0",
|
|
9
9
|
"cosmiconfig": "^8.0.0",
|
|
10
10
|
"happy-dom": "^20.1.0",
|
|
11
11
|
"minimatch": "^9.0.5",
|
|
12
|
-
"oxc-parser": "0.131.0",
|
|
13
|
-
"oxc-resolver": "11.19.1",
|
|
14
|
-
"oxc-transform": "0.131.0",
|
|
12
|
+
"oxc-parser": "^0.131.0",
|
|
13
|
+
"oxc-resolver": "^11.19.1",
|
|
14
|
+
"oxc-transform": "^0.131.0",
|
|
15
15
|
"source-map": "^0.7.4",
|
|
16
16
|
"stylis": "^4.3.0",
|
|
17
17
|
"ts-invariant": "^0.10.3"
|
package/types/index.d.ts
CHANGED
|
@@ -10,7 +10,7 @@ export { default as shaker, oxcShaker } from './shaker';
|
|
|
10
10
|
export { transform } from './transform';
|
|
11
11
|
export { disposeEvalBroker } from './eval/broker';
|
|
12
12
|
export { isUnprocessedEntrypointError, UnprocessedEntrypointError, } from './transform/actions/UnprocessedEntrypointError';
|
|
13
|
-
export type { Dependencies, ITransformFileResult, JSONArray, JSONObject, JSONValue, Options, ParentEntrypoint, PluginOptions, Preprocessor, PreprocessorFn, Result, Serializable, Stage, } from './types';
|
|
13
|
+
export type { Dependencies, ITransformFileResult, JSONArray, JSONObject, JSONValue, Options, ParentEntrypoint, PluginOptions, Preprocessor, PreprocessorFn, Result, Serializable, Stage, WywInJsProcessorOptions, } from './types';
|
|
14
14
|
export { EvaluatedEntrypoint } from './transform/EvaluatedEntrypoint';
|
|
15
15
|
export type { IEvaluatedEntrypoint } from './transform/EvaluatedEntrypoint';
|
|
16
16
|
export { parseFile } from './transform/Entrypoint.helpers';
|
|
@@ -86,7 +86,9 @@ export function* processImports() {
|
|
|
86
86
|
}
|
|
87
87
|
continue;
|
|
88
88
|
}
|
|
89
|
-
const nextEntrypoint =
|
|
89
|
+
const nextEntrypoint = dependency.loadedCode === undefined
|
|
90
|
+
? this.entrypoint.createChild(resolved, requiredOnly)
|
|
91
|
+
: this.entrypoint.createChild(resolved, requiredOnly, dependency.loadedCode);
|
|
90
92
|
if (nextEntrypoint === 'loop' || nextEntrypoint.ignored) {
|
|
91
93
|
continue;
|
|
92
94
|
}
|
|
@@ -105,6 +105,30 @@ function filterUnresolved(entrypoint, resolvedImports) {
|
|
|
105
105
|
return true;
|
|
106
106
|
});
|
|
107
107
|
}
|
|
108
|
+
async function loadDependencyCodes(services, entrypoint, dependencies) {
|
|
109
|
+
if (!services.loadDependencyCode) {
|
|
110
|
+
return dependencies;
|
|
111
|
+
}
|
|
112
|
+
const { loadDependencyCode } = services;
|
|
113
|
+
return Promise.all(dependencies.map(async (dependency) => {
|
|
114
|
+
if (!dependency.resolved) {
|
|
115
|
+
return dependency;
|
|
116
|
+
}
|
|
117
|
+
try {
|
|
118
|
+
const loadedCode = await loadDependencyCode(dependency.resolved, entrypoint.name, dependency.source);
|
|
119
|
+
return loadedCode === undefined
|
|
120
|
+
? dependency
|
|
121
|
+
: {
|
|
122
|
+
...dependency,
|
|
123
|
+
loadedCode,
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
catch (err) {
|
|
127
|
+
entrypoint.log('[load] ❌ cannot load %s in %s: %O', dependency.source, entrypoint.name, err);
|
|
128
|
+
return dependency;
|
|
129
|
+
}
|
|
130
|
+
}));
|
|
131
|
+
}
|
|
108
132
|
function getPreResolvedImports(preResolved) {
|
|
109
133
|
return new Map((preResolved ?? []).map((dependency) => [dependency.source, dependency]));
|
|
110
134
|
}
|
|
@@ -222,6 +246,7 @@ export async function* asyncResolveImports(resolve) {
|
|
|
222
246
|
log('resolved %d imports', resolvedImports.length);
|
|
223
247
|
const overriddenImports = applyImportOverrides(this.services, entrypoint, resolvedImports);
|
|
224
248
|
const filteredImports = filterUnresolved(entrypoint, overriddenImports);
|
|
225
|
-
|
|
226
|
-
|
|
249
|
+
const loadedImports = await loadDependencyCodes(this.services, entrypoint, filteredImports);
|
|
250
|
+
emitDependency(eventEmitter, entrypoint, loadedImports, this.data.phase);
|
|
251
|
+
return loadedImports;
|
|
227
252
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Services } from '../types';
|
|
2
2
|
type RequiredServices = 'options';
|
|
3
3
|
export type PartialServices = Partial<Omit<Services, RequiredServices>> & Pick<Services, RequiredServices>;
|
|
4
|
-
export declare const withDefaultServices: ({ cache, emitWarning, eventEmitter, loadAndParseFn, log, options, asyncResolveKey, }: PartialServices) => Services;
|
|
4
|
+
export declare const withDefaultServices: ({ cache, emitWarning, eventEmitter, loadDependencyCode, loadAndParseFn, log, options, asyncResolveKey, }: PartialServices) => Services;
|
|
5
5
|
export {};
|
|
@@ -2,10 +2,11 @@ import { TransformCacheCollection } from '../../cache';
|
|
|
2
2
|
import { EventEmitter } from '../../utils/EventEmitter';
|
|
3
3
|
import { loadAndParse } from '../Entrypoint.helpers';
|
|
4
4
|
import { rootLog } from '../rootLog';
|
|
5
|
-
export const withDefaultServices = ({ cache = new TransformCacheCollection(), emitWarning, eventEmitter = EventEmitter.dummy, loadAndParseFn = loadAndParse, log = rootLog, options, asyncResolveKey, }) => ({
|
|
5
|
+
export const withDefaultServices = ({ cache = new TransformCacheCollection(), emitWarning, eventEmitter = EventEmitter.dummy, loadDependencyCode, loadAndParseFn = loadAndParse, log = rootLog, options, asyncResolveKey, }) => ({
|
|
6
6
|
cache,
|
|
7
7
|
emitWarning,
|
|
8
8
|
eventEmitter,
|
|
9
|
+
loadDependencyCode,
|
|
9
10
|
loadAndParseFn,
|
|
10
11
|
log,
|
|
11
12
|
options,
|
|
@@ -10,10 +10,12 @@ import type { LoadAndParseFn, IEntrypointDependency } from './Entrypoint.types';
|
|
|
10
10
|
import type { BaseAction } from './actions/BaseAction';
|
|
11
11
|
import type { IExtracted, IWorkflowActionLinariaResult, IWorkflowActionNonLinariaResult } from './actions/types';
|
|
12
12
|
import type { EvalBroker } from '../eval/broker';
|
|
13
|
+
export type LoadDependencyCodeFn = (resolved: string, importer: string, source: string) => Promise<string | undefined>;
|
|
13
14
|
export type Services = {
|
|
14
15
|
cache: TransformCacheCollection;
|
|
15
16
|
emitWarning?: (message: string) => void;
|
|
16
17
|
eventEmitter: EventEmitter;
|
|
18
|
+
loadDependencyCode?: LoadDependencyCodeFn;
|
|
17
19
|
loadAndParseFn: LoadAndParseFn;
|
|
18
20
|
log: Debugger;
|
|
19
21
|
options: Options & {
|
package/types/transform.js
CHANGED
|
@@ -44,7 +44,7 @@ const canonicalizeForHash = (value) => {
|
|
|
44
44
|
}
|
|
45
45
|
return value;
|
|
46
46
|
};
|
|
47
|
-
const getEvalCacheKey = (pluginOptions, asyncResolveKey, asyncResolve) => {
|
|
47
|
+
const getEvalCacheKey = (pluginOptions, asyncResolveKey, asyncResolve, loadDependencyCode) => {
|
|
48
48
|
const evalOptions = pluginOptions.eval ?? {};
|
|
49
49
|
const payload = JSON.stringify({
|
|
50
50
|
errors: evalOptions.errors,
|
|
@@ -59,6 +59,7 @@ const getEvalCacheKey = (pluginOptions, asyncResolveKey, asyncResolve) => {
|
|
|
59
59
|
// them to provide a stable scope key so cache/broker reuse tracks resolver
|
|
60
60
|
// semantics instead of closure identity.
|
|
61
61
|
bundlerResolver: asyncResolveKey ?? getResolverId(asyncResolve),
|
|
62
|
+
bundlerLoader: getResolverId(loadDependencyCode),
|
|
62
63
|
overrideContext: getResolverId(pluginOptions.overrideContext),
|
|
63
64
|
importOverrides: pluginOptions.importOverrides ?? null,
|
|
64
65
|
extensions: pluginOptions.extensions,
|
|
@@ -91,7 +92,7 @@ export async function transform(partialServices, originalCode, asyncResolve, cus
|
|
|
91
92
|
// If global cache is disabled, we need to create a new cache for each file
|
|
92
93
|
services.cache = new TransformCacheCollection();
|
|
93
94
|
}
|
|
94
|
-
const evalCacheKey = getEvalCacheKey(pluginOptions, services.asyncResolveKey, asyncResolve);
|
|
95
|
+
const evalCacheKey = getEvalCacheKey(pluginOptions, services.asyncResolveKey, asyncResolve, services.loadDependencyCode);
|
|
95
96
|
services.cache.setKeySalt(evalCacheKey);
|
|
96
97
|
services.asyncResolve = asyncResolve;
|
|
97
98
|
services.evalBroker = getEvalBroker(services, asyncResolve, evalCacheKey);
|
package/types/types.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import type { RawSourceMap } from 'source-map';
|
|
2
|
-
import type { Debugger, Replacement, Rules, StrictOptions } from '@wyw-in-js/shared';
|
|
2
|
+
import type { Debugger, Replacement, Rules, StrictOptions, WywInJsProcessorOptions } from '@wyw-in-js/shared';
|
|
3
3
|
import type { WYWTransformMetadata, WYWTransformResultMetadata } from './utils/TransformMetadata';
|
|
4
4
|
import type { WYWTransformDiagnostic } from './utils/TransformDiagnostics';
|
|
5
|
-
export type
|
|
5
|
+
export type { WywInJsProcessorOptions };
|
|
6
|
+
export interface PluginOptions extends StrictOptions {
|
|
6
7
|
configFile?: string | false;
|
|
7
8
|
stage?: Stage;
|
|
8
|
-
}
|
|
9
|
+
}
|
|
9
10
|
export type ParentEntrypoint = {
|
|
10
11
|
evaluated: boolean;
|
|
11
12
|
log: Debugger;
|
|
@@ -2,7 +2,7 @@ import type { BaseProcessor, IFileContext } from '@wyw-in-js/processor-utils';
|
|
|
2
2
|
import type { StrictOptions } from '@wyw-in-js/shared';
|
|
3
3
|
import { EventEmitter } from '../EventEmitter';
|
|
4
4
|
import type { ApplyOxcProcessorsResult } from './types';
|
|
5
|
-
export declare const applyOxcProcessors: (code: string, fileContext: IFileContext, options: Pick<StrictOptions, "classNameSlug" | "displayName" | "eval" | "extensions" | "staticBindings" | "tagResolver"> & {
|
|
5
|
+
export declare const applyOxcProcessors: (code: string, fileContext: IFileContext, options: Pick<StrictOptions, "classNameSlug" | "displayName" | "eval" | "extensions" | "processors" | "staticBindings" | "tagResolver"> & {
|
|
6
6
|
eventEmitter?: EventEmitter;
|
|
7
7
|
preserveSideEffectImportOrderLocals?: Set<string>;
|
|
8
8
|
preserveSideEffectImportLocals?: Set<string>;
|
|
@@ -4,4 +4,4 @@ import type { Expression, Node } from 'oxc-parser';
|
|
|
4
4
|
import type { CreatedProcessor, DefinedProcessor, LocationLookup, Replacement } from './types';
|
|
5
5
|
export declare const isReplacementPure: (replacement: ProcessorExpression) => boolean;
|
|
6
6
|
export declare const shouldCollectStaticExpressionValues: (options: Pick<StrictOptions, "eval">) => boolean;
|
|
7
|
-
export declare const createProcessor: (definedProcessor: DefinedProcessor, params: Params, target: Expression, replacementTarget: Expression, ancestors: Node[], fileContext: IFileContext, options: Pick<StrictOptions, "classNameSlug" | "displayName" | "extensions" | "tagResolver">, code: string, loc: LocationLookup, idx: number, isReferenced: boolean, usedNames: Set<string>, replacements: Replacement[]) => CreatedProcessor | null;
|
|
7
|
+
export declare const createProcessor: (definedProcessor: DefinedProcessor, params: Params, target: Expression, replacementTarget: Expression, ancestors: Node[], fileContext: IFileContext, options: Pick<StrictOptions, "classNameSlug" | "displayName" | "extensions" | "processors" | "tagResolver">, code: string, loc: LocationLookup, idx: number, isReferenced: boolean, usedNames: Set<string>, replacements: Replacement[]) => CreatedProcessor | null;
|
|
@@ -1,16 +1,7 @@
|
|
|
1
1
|
/* eslint-disable no-restricted-syntax */
|
|
2
|
-
import {
|
|
2
|
+
import { parseOxcProgramCached } from '../parseOxc';
|
|
3
3
|
const parseOxc = (code, filename) => {
|
|
4
|
-
|
|
5
|
-
astType: filename.endsWith('.ts') || filename.endsWith('.tsx') ? 'ts' : 'js',
|
|
6
|
-
range: true,
|
|
7
|
-
sourceType: 'module',
|
|
8
|
-
});
|
|
9
|
-
const fatalError = parsed.errors.find((error) => error.severity === 'Error');
|
|
10
|
-
if (fatalError) {
|
|
11
|
-
throw new Error(fatalError.message);
|
|
12
|
-
}
|
|
13
|
-
return parsed.program;
|
|
4
|
+
return parseOxcProgramCached(filename, code, 'module');
|
|
14
5
|
};
|
|
15
6
|
const applyReplacements = (code, replacements) => {
|
|
16
7
|
let result = code;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { StrictOptions } from '@wyw-in-js/shared';
|
|
2
2
|
import type { RawSourceMap } from 'source-map';
|
|
3
3
|
import type { WYWTransformMetadata } from '../TransformMetadata';
|
|
4
|
-
export type OxcCollectOptions = Pick<StrictOptions, 'classNameSlug' | 'displayName' | 'eval' | 'extensions' | 'tagResolver' | 'variableNameConfig'> & {
|
|
4
|
+
export type OxcCollectOptions = Pick<StrictOptions, 'classNameSlug' | 'displayName' | 'eval' | 'extensions' | 'processors' | 'tagResolver' | 'variableNameConfig'> & {
|
|
5
5
|
preserveSideEffectImportOrderLocals?: Set<string>;
|
|
6
6
|
preserveSideEffectImportLocals?: Set<string>;
|
|
7
7
|
};
|
|
@@ -50,6 +50,61 @@ const getObjectMember = (objectValue, property) => {
|
|
|
50
50
|
}
|
|
51
51
|
return objectValue[property];
|
|
52
52
|
};
|
|
53
|
+
const staticObjectPropertyKey = (property, ctx, env, stack) => {
|
|
54
|
+
if (!property.key) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
let key;
|
|
58
|
+
if (property.computed) {
|
|
59
|
+
key = evaluateStatic(property.key, ctx, env, stack);
|
|
60
|
+
}
|
|
61
|
+
else if (property.key.type === 'Identifier') {
|
|
62
|
+
key = property.key.name;
|
|
63
|
+
}
|
|
64
|
+
else if (property.key.type === 'Literal') {
|
|
65
|
+
key = property.key.value;
|
|
66
|
+
}
|
|
67
|
+
return typeof key === 'string' || typeof key === 'number' ? key : null;
|
|
68
|
+
};
|
|
69
|
+
const evaluateObjectExpressionMember = (expression, propertyKey, ctx, env, stack) => {
|
|
70
|
+
if (expression.type !== 'ObjectExpression') {
|
|
71
|
+
return undefined;
|
|
72
|
+
}
|
|
73
|
+
for (let idx = expression.properties.length - 1; idx >= 0; idx -= 1) {
|
|
74
|
+
const property = expression.properties[idx];
|
|
75
|
+
if (property.type === 'SpreadElement') {
|
|
76
|
+
return undefined;
|
|
77
|
+
}
|
|
78
|
+
const key = staticObjectPropertyKey(property, ctx, env, stack);
|
|
79
|
+
if (key === null) {
|
|
80
|
+
return undefined;
|
|
81
|
+
}
|
|
82
|
+
if (key === propertyKey) {
|
|
83
|
+
return evaluateStatic(property.value, ctx, env, stack);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return undefined;
|
|
87
|
+
};
|
|
88
|
+
const evaluateKnownObjectMember = (expression, propertyKey, ctx, env, stack) => {
|
|
89
|
+
const objectMember = evaluateObjectExpressionMember(expression, propertyKey, ctx, env, stack);
|
|
90
|
+
if (objectMember !== undefined) {
|
|
91
|
+
return objectMember;
|
|
92
|
+
}
|
|
93
|
+
if (expression.type !== 'Identifier' || env.has(expression.name)) {
|
|
94
|
+
return undefined;
|
|
95
|
+
}
|
|
96
|
+
const binding = resolveBindingAt(ctx, expression.name, expression.start);
|
|
97
|
+
if (!binding ||
|
|
98
|
+
binding.kind === 'param' ||
|
|
99
|
+
binding.importedFrom ||
|
|
100
|
+
binding.isRoot ||
|
|
101
|
+
stack.includes(binding.name) ||
|
|
102
|
+
!binding.declarator?.init ||
|
|
103
|
+
binding.declarator.id.type !== 'Identifier') {
|
|
104
|
+
return undefined;
|
|
105
|
+
}
|
|
106
|
+
return evaluateKnownObjectMember(binding.declarator.init, propertyKey, ctx, env, [...stack, binding.name]);
|
|
107
|
+
};
|
|
53
108
|
const oxcStaticCallableValue = Symbol('wyw.oxc.staticCallableValue');
|
|
54
109
|
const isOxcStaticCallableValue = (value) => typeof value === 'object' &&
|
|
55
110
|
value !== null &&
|
|
@@ -514,6 +569,10 @@ export const evaluateStatic = (expression, ctx, env = new Map(), stack = []) =>
|
|
|
514
569
|
// ?? / || branch (or a runtime read) is more predictable.
|
|
515
570
|
return undefined;
|
|
516
571
|
}
|
|
572
|
+
const knownObjectMember = evaluateKnownObjectMember(expression.object, key, ctx, env, stack);
|
|
573
|
+
if (knownObjectMember !== undefined) {
|
|
574
|
+
return knownObjectMember;
|
|
575
|
+
}
|
|
517
576
|
const objectValue = evaluateStatic(expression.object, ctx, env, stack);
|
|
518
577
|
if (objectValue === undefined) {
|
|
519
578
|
return undefined;
|