hackmud-script-manager 0.20.4-3533b3b → 0.20.4-4605f71
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/bin/hsm.js +15 -6
- package/env.d.ts +43 -26
- package/package.json +1 -1
- package/push.d.ts +9 -1
- package/push.js +30 -10
package/bin/hsm.js
CHANGED
@@ -12,7 +12,7 @@ import { pull } from "../pull.js"
|
|
12
12
|
import { syncMacros } from "../syncMacros.js"
|
13
13
|
import "@samual/lib/readDirectoryWithStats"
|
14
14
|
import "@samual/lib/copyFilePersistent"
|
15
|
-
const version = "0.20.4-
|
15
|
+
const version = "0.20.4-4605f71",
|
16
16
|
options = new Map(),
|
17
17
|
commands = [],
|
18
18
|
userColours = new Cache(user => {
|
@@ -119,16 +119,25 @@ switch (commands[0]) {
|
|
119
119
|
logHelp()
|
120
120
|
break
|
121
121
|
}
|
122
|
-
const { push } = await pushModule
|
123
|
-
|
124
|
-
await push(sourcePath, hackmudPath, {
|
122
|
+
const { push, MissingSourceFolderError, MissingHackmudFolderError, NoUsersError } = await pushModule,
|
123
|
+
infos = await push(sourcePath, hackmudPath, {
|
125
124
|
scripts,
|
126
125
|
onPush: info => logInfo(info, hackmudPath),
|
127
126
|
minify: shouldMinify,
|
128
127
|
mangleNames: shouldMangleNames,
|
129
128
|
forceQuineCheats: shouldforceQuineCheats
|
130
129
|
})
|
131
|
-
|
130
|
+
if (infos instanceof Error) {
|
131
|
+
logError(infos.message)
|
132
|
+
if (infos instanceof MissingSourceFolderError || infos instanceof NoUsersError) {
|
133
|
+
console.log()
|
134
|
+
logHelp()
|
135
|
+
} else
|
136
|
+
infos instanceof MissingHackmudFolderError &&
|
137
|
+
log(
|
138
|
+
`If this is not where your hackmud folder is, you can specify it with the\n${colourN("--hackmud-path")}=${colourB("<path>")} option or ${colourN("HSM_HACKMUD_PATH")} environment variable`
|
139
|
+
)
|
140
|
+
} else infos.length || logError("Could not find any scripts to push")
|
132
141
|
}
|
133
142
|
break
|
134
143
|
case "dev":
|
@@ -245,7 +254,7 @@ switch (commands[0]) {
|
|
245
254
|
typeDeclaration = await generateTypeDeclaration(sourcePath, getHackmudPath())
|
246
255
|
let typeDeclarationPath = resolve(outputPath)
|
247
256
|
await writeFile(typeDeclarationPath, typeDeclaration).catch(error => {
|
248
|
-
assert(error instanceof Error, "src/bin/hsm.ts:
|
257
|
+
assert(error instanceof Error, "src/bin/hsm.ts:340:35")
|
249
258
|
if ("EISDIR" != error.code) throw error
|
250
259
|
typeDeclarationPath = resolve(typeDeclarationPath, "player.d.ts")
|
251
260
|
return writeFile(typeDeclarationPath, typeDeclaration)
|
package/env.d.ts
CHANGED
@@ -1,18 +1,14 @@
|
|
1
|
-
type Replace<
|
1
|
+
type Replace<A, B> = Omit<A, keyof B> & B
|
2
2
|
type ScriptSuccess<T = object> = { ok: true } & T
|
3
3
|
type ScriptFailure = { ok: false, msg?: string }
|
4
4
|
type ScriptResponse<T = object> = ScriptSuccess<T> | ScriptFailure
|
5
5
|
type ErrorScripts = Record<string, () => ScriptFailure>
|
6
6
|
|
7
|
-
type AllOptional<T> = {
|
8
|
-
[K in keyof T]-?: {} extends Pick<T, K> ? true : false
|
9
|
-
}[keyof T]
|
7
|
+
type AllOptional<T> = { [K in keyof T]-?: {} extends Pick<T, K> ? true : false }[keyof T]
|
10
8
|
|
11
9
|
type Scriptor<Args = unknown, Ret = unknown> = {
|
12
|
-
name: string
|
13
|
-
call: AllOptional<Args> extends true
|
14
|
-
? (args?: Args) => Ret
|
15
|
-
: (args: Args) => Ret
|
10
|
+
name: string
|
11
|
+
call: AllOptional<Args> extends true ? (args?: Args) => Ret : (args: Args) => Ret
|
16
12
|
}
|
17
13
|
|
18
14
|
type Subscripts = Record<string, Record<string, (...args: any) => any>> & {
|
@@ -41,7 +37,7 @@ type UpgradeRarityString = "`0noob`" | "`1kiddie`" | "`2h4x0r`" | "`3h4rdc0r3`"
|
|
41
37
|
type UpgradeRarityNumber = 0 | 1 | 2 | 3 | 4 | 5;
|
42
38
|
type UpgradeRarity = UpgradeRarityString | UpgradeRarityNumber;
|
43
39
|
|
44
|
-
type
|
40
|
+
type UpgradeBase = {
|
45
41
|
name: string
|
46
42
|
type: "lock" | "script_space" | "chat" | "script" | "tool" | "bot_brain" | "glam"
|
47
43
|
up_class?: -1 | 0 | 1 | 2 | 3
|
@@ -53,9 +49,9 @@ type UpgradeCore = {
|
|
53
49
|
description: string
|
54
50
|
}
|
55
51
|
|
56
|
-
type Upgrade =
|
52
|
+
type Upgrade = UpgradeBase & Record<string, null | boolean | number | string>
|
57
53
|
|
58
|
-
type
|
54
|
+
type CliUpgrade = Omit<UpgradeBase, `rarity`> & {
|
59
55
|
[x: string]: null | boolean | number | string
|
60
56
|
rarity: UpgradeRarityString
|
61
57
|
}
|
@@ -155,7 +151,7 @@ type Fullsec = Subscripts & PlayerFullsec & {
|
|
155
151
|
market: {
|
156
152
|
/** **FULLSEC** */ browse: {
|
157
153
|
(args:
|
158
|
-
Partial<{ seller: string, listed_before: number, listed_after: number, cost: number | string } & Omit<
|
154
|
+
Partial<{ seller: string, listed_before: number, listed_after: number, cost: number | string } & Omit<CliUpgrade, "rarity">>
|
159
155
|
): { i: string, name: string, rarity: Upgrade["rarity"], cost: number }[] | ScriptFailure
|
160
156
|
|
161
157
|
<I extends string>(args: { i: I }): {
|
@@ -357,7 +353,7 @@ type Fullsec = Subscripts & PlayerFullsec & {
|
|
357
353
|
* const arr = [ 1, 2, 2, 3, 2 ]
|
358
354
|
*
|
359
355
|
* $D(uniq(arr)) // [ 1, 2, 3, 2 ] */
|
360
|
-
uniq: (array: T[]) => T[]
|
356
|
+
uniq: <T>(array: T[]) => T[]
|
361
357
|
|
362
358
|
/** Sorts an array of numbers or number-coercible strings in descending order. */
|
363
359
|
u_sort_num_arr_desc: <T>(array: T[]) => T[]
|
@@ -424,17 +420,17 @@ type Fullsec = Subscripts & PlayerFullsec & {
|
|
424
420
|
upgrades_of_owner: {
|
425
421
|
<F extends Partial<Upgrade & { loaded: boolean }> = object>(args?: { filter?: F, full?: false }): (
|
426
422
|
Omit<
|
427
|
-
Pick<
|
423
|
+
Pick<UpgradeBase, "tier" | "rarity" | "name" | "type" | "i" | "loaded">,
|
428
424
|
keyof F
|
429
425
|
> & Pick<F, "tier" | "rarity" | "name" | "type" | "i" | "loaded">
|
430
426
|
)[] | ScriptFailure
|
431
427
|
|
432
428
|
<F extends Partial<Upgrade & { loaded: boolean }> = object>(args: { filter?: F, full: true }): (
|
433
|
-
Omit<
|
429
|
+
Omit<UpgradeBase, keyof F> & F & Record<string, null | boolean | number | string>
|
434
430
|
)[] | ScriptFailure
|
435
431
|
|
436
432
|
<I extends number>(args: { i: I }): (
|
437
|
-
Omit<
|
433
|
+
Omit<UpgradeBase, "i"> & { [x: string]: null | boolean | number | string, i: I }
|
438
434
|
) | ScriptFailure
|
439
435
|
}
|
440
436
|
|
@@ -511,7 +507,7 @@ type Highsec = Fullsec & PlayerHighsec & {
|
|
511
507
|
/** **HIGHSEC** */
|
512
508
|
upgrades: {
|
513
509
|
<I extends number>(args: { i: I }): (
|
514
|
-
Omit<
|
510
|
+
Omit<UpgradeBase, "i"> & { [x: string]: null | boolean | number | string, i: I }
|
515
511
|
) | ScriptFailure
|
516
512
|
|
517
513
|
<F extends Partial<Upgrade & { loaded: boolean }> = object>(args?: {
|
@@ -519,20 +515,20 @@ type Highsec = Fullsec & PlayerHighsec & {
|
|
519
515
|
is_script?: true
|
520
516
|
full?: false
|
521
517
|
}): (
|
522
|
-
Omit<Pick<
|
518
|
+
Omit<Pick<UpgradeBase, "tier" | "rarity" | "name" | "type" | "i" | "loaded">, keyof F> & F &
|
523
519
|
Record<string, null | boolean | number | string>
|
524
520
|
)[] | ScriptFailure
|
525
521
|
|
526
522
|
<F extends Partial<Upgrade & { loaded: boolean }> = object>(args?:
|
527
523
|
{ filter?: F, is_script?: true, full: true }
|
528
|
-
): (Omit<
|
524
|
+
): (Omit<UpgradeBase, keyof F> & F & Record<string, null | boolean | number | string>)[] | ScriptFailure
|
529
525
|
|
530
526
|
(args?: { filter?: Partial<Upgrade & { loaded: boolean }>, is_script: false, full?: false }):
|
531
527
|
{ msg: string, upgrades: string[] } | ScriptFailure
|
532
528
|
|
533
529
|
<F extends Partial<Upgrade & { loaded: boolean }> = object>(
|
534
530
|
args?: { filter?: F, is_script: false, full: true }
|
535
|
-
): (Omit<
|
531
|
+
): (Omit<UpgradeBase, keyof F | `rarity`> & F & {
|
536
532
|
[x: string]: null | boolean | number | string
|
537
533
|
rarity: UpgradeRarityString
|
538
534
|
})[] | ScriptFailure
|
@@ -766,7 +762,7 @@ type Cursor = {
|
|
766
762
|
ObjectId: () => any
|
767
763
|
}
|
768
764
|
|
769
|
-
type
|
765
|
+
type CliContext = {
|
770
766
|
/** The name of the user who is calling the script. */ caller: string
|
771
767
|
/** The name of this script. */ this_script: string
|
772
768
|
/** The number of columns in the caller’s terminal. */ cols: number
|
@@ -774,17 +770,23 @@ type CLIContext = {
|
|
774
770
|
|
775
771
|
/** The name of the script that directly called this script, or null if called on the command line or as a
|
776
772
|
* scriptor. */ calling_script: null
|
773
|
+
is_scriptor?: undefined
|
774
|
+
is_brain?: undefined
|
777
775
|
}
|
778
776
|
|
779
|
-
type SubscriptContext = Replace<
|
777
|
+
type SubscriptContext = Replace<CliContext, {
|
780
778
|
/** The name of the script that directly called this script, or null if called on the command line or as a scriptor.
|
781
779
|
*/
|
782
780
|
calling_script: string
|
783
781
|
}>
|
784
782
|
|
785
|
-
type ScriptorContext =
|
786
|
-
|
787
|
-
|
783
|
+
type ScriptorContext =
|
784
|
+
Replace<CliContext, { /** Whether the script is being run as a scriptor. */ is_scriptor: true }>
|
785
|
+
|
786
|
+
type BrainContext =
|
787
|
+
Replace<CliContext, { /** Whether the script is being run via a bot brain. */ is_brain: true }>
|
788
|
+
|
789
|
+
type Context = CliContext | SubscriptContext | ScriptorContext | BrainContext
|
788
790
|
|
789
791
|
/** Subscript space that can call FULLSEC scripts. */ declare const $fs: Fullsec
|
790
792
|
|
@@ -827,6 +829,8 @@ declare const $0s: typeof $ns
|
|
827
829
|
* } */
|
828
830
|
declare const $s: Nullsec
|
829
831
|
|
832
|
+
type ObjectId = { $oid: string }
|
833
|
+
|
830
834
|
declare const $db: {
|
831
835
|
/** Insert a document or documents into a collection.
|
832
836
|
* @param documents A document or array of documents to insert into the collection. */
|
@@ -920,6 +924,8 @@ declare const $db: {
|
|
920
924
|
signature: { hash: "Undefined Conversion", keyId: "Undefined Conversion" }
|
921
925
|
}
|
922
926
|
}
|
927
|
+
|
928
|
+
ObjectId: () => ObjectId
|
923
929
|
}
|
924
930
|
|
925
931
|
/** Debug Log.
|
@@ -956,7 +962,7 @@ declare const $FMCL: undefined | true
|
|
956
962
|
* @example
|
957
963
|
* if (!$G.dbCache)
|
958
964
|
* $G.dbCache = $db.f({ whatever: true }).first() */
|
959
|
-
declare const $G: any
|
965
|
+
declare const $G: Record<string | symbol, any>
|
960
966
|
|
961
967
|
/** This contains a JS timestamp (not Date) set immediately before your code begins running.
|
962
968
|
* @example
|
@@ -1005,3 +1011,14 @@ declare const _FULL_SCRIPT_NAME: string
|
|
1005
1011
|
*
|
1006
1012
|
* In rare cases where it's not known at build time, it's `-1`. */
|
1007
1013
|
declare const _SECLEVEL: -1 | 0 | 1 | 2 | 3 | 4
|
1014
|
+
|
1015
|
+
type DeepFreeze<T> = { readonly [P in keyof T]: DeepFreeze<T[P]> }
|
1016
|
+
|
1017
|
+
/** Recursively
|
1018
|
+
* [`Object.freeze()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/freeze)
|
1019
|
+
* an object and its properties' objects and its properties' objects and so on.
|
1020
|
+
*
|
1021
|
+
* [Official Hackmud Wiki](https://wiki.hackmud.com/scripting/extensions/deep_freeze) */
|
1022
|
+
declare const DEEP_FREEZE: <T>(value: T) => DeepFreeze<T>
|
1023
|
+
|
1024
|
+
declare const _RUN_ID: string
|
package/package.json
CHANGED
package/push.d.ts
CHANGED
@@ -18,6 +18,14 @@ export type PushOptions = LaxPartial<{
|
|
18
18
|
*/
|
19
19
|
forceQuineCheats: boolean;
|
20
20
|
}>;
|
21
|
+
export declare class MissingSourceFolderError extends Error {
|
22
|
+
}
|
23
|
+
export declare class MissingHackmudFolderError extends Error {
|
24
|
+
}
|
25
|
+
export declare class NoUsersError extends Error {
|
26
|
+
}
|
27
|
+
export declare class NoScriptsError extends Error {
|
28
|
+
}
|
21
29
|
/** Push scripts from a source directory to the hackmud directory.
|
22
30
|
*
|
23
31
|
* Pushes files directly in the source folder to all users
|
@@ -25,4 +33,4 @@ export type PushOptions = LaxPartial<{
|
|
25
33
|
* @param hackmudPath directory created by hackmud containing user data including scripts
|
26
34
|
* @param options {@link PushOptions details}
|
27
35
|
* @returns array of info on pushed scripts */
|
28
|
-
export declare function push(sourcePath: string, hackmudPath: string, { scripts, onPush, minify, mangleNames, forceQuineCheats }?: PushOptions): Promise<Info[]>;
|
36
|
+
export declare function push(sourcePath: string, hackmudPath: string, { scripts, onPush, minify, mangleNames, forceQuineCheats }?: PushOptions): Promise<MissingSourceFolderError | MissingHackmudFolderError | NoUsersError | NoScriptsError | Info[]>;
|
package/push.js
CHANGED
@@ -42,19 +42,37 @@ import "./processScript/preprocess.js"
|
|
42
42
|
import "import-meta-resolve"
|
43
43
|
import "./processScript/transform.js"
|
44
44
|
import "@samual/lib/clearObject"
|
45
|
+
class MissingSourceFolderError extends Error {}
|
46
|
+
Object.defineProperty(MissingSourceFolderError.prototype, "name", { value: "MissingSourceFolderError" })
|
47
|
+
class MissingHackmudFolderError extends Error {}
|
48
|
+
Object.defineProperty(MissingHackmudFolderError.prototype, "name", { value: "MissingHackmudFolderError" })
|
49
|
+
class NoUsersError extends Error {}
|
50
|
+
Object.defineProperty(NoUsersError.prototype, "name", { value: "NoUsersError" })
|
51
|
+
class NoScriptsError extends Error {}
|
52
|
+
Object.defineProperty(NoScriptsError.prototype, "name", { value: "NoScriptsError" })
|
45
53
|
async function push(
|
46
54
|
sourcePath,
|
47
55
|
hackmudPath,
|
48
56
|
{ scripts = ["*.*"], onPush = () => {}, minify = !0, mangleNames = !1, forceQuineCheats } = {}
|
49
57
|
) {
|
50
58
|
const [sourceFolder, hackmudFolder] = await Promise.all([
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
59
|
+
readDirectoryWithStats(sourcePath).catch(error => {
|
60
|
+
if (error && "ENOENT" == error.code)
|
61
|
+
return new MissingSourceFolderError("There is no folder at " + sourcePath)
|
62
|
+
throw error
|
63
|
+
}),
|
64
|
+
readDirectoryWithStats(hackmudPath).catch(error => {
|
65
|
+
if (error && "ENOENT" == error.code)
|
66
|
+
return new MissingHackmudFolderError("There is no folder at " + hackmudPath)
|
67
|
+
throw error
|
68
|
+
})
|
69
|
+
])
|
70
|
+
if (sourceFolder instanceof Error) return sourceFolder
|
71
|
+
if (hackmudFolder instanceof Error) return hackmudFolder
|
72
|
+
const sourceFolderFolders = sourceFolder.filter(({ stats }) => stats.isDirectory()),
|
55
73
|
allUsers = new Set([
|
56
74
|
...scripts
|
57
|
-
.map(scriptName => ensure(scriptName.split(".")[0], "src/push.ts:
|
75
|
+
.map(scriptName => ensure(scriptName.split(".")[0], "src/push.ts:82:65"))
|
58
76
|
.filter(name => "*" != name),
|
59
77
|
...sourceFolderFolders.map(({ name }) => name),
|
60
78
|
...hackmudFolder.filter(({ stats }) => stats.isDirectory()).map(({ name }) => name),
|
@@ -63,13 +81,15 @@ async function push(
|
|
63
81
|
.map(({ name }) => name.slice(0, -4))
|
64
82
|
])
|
65
83
|
if (!allUsers.size)
|
66
|
-
|
84
|
+
return new NoUsersError(
|
85
|
+
"Could not find any users. Either provide the names of your users or log into a user in hackmud"
|
86
|
+
)
|
67
87
|
const usersToScriptsToPush = new Cache(_user => new Map()),
|
68
88
|
scriptNamesToUsers = new Cache(_scriptName => new Set())
|
69
89
|
for (const script of scripts) {
|
70
90
|
const [user, scriptName] = script.split(".")
|
71
|
-
assert(user, "src/push.ts:
|
72
|
-
assert(scriptName, "src/push.ts:
|
91
|
+
assert(user, "src/push.ts:105:16")
|
92
|
+
assert(scriptName, "src/push.ts:106:22")
|
73
93
|
"*" == user ? scriptNamesToUsers.set(scriptName, allUsers) : scriptNamesToUsers.get(scriptName).add(user)
|
74
94
|
}
|
75
95
|
const sourceFolderFiles = sourceFolder.filter(({ stats }) => stats.isFile()),
|
@@ -100,7 +120,7 @@ async function push(
|
|
100
120
|
for (const [scriptName, users] of scriptNamesToUsers)
|
101
121
|
for (const user of users)
|
102
122
|
if (!usersToScriptsToPush.get(user).has(scriptName))
|
103
|
-
|
123
|
+
return new NoScriptsError(`Could not find script ${user}.${scriptName} to push`)
|
104
124
|
const pathsToUsers = new Cache(_path => new Set())
|
105
125
|
for (const [user, scriptsToPush] of usersToScriptsToPush)
|
106
126
|
for (const path of scriptsToPush.values()) pathsToUsers.get(path).add(user)
|
@@ -137,4 +157,4 @@ async function push(
|
|
137
157
|
)
|
138
158
|
return allInfo
|
139
159
|
}
|
140
|
-
export { push }
|
160
|
+
export { MissingHackmudFolderError, MissingSourceFolderError, NoScriptsError, NoUsersError, push }
|