@markw65/monkeyc-optimizer 1.1.81 → 1.1.83
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/CHANGELOG.md +11 -0
- package/build/api.cjs +38 -38
- package/build/{chunk-W4QVHCFN.cjs → chunk-UNU55JJ3.cjs} +581 -410
- package/build/optimizer.cjs +18 -18
- package/build/sdk-util.cjs +14 -14
- package/build/src/api.d.ts +1 -1
- package/build/src/build-config.d.ts +1 -1
- package/build/src/optimizer-types.d.ts +2 -1
- package/build/src/type-flow/interp-call.d.ts +2 -1
- package/build/src/type-flow/types.d.ts +10 -5
- package/build/src/type-flow/union-type.d.ts +1 -1
- package/build/worker-thread.cjs +3 -3
- package/package.json +1 -1
package/build/optimizer.cjs
CHANGED
|
@@ -18,30 +18,30 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
19
|
var optimizer_exports = {};
|
|
20
20
|
__export(optimizer_exports, {
|
|
21
|
-
StateNodeAttributes: () =>
|
|
22
|
-
buildConfigDescription: () =>
|
|
23
|
-
buildOptimizedProject: () =>
|
|
21
|
+
StateNodeAttributes: () => import_chunk_UNU55JJ3.StateNodeAttributes,
|
|
22
|
+
buildConfigDescription: () => import_chunk_UNU55JJ3.buildConfigDescription,
|
|
23
|
+
buildOptimizedProject: () => import_chunk_UNU55JJ3.buildOptimizedProject,
|
|
24
24
|
copyRecursiveAsNeeded: () => import_chunk_X7QCZR3F.copyRecursiveAsNeeded,
|
|
25
|
-
defaultConfig: () =>
|
|
26
|
-
display: () =>
|
|
27
|
-
generateOneConfig: () =>
|
|
28
|
-
generateOptimizedProject: () =>
|
|
29
|
-
getConfig: () =>
|
|
30
|
-
getFnMapAnalysis: () =>
|
|
31
|
-
getProjectAnalysis: () =>
|
|
32
|
-
get_jungle: () =>
|
|
33
|
-
isErrorWithLocation: () =>
|
|
34
|
-
launchSimulator: () =>
|
|
35
|
-
manifestProducts: () =>
|
|
36
|
-
mctree: () =>
|
|
37
|
-
simulateProgram: () =>
|
|
25
|
+
defaultConfig: () => import_chunk_UNU55JJ3.defaultConfig,
|
|
26
|
+
display: () => import_chunk_UNU55JJ3.display,
|
|
27
|
+
generateOneConfig: () => import_chunk_UNU55JJ3.generateOneConfig,
|
|
28
|
+
generateOptimizedProject: () => import_chunk_UNU55JJ3.generateOptimizedProject,
|
|
29
|
+
getConfig: () => import_chunk_UNU55JJ3.getConfig,
|
|
30
|
+
getFnMapAnalysis: () => import_chunk_UNU55JJ3.getFnMapAnalysis,
|
|
31
|
+
getProjectAnalysis: () => import_chunk_UNU55JJ3.getProjectAnalysis,
|
|
32
|
+
get_jungle: () => import_chunk_UNU55JJ3.get_jungle,
|
|
33
|
+
isErrorWithLocation: () => import_chunk_UNU55JJ3.isErrorWithLocation,
|
|
34
|
+
launchSimulator: () => import_chunk_UNU55JJ3.launchSimulator,
|
|
35
|
+
manifestProducts: () => import_chunk_UNU55JJ3.manifestProducts,
|
|
36
|
+
mctree: () => import_chunk_UNU55JJ3.mctree,
|
|
37
|
+
simulateProgram: () => import_chunk_UNU55JJ3.simulateProgram
|
|
38
38
|
});
|
|
39
39
|
module.exports = __toCommonJS(optimizer_exports);
|
|
40
|
-
var
|
|
40
|
+
var import_chunk_UNU55JJ3 = require("./chunk-UNU55JJ3.cjs");
|
|
41
41
|
var import_chunk_X7QCZR3F = require("./chunk-X7QCZR3F.cjs");
|
|
42
42
|
var import_chunk_JDC43A3I = require("./chunk-JDC43A3I.cjs");
|
|
43
43
|
var import_chunk_ABYVSU2C = require("./chunk-ABYVSU2C.cjs");
|
|
44
|
-
(0,
|
|
44
|
+
(0, import_chunk_UNU55JJ3.init_optimizer)();
|
|
45
45
|
// Annotate the CommonJS export names for ESM import in node:
|
|
46
46
|
0 && (module.exports = {
|
|
47
47
|
StateNodeAttributes,
|
package/build/sdk-util.cjs
CHANGED
|
@@ -18,25 +18,25 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
19
|
var sdk_util_exports = {};
|
|
20
20
|
__export(sdk_util_exports, {
|
|
21
|
-
SectionKinds: () =>
|
|
22
|
-
appSupport: () =>
|
|
23
|
-
connectiq: () =>
|
|
24
|
-
getDeviceInfo: () =>
|
|
25
|
-
getFunctionDocumentation: () =>
|
|
26
|
-
getLanguages: () =>
|
|
27
|
-
getSdkPath: () =>
|
|
28
|
-
isWin: () =>
|
|
29
|
-
optimizeProgram: () =>
|
|
30
|
-
readPrg: () =>
|
|
31
|
-
readPrgWithOffsets: () =>
|
|
32
|
-
xmlUtil: () =>
|
|
21
|
+
SectionKinds: () => import_chunk_UNU55JJ3.SectionKinds,
|
|
22
|
+
appSupport: () => import_chunk_UNU55JJ3.appSupport,
|
|
23
|
+
connectiq: () => import_chunk_UNU55JJ3.connectiq,
|
|
24
|
+
getDeviceInfo: () => import_chunk_UNU55JJ3.getDeviceInfo,
|
|
25
|
+
getFunctionDocumentation: () => import_chunk_UNU55JJ3.getFunctionDocumentation,
|
|
26
|
+
getLanguages: () => import_chunk_UNU55JJ3.getLanguages,
|
|
27
|
+
getSdkPath: () => import_chunk_UNU55JJ3.getSdkPath,
|
|
28
|
+
isWin: () => import_chunk_UNU55JJ3.isWin,
|
|
29
|
+
optimizeProgram: () => import_chunk_UNU55JJ3.optimizeProgram,
|
|
30
|
+
readPrg: () => import_chunk_UNU55JJ3.readPrg,
|
|
31
|
+
readPrgWithOffsets: () => import_chunk_UNU55JJ3.readPrgWithOffsets,
|
|
32
|
+
xmlUtil: () => import_chunk_UNU55JJ3.xml_util_exports
|
|
33
33
|
});
|
|
34
34
|
module.exports = __toCommonJS(sdk_util_exports);
|
|
35
|
-
var
|
|
35
|
+
var import_chunk_UNU55JJ3 = require("./chunk-UNU55JJ3.cjs");
|
|
36
36
|
var import_chunk_X7QCZR3F = require("./chunk-X7QCZR3F.cjs");
|
|
37
37
|
var import_chunk_JDC43A3I = require("./chunk-JDC43A3I.cjs");
|
|
38
38
|
var import_chunk_ABYVSU2C = require("./chunk-ABYVSU2C.cjs");
|
|
39
|
-
(0,
|
|
39
|
+
(0, import_chunk_UNU55JJ3.init_sdk_util)();
|
|
40
40
|
// Annotate the CommonJS export names for ESM import in node:
|
|
41
41
|
0 && (module.exports = {
|
|
42
42
|
SectionKinds,
|
package/build/src/api.d.ts
CHANGED
|
@@ -31,7 +31,7 @@ export declare function findNamesInScope(declStack: StateNode[][], pattern: stri
|
|
|
31
31
|
readonly parent: StateNode;
|
|
32
32
|
readonly depth: number;
|
|
33
33
|
}])[];
|
|
34
|
-
export declare function mapVarDeclsByType(state: ProgramStateAnalysis, decls: StateNodeDecl[], node: mctree.Node, typeMap: TypeMap | null | undefined): (mctree.Identifier | mctree.EnumStringMember | mctree.AsIdentifier | ProgramStateNode | FunctionStateNode | ModuleStateNode | ClassStateNode | VariableStateNode | import("./optimizer-types").BlockStateNode |
|
|
34
|
+
export declare function mapVarDeclsByType(state: ProgramStateAnalysis, decls: StateNodeDecl[], node: mctree.Node, typeMap: TypeMap | null | undefined): (mctree.Identifier | mctree.EnumStringMember | mctree.AsIdentifier | ProgramStateNode | FunctionStateNode | ModuleStateNode | ClassStateNode | TypedefStateNode | VariableStateNode | import("./optimizer-types").BlockStateNode | EnumStateNode)[];
|
|
35
35
|
export declare function formatScopedName(node: mctree.ScopedName | mctree.ThisExpression): string;
|
|
36
36
|
export declare function formatAstLongLines(node: mctree.Node): Promise<string>;
|
|
37
37
|
export declare function createDocumentationMap(functionDocumentation: {
|
|
@@ -42,7 +42,7 @@ export type BuildConfig = {
|
|
|
42
42
|
postBuildOptimizer?: boolean;
|
|
43
43
|
singleUseCopyProp?: boolean;
|
|
44
44
|
iterateOptimizer?: boolean;
|
|
45
|
-
|
|
45
|
+
extraReferenceTypeChecks?: boolean;
|
|
46
46
|
checkTypes?: DiagnosticType | "OFF";
|
|
47
47
|
strictTypeCheck?: "On" | "Off" | "Default";
|
|
48
48
|
removeArgc?: boolean;
|
|
@@ -138,6 +138,7 @@ export type ProgramState = {
|
|
|
138
138
|
allClasses?: ClassStateNode[];
|
|
139
139
|
nestedClasses?: Record<string, ClassStateNode[]>;
|
|
140
140
|
allModules?: Set<ModuleStateNode>;
|
|
141
|
+
allTypedefs?: Set<TypedefStateNode>;
|
|
141
142
|
invokeInfo?: FunctionInfo;
|
|
142
143
|
allDeclarations?: Record<string, ByNameStateNodeDecls[]>;
|
|
143
144
|
fnMap?: FilesToOptimizeMap;
|
|
@@ -191,7 +192,7 @@ export type Finalized<T, Keys extends keyof T> = T & {
|
|
|
191
192
|
[key in Keys]-?: NonNullable<T[key]>;
|
|
192
193
|
};
|
|
193
194
|
export type ProgramStateLive = Finalized<ProgramState, "stack" | "top" | "lookup" | "lookupValue" | "lookupType" | "lookupNonlocal" | "stackClone" | "traverse" | "index" | "constants" | "removeNodeComments" | "inType" | "nextExposed" | "lookupRules">;
|
|
194
|
-
export type ProgramStateAnalysis = Finalized<ProgramStateLive, "allClasses" | "nestedClasses" | "allModules" | "allFunctions" | "fnMap" | "allDeclarations" | "invokeInfo">;
|
|
195
|
+
export type ProgramStateAnalysis = Finalized<ProgramStateLive, "allClasses" | "nestedClasses" | "allModules" | "allTypedefs" | "allFunctions" | "fnMap" | "allDeclarations" | "invokeInfo">;
|
|
195
196
|
export type ProgramStateOptimizer = Finalized<ProgramStateAnalysis, "localsStack" | "exposed" | "calledFunctions" | "usedByName">;
|
|
196
197
|
export type ExcludeAnnotationsMap = {
|
|
197
198
|
[key: string]: boolean;
|
|
@@ -10,7 +10,8 @@ type SysCallHelperResult = {
|
|
|
10
10
|
argTypes?: ExactOrUnion[];
|
|
11
11
|
effectFree?: true;
|
|
12
12
|
argEffects?: true;
|
|
13
|
+
diagnostic?: string;
|
|
13
14
|
};
|
|
14
|
-
type SysCallHelper = (
|
|
15
|
+
type SysCallHelper = (istate: InterpState, func: FunctionStateNode, calleeObj: ExactOrUnion, getArgs: () => Array<ExactOrUnion>) => SysCallHelperResult;
|
|
15
16
|
export declare function sysCallInfo(state: ProgramStateAnalysis, func: FunctionStateNode): SysCallHelper | null;
|
|
16
17
|
export {};
|
|
@@ -102,7 +102,7 @@ export interface StringType extends AbstractValue {
|
|
|
102
102
|
}
|
|
103
103
|
export interface ArrayType extends AbstractValue {
|
|
104
104
|
type: TypeTag.Array;
|
|
105
|
-
value?: ExactOrUnion | ExactOrUnion[] | undefined;
|
|
105
|
+
value?: ExactOrUnion | ExactOrUnion[] | Set<ExactOrUnion | ExactOrUnion[]> | undefined;
|
|
106
106
|
}
|
|
107
107
|
export interface DictionaryType extends AbstractValue {
|
|
108
108
|
type: TypeTag.Dictionary;
|
|
@@ -144,11 +144,8 @@ export interface ObjectType extends AbstractValue {
|
|
|
144
144
|
export interface EnumType extends AbstractValue {
|
|
145
145
|
type: TypeTag.Enum;
|
|
146
146
|
value?: {
|
|
147
|
-
enum: EnumStateNode;
|
|
147
|
+
enum: EnumStateNode | EnumStateNode[];
|
|
148
148
|
value?: ExactOrUnion | undefined;
|
|
149
|
-
} | {
|
|
150
|
-
enum?: undefined;
|
|
151
|
-
value: ExactOrUnion;
|
|
152
149
|
} | undefined;
|
|
153
150
|
}
|
|
154
151
|
export interface SymbolType extends AbstractValue {
|
|
@@ -215,4 +212,12 @@ export declare function getStateNodeDeclsWithExactFromType(state: ProgramStateAn
|
|
|
215
212
|
sn: StateNode;
|
|
216
213
|
exact: boolean;
|
|
217
214
|
}[];
|
|
215
|
+
export declare function isTupleUnion(t: ExactOrUnion[] | ExactOrUnion[][]): t is ExactOrUnion[][];
|
|
216
|
+
export declare function tupleForEach(t: NonNullable<ArrayType["value"]>, tupleFn: (v: ExactOrUnion[]) => unknown, arrayFn: (v: ExactOrUnion) => unknown): void;
|
|
217
|
+
export declare function tupleMap<T, U, V>(t: NonNullable<ArrayType["value"]>, tupleFn: (v: ExactOrUnion[]) => U | null, arrayFn: (v: ExactOrUnion) => V | null, reduceFn: (v: Array<U | V>) => T): T;
|
|
218
|
+
export declare function tupleReduce(v: Array<ExactOrUnion | ExactOrUnion[]>): UnionType | NumberType | LongType | FloatType | DoubleType | CharType | StringType | ArrayType | DictionaryType | MethodType | ModuleType | FunctionType | ClassType | ObjectType | EnumType | SymbolType | TypedefType | ExactOrUnion[] | Set<ExactOrUnion | ExactOrUnion[]>;
|
|
219
|
+
export declare function reducedArrayType(t: Set<ExactOrUnion[] | ExactOrUnion> | ExactOrUnion[] | ExactOrUnion): ExactOrUnion;
|
|
220
|
+
export declare function checkArrayCovariance(arg: NonNullable<ArrayType["value"]>, param: NonNullable<ArrayType["value"]>): boolean;
|
|
221
|
+
export declare function safeReferenceArg(arg: mctree.Expression): boolean;
|
|
222
|
+
export declare function typeFromEnumValue(arg: EnumType["value"] | null): UnionType | NumberType | LongType | FloatType | DoubleType | CharType | StringType | ArrayType | DictionaryType | MethodType | ModuleType | FunctionType | ClassType | ObjectType | EnumType | SymbolType | TypedefType;
|
|
218
223
|
export {};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { ExactOrUnion, TypeTag } from "./types";
|
|
2
2
|
export declare function unionInto(to: ExactOrUnion, from: ExactOrUnion): boolean;
|
|
3
|
+
export declare function unionHelper(to: ExactOrUnion, from: ExactOrUnion, widenDepth: number): boolean;
|
|
3
4
|
export declare function clearValuesUnder(v: ExactOrUnion, tag: TypeTag, clearTag?: boolean): void;
|
|
4
|
-
export declare function widenType(t: ExactOrUnion): null;
|
package/build/worker-thread.cjs
CHANGED
|
@@ -21,17 +21,17 @@ __export(worker_thread_exports, {
|
|
|
21
21
|
default: () => worker_thread_default
|
|
22
22
|
});
|
|
23
23
|
module.exports = __toCommonJS(worker_thread_exports);
|
|
24
|
-
var
|
|
24
|
+
var import_chunk_UNU55JJ3 = require("./chunk-UNU55JJ3.cjs");
|
|
25
25
|
var import_chunk_X7QCZR3F = require("./chunk-X7QCZR3F.cjs");
|
|
26
26
|
var import_chunk_JDC43A3I = require("./chunk-JDC43A3I.cjs");
|
|
27
27
|
var import_chunk_ABYVSU2C = require("./chunk-ABYVSU2C.cjs");
|
|
28
28
|
var import_node_worker_threads = require("node:worker_threads");
|
|
29
29
|
var require_worker_thread = (0, import_chunk_ABYVSU2C.__commonJS)({
|
|
30
30
|
"src/worker-thread.ts"() {
|
|
31
|
-
(0,
|
|
31
|
+
(0, import_chunk_UNU55JJ3.init_worker_task)();
|
|
32
32
|
if (import_node_worker_threads.parentPort) {
|
|
33
33
|
import_node_worker_threads.parentPort.on("message", async (task) => {
|
|
34
|
-
return import_node_worker_threads.parentPort.postMessage(await (0,
|
|
34
|
+
return import_node_worker_threads.parentPort.postMessage(await (0, import_chunk_UNU55JJ3.performTask)(task));
|
|
35
35
|
});
|
|
36
36
|
}
|
|
37
37
|
}
|
package/package.json
CHANGED