hackmud-script-manager 0.12.0-c276bb2 → 0.13.0-02e8706

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hackmud-script-manager",
3
- "version": "0.12.0-c276bb2",
3
+ "version": "0.13.0-02e8706",
4
4
  "description": "Script manager for game hackmud, with minification, TypeScript support, and player script type definition generation.",
5
5
  "keywords": [
6
6
  "api",
@@ -21,47 +21,103 @@
21
21
  "bugs": "https://github.com/samualtnorman/hackmud-script-manager/issues",
22
22
  "license": "GPL-3.0-or-later",
23
23
  "author": "Samual Norman",
24
- "files": [
25
- "index.d.ts",
26
- "shared.js"
27
- ],
28
24
  "main": "index.js",
29
- "bin": {
30
- "hsm": "bin/hsm.js"
31
- },
32
25
  "repository": {
33
26
  "type": "git",
34
27
  "url": "https://github.com/samualtnorman/hackmud-script-manager.git"
35
28
  },
36
- "scripts": {
37
- "build": "rollup -c",
38
- "dev": "rollup -cw"
39
- },
40
29
  "dependencies": {
41
- "acorn": "8.x",
42
- "chalk": "4.x",
43
- "chokidar": "3.x",
44
- "escodegen": "^2.0.0",
45
- "esprima": "^4.0.1",
46
- "esquery": "^1.4.0",
47
- "terser": "5.x",
48
- "typescript": "^4.4.0-beta"
30
+ "@babel/core": "^7.16.0",
31
+ "@babel/generator": "^7.16.0",
32
+ "@babel/parser": "^7.16.4",
33
+ "@babel/plugin-proposal-class-properties": "^7.16.0",
34
+ "@babel/plugin-proposal-class-static-block": "^7.16.0",
35
+ "@babel/plugin-proposal-decorators": "^7.16.4",
36
+ "@babel/plugin-proposal-do-expressions": "^7.16.0",
37
+ "@babel/plugin-proposal-function-bind": "^7.16.0",
38
+ "@babel/plugin-proposal-function-sent": "^7.16.0",
39
+ "@babel/plugin-proposal-json-strings": "^7.16.0",
40
+ "@babel/plugin-proposal-logical-assignment-operators": "^7.16.0",
41
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.16.0",
42
+ "@babel/plugin-proposal-numeric-separator": "^7.16.0",
43
+ "@babel/plugin-proposal-object-rest-spread": "^7.16.0",
44
+ "@babel/plugin-proposal-optional-catch-binding": "^7.16.0",
45
+ "@babel/plugin-proposal-optional-chaining": "^7.16.0",
46
+ "@babel/plugin-proposal-partial-application": "^7.16.0",
47
+ "@babel/plugin-proposal-pipeline-operator": "^7.16.0",
48
+ "@babel/plugin-proposal-private-property-in-object": "^7.16.0",
49
+ "@babel/plugin-proposal-record-and-tuple": "^7.16.0",
50
+ "@babel/plugin-proposal-throw-expressions": "^7.16.0",
51
+ "@babel/plugin-transform-exponentiation-operator": "^7.16.0",
52
+ "@babel/plugin-transform-typescript": "^7.16.1",
53
+ "@babel/traverse": "^7.16.3",
54
+ "@babel/types": "^7.16.0",
55
+ "@bloomberg/record-tuple-polyfill": "^0.0.4",
56
+ "@rollup/plugin-babel": "^5.3.0",
57
+ "@rollup/plugin-commonjs": "^21.0.1",
58
+ "@rollup/plugin-json": "^4.1.0",
59
+ "@rollup/plugin-node-resolve": "^13.0.6",
60
+ "acorn": "^8.5.0",
61
+ "chalk": "^5.0.0",
62
+ "chokidar": "^3.5.2",
63
+ "prettier": "^2.4.1",
64
+ "proxy-polyfill": "^0.3.2",
65
+ "rollup": "^2.60.0",
66
+ "terser": "^5.10.0"
49
67
  },
50
68
  "devDependencies": {
51
- "@rollup/plugin-typescript": "^8.2.5",
52
- "@types/escodegen": "^0.0.7",
53
- "@types/esprima": "^4.0.3",
54
- "@types/esquery": "^1.0.2",
55
- "@types/node": "12.x",
56
- "@types/semver": "7.x",
57
- "rollup": "^2.56.3",
69
+ "@babel/preset-env": "^7.16.4",
70
+ "@babel/preset-typescript": "^7.16.0",
71
+ "@samual/lib": "^0.2.0-890d658",
72
+ "@types/babel__core": "^7.1.16",
73
+ "@types/node": "^12.20.37",
74
+ "@types/prettier": "^2.4.2",
75
+ "@types/semver": "^7.3.9",
76
+ "@typescript-eslint/eslint-plugin": "^5.8.0",
77
+ "@typescript-eslint/parser": "^5.8.1",
78
+ "eslint": "^8.5.0",
79
+ "eslint-plugin-array-func": "^3.1.7",
80
+ "eslint-plugin-eslint-comments": "^3.2.0",
81
+ "eslint-plugin-optimize-regex": "^1.2.1",
82
+ "eslint-plugin-regexp": "^1.5.1",
83
+ "eslint-plugin-unicorn": "^39.0.0",
84
+ "eslint-plugin-write-good-comments": "^0.1.3",
58
85
  "rollup-plugin-preserve-shebang": "^1.0.1",
59
- "semver": "7.x",
60
- "tslib": "^2.3.1"
86
+ "rollup-plugin-terser": "^7.0.2",
87
+ "semver": "^7.3.5",
88
+ "typescript": "^4.5.2"
89
+ },
90
+ "optionalDependencies": {
91
+ "deasync": "^0.1.24"
61
92
  },
62
93
  "engines": {
63
- "node": ">=12"
94
+ "node": "^12.20 || >=14"
64
95
  },
65
96
  "types": "index.d.ts",
66
- "type": "module"
67
- }
97
+ "type": "module",
98
+ "exports": {
99
+ ".": {
100
+ "import": "./index.js",
101
+ "require": "./index.cjs"
102
+ },
103
+ "./*": "./*",
104
+ "./generateTypings": "./generateTypings.js",
105
+ "./index": "./index.js",
106
+ "./pull": "./pull.js",
107
+ "./push": "./push.js",
108
+ "./syncMacros": "./syncMacros.js",
109
+ "./test": "./test.js",
110
+ "./watch": "./watch.js",
111
+ "./bin/hsm": "./bin/hsm.js",
112
+ "./processScript/index": "./processScript/index.js",
113
+ "./processScript": "./processScript/index.js",
114
+ "./processScript/minify": "./processScript/minify.js",
115
+ "./processScript/postprocess": "./processScript/postprocess.js",
116
+ "./processScript/preprocess": "./processScript/preprocess.js",
117
+ "./processScript/shared": "./processScript/shared.js",
118
+ "./processScript/transform": "./processScript/transform.js"
119
+ },
120
+ "bin": {
121
+ "hsm": "./bin/hsm.js"
122
+ }
123
+ }
@@ -0,0 +1,33 @@
1
+ export { minify } from "./minify";
2
+ export { postprocess } from "./postprocess";
3
+ export { preprocess } from "./preprocess";
4
+ export { transform as compile } from "./transform";
5
+ export declare type ProcessOptions = {
6
+ /** whether to minify the given code */
7
+ minify: boolean;
8
+ /** 11 a-z 0-9 characters */
9
+ uniqueID: string;
10
+ /** the user going to be hosting this script (or set to `true` if not yet known) */
11
+ scriptUser: string | true;
12
+ /** the name of this script (or set to `true` if not yet known) */
13
+ scriptName: string | true;
14
+ filePath: string;
15
+ /** whether to mangle function and class names (defaults to `false`) */
16
+ mangleNames: boolean;
17
+ };
18
+ /**
19
+ * Minifies a given script
20
+ *
21
+ * @param code JavaScript or TypeScript code
22
+ * @param options {@link ProcessOptions details}
23
+ */
24
+ export declare function processScript(code: string, { minify: shouldMinify, uniqueID, scriptUser, scriptName, filePath, mangleNames }?: Partial<ProcessOptions>): Promise<{
25
+ srcLength: number;
26
+ script: string;
27
+ warnings: {
28
+ message: string;
29
+ line: number;
30
+ }[];
31
+ timeTook: number;
32
+ }>;
33
+ export default processScript;
@@ -0,0 +1 @@
1
+ import e from"@babel/generator";import{parse as o}from"@babel/parser";import r from"@babel/plugin-proposal-class-properties";import t from"@babel/plugin-proposal-class-static-block";import s from"@babel/plugin-proposal-decorators";import p from"@babel/plugin-proposal-do-expressions";import a from"@babel/plugin-proposal-function-bind";import l from"@babel/plugin-proposal-function-sent";import i from"@babel/plugin-proposal-json-strings";import n from"@babel/plugin-proposal-logical-assignment-operators";import m from"@babel/plugin-proposal-nullish-coalescing-operator";import c from"@babel/plugin-proposal-numeric-separator";import f from"@babel/plugin-proposal-object-rest-spread";import u from"@babel/plugin-proposal-optional-catch-binding";import b from"@babel/plugin-proposal-optional-chaining";import d from"@babel/plugin-proposal-partial-application";import g from"@babel/plugin-proposal-pipeline-operator";import h from"@babel/plugin-proposal-private-property-in-object";import w from"@babel/plugin-proposal-record-and-tuple";import y from"@babel/plugin-proposal-throw-expressions";import x from"@babel/plugin-transform-exponentiation-operator";import j from"@babel/plugin-transform-typescript";import S from"@babel/traverse";import k from"@babel/types";import v from"@rollup/plugin-babel";import E from"@rollup/plugin-commonjs";import N from"@rollup/plugin-json";import C from"@rollup/plugin-node-resolve";import{a as L}from"../assert-1b7dada8.js";import{resolve as _}from"path";import{c as I,minify as D}from"./minify.js";export{minify}from"./minify.js";import{performance as U}from"perf_hooks";import $ from"prettier";import{rollup as M}from"rollup";import{postprocess as W}from"./postprocess.js";export{postprocess}from"./postprocess.js";import{preprocess as q}from"./preprocess.js";export{preprocess}from"./preprocess.js";import{transform as F}from"./transform.js";export{transform as compile}from"./transform.js";import"../spliceString-2c6f214f.js";import"acorn";import"terser";import"./shared.js";const T=[".js",".ts"],{default:H}=v,{format:O}=$,{default:P}=e,{default:K}=S;async function processScript(e,{minify:S=!0,uniqueID:v=Math.floor(Math.random()*2**52).toString(36).padStart(11,"0"),scriptUser:$="UNKNOWN",scriptName:z="UNKNOWN",filePath:B,mangleNames:G=!1}={}){L(/^\w{11}$/.exec(v)),B=B?_(B):"script";const A=U.now(),J=e;let Q,R;const V=/^function\s*\(.+\/\/(?<autocomplete>.+)/.exec(e);if(V)e=`export default ${e}`,({autocomplete:Q}=V.groups);else for(const o of e.split("\n")){const e=/^\s*\/\/(?<commentContent>.+)/.exec(o);if(!e)break;const r=e.groups.commentContent.trim();if(r.startsWith("@autocomplete "))Q=r.slice(14).trimStart();else if(r.startsWith("@seclevel ")){const e=r.slice(10).trimStart().toLowerCase();switch(e){case"fullsec":case"full":case"fs":case"4s":case"f":case"4":R=4;break;case"highsec":case"high":case"hs":case"3s":case"h":case"3":R=3;break;case"midsec":case"mid":case"ms":case"2s":case"m":case"2":R=2;break;case"lowsec":case"low":case"ls":case"1s":case"l":case"1":R=1;break;case"nullsec":case"null":case"ns":case"0s":case"n":case"0":R=0;break;default:throw new Error(`unrecognised seclevel "${e}"`)}}}L(/^\w{11}$/.exec(v));const X=B?_(B):"script";let Y=4;const Z=await M({plugins:[{name:"emit script",buildStart(){this.emitFile({type:"chunk",id:X})},load:o=>o==X?e:null,transform(e){const{code:o,seclevel:r}=q(e,{uniqueID:v});return Y=Math.min(Y,r),o}},H({babelHelpers:"bundled",plugins:[[j.default,{allowDeclareFields:!0,optimizeConstEnums:!0}],[s.default,{decoratorsBeforeExport:!0}],[p.default],[a.default],[l.default],[d.default],[g.default,{proposal:"hack",topicToken:"%"}],[y.default],[w.default,{syntaxType:"hash",importPolyfill:!0}],[r.default],[t.default],[h.default],[n.default],[c.default],[m.default],[b.default],[u.default],[i.default],[f.default],[x.default]],configFile:!1,extensions:T}),E(),C({extensions:T}),N()],treeshake:{moduleSideEffects:!1}}),ee=["NULLSEC","LOWSEC","MIDSEC","HIGHSEC","FULLSEC"];let oe;if(e=(await Z.generate({})).output[0].code,({file:oe,seclevel:Y}=await F(o(e,{sourceType:"module"}),J,{uniqueID:v,scriptUser:$,scriptName:z,seclevel:Y})),null!=R&&Y<R)throw new Error(`detected seclevel ${ee[Y]} is lower than stated seclevel ${ee[R]}`);e=P(oe).code;const re=I(e.replace(/^function\s*\w+\(/,"function("));return S?e=await D(oe,Q,{uniqueID:v,mangleNames:G}):(K(oe,{MemberExpression({node:e}){e.computed||(L("Identifier"==e.property.type),"prototype"==e.property.name?(e.computed=!0,e.property=k.stringLiteral("prototype")):"__proto__"==e.property.name&&(e.computed=!0,e.property=k.stringLiteral("__proto__")))}}),e=O(P(oe).code,{parser:"babel",arrowParens:"avoid",semi:!1,trailingComma:"none"})),{srcLength:re,script:e=W(e,Y,v),warnings:[],timeTook:U.now()-A}}export{processScript as default,processScript,T as s};
@@ -0,0 +1,14 @@
1
+ import { File } from "@babel/types";
2
+ declare type MinifyOptions = {
3
+ /** 11 a-z 0-9 characters */
4
+ uniqueID: string;
5
+ /** whether to mangle function and class names (defaults to `false`) */
6
+ mangleNames: boolean;
7
+ };
8
+ /**
9
+ * @param code compiled code and/or hackmud compatible code
10
+ * @param autocomplete the comment inserted after the function signature
11
+ * @param options {@link MinifyOptions details}
12
+ */
13
+ export declare function minify(file: File, autocomplete?: string, { uniqueID, mangleNames }?: Partial<MinifyOptions>): Promise<string>;
14
+ export default minify;
@@ -0,0 +1 @@
1
+ import e from"@babel/generator";import t from"@babel/traverse";import r from"@babel/types";import{a as i}from"../assert-1b7dada8.js";import{s as n}from"../spliceString-2c6f214f.js";import{tokenizer as a,tokTypes as s}from"acorn";import*as o from"terser";import{getReferencePathsToGlobal as p}from"./shared.js";function countHackmudCharacters(e){return e.replace(/\/\/.*/g,"").replace(/[ \t\n\r\u00a0\u1680\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000]/g,"").length}const{default:l}=e,{default:u}=t;async function minify(e,t,{uniqueID:a="00000000000",mangleNames:s=!1}={}){let c;i(/^\w{11}$/.exec(a)),u(e,{Program(e){c=e,e.skip()}});const f=c.get("body.0");for(const e of[...f.node.params].reverse()){if("Identifier"==e.type){if(!f.scope.getBinding(e.name).referenced){f.node.params.pop();continue}}break}for(const e in c.scope.globals){if("arguments"==e||e.startsWith(`$${a}`))continue;const t=p(e,c);if(!(5+e.length+t.length>=e.length*t.length)){for(const i of t)i.replaceWith(r.identifier(`_GLOBAL_${e}_${a}_`));f.node.body.body.unshift(r.variableDeclaration("let",[r.variableDeclarator(r.identifier(`_GLOBAL_${e}_${a}_`),r.identifier(e))]))}}const d=[];let m=!1;const _=r.cloneNode(e);u(_,{MemberExpression({node:e}){e.computed||(i("Identifier"==e.property.type),"prototype"==e.property.name?(e.computed=!0,e.property=r.identifier(`_PROTOTYPE_PROPERTY_${a}_`)):"__proto__"==e.property.name&&(e.computed=!0,e.property=r.identifier(`_PROTO_PROPERTY_${a}_`)))}});const y=(await o.minify(l(_).code,{ecma:2015,compress:{passes:1/0,unsafe:!0,unsafe_arrows:!0,unsafe_comps:!0,unsafe_symbols:!0,unsafe_methods:!0,unsafe_proto:!0,unsafe_regexp:!0,unsafe_undefined:!0,sequences:!1},format:{semicolons:!1},keep_classnames:!s,keep_fnames:!s})).code.replace(new RegExp(`_PROTOTYPE_PROPERTY_${a}_`,"g"),'"prototype"').replace(new RegExp(`_PROTO_PROPERTY_${a}_`,"g"),'"__proto__"');let E,$=null,b=!1;{const t=[];u(e,{FunctionDeclaration(e){e.traverse({Function(e){"CallExpression"!=e.parent.type&&"callee"!=e.parentKey&&e.skip()},Loop(e){e.skip()},ObjectExpression(e){const t={};parseObjectExpression(e.node,t)&&e.replaceWith(r.identifier(`_JSON_VALUE_${d.push(t)-1}_${a}_`))},ArrayExpression(e){const t=[];parseArrayExpression(e.node,t)&&e.replaceWith(r.identifier(`_JSON_VALUE_${d.push(t)-1}_${a}_`))}}),e.traverse({TemplateLiteral(e){const t=e.node;let i=r.stringLiteral(t.quasis[0].value.cooked);for(let e=0;e<t.expressions.length;e++){const n=t.expressions[e],a=t.quasis[e+1];i=r.binaryExpression("+",i,n),a.value.cooked&&(i=r.binaryExpression("+",i,r.stringLiteral(a.value.cooked)))}e.replaceWith(i)},MemberExpression({node:e}){e.computed||(i("Identifier"==e.property.type),e.property.name.length<3||(e.computed=!0,e.property=r.stringLiteral(e.property.name)))},UnaryExpression(e){if("void"==e.node.operator)"NumericLiteral"!=e.node.argument.type||e.node.argument.value||(e.replaceWith(r.identifier(`_UNDEFINED_${a}_`)),m=!0);else if("-"==e.node.operator&&"NumericLiteral"==e.node.argument.type){const i=-e.node.argument.value;t.push((async()=>{if((await minifyNumber(i)).length<=3)return;"key"==e.parentKey&&"ObjectProperty"==e.parent.type&&(e.parent.computed=!0);let t=d.indexOf(i);-1==t&&(t+=d.push(i)),e.replaceWith(r.identifier(`_JSON_VALUE_${t}_${a}_`))})()),e.skip()}},NullLiteral(e){let t=d.indexOf(null);-1==t&&(t+=d.push(null)),e.replaceWith(r.identifier(`_JSON_VALUE_${t}_${a}_`))},BooleanLiteral(e){let t=d.indexOf(e.node.value);-1==t&&(t+=d.push(e.node.value)),e.replaceWith(r.identifier(`_JSON_VALUE_${t}_${a}_`))},NumericLiteral(e){t.push((async()=>{if((await minifyNumber(e.node.value)).length<=3)return;"key"==e.parentKey&&"ObjectProperty"==e.parent.type&&(e.parent.computed=!0);let t=d.indexOf(e.node.value);-1==t&&(t+=d.push(e.node.value)),e.replaceWith(r.identifier(`_JSON_VALUE_${t}_${a}_`))})())},StringLiteral(e){if(e.node.value.includes("\0")||e.toString().length<4)return;"key"==e.parentKey&&"ObjectProperty"==e.parent.type&&(e.parent.computed=!0);let t=d.indexOf(e.node.value);-1==t&&(t+=d.push(e.node.value)),e.replaceWith(r.identifier(`_JSON_VALUE_${t}_${a}_`))},ObjectProperty({node:e}){if(e.computed||"Identifier"!=e.key.type||e.key.name.length<4)return;let t=d.indexOf(e.key.name);-1==t&&(t+=d.push(e.key.name)),e.computed=!0,e.key=r.identifier(`_JSON_VALUE_${t}_${a}_`)}}),e.skip()}}),await Promise.all(t);const n=e.program.body[0];if(i("FunctionDeclaration"==n.type),d.length)if(b=!0,1==d.length)if("string"!=typeof d[0]||d[0].includes("\n")||d[0].includes("\t")){const e=r.variableDeclaration("let",[r.variableDeclarator(r.identifier(`_JSON_VALUE_0_${a}_`),r.callExpression(r.memberExpression(r.identifier("JSON"),r.identifier("parse")),[r.memberExpression(r.taggedTemplateExpression(r.memberExpression(r.callExpression(r.identifier(`$${a}$SUBSCRIPT$scripts$quine`),[]),r.identifier("split")),r.templateLiteral([r.templateElement({raw:"\t",cooked:"\t"},!0)],[])),r.identifier(`$${a}$SPLIT_INDEX`),!0)]))]);m&&e.declarations.push(r.variableDeclarator(r.identifier(`_UNDEFINED_${a}_`))),n.body.body.unshift(e),$=JSON.stringify(d[0])}else{const e=r.variableDeclaration("let",[r.variableDeclarator(r.identifier(`_JSON_VALUE_0_${a}_`),r.memberExpression(r.taggedTemplateExpression(r.memberExpression(r.callExpression(r.identifier(`$${a}$SUBSCRIPT$scripts$quine`),[]),r.identifier("split")),r.templateLiteral([r.templateElement({raw:"\t",cooked:"\t"},!0)],[])),r.identifier(`$${a}$SPLIT_INDEX`),!0))]);m&&e.declarations.push(r.variableDeclarator(r.identifier(`_UNDEFINED_${a}_`))),n.body.body.unshift(e),$=d[0]}else{const e=r.variableDeclaration("let",[r.variableDeclarator(r.arrayPattern(d.map(((e,t)=>r.identifier(`_JSON_VALUE_${t}_${a}_`)))),r.callExpression(r.memberExpression(r.identifier("JSON"),r.identifier("parse")),[r.memberExpression(r.taggedTemplateExpression(r.memberExpression(r.callExpression(r.identifier(`$${a}$SUBSCRIPT$scripts$quine`),[]),r.identifier("split")),r.templateLiteral([r.templateElement({raw:"\t",cooked:"\t"},!0)],[])),r.identifier(`$${a}$SPLIT_INDEX`),!0)]))]);m&&e.declarations.push(r.variableDeclarator(r.identifier(`_UNDEFINED_${a}_`))),n.body.body.unshift(e),$=JSON.stringify(d)}else m&&n.body.body.unshift(r.variableDeclaration("let",[r.variableDeclarator(r.identifier(`_UNDEFINED_${a}_`))]));E=l(e).code}return E=(await o.minify(E,{ecma:2015,compress:{passes:1/0,unsafe:!0,unsafe_arrows:!0,unsafe_comps:!0,unsafe_symbols:!0,unsafe_methods:!0,unsafe_proto:!0,unsafe_regexp:!0,unsafe_undefined:!0,sequences:!1},format:{semicolons:!1},keep_classnames:!s,keep_fnames:!s})).code||"",null!=$&&(E=n(E,`${t?`//${t}\n`:""}\n//\t${$}\t\n`,getFunctionBodyStart(E)+1),E=E.replace(`$${a}$SPLIT_INDEX`,await minifyNumber(E.split("\t").findIndex((e=>e==$))))),countHackmudCharacters(y)<=countHackmudCharacters(E)+Number(b)&&(E=y,t&&(E=n(E,`//${t}\n`,getFunctionBodyStart(E)+1))),E}function parseObjectExpression(e,t){if(!e.properties.length)return!1;for(const r of e.properties){if("ObjectProperty"!=r.type||r.computed)return!1;if(i("Identifier"==r.key.type||"NumericLiteral"==r.key.type||"StringLiteral"==r.key.type),"ArrayExpression"==r.value.type){const e=[];if(!parseArrayExpression(r.value,e))return!1;t["Identifier"==r.key.type?r.key.name:r.key.value]=e}else if("ObjectExpression"==r.value.type){const e={};if(!parseObjectExpression(r.value,e))return!1;t["Identifier"==r.key.type?r.key.name:r.key.value]=e}else if("NullLiteral"==r.value.type)t["Identifier"==r.key.type?r.key.name:r.key.value]=null;else{if("BooleanLiteral"!=r.value.type&&"NumericLiteral"!=r.value.type&&"StringLiteral"!=r.value.type)return!1;t["Identifier"==r.key.type?r.key.name:r.key.value]=r.value.value}}return!0}function parseArrayExpression(e,t){if(!e.elements.length)return!1;for(const r of e.elements){if(!r)return!1;if("ArrayExpression"==r.type){const e=[];if(!parseArrayExpression(r,e))return!1;e.push(e)}else if("ObjectExpression"==r.type){const e={};if(!parseObjectExpression(r,e))return!1;t.push(e)}else if("NullLiteral"==r.type)t.push(null);else{if("BooleanLiteral"!=r.type&&"NumericLiteral"!=r.type&&"StringLiteral"!=r.type)return!1;t.push(r.value)}}return!0}async function minifyNumber(e){return/\$\((?<number>.+)\)/.exec((await o.minify(`$(${e})`,{ecma:2015})).code).groups.number}function getFunctionBodyStart(e){const t=a(e,{ecmaVersion:2015});t.getToken(),t.getToken(),t.getToken();let r=1;for(;r;){const e=t.getToken();e.type==s.parenL?r++:e.type==s.parenR&&r--}return t.getToken().start}export{countHackmudCharacters as c,minify as default,minify};
@@ -0,0 +1,2 @@
1
+ export declare function postprocess(code: string, seclevel: number, uniqueID: string): string;
2
+ export default postprocess;
@@ -0,0 +1 @@
1
+ import{s as e}from"../spliceString-2c6f214f.js";function*findMatches(e,s){let t;for(;t=e.exec(s);)yield{index:t.index,match:t[0]}}function postprocess(s,t,n){s=s.replace(/^function\s*\w+\(/,"function(");for(const{index:c,match:r}of[...findMatches(new RegExp(`\\$${n}\\$[\\w$]+`,"g"),s)].reverse()){const[n,...o]=r.slice(13).split("$");switch(n){case"SUBSCRIPT":s=e(s,`#${"nlmhf"[t]}s.${o[0]}.${o[1]}`,c,r.length);break;case"DEBUG":s=e(s,"#D",c,r.length);break;case"FMCL":s=e(s,"#FMCL",c,r.length);break;case"GLOBAL":s=e(s,"#G",c,r.length);break;case"DB":s=e(s,`#db.${o[0]}`,c,r.length);break;default:throw new Error(`unknown type "${n}"`)}}return s}export{postprocess as default,postprocess};
@@ -0,0 +1,13 @@
1
+ export declare type PreprocessOptions = {
2
+ /** 11 a-z 0-9 characters */
3
+ uniqueID: string;
4
+ };
5
+ /**
6
+ * @param code source code for preprocessing
7
+ * @param options {@link PreprocessOptions details}
8
+ */
9
+ export declare function preprocess(code: string, { uniqueID }?: Partial<PreprocessOptions>): {
10
+ code: string;
11
+ seclevel: number;
12
+ };
13
+ export default preprocess;
@@ -0,0 +1 @@
1
+ import e from"@babel/generator";import{parse as r}from"@babel/parser";import o from"@babel/traverse";import i from"@babel/types";import{a as t}from"../assert-1b7dada8.js";import{s}from"../spliceString-2c6f214f.js";const{default:p}=o,{default:a}=e;function preprocess(e,{uniqueID:o="00000000000"}={}){if(t(/^\w{11}$/.test(o)),/(?:SC|DB)\$/.test(e))throw new Error("SC$ and DB$ are protected and cannot appear in a script");const n=e;e=e.replace(/^function\s*\(/,"export default function (");const l={f:4,h:3,m:2,l:1,n:0,4:4,3:3,2:2,1:1,0:0};let c,f,d=4;for(;;){let i;try{c=r(e,{plugins:["typescript",["decorators",{decoratorsBeforeExport:!0}],"doExpressions","functionBind","functionSent","partialApplication",["pipelineOperator",{proposal:"hack",topicToken:"%"}],"throwExpressions",["recordAndTuple",{syntaxType:"hash"}],"classProperties","classPrivateProperties","classPrivateMethods","logicalAssignment","numericSeparator","nullishCoalescingOperator","optionalChaining","optionalCatchBinding","objectRestSpread"],sourceType:"module"});break}catch(e){t(e instanceof SyntaxError),i=e}var m;if("BABEL_PARSER_SYNTAX_ERROR"!=i.code||"PrivateInExpectedIn"!=i.reasonCode)throw console.log(null===(m=/.+/.exec(e.slice(i.pos)))||void 0===m?void 0:m[0]),i;const p=e.slice(i.pos);let a;if(a=/^#[0-4fhmln]s\.scripts\.quine\(\)/.exec(p))e=s(e,JSON.stringify(n),i.pos,a[0].length);else if(a=/^#(?<seclevel>[0-4fhmln])?s\.(?<userName>[_a-z][\d_a-z]{0,24})\.(?<scriptName>[_a-z][\d_a-z]{0,24})\(/.exec(p))a[1]&&(d=Math.min(d,l[a[1]])),e=s(e,`$${o}$SUBSCRIPT$${a[2]}$${a[3]}(`,i.pos,a[0].length);else if(a=/^#D\(/.exec(p))e=s(e,`$${o}$DEBUG(`,i.pos,a[0].length);else if(a=/^#FMCL/.exec(p))e=s(e,`$${o}$FMCL`,i.pos,a[0].length);else if(a=/^#G/.exec(p))e=s(e,`$${o}$GLOBAL`,i.pos,a[0].length);else{if(!(a=/^#db\.(?<methodName>[irfu]|u1|us|ObjectId)\(/.exec(p)))throw i;e=s(e,`$${o}$DB$${a[1]}(`,i.pos,a[0].length)}}p(c,{Program(e){f=e,e.skip()}});const u=f.scope.hasGlobal("Record"),h=f.scope.hasGlobal("Tuple");return(u||h)&&c.program.body.unshift(i.importDeclaration(u?h?[i.importSpecifier(i.identifier("Record"),i.identifier("Record")),i.importSpecifier(i.identifier("Tuple"),i.identifier("Tuple"))]:[i.importSpecifier(i.identifier("Record"),i.identifier("Record"))]:[i.importSpecifier(i.identifier("Tuple"),i.identifier("Tuple"))],i.stringLiteral("@bloomberg/record-tuple-polyfill"))),f.scope.hasGlobal("Proxy")&&c.program.body.unshift(i.importDeclaration([i.importDefaultSpecifier(i.identifier("Proxy"))],i.stringLiteral("proxy-polyfill/src/proxy.js"))),{code:a(c).code,seclevel:d}}export{preprocess as default,preprocess};
@@ -0,0 +1,3 @@
1
+ import { NodePath } from "@babel/traverse";
2
+ import t, { Program } from "@babel/types";
3
+ export declare function getReferencePathsToGlobal(name: string, program: NodePath<Program>): NodePath<t.Identifier>[];
@@ -0,0 +1 @@
1
+ import e from"@babel/types";import{e as r}from"../assert-1b7dada8.js";function getReferencePathsToGlobal(t,a){const[o]=a.unshiftContainer("body",e.variableDeclaration("let",[e.variableDeclarator(e.identifier(t))]));a.scope.crawl();const n=r(a.scope.getBinding(t));return o.remove(),n.referencePaths}export{getReferencePathsToGlobal};
@@ -0,0 +1,22 @@
1
+ import t, { File } from "@babel/types";
2
+ export declare type TransformOptions = {
3
+ /** 11 a-z 0-9 characters */
4
+ uniqueID: string;
5
+ /** the user going to be hosting this script (or set to `true` if not yet known) */
6
+ scriptUser: string | true;
7
+ /** the name of this script (or set to `true` if not yet known) */
8
+ scriptName: string | true;
9
+ seclevel: number;
10
+ };
11
+ /**
12
+ * transform a given babel `File` to be hackmud compatible
13
+ *
14
+ * (returned File will need `postprocess()`ing)
15
+ *
16
+ * @param options {@link TransformOptions details}
17
+ */
18
+ export declare function transform(file: File, sourceCode: string, { uniqueID, scriptUser, scriptName, seclevel }?: Partial<TransformOptions>): {
19
+ file: t.File;
20
+ seclevel: number;
21
+ };
22
+ export default transform;
@@ -0,0 +1 @@
1
+ import e from"@babel/traverse";import t from"@babel/types";import{a as i}from"../assert-1b7dada8.js";import{getReferencePathsToGlobal as r}from"./shared.js";function clearObject(e,t=Object.prototype){for(const t of Object.getOwnPropertyNames(e))delete e[t];for(const t of Object.getOwnPropertySymbols(e))delete e[t];return Object.setPrototypeOf(e,t),e}const{default:n}=e,o=["Map","Set","Date","JSON","Math","Array","Error","isNaN","Number","Object","RegExp","String","Symbol","BigInt"];function transform(e,a,{uniqueID:s="00000000000",scriptUser:p="UNKNOWN",scriptName:l="UNKNOWN",seclevel:c=4}={}){const d=`_SCRIPT_${s}_`,f=new Map,b=new Map;let y;if(n(e,{Program(e){y=e,e.skip()}}),y.scope.hasGlobal("_START"))for(const e of r("_START",y))e.replaceWith(t.identifier("_ST"));if(y.scope.hasGlobal("_TIMEOUT"))for(const e of r("_START",y))e.replaceWith(t.identifier("_TO"));if(y.scope.hasGlobal("_SOURCE"))for(const e of r("_SOURCE",y))e.replaceWith(t.stringLiteral(a));if(y.scope.hasGlobal("_BUILD_DATE"))for(const e of r("_BUILD_DATE",y))e.replaceWith(t.numericLiteral(Date.now()));if(y.scope.hasGlobal("_SCRIPT_USER"))for(const e of r("_SCRIPT_USER",y))1==p?e.replaceWith(t.stringLiteral(`$${s}$SCRIPT_USER`)):e.replaceWith(t.stringLiteral(p));if(y.scope.hasGlobal("_SCRIPT_NAME"))for(const e of r("_SCRIPT_NAME",y))1==l?e.replaceWith(t.stringLiteral(`$${s}$SCRIPT_NAME`)):e.replaceWith(t.stringLiteral(l));if(y.scope.hasGlobal("_FULL_SCRIPT_NAME"))for(const e of r("_FULL_SCRIPT_NAME",y))1==p||1==l?e.replaceWith(t.stringLiteral(`$${s}$FULL_SCRIPT_NAME`)):e.replaceWith(t.stringLiteral(`${p}.${l}`));let h=!1;if(y.scope.hasGlobal("Function")){const e=r("Function",y);if(1==e.length){const t=e[0];i("MemberExpression"==t.parent.type,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),i("Identifier"==t.parent.property.type,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),i("prototype"==t.parent.property.name,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),t.parentPath.replaceWith(createGetFunctionPrototypeNode())}else{for(const r of e)i("MemberExpression"==r.parent.type,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),i("Identifier"==r.parent.property.type,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),i("prototype"==r.parent.property.name,"`Function` isn't available in hackmud, only `Function.prototype` is accessible"),h=!0,r.parentPath.replaceWith(t.identifier(`$${s}$FUNCTION_DOT_PROTOTYPE`));h=!0}}let $=4;for(const e of["$fs","$4s","$s"])if(y.scope.hasGlobal(e))for(const n of r(e,y)){var m;i("MemberExpression"==n.parent.type),i("Identifier"==n.parent.property.type),i("MemberExpression"==(null===(m=n.parentPath.parentPath)||void 0===m?void 0:m.node.type)),i("Identifier"==n.parentPath.parentPath.node.property.type),n.parentPath.parentPath.replaceWith(t.identifier(`$${s}$SUBSCRIPT$${n.parent.property.name}$${n.parentPath.parentPath.node.property.name}`))}for(const e of["$hs","$3s"])if(y.scope.hasGlobal(e)){$=3;for(const n of r(e,y)){var E;i("MemberExpression"==n.parent.type),i("Identifier"==n.parent.property.type),i("MemberExpression"==(null===(E=n.parentPath.parentPath)||void 0===E?void 0:E.node.type)),i("Identifier"==n.parentPath.parentPath.node.property.type),n.parentPath.parentPath.replaceWith(t.identifier(`$${s}$SUBSCRIPT$${n.parent.property.name}$${n.parentPath.parentPath.node.property.name}`))}}for(const e of["$ms","$2s"])if(y.scope.hasGlobal(e)){$=2;for(const n of r(e,y)){var u;i("MemberExpression"==n.parent.type),i("Identifier"==n.parent.property.type),i("MemberExpression"==(null===(u=n.parentPath.parentPath)||void 0===u?void 0:u.node.type)),i("Identifier"==n.parentPath.parentPath.node.property.type),n.parentPath.parentPath.replaceWith(t.identifier(`$${s}$SUBSCRIPT$${n.parent.property.name}$${n.parentPath.parentPath.node.property.name}`))}}for(const e of["$ls","$1s"])if(y.scope.hasGlobal(e)){$=1;for(const n of r(e,y)){var P;i("MemberExpression"==n.parent.type),i("Identifier"==n.parent.property.type),i("MemberExpression"==(null===(P=n.parentPath.parentPath)||void 0===P?void 0:P.node.type)),i("Identifier"==n.parentPath.parentPath.node.property.type),n.parentPath.parentPath.replaceWith(t.identifier(`$${s}$SUBSCRIPT$${n.parent.property.name}$${n.parentPath.parentPath.node.property.name}`))}}for(const e of["$ns","$0s"])if(y.scope.hasGlobal(e)){$=0;for(const n of r(e,y)){var _;i("MemberExpression"==n.parent.type),i("Identifier"==n.parent.property.type),i("MemberExpression"==(null===(_=n.parentPath.parentPath)||void 0===_?void 0:_.node.type)),i("Identifier"==n.parentPath.parentPath.node.property.type),n.parentPath.parentPath.replaceWith(t.identifier(`$${s}$SUBSCRIPT$${n.parent.property.name}$${n.parentPath.parentPath.node.property.name}`))}}if(c=Math.min(c,$),y.scope.hasGlobal("$db"))for(const e of r("$db",y))i("MemberExpression"==e.parentPath.node.type),i("Identifier"==e.parentPath.node.property.type),e.parentPath.replaceWith(t.identifier(`$${s}$DB$${e.parentPath.node.property.name}`));if(y.scope.hasGlobal("$D"))for(const e of r("$D",y))e.replaceWith(t.identifier(`$${s}$DEBUG`));if(y.scope.hasGlobal("$FMCL"))for(const e of r("$FMCL",y))e.replaceWith(t.identifier(`$${s}$FMCL`));if(y.scope.hasGlobal("$G"))for(const e of r("$G",y))e.replaceWith(t.identifier(`$${s}$GLOBAL`));if(y.scope.hasGlobal("_SECLEVEL"))for(const e of r("_SECLEVEL",y))e.replaceWith(t.numericLiteral(c));let T=!1,O=!1;if(y.scope.hasGlobal("Object"))for(const e of r("Object",y))"MemberExpression"!=e.parent.type||e.parent.computed||(i("Identifier"==e.parent.property.type),"getPrototypeOf"==e.parent.property.name?(e.parentPath.replaceWith(t.identifier(`$${s}$GET_PROTOTYPE_OF`)),T=!0):"setPrototypeOf"==e.parent.property.name&&(e.parentPath.replaceWith(t.identifier(`$${s}$SET_PROTOTYPE_OF`)),O=!0));const x=y.node.body[y.node.body.length-1];let S;if("ExportNamedDeclaration"==x.type){y.node.body.pop();for(const e of x.specifiers){i("ExportSpecifier"==e.type,`${e.type} is currently unsupported`);const t="Identifier"==e.exported.type?e.exported.name:e.exported.value;"default"==t?S=e.local.name:f.set(e.local.name,t)}}const v=t.blockStatement([]);let D;for(const e of y.node.body)if("VariableDeclaration"==e.type)for(const i of e.declarations)if("Identifier"!=i.id.type||i.id.name!=S||!i.init||"FunctionExpression"!=i.init.type&&"ArrowFunctionExpression"!=i.init.type||i.init.async||i.init.generator){for(const r in t.getBindingIdentifiers(i.id))r==S&&(D=t.functionDeclaration(t.identifier(d),[t.identifier("context"),t.identifier("args")],t.blockStatement([t.returnStatement(t.callExpression(t.identifier(S),[]))]))),"const"!=e.kind&&f.has(r)&&(b.set(r,f.get(r)),f.delete(r)),v.body.push(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(r))]));i.init&&v.body.push(t.expressionStatement(t.assignmentExpression("=",i.id,i.init)))}else D=t.functionDeclaration(t.identifier(d),i.init.params,"BlockStatement"==i.init.body.type?i.init.body:t.blockStatement([t.returnStatement(i.init.body)]));else"FunctionDeclaration"==e.type?e.id.name==S?D=e:v.body.push(t.variableDeclaration("let",[t.variableDeclarator(e.id,t.functionExpression(null,e.params,e.body,e.generator,e.async))])):v.body.push(e);if(D||(D=t.functionDeclaration(t.identifier(d),[t.identifier("context"),t.identifier("args")],t.blockStatement([]))),y.node.body=[D],v.body.length){(f.size||b.size)&&D.body.body.push(t.returnStatement(t.objectExpression([...[...f].map((([e,i])=>t.objectProperty(t.identifier(i),t.identifier(e)))),...[...b].map((([e,i])=>t.objectMethod("get",t.identifier(i),[],t.blockStatement([t.returnStatement(t.identifier(e))]))))]))),y.scope.crawl();const e=new Set;let n=0;for(const[r,o]of[...v.body.entries()].reverse())if("VariableDeclaration"==o.type){i(1==o.declarations.length);const a=o.declarations[0];if(i("Identifier"==a.id.type,`declarator.id.type was "${a.id.type}"`),y.scope.crawl(),y.scope.hasGlobal(a.id.name)){v.body.splice(r,1);const[p]=y.unshiftContainer("body",v),[l]=y.unshiftContainer("body",o);if(y.scope.crawl(),!a.init||"FunctionExpression"!=a.init.type&&"ArrowFunctionExpression"!=a.init.type||Object.keys(y.scope.globals).some((t=>e.has(t)))){const e=y.scope.getBinding(a.id.name);i(e);for(const r of e.referencePaths)i("Identifier"==r.node.type),r.replaceWith(t.memberExpression(t.identifier(`$${s}$GLOBAL`),t.identifier(r.node.name)));for(const i of e.constantViolations)if("AssignmentExpression"==i.node.type)for(const[e,r]of Object.entries(t.getBindingIdentifiers(i.node)))e==a.id.name&&Object.assign(clearObject(r),t.memberExpression(t.identifier(`$${s}$GLOBAL`),t.identifier(e)));p.remove(),l.remove(),a.init&&v.body.splice(r,0,t.expressionStatement(t.assignmentExpression("=",t.memberExpression(t.identifier(`$${s}$GLOBAL`),t.identifier(a.id.name)),a.init)))}else p.remove(),l.remove(),D.body.body.unshift(o),n++}else e.add(a.id.name)}else if("ClassDeclaration"==o.type&&(y.scope.crawl(),y.scope.hasGlobal(o.id.name))){v.body.splice(r,1);const[e]=y.unshiftContainer("body",v),[n]=y.unshiftContainer("body",o);y.scope.crawl();const a=y.scope.getBinding(o.id.name);i(a);for(const e of a.referencePaths)i("Identifier"==e.node.type),e.replaceWith(t.memberExpression(t.identifier(`$${s}$GLOBAL`),t.identifier(e.node.name)));e.remove(),n.remove(),v.body.splice(r,0,t.expressionStatement(t.assignmentExpression("=",t.memberExpression(t.identifier(`$${s}$GLOBAL`),t.identifier(o.id.name)),t.classExpression(null,o.superClass,o.body,o.decorators))))}if(y.scope.hasGlobal("_EXPORTS"))for(const e of r("_EXPORTS",y))e.replaceWith(t.arrayExpression([...f.keys(),...b.keys()].map((e=>t.stringLiteral(e)))));v.body.length&&D.body.body.splice(n,0,t.ifStatement(t.unaryExpression("!",t.identifier(`$${s}$FMCL`)),v))}return h&&D.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`$${s}$FUNCTION_DOT_PROTOTYPE`),createGetFunctionPrototypeNode())])),O&&D.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`$${s}$SET_PROTOTYPE_OF`),t.callExpression(t.memberExpression(t.memberExpression(t.identifier("Object"),t.identifier("call")),t.identifier("bind")),[t.identifier(`$${s}$DUNDER_PROTO_SETTER`)]))])),T&&D.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`$${s}$GET_PROTOTYPE_OF`),t.callExpression(t.memberExpression(t.memberExpression(t.identifier("Object"),t.identifier("call")),t.identifier("bind")),[t.identifier(`$${s}$DUNDER_PROTO_GETTER`)]))])),(T||O)&&D.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.objectPattern(T?O?[t.objectProperty(t.identifier("get"),t.identifier(`$${s}$DUNDER_PROTO_GETTER`)),t.objectProperty(t.identifier("set"),t.identifier(`$${s}$DUNDER_PROTO_SETTER`))]:[t.objectProperty(t.identifier("get"),t.identifier(`$${s}$DUNDER_PROTO_GETTER`))]:[t.objectProperty(t.identifier("set"),t.identifier(`$${s}$DUNDER_PROTO_SETTER`))]),t.callExpression(t.memberExpression(t.identifier("Object"),t.identifier("getOwnPropertyDescriptor")),[t.memberExpression(t.identifier("Object"),t.identifier("prototype")),t.stringLiteral("__proto__")]))])),n(e,{BlockStatement({node:e}){for(const[i,r]of e.body.entries())"FunctionDeclaration"!=r.type||r.generator||(e.body.splice(i,1),e.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(r.id,t.arrowFunctionExpression(r.params,r.body,r.async))])))},ClassBody({node:e,scope:r,parent:o}){i(t.isClass(o));let a=!1;for(const i of e.body){if("ClassMethod"!=i.type)continue;let e=!1;if(n(i.body,{ThisExpression(i){e=!0,a=!0,i.replaceWith(t.identifier(`_THIS_${s}_`))},Function(e){e.skip()}},r),e)if("constructor"!=i.kind)i.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`_THIS_${s}_`),t.callExpression(t.memberExpression(t.super(),t.identifier("valueOf")),[]))]));else{const e=[];if(n(i.body,{CallExpression(t){"Super"==t.node.callee.type&&e.push(t)}},r),e.length)if(1==e.length&&"ExpressionStatement"==e[0].parent.type&&e[0].parentPath.parentPath.parent==i)e[0].parentPath.replaceWith(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`_THIS_${s}_`),e[0].node)]));else{for(const i of e)i.replaceWith(t.assignmentExpression("=",t.identifier(`_THIS_${s}_`),i.node));i.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`_THIS_${s}_`))]))}else i.body.body.unshift(t.variableDeclaration("let",[t.variableDeclarator(t.identifier(`_THIS_${s}_`),t.callExpression(t.super(),[]))]))}}!o.superClass&&a&&(o.superClass=t.identifier("Object"))},VariableDeclaration({node:e}){"const"==e.kind&&(e.kind="let")},ThisExpression(e){e.replaceWith(t.identifier("undefined"))},BigIntLiteral(e){const i=Number(e.node.value);BigInt(i)==BigInt(e.node.value)?e.replaceWith(t.callExpression(t.identifier("BigInt"),[t.numericLiteral(i)])):e.replaceWith(t.callExpression(t.identifier("BigInt"),[t.stringLiteral(e.node.value)]))}}),{file:e,seclevel:c};function createGetFunctionPrototypeNode(){for(const e of o)if(!y.scope.hasOwnBinding(e))return t.memberExpression(t.memberExpression(t.identifier(e),t.identifier("constructor")),t.identifier("prototype"));return t.memberExpression(t.memberExpression(t.arrowFunctionExpression([t.identifier("_")],t.identifier("_")),t.identifier("constructor")),t.identifier("prototype"))}}export{transform as default,transform};
package/pull.d.ts ADDED
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Copies script from hackmud to local source folder.
3
+ *
4
+ * @param sourceFolderPath path to folder containing source files
5
+ * @param hackmudPath path to hackmud directory
6
+ * @param script to pull in `user.name` format
7
+ */
8
+ export declare function pull(sourceFolderPath: string, hackmudPath: string, script: string): Promise<void>;
9
+ export default pull;
package/pull.js ADDED
@@ -0,0 +1 @@
1
+ import{promises as t}from"fs";import{dirname as r,resolve as i}from"path";const{mkdir:s,copyFile:o}=t;async function pull(t,a,e){const[c,n]=e.split(".");if(!c||!n)throw new Error('`script` argument must be in "user.name" format');await function copyFilePersistent(t,i,a){return o(t,i,a).catch((async e=>{if("ENOENT"!=e.code)throw e;await s(r(i),{recursive:!0}),await o(t,i,a)}))}(i(a,c,"scripts",`${n}.js`),i(t,c,`${n}.js`))}export{pull as default,pull};
package/push.d.ts ADDED
@@ -0,0 +1,28 @@
1
+ import { Info } from ".";
2
+ declare type PushOptions = {
3
+ /** whether to do the minify step (defaults to `true`) */
4
+ minify: boolean;
5
+ /** whether to mangle function and class names (defaults to `false`) */
6
+ mangleNames: boolean;
7
+ /**
8
+ * array of scripts in the format `foo.bar`
9
+ *
10
+ * also accepts wild card (`*`) e.g. `*.bar` or `foo.*`
11
+ *
12
+ * pushes everything by default (`*.*`)
13
+ */
14
+ scripts: string | string[];
15
+ /** callback called on script push */
16
+ onPush: (info: Info) => void;
17
+ };
18
+ /**
19
+ * Push scripts from a source directory to the hackmud directory.
20
+ *
21
+ * Pushes files directly in the source folder to all users
22
+ * @param sourceDirectory directory containing source code
23
+ * @param hackmudDirectory directory created by hackmud containing user data including scripts
24
+ * @param options {@link PushOptions details}
25
+ * @returns array of info on pushed scripts
26
+ */
27
+ export declare function push(sourceDirectory: string, hackmudDirectory: string, { scripts, onPush, minify, mangleNames }?: Partial<PushOptions>): Promise<Info[]>;
28
+ export default push;
package/push.js ADDED
@@ -0,0 +1 @@
1
+ import e,{promises as r}from"fs";import{dirname as t,resolve as i,extname as a,basename as s}from"path";import{c as p}from"./processScript/minify.js";import{s as o,processScript as n}from"./processScript/index.js";import"@babel/generator";import"@babel/traverse";import"@babel/types";import"./assert-1b7dada8.js";import"./spliceString-2c6f214f.js";import"acorn";import"terser";import"./processScript/shared.js";import"@babel/parser";import"@babel/plugin-proposal-class-properties";import"@babel/plugin-proposal-class-static-block";import"@babel/plugin-proposal-decorators";import"@babel/plugin-proposal-do-expressions";import"@babel/plugin-proposal-function-bind";import"@babel/plugin-proposal-function-sent";import"@babel/plugin-proposal-json-strings";import"@babel/plugin-proposal-logical-assignment-operators";import"@babel/plugin-proposal-nullish-coalescing-operator";import"@babel/plugin-proposal-numeric-separator";import"@babel/plugin-proposal-object-rest-spread";import"@babel/plugin-proposal-optional-catch-binding";import"@babel/plugin-proposal-optional-chaining";import"@babel/plugin-proposal-partial-application";import"@babel/plugin-proposal-pipeline-operator";import"@babel/plugin-proposal-private-property-in-object";import"@babel/plugin-proposal-record-and-tuple";import"@babel/plugin-proposal-throw-expressions";import"@babel/plugin-transform-exponentiation-operator";import"@babel/plugin-transform-typescript";import"@rollup/plugin-babel";import"@rollup/plugin-commonjs";import"@rollup/plugin-json";import"@rollup/plugin-node-resolve";import"perf_hooks";import"prettier";import"rollup";import"./processScript/postprocess.js";import"./processScript/preprocess.js";import"./processScript/transform.js";class DynamicMap extends Map{constructor(e){super(),this.fallbackHandler=e}get(e){if(super.has(e))return super.get(e);const r=this.fallbackHandler(e);return super.set(e,r),r}}const{writeFile:l,mkdir:c}=r;function writeFilePersistent(e,r,i){return l(e,r,i).catch((async a=>{if("ENOENT"!=a.code)throw a;await c(t(e),{recursive:!0}),await l(e,r,i)}))}const{readFile:m,readdir:u}=e.promises;async function push(e,r,{scripts:t="*.*",onPush:l=(()=>{}),minify:c=!0,mangleNames:g=!1}={}){"string"==typeof t&&(t=[t]);const f=new DynamicMap((e=>new Set)),b=new Set,h=new Set;let w=!1;for(const e of t){const[r,t]=e.split(".");r&&"*"!=r?t&&"*"!=t?f.get(r).add(t):b.add(r):t&&"*"!=t?h.add(t):w=!0}const d=new DynamicMap((e=>new Set)),y=[],$=new DynamicMap((e=>new Set));let P;if(h.size||w){const t=await u(i(r),{withFileTypes:!0}),s=new Set([...(P=await u(i(e),{withFileTypes:!0})).filter((e=>e.isDirectory())).map((e=>e.name)),...t.filter((e=>e.isDirectory())).map((e=>e.name)),...t.filter((e=>e.isFile()&&".key"==a(e.name))).map((e=>e.name.slice(0,-4))),...f.keys(),...b]);if(w)for(const e of s)b.add(e);else for(const e of s){const r=f.get(e);for(const e of h)r.add(e)}}return await Promise.all([...b].map((async t=>{await u(i(e,t),{withFileTypes:!0}).then((async u=>{await Promise.all(u.map((async u=>{const f=a(u.name);if(u.isFile()&&o.includes(f)){const a=s(u.name,f),o=i(e,t,u.name),{srcLength:b,script:h}=await n(await m(o,{encoding:"utf-8"}),{minify:c,scriptUser:t,scriptName:a,filePath:o,mangleNames:g}),w={file:`${t}/${u.name}`,users:[t],minLength:p(h),error:null,srcLength:b};$.get(t).add(a),y.push(w),await writeFilePersistent(i(r,t,`scripts/${a}.js`),h),l(w)}})))}),(e=>{if("ENOENT"!=e.code)throw e}))}))),await Promise.all([...f].map((async([t,a])=>{b.has(t)||await Promise.all([...a].map((async a=>{let s,u,f;for(const r of o)try{u=`${a}${r}`,s=await m(f=i(e,t,u),{encoding:"utf-8"});break}catch{}if(s){const{srcLength:e,script:o}=await n(s,{minify:c,scriptUser:t,scriptName:a,filePath:f,mangleNames:g}),m={file:`${t}/${u}`,users:[t],minLength:p(o),error:null,srcLength:e};y.push(m),await writeFilePersistent(i(r,t,"scripts",`${a}.js`),o),l(m)}else d.get(a).add(t)})))}))),await(b.size?Promise.all((P||await u(i(e),{withFileTypes:!0})).map((async t=>{const u=a(t.name);if(!t.isFile()||!o.includes(u))return;const f=s(t.name,u),h=[...b,...d.get(f)].filter((e=>!$.get(e).has(f)));if(!h.length)return;const w=Math.floor(Math.random()*2**52).toString(36).padStart(11,"0"),P=i(e,t.name),{srcLength:S,script:j}=await n(await m(P,{encoding:"utf-8"}),{minify:c,scriptUser:!0,scriptName:f,uniqueID:w,filePath:P,mangleNames:g}),F={file:t.name,users:h,minLength:p(j),error:null,srcLength:S};await Promise.all(h.map((e=>writeFilePersistent(i(r,e,`scripts/${f}.js`),j.replace(new RegExp(`$${w}$SCRIPT_USER`,"g"),e).replace(new RegExp(`$${w}$FULL_SCRIPT_NAME`,"g"),`${e}.${f}`))))),y.push(F),l(F)}))):Promise.all([...d].map((async([t,a])=>{let s,u,f;for(const r of o)try{u=`${t}${r}`,s=await m(f=i(e,u),{encoding:"utf-8"});break}catch{}if(s){const e=Math.floor(Math.random()*2**52).toString(36).padStart(11,"0"),{srcLength:o,script:m}=await n(s,{minify:c,scriptUser:!0,scriptName:t,uniqueID:e,filePath:f,mangleNames:g}),b={file:u,users:[...a],minLength:p(m),error:null,srcLength:o};await Promise.all([...a].map((a=>writeFilePersistent(i(r,a,`scripts/${t}.js`),m.replace(new RegExp(`$${e}$SCRIPT_USER`,"g"),a).replace(new RegExp(`$${e}$FULL_SCRIPT_NAME`,"g"),`${a}.${t}`))))),y.push(b),l(b)}})))),y}export{DynamicMap as D,push as default,push,writeFilePersistent as w};
@@ -0,0 +1 @@
1
+ function spliceString(i,e,s,c=0){return i.slice(0,s)+e+i.slice(s+c)}export{spliceString as s};
@@ -0,0 +1,5 @@
1
+ export declare function syncMacros(hackmudPath: string): Promise<{
2
+ macrosSynced: number;
3
+ usersSynced: number;
4
+ }>;
5
+ export default syncMacros;
package/syncMacros.js ADDED
@@ -0,0 +1 @@
1
+ import e from"fs";import{extname as a,basename as s,resolve as t}from"path";const{readFile:o,readdir:n,stat:r,writeFile:c}=e.promises;async function syncMacros(e){const i=await n(e,{withFileTypes:!0}),m=new Map,l=[];await Promise.all(i.map((async n=>{if(n.isFile())switch(a(n.name)){case".macros":{const[a,s]=await Promise.all([o(t(e,n.name),{encoding:"utf-8"}).then((e=>e.split("\n"))),r(t(e,n.name)).then((({mtime:e})=>e))]);for(let e=0;e<a.length/2-1;e++){const t=a[2*e],o=m.get(t);(!o||s>o.date)&&m.set(t,{date:s,macro:a[2*e+1]})}}break;case".key":l.push(s(n.name,".key"))}})));let f="",p=0;for(const[e,{macro:a}]of[...m].sort((([e],[a])=>(e>a)-(e<a))))a[0]==a[0].toLowerCase()&&(f+=`${e}\n${a}\n`,p++);for(const a of l)c(t(e,`${a}.macros`),f);return{macrosSynced:p,usersSynced:l.length}}export{syncMacros as default,syncMacros};
package/test.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ export declare function test(sourcePath: string): Promise<{
2
+ file: string;
3
+ message: string;
4
+ line: number;
5
+ }[]>;
6
+ export default test;
package/test.js ADDED
@@ -0,0 +1 @@
1
+ import p from"fs";import{resolve as o,extname as r}from"path";import{s as i,processScript as e}from"./processScript/index.js";import"@babel/generator";import"@babel/parser";import"@babel/plugin-proposal-class-properties";import"@babel/plugin-proposal-class-static-block";import"@babel/plugin-proposal-decorators";import"@babel/plugin-proposal-do-expressions";import"@babel/plugin-proposal-function-bind";import"@babel/plugin-proposal-function-sent";import"@babel/plugin-proposal-json-strings";import"@babel/plugin-proposal-logical-assignment-operators";import"@babel/plugin-proposal-nullish-coalescing-operator";import"@babel/plugin-proposal-numeric-separator";import"@babel/plugin-proposal-object-rest-spread";import"@babel/plugin-proposal-optional-catch-binding";import"@babel/plugin-proposal-optional-chaining";import"@babel/plugin-proposal-partial-application";import"@babel/plugin-proposal-pipeline-operator";import"@babel/plugin-proposal-private-property-in-object";import"@babel/plugin-proposal-record-and-tuple";import"@babel/plugin-proposal-throw-expressions";import"@babel/plugin-transform-exponentiation-operator";import"@babel/plugin-transform-typescript";import"@babel/traverse";import"@babel/types";import"@rollup/plugin-babel";import"@rollup/plugin-commonjs";import"@rollup/plugin-json";import"@rollup/plugin-node-resolve";import"./assert-1b7dada8.js";import"./processScript/minify.js";import"./spliceString-2c6f214f.js";import"acorn";import"terser";import"./processScript/shared.js";import"perf_hooks";import"prettier";import"rollup";import"./processScript/postprocess.js";import"./processScript/preprocess.js";import"./processScript/transform.js";const{readFile:s,readdir:t}=p.promises;async function test(p){const l=[],a=[];for(const n of await t(p,{withFileTypes:!0}))n.isDirectory()?l.push(t(o(p,n.name),{withFileTypes:!0}).then((t=>{const l=[];for(const m of t)m.isFile()&&i.includes(r(m.name))&&l.push(s(o(p,n.name,m.name),{encoding:"utf-8"}).then(e).then((({warnings:p})=>a.push(...p.map((({message:p,line:o})=>({file:`${n.name}/${m.name}`,message:p,line:o})))))));return Promise.all(l)}))):n.isFile()&&i.includes(r(n.name))&&l.push(s(o(p,n.name),{encoding:"utf-8"}).then(e).then((({warnings:p})=>a.push(...p.map((({message:p,line:o})=>({file:n.name,message:p,line:o})))))));return await Promise.all(l),a}export{test as default,test};
package/watch.d.ts ADDED
@@ -0,0 +1,14 @@
1
+ import { Info } from ".";
2
+ /**
3
+ * Watches target file or folder for updates and builds and pushes updated file.
4
+ *
5
+ * @param sourceDirectory path to folder containing source files
6
+ * @param hackmudDirectory path to hackmud directory
7
+ * @param users to push to (pushes to all if empty)
8
+ * @param scripts to push from (pushes from all if empty)
9
+ * @param onPush function that's called on each script push
10
+ */
11
+ export declare function watch(sourceDirectory: string, hackmudDirectory: string, users: string[], scripts: string[], onPush?: (info: Info) => void, { genTypes }?: {
12
+ genTypes?: string | undefined;
13
+ }): void;
14
+ export default watch;
package/watch.js ADDED
@@ -0,0 +1 @@
1
+ import{watch as o}from"chokidar";import p from"fs";import{extname as r,basename as i,resolve as t}from"path";import{s as e,processScript as s}from"./processScript/index.js";import{generateTypings as n}from"./generateTypings.js";import"@babel/generator";import"@babel/parser";import"@babel/plugin-proposal-class-properties";import"@babel/plugin-proposal-class-static-block";import"@babel/plugin-proposal-decorators";import"@babel/plugin-proposal-do-expressions";import"@babel/plugin-proposal-function-bind";import"@babel/plugin-proposal-function-sent";import"@babel/plugin-proposal-json-strings";import"@babel/plugin-proposal-logical-assignment-operators";import"@babel/plugin-proposal-nullish-coalescing-operator";import"@babel/plugin-proposal-numeric-separator";import"@babel/plugin-proposal-object-rest-spread";import"@babel/plugin-proposal-optional-catch-binding";import"@babel/plugin-proposal-optional-chaining";import"@babel/plugin-proposal-partial-application";import"@babel/plugin-proposal-pipeline-operator";import"@babel/plugin-proposal-private-property-in-object";import"@babel/plugin-proposal-record-and-tuple";import"@babel/plugin-proposal-throw-expressions";import"@babel/plugin-transform-exponentiation-operator";import"@babel/plugin-transform-typescript";import"@babel/traverse";import"@babel/types";import"@rollup/plugin-babel";import"@rollup/plugin-commonjs";import"@rollup/plugin-json";import"@rollup/plugin-node-resolve";import"./assert-1b7dada8.js";import"./processScript/minify.js";import"./spliceString-2c6f214f.js";import"acorn";import"terser";import"./processScript/shared.js";import"perf_hooks";import"prettier";import"rollup";import"./processScript/postprocess.js";import"./processScript/preprocess.js";import"./processScript/transform.js";const{readFile:a,readdir:l}=p.promises;function watch(p,c,m,b,u,{genTypes:g}={}){const h=o("",{depth:1,cwd:p,awaitWriteFinish:{stabilityThreshold:100}}).on("change",(async o=>{const n=r(o);if(e.includes(n)){const c=i(o,n);if(o==i(o)){if(!b.length||b.includes(c)){const n=await a(t(p,o),{encoding:"utf-8"}),c=new Map;await Promise.all((await l(p,{withFileTypes:!0})).map((async o=>{o.isDirectory()&&await l(t(p,o.name),{withFileTypes:!0}).then((p=>{for(const t of p){if(!t.isFile())continue;const p=r(t.name);if(!e.includes(p))continue;const s=i(t.name,p),n=c.get(s);n?n.push(o.name):c.set(s,[o.name])}}))})));let m=null;const{srcLength:b}=await s(n).catch((o=>(m=o,{script:"",srcLength:0}))),g={file:o,users:[],minLength:0,error:m,srcLength:b};u&&u(g)}}else{const r=i(t(o,".."));if((!m.length||m.includes(r))&&(!b.length||b.includes(c))){const i=await a(t(p,o),{encoding:"utf-8"});let e=null;const{srcLength:n}=await s(i).catch((o=>(e=o,{script:"",srcLength:0}))),l={file:o,users:[r],minLength:0,error:e,srcLength:n};null==u||u(l)}}}}));g&&(n(p,t(p,g),c),h.on("add",(()=>n(p,t(p,g),c))),h.on("unlink",(()=>n(p,t(p,g),c))))}export{watch as default,watch};