pw-js-world 0.3.6-dev.3de8e56 → 0.3.6-dev.522a1b7
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/Block.js +10 -4
- package/package.json +1 -1
- package/cm/Block.d.ts +0 -115
- package/cm/Block.js +0 -171
- package/cm/Helper.d.ts +0 -119
- package/cm/Helper.js +0 -510
- package/cm/Structure.d.ts +0 -104
- package/cm/Structure.js +0 -214
- package/cm/index.d.ts +0 -9
- package/cm/index.js +0 -26
package/esm/Block.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import BufferReader from "./BufferReader.js";
|
|
1
|
+
import BufferReader, { ComponentTypeHeader } from "./BufferReader.js";
|
|
2
2
|
import { PWApiClient } from "pw-js-api";
|
|
3
3
|
import { MissingBlockError } from "./util/Error.js";
|
|
4
4
|
export default class Block {
|
|
@@ -150,7 +150,8 @@ export default class Block {
|
|
|
150
150
|
*/
|
|
151
151
|
static getArgTypesByBlockId(blockId) {
|
|
152
152
|
var _a, _b, _c;
|
|
153
|
-
|
|
153
|
+
const block = (_a = PWApiClient.listBlocks) === null || _a === void 0 ? void 0 : _a[blockId];
|
|
154
|
+
return block ? (_c = (_b = MissingBlockData[block === null || block === void 0 ? void 0 : block.PaletteId.toUpperCase()]) !== null && _b !== void 0 ? _b : (block.BlockDataArgs)) !== null && _c !== void 0 ? _c : [] : [];
|
|
154
155
|
}
|
|
155
156
|
/**
|
|
156
157
|
* Returns the arg types for that block by given palette ID (full upper case).
|
|
@@ -161,7 +162,12 @@ export default class Block {
|
|
|
161
162
|
*/
|
|
162
163
|
static getArgTypesByPaletteId(paletteId) {
|
|
163
164
|
var _a, _b, _c;
|
|
164
|
-
return (_c = (
|
|
165
|
+
return (_c = (_a = MissingBlockData[paletteId]) !== null && _a !== void 0 ? _a : ((_b = PWApiClient.listBlocksObj) === null || _b === void 0 ? void 0 : _b[paletteId].BlockDataArgs)) !== null && _c !== void 0 ? _c : [];
|
|
165
166
|
}
|
|
166
167
|
}
|
|
167
|
-
|
|
168
|
+
// Temporary fix as some blocks currently have incorrect args
|
|
169
|
+
const MissingBlockData = {
|
|
170
|
+
SWITCH_LOCAL_ACTIVATOR: [ComponentTypeHeader.Int32, ComponentTypeHeader.Byte],
|
|
171
|
+
SWITCH_GLOBAL_ACTIVATOR: [ComponentTypeHeader.Int32, ComponentTypeHeader.Byte],
|
|
172
|
+
};
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmxvY2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvQmxvY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxZQUFZLEVBQUUsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRXRFLE9BQU8sRUFBRSxXQUFXLEVBQWtCLE1BQU0sV0FBVyxDQUFDO0FBQ3hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXBELE1BQU0sQ0FBQyxPQUFPLE9BQU8sS0FBSztJQUl0QixZQUFZLEdBQWdDLEVBQUUsSUFBaUI7UUFGL0QsU0FBSSxHQUFlLEVBQUUsQ0FBQztRQUdsQixJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVE7WUFBRSxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQzthQUN2QyxDQUFDO1lBQ0YsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RDLENBQUM7UUFFRCxJQUFJLElBQUk7WUFBRSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUMvQixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE9BQU87UUFDSCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFvQjtRQUNuQyxPQUFPLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRVMsZUFBZSxDQUFDLE1BQW9CLEVBQUUsSUFBSSxHQUFHLEtBQUs7O1FBQ3hELE1BQU0sTUFBTSxHQUEwQixLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUEsd0NBQXdDO1FBRW5ILEtBQUssSUFBSSxDQUFD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
|
package/package.json
CHANGED
package/cm/Block.d.ts
DELETED
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import type { BlockArg, Point, SendableBlockPacket } from "./types/index.js";
|
|
2
|
-
import BufferReader, { ComponentTypeHeader } from "./BufferReader.js";
|
|
3
|
-
import { LayerType } from "./Constants.js";
|
|
4
|
-
import { type BlockKeys } from "pw-js-api";
|
|
5
|
-
export default class Block {
|
|
6
|
-
bId: number;
|
|
7
|
-
args: BlockArg[];
|
|
8
|
-
constructor(bId: number | BlockKeys | string, args?: BlockArg[]);
|
|
9
|
-
/**
|
|
10
|
-
* I mean... Just use .args.length !== 0 to see if it has args.
|
|
11
|
-
*
|
|
12
|
-
* But anyway, this will return true if there is at least one args, otherwise false.
|
|
13
|
-
*/
|
|
14
|
-
hasArgs(): boolean;
|
|
15
|
-
/**
|
|
16
|
-
* For helper.
|
|
17
|
-
*
|
|
18
|
-
* This is in Block class for organisation.
|
|
19
|
-
*
|
|
20
|
-
* This will deserialise by using the reader to get the block ID then retrieve the args, if applicable.
|
|
21
|
-
*/
|
|
22
|
-
static deserialize(reader: BufferReader): Block;
|
|
23
|
-
protected deserializeArgs(reader: BufferReader, flag?: boolean): this;
|
|
24
|
-
/**
|
|
25
|
-
* For helper.
|
|
26
|
-
*
|
|
27
|
-
* This is in Block class for organisation.
|
|
28
|
-
*/
|
|
29
|
-
static deserializeArgs(reader: BufferReader): BlockArg[];
|
|
30
|
-
/**
|
|
31
|
-
* Serializes the block into a buffer. This is used to convert
|
|
32
|
-
* the block into a binary format that can be sent over the game
|
|
33
|
-
* server. As this is static, block id and args are required.
|
|
34
|
-
*
|
|
35
|
-
* - Little Endian
|
|
36
|
-
* - With Id
|
|
37
|
-
* - Type Byte omitted
|
|
38
|
-
*/
|
|
39
|
-
static serializeArgs(bId: number, args: BlockArg[]): Buffer;
|
|
40
|
-
/**
|
|
41
|
-
* Serializes the block into a buffer. This is used to convert
|
|
42
|
-
* the block into a binary format that can be sent over the game
|
|
43
|
-
* server. As this is static, block id and args are required.
|
|
44
|
-
*
|
|
45
|
-
* - Big Endian
|
|
46
|
-
* - No Id
|
|
47
|
-
* - Type Byte included
|
|
48
|
-
*/
|
|
49
|
-
static serializeArgs(bId: number, args: BlockArg[], options: {
|
|
50
|
-
endian: "big";
|
|
51
|
-
writeId: false;
|
|
52
|
-
readTypeByte: true;
|
|
53
|
-
}): Buffer;
|
|
54
|
-
static serializeArgs(bId: number, args: BlockArg[], options: {
|
|
55
|
-
endian: "little";
|
|
56
|
-
writeId: false;
|
|
57
|
-
readTypeByte: true;
|
|
58
|
-
}): Buffer;
|
|
59
|
-
/**
|
|
60
|
-
*
|
|
61
|
-
* @param pos List of points (X and Y)
|
|
62
|
-
*/
|
|
63
|
-
toPacket(pos: Point[], layer: LayerType): SendableBlockPacket;
|
|
64
|
-
toPacket(x: number, y: number, layer: LayerType): SendableBlockPacket;
|
|
65
|
-
/**
|
|
66
|
-
* This will return the block name in UPPER_CASE form.
|
|
67
|
-
*
|
|
68
|
-
* For eg EFFECTS_INVULNERABILITY.
|
|
69
|
-
*
|
|
70
|
-
* @throws {MissingBlockError}
|
|
71
|
-
* If the ID of this block is not known.
|
|
72
|
-
*/
|
|
73
|
-
get name(): string;
|
|
74
|
-
/**
|
|
75
|
-
* Returns a copy of the block.
|
|
76
|
-
*/
|
|
77
|
-
clone(obj?: false): Block;
|
|
78
|
-
clone(obj: true): {
|
|
79
|
-
bId: number;
|
|
80
|
-
args: BlockArg[];
|
|
81
|
-
name: string;
|
|
82
|
-
};
|
|
83
|
-
/**
|
|
84
|
-
* This can be convenient as it will always return the ID if it exists, and it will throw an error if it doesn't.
|
|
85
|
-
*
|
|
86
|
-
* This expects the name sent to be in full upper capital form though.
|
|
87
|
-
*
|
|
88
|
-
* @throws {MissingBlockError}
|
|
89
|
-
* If the connection is unknown, this can be because you're trying to use this function when Api#getListBlocks has never been invoked, or the object is missing.
|
|
90
|
-
*/
|
|
91
|
-
static getIdByName(paletteId: string): number;
|
|
92
|
-
/**
|
|
93
|
-
* This will return the corresponding palette id by the ID of that block.
|
|
94
|
-
*
|
|
95
|
-
* The name sent will be in full upper capital if it exists.
|
|
96
|
-
*
|
|
97
|
-
* @throws {MissingBlockError}
|
|
98
|
-
* If the connection is unknown, this can be because you're trying to use this function when Api#getListBlocks has never been invoked, or the object is missing.
|
|
99
|
-
*/
|
|
100
|
-
static getPaletteIdById(blockId: number): string;
|
|
101
|
-
/**
|
|
102
|
-
* Returns the arg types for that block by given block ID.
|
|
103
|
-
*
|
|
104
|
-
* If a block don't have args, it will return an empty array.
|
|
105
|
-
*/
|
|
106
|
-
static getArgTypesByBlockId(blockId: number): ComponentTypeHeader[];
|
|
107
|
-
/**
|
|
108
|
-
* Returns the arg types for that block by given palette ID (full upper case).
|
|
109
|
-
*
|
|
110
|
-
* For eg "EMPTY" or "SIGN_GOLD"
|
|
111
|
-
*
|
|
112
|
-
* If a block don't have args, it will return an empty array.
|
|
113
|
-
*/
|
|
114
|
-
static getArgTypesByPaletteId(paletteId: string): ComponentTypeHeader[];
|
|
115
|
-
}
|
package/cm/Block.js
DELETED
|
@@ -1,171 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const tslib_1 = require("tslib");
|
|
4
|
-
const BufferReader_js_1 = tslib_1.__importDefault(require("./BufferReader.js"));
|
|
5
|
-
const pw_js_api_1 = require("pw-js-api");
|
|
6
|
-
const Error_js_1 = require("./util/Error.js");
|
|
7
|
-
class Block {
|
|
8
|
-
constructor(bId, args) {
|
|
9
|
-
this.args = [];
|
|
10
|
-
if (typeof bId === "number")
|
|
11
|
-
this.bId = bId;
|
|
12
|
-
else {
|
|
13
|
-
this.bId = Block.getIdByName(bId);
|
|
14
|
-
}
|
|
15
|
-
if (args)
|
|
16
|
-
this.args = args;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* I mean... Just use .args.length !== 0 to see if it has args.
|
|
20
|
-
*
|
|
21
|
-
* But anyway, this will return true if there is at least one args, otherwise false.
|
|
22
|
-
*/
|
|
23
|
-
hasArgs() {
|
|
24
|
-
return this.args.length !== 0;
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* For helper.
|
|
28
|
-
*
|
|
29
|
-
* This is in Block class for organisation.
|
|
30
|
-
*
|
|
31
|
-
* This will deserialise by using the reader to get the block ID then retrieve the args, if applicable.
|
|
32
|
-
*/
|
|
33
|
-
static deserialize(reader) {
|
|
34
|
-
return new Block(reader.readUInt32LE()).deserializeArgs(reader);
|
|
35
|
-
}
|
|
36
|
-
deserializeArgs(reader, flag = false) {
|
|
37
|
-
var _a;
|
|
38
|
-
const format = Block.getArgTypesByBlockId(this.bId); //(BlockArgsHeadings as any)[this.name];
|
|
39
|
-
for (let i = 0; i < ((_a = format === null || format === void 0 ? void 0 : format.length) !== null && _a !== void 0 ? _a : 0); i++) {
|
|
40
|
-
if (flag) {
|
|
41
|
-
reader.expectUInt8(format[i]);
|
|
42
|
-
}
|
|
43
|
-
this.args[i] = reader.read(format[i], !flag);
|
|
44
|
-
}
|
|
45
|
-
return this;
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* For helper.
|
|
49
|
-
*
|
|
50
|
-
* This is in Block class for organisation.
|
|
51
|
-
*/
|
|
52
|
-
static deserializeArgs(reader) {
|
|
53
|
-
// const args =
|
|
54
|
-
return reader.deserialize();
|
|
55
|
-
// for (let i = 0; i < (format?.length ?? 0); i++) {
|
|
56
|
-
// if (flag) {
|
|
57
|
-
// reader.expectUInt8(format[i]);
|
|
58
|
-
// }
|
|
59
|
-
// args[i] = reader.read(format[i], !flag);
|
|
60
|
-
// }
|
|
61
|
-
// return args;
|
|
62
|
-
}
|
|
63
|
-
static serializeArgs(bId, args, options) {
|
|
64
|
-
options || (options = {
|
|
65
|
-
endian: "little",
|
|
66
|
-
writeId: true,
|
|
67
|
-
readTypeByte: false,
|
|
68
|
-
});
|
|
69
|
-
const buffer = [];
|
|
70
|
-
if (options.writeId) {
|
|
71
|
-
const idBuffer = Buffer.alloc(4);
|
|
72
|
-
idBuffer.writeUInt32LE(bId);
|
|
73
|
-
buffer.push(idBuffer);
|
|
74
|
-
}
|
|
75
|
-
const blockData = Block.getArgTypesByBlockId(bId);
|
|
76
|
-
for (let i = 0, len = blockData.length; i < len; i++) {
|
|
77
|
-
const entry = BufferReader_js_1.default.Dynamic(blockData[i], args[i]);
|
|
78
|
-
buffer.push(entry);
|
|
79
|
-
}
|
|
80
|
-
return Buffer.concat(buffer);
|
|
81
|
-
}
|
|
82
|
-
toPacket(pos, y, layer) {
|
|
83
|
-
if (typeof pos === "number") {
|
|
84
|
-
pos = [{
|
|
85
|
-
x: pos, y
|
|
86
|
-
}];
|
|
87
|
-
layer = layer !== null && layer !== void 0 ? layer : 0;
|
|
88
|
-
}
|
|
89
|
-
else
|
|
90
|
-
layer = y !== null && y !== void 0 ? y : 0;
|
|
91
|
-
return {
|
|
92
|
-
isFillOperation: false,
|
|
93
|
-
blockId: this.bId,
|
|
94
|
-
layer,
|
|
95
|
-
positions: pos,
|
|
96
|
-
extraFields: Block.serializeArgs(this.bId, this.args, { endian: "big", writeId: false, readTypeByte: true })
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* This will return the block name in UPPER_CASE form.
|
|
101
|
-
*
|
|
102
|
-
* For eg EFFECTS_INVULNERABILITY.
|
|
103
|
-
*
|
|
104
|
-
* @throws {MissingBlockError}
|
|
105
|
-
* If the ID of this block is not known.
|
|
106
|
-
*/
|
|
107
|
-
get name() {
|
|
108
|
-
var _a;
|
|
109
|
-
const block = (_a = pw_js_api_1.PWApiClient.listBlocks) === null || _a === void 0 ? void 0 : _a[this.bId];
|
|
110
|
-
if (block === undefined)
|
|
111
|
-
throw new Error_js_1.MissingBlockError("Current block data is missing, run Api#listBlocks first?", this.bId);
|
|
112
|
-
return block.PaletteId.toUpperCase();
|
|
113
|
-
}
|
|
114
|
-
clone(obj = false) {
|
|
115
|
-
if (obj === true)
|
|
116
|
-
return { bId: this.bId, args: this.args, name: this.name };
|
|
117
|
-
return new Block(this.bId, this.args);
|
|
118
|
-
}
|
|
119
|
-
/**
|
|
120
|
-
* This can be convenient as it will always return the ID if it exists, and it will throw an error if it doesn't.
|
|
121
|
-
*
|
|
122
|
-
* This expects the name sent to be in full upper capital form though.
|
|
123
|
-
*
|
|
124
|
-
* @throws {MissingBlockError}
|
|
125
|
-
* If the connection is unknown, this can be because you're trying to use this function when Api#getListBlocks has never been invoked, or the object is missing.
|
|
126
|
-
*/
|
|
127
|
-
static getIdByName(paletteId) {
|
|
128
|
-
var _a;
|
|
129
|
-
const block = (_a = pw_js_api_1.PWApiClient.listBlocksObj) === null || _a === void 0 ? void 0 : _a[paletteId];
|
|
130
|
-
if (block === undefined)
|
|
131
|
-
throw new Error_js_1.MissingBlockError("Current block data is missing, run Api#listBlocks first?", paletteId);
|
|
132
|
-
return block.Id;
|
|
133
|
-
}
|
|
134
|
-
/**
|
|
135
|
-
* This will return the corresponding palette id by the ID of that block.
|
|
136
|
-
*
|
|
137
|
-
* The name sent will be in full upper capital if it exists.
|
|
138
|
-
*
|
|
139
|
-
* @throws {MissingBlockError}
|
|
140
|
-
* If the connection is unknown, this can be because you're trying to use this function when Api#getListBlocks has never been invoked, or the object is missing.
|
|
141
|
-
*/
|
|
142
|
-
static getPaletteIdById(blockId) {
|
|
143
|
-
var _a;
|
|
144
|
-
const block = (_a = pw_js_api_1.PWApiClient.listBlocks) === null || _a === void 0 ? void 0 : _a[blockId];
|
|
145
|
-
if (block === undefined)
|
|
146
|
-
throw new Error_js_1.MissingBlockError("Current block data is missing, run Api#listBlocks first?", blockId);
|
|
147
|
-
return block.PaletteId.toUpperCase();
|
|
148
|
-
}
|
|
149
|
-
/**
|
|
150
|
-
* Returns the arg types for that block by given block ID.
|
|
151
|
-
*
|
|
152
|
-
* If a block don't have args, it will return an empty array.
|
|
153
|
-
*/
|
|
154
|
-
static getArgTypesByBlockId(blockId) {
|
|
155
|
-
var _a, _b, _c;
|
|
156
|
-
return (_c = ((_b = (_a = pw_js_api_1.PWApiClient.listBlocks) === null || _a === void 0 ? void 0 : _a[blockId]) === null || _b === void 0 ? void 0 : _b.BlockDataArgs)) !== null && _c !== void 0 ? _c : [];
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Returns the arg types for that block by given palette ID (full upper case).
|
|
160
|
-
*
|
|
161
|
-
* For eg "EMPTY" or "SIGN_GOLD"
|
|
162
|
-
*
|
|
163
|
-
* If a block don't have args, it will return an empty array.
|
|
164
|
-
*/
|
|
165
|
-
static getArgTypesByPaletteId(paletteId) {
|
|
166
|
-
var _a, _b, _c;
|
|
167
|
-
return (_c = ((_b = (_a = pw_js_api_1.PWApiClient.listBlocksObj) === null || _a === void 0 ? void 0 : _a[paletteId]) === null || _b === void 0 ? void 0 : _b.BlockDataArgs)) !== null && _c !== void 0 ? _c : [];
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
exports.default = Block;
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmxvY2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvQmxvY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsZ0ZBQXNFO0FBRXRFLHlDQUF3RDtBQUN4RCw4Q0FBb0Q7QUFFcEQsTUFBcUIsS0FBSztJQUl0QixZQUFZLEdBQWdDLEVBQUUsSUFBaUI7UUFGL0QsU0FBSSxHQUFlLEVBQUUsQ0FBQztRQUdsQixJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVE7WUFBRSxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQzthQUN2QyxDQUFDO1lBQ0YsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RDLENBQUM7UUFFRCxJQUFJLElBQUk7WUFBRSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUMvQixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE9BQU87UUFDSCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFvQjtRQUNuQyxPQUFPLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRVMsZUFBZSxDQUFDLE1BQW9CLEVBQUUsSUFBSSxHQUFHLEtBQUs7O1FBQ3hELE1BQU0sTUFBTSxHQUEwQixLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUEsd0NBQXdDO1FBRW5ILEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQUEsTUFBTSxhQUFOLE1BQU0sdUJBQU4sTUFBTSxDQUFFLE1BQU0sbUNBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZ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
|
package/cm/Helper.d.ts
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import { type Hook } from "pw-js-api";
|
|
2
|
-
import type { ProtoGen } from "pw-js-api";
|
|
3
|
-
import Block from "./Block.js";
|
|
4
|
-
import Player from "./Player.js";
|
|
5
|
-
import { LayerType } from "./Constants.js";
|
|
6
|
-
import type { Point, PWGameHook } from "./types/index.js";
|
|
7
|
-
import { DeserialisedStructure } from "./Structure.js";
|
|
8
|
-
/**
|
|
9
|
-
* To use this helper, you must first create an instance of this,
|
|
10
|
-
*
|
|
11
|
-
* then: <PWGameClient>.addCallback("raw", helper.onRawPacketRecv)
|
|
12
|
-
*/
|
|
13
|
-
export default class PWGameWorldHelper {
|
|
14
|
-
/**
|
|
15
|
-
* Arrays of blocks (by layer, x, y)
|
|
16
|
-
*/
|
|
17
|
-
blocks: [Block[][], Block[][]];
|
|
18
|
-
players: Map<number, Player>;
|
|
19
|
-
globalSwitches: boolean[];
|
|
20
|
-
private _meta?;
|
|
21
|
-
private _width;
|
|
22
|
-
private _height;
|
|
23
|
-
private _init;
|
|
24
|
-
private _selfPlayerId;
|
|
25
|
-
/**
|
|
26
|
-
* The current world's width.
|
|
27
|
-
*
|
|
28
|
-
* If you didn't put the hook before init, this may throw error.
|
|
29
|
-
*/
|
|
30
|
-
get width(): number;
|
|
31
|
-
/**
|
|
32
|
-
* The current world's height.
|
|
33
|
-
*
|
|
34
|
-
* If you didn't put the hook before init, this may throw error.
|
|
35
|
-
*/
|
|
36
|
-
get height(): number;
|
|
37
|
-
/**
|
|
38
|
-
* The current world's metadata.
|
|
39
|
-
*
|
|
40
|
-
* If you didn't put the hook before init, this may throw error.
|
|
41
|
-
*/
|
|
42
|
-
get meta(): ProtoGen.WorldMeta | null;
|
|
43
|
-
/**
|
|
44
|
-
* If this helper is ready. When it's false, the helper will not return anything for any of the packets.
|
|
45
|
-
*/
|
|
46
|
-
get initialised(): boolean;
|
|
47
|
-
/**
|
|
48
|
-
* The bot's player object.
|
|
49
|
-
*
|
|
50
|
-
* If you didn't put the hook before init, this may throw error.
|
|
51
|
-
*/
|
|
52
|
-
get botPlayer(): Player;
|
|
53
|
-
/**
|
|
54
|
-
* The bot's player id in the world.
|
|
55
|
-
*
|
|
56
|
-
* If you didn't put the hook before init, this may throw error.
|
|
57
|
-
*/
|
|
58
|
-
get botPlayerId(): number;
|
|
59
|
-
/**
|
|
60
|
-
* This must go in .use() of the main PW-JS-API Game Client class.
|
|
61
|
-
*
|
|
62
|
-
* <PWGameClient>.use(<PWGameWorldHelper>.receiveHook)
|
|
63
|
-
*
|
|
64
|
-
* DO NOT PUT () AFTER RECEIVEHOOK
|
|
65
|
-
*/
|
|
66
|
-
receiveHook: Hook<PWGameHook>;
|
|
67
|
-
/**
|
|
68
|
-
* Internal function.
|
|
69
|
-
*/
|
|
70
|
-
private initialise;
|
|
71
|
-
/**
|
|
72
|
-
* Internal function.
|
|
73
|
-
*/
|
|
74
|
-
private deserialize;
|
|
75
|
-
private convertSwitchState;
|
|
76
|
-
/**
|
|
77
|
-
* Internal function, this triggers when the world gets cleared.
|
|
78
|
-
*
|
|
79
|
-
* Clears the blocks map and promptly fill it with empty except the border which becomes basci gray.
|
|
80
|
-
*/
|
|
81
|
-
private clear;
|
|
82
|
-
/**
|
|
83
|
-
* Gets the block at the position.
|
|
84
|
-
*
|
|
85
|
-
* Difference between this and using this.blocks directly is that this function will validate the positions and the layer.
|
|
86
|
-
*/
|
|
87
|
-
getBlockAt(pos: Point, l: LayerType): Block;
|
|
88
|
-
getBlockAt(x: number | Point, y: number, l: LayerType): Block;
|
|
89
|
-
/**
|
|
90
|
-
* Player ID.
|
|
91
|
-
*
|
|
92
|
-
* The main bot player is excluded from the criteria.
|
|
93
|
-
*/
|
|
94
|
-
getPlayer(id: number, isAccount?: false): Player | undefined;
|
|
95
|
-
/**
|
|
96
|
-
* Username is case insensitive.
|
|
97
|
-
*
|
|
98
|
-
* The main bot player is excluded from the criteria.
|
|
99
|
-
*/
|
|
100
|
-
getPlayer(username: string, isAccount?: false): Player | undefined;
|
|
101
|
-
/**
|
|
102
|
-
* The ID of the account (must have second parameter set to true)
|
|
103
|
-
*
|
|
104
|
-
* The main bot player is excluded from the criteria.
|
|
105
|
-
*/
|
|
106
|
-
getPlayer(accountId: string, isAccount: true): Player | undefined;
|
|
107
|
-
/**
|
|
108
|
-
* Returns the list of current players in the world.
|
|
109
|
-
*/
|
|
110
|
-
getPlayers(): Player[];
|
|
111
|
-
/**
|
|
112
|
-
* This will return a DeserialisedStructure which will allow you to easily save to a file if you wish.
|
|
113
|
-
*
|
|
114
|
-
* The blocks are cloned and thus you're free to modify the blocks in the structure without the risk of it affecting this helper's blocks.
|
|
115
|
-
*
|
|
116
|
-
* NOTE: endX and endY are also included!
|
|
117
|
-
*/
|
|
118
|
-
sectionBlocks(startX: number, startY: number, endX: number, endY: number): DeserialisedStructure;
|
|
119
|
-
}
|