pw-js-world 0.1.5-dev.5ce0683 → 0.2.1-dev.ee2fd11
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/BufferReader.js +2 -2
- package/esm/Helper.js +13 -3
- package/esm/Player.d.ts +33 -0
- package/esm/Player.js +38 -1
- package/esm/index.d.ts +2 -1
- package/esm/index.js +4 -2
- package/esm/types/index.d.ts +1 -0
- package/package.json +2 -2
- package/cm/Block.d.ts +0 -184
- package/cm/Block.js +0 -223
- package/cm/BufferReader.d.ts +0 -330
- package/cm/BufferReader.js +0 -691
- package/cm/Constants.d.ts +0 -4
- package/cm/Constants.js +0 -9
- package/cm/Helper.d.ts +0 -119
- package/cm/Helper.js +0 -497
- package/cm/Player.d.ts +0 -222
- package/cm/Player.js +0 -116
- package/cm/Structure.d.ts +0 -104
- package/cm/Structure.js +0 -208
- package/cm/Util.d.ts +0 -23
- package/cm/Util.js +0 -100
- package/cm/index.d.ts +0 -8
- package/cm/index.js +0 -22
package/cm/Player.d.ts
DELETED
|
@@ -1,222 +0,0 @@
|
|
|
1
|
-
import type { ProtoGen } from "pw-js-api";
|
|
2
|
-
import type { Point } from "./types/index.js";
|
|
3
|
-
export interface IPlayer {
|
|
4
|
-
/**
|
|
5
|
-
* ID of the player.
|
|
6
|
-
*/
|
|
7
|
-
playerId: number;
|
|
8
|
-
/**
|
|
9
|
-
* ID of the player's account.
|
|
10
|
-
*/
|
|
11
|
-
accountId: string;
|
|
12
|
-
/**
|
|
13
|
-
* Name of the player.
|
|
14
|
-
*/
|
|
15
|
-
username: string;
|
|
16
|
-
/**
|
|
17
|
-
* ID of the player's equipped smiley.
|
|
18
|
-
*/
|
|
19
|
-
face: number;
|
|
20
|
-
/**
|
|
21
|
-
* String, could be an admin or developer.
|
|
22
|
-
*/
|
|
23
|
-
role: string;
|
|
24
|
-
/**
|
|
25
|
-
* If player is bot user's friend.
|
|
26
|
-
*/
|
|
27
|
-
isFriend: boolean;
|
|
28
|
-
/**
|
|
29
|
-
* Position of the user.
|
|
30
|
-
*
|
|
31
|
-
* Note: This helper does not simulate physics so positions will always be inaccurate.
|
|
32
|
-
*/
|
|
33
|
-
position?: Point;
|
|
34
|
-
/**
|
|
35
|
-
* If player is the world owner.
|
|
36
|
-
*/
|
|
37
|
-
isWorldOwner: boolean;
|
|
38
|
-
/**
|
|
39
|
-
* Rights
|
|
40
|
-
*/
|
|
41
|
-
rights: IPlayerRights;
|
|
42
|
-
/**
|
|
43
|
-
* current world state.
|
|
44
|
-
*/
|
|
45
|
-
states: IPlayerWorldState;
|
|
46
|
-
/**
|
|
47
|
-
* List of active effects the player has.
|
|
48
|
-
*/
|
|
49
|
-
effects: PlayerEffect[];
|
|
50
|
-
/**
|
|
51
|
-
* If this player is the bot.
|
|
52
|
-
*/
|
|
53
|
-
isMe: boolean;
|
|
54
|
-
}
|
|
55
|
-
export interface IPlayerRights {
|
|
56
|
-
/**
|
|
57
|
-
* If the player has edit rights.
|
|
58
|
-
*/
|
|
59
|
-
canEdit: boolean;
|
|
60
|
-
/**
|
|
61
|
-
* If the player has god rights.
|
|
62
|
-
*/
|
|
63
|
-
canGod: boolean;
|
|
64
|
-
/**
|
|
65
|
-
* If the player has the ability to toggle minimap.
|
|
66
|
-
*/
|
|
67
|
-
canToggleMinimap: boolean;
|
|
68
|
-
/**
|
|
69
|
-
* If the player has the ability to change the world settings.
|
|
70
|
-
*/
|
|
71
|
-
canChangeWorldSettings: boolean;
|
|
72
|
-
/**
|
|
73
|
-
* List of commands (string) the player can use.
|
|
74
|
-
*/
|
|
75
|
-
availableCommands: string[];
|
|
76
|
-
}
|
|
77
|
-
export interface IPlayerWorldState {
|
|
78
|
-
/**
|
|
79
|
-
* Number of gold coins the player has.
|
|
80
|
-
*/
|
|
81
|
-
coinsGold: number;
|
|
82
|
-
/**
|
|
83
|
-
* Number of blue coins the player has.
|
|
84
|
-
*/
|
|
85
|
-
coinsBlue: number;
|
|
86
|
-
/**
|
|
87
|
-
* Number of times the player died.
|
|
88
|
-
*/
|
|
89
|
-
deaths: number;
|
|
90
|
-
/**
|
|
91
|
-
* Coordinates of collected coins?
|
|
92
|
-
*/
|
|
93
|
-
collectedItems: Point[];
|
|
94
|
-
/**
|
|
95
|
-
* If player has gold crown on.
|
|
96
|
-
*/
|
|
97
|
-
hasGoldCrown: boolean;
|
|
98
|
-
/**
|
|
99
|
-
* If player has won the world.
|
|
100
|
-
*/
|
|
101
|
-
hasSilverCrown: boolean;
|
|
102
|
-
/**
|
|
103
|
-
* Zero indexed, map of the player's switch state.
|
|
104
|
-
*/
|
|
105
|
-
switches: boolean[];
|
|
106
|
-
/**
|
|
107
|
-
* If player is in god mode right now.
|
|
108
|
-
*/
|
|
109
|
-
godmode: boolean;
|
|
110
|
-
/**
|
|
111
|
-
* If player is in mod mode right now.
|
|
112
|
-
*/
|
|
113
|
-
modmode: boolean;
|
|
114
|
-
/**
|
|
115
|
-
* ID of the team the player is associated with right now.
|
|
116
|
-
*/
|
|
117
|
-
teamId: number;
|
|
118
|
-
}
|
|
119
|
-
export interface IPlayerEffect {
|
|
120
|
-
/**
|
|
121
|
-
* The ID of the effect.
|
|
122
|
-
*/
|
|
123
|
-
effectId: number;
|
|
124
|
-
/**
|
|
125
|
-
* If applicable, the duration of the effect.
|
|
126
|
-
*/
|
|
127
|
-
duration?: number;
|
|
128
|
-
/**
|
|
129
|
-
* If applicable, the strength of the effect. (For example speed or multi jump effect)
|
|
130
|
-
*/
|
|
131
|
-
strength?: number;
|
|
132
|
-
}
|
|
133
|
-
export default class Player {
|
|
134
|
-
/**
|
|
135
|
-
* ID of the player.
|
|
136
|
-
*/
|
|
137
|
-
playerId: number;
|
|
138
|
-
/**
|
|
139
|
-
* ID of the player's account.
|
|
140
|
-
*/
|
|
141
|
-
accountId: string;
|
|
142
|
-
/**
|
|
143
|
-
* Name of the player.
|
|
144
|
-
*/
|
|
145
|
-
username: string;
|
|
146
|
-
/**
|
|
147
|
-
* ID of the player's equipped smiley.
|
|
148
|
-
*/
|
|
149
|
-
face: number;
|
|
150
|
-
/**
|
|
151
|
-
* String, could be an admin or developer.
|
|
152
|
-
*/
|
|
153
|
-
role: string;
|
|
154
|
-
/**
|
|
155
|
-
* If player is bot user's friend.
|
|
156
|
-
*/
|
|
157
|
-
isFriend: boolean;
|
|
158
|
-
/**
|
|
159
|
-
* Position of the user.
|
|
160
|
-
*
|
|
161
|
-
* Note: This helper does not simulate physics so positions will always be inaccurate.
|
|
162
|
-
*/
|
|
163
|
-
position?: Point;
|
|
164
|
-
/**
|
|
165
|
-
* If player is the world owner.
|
|
166
|
-
*/
|
|
167
|
-
isWorldOwner: boolean;
|
|
168
|
-
/**
|
|
169
|
-
* Rights
|
|
170
|
-
*/
|
|
171
|
-
rights: IPlayerRights;
|
|
172
|
-
/**
|
|
173
|
-
* current world state.
|
|
174
|
-
*/
|
|
175
|
-
states: IPlayerWorldState;
|
|
176
|
-
/**
|
|
177
|
-
* List of active effects the player has.
|
|
178
|
-
*/
|
|
179
|
-
effects: PlayerEffect[];
|
|
180
|
-
/**
|
|
181
|
-
* If this player is the bot.
|
|
182
|
-
*/
|
|
183
|
-
isMe: boolean;
|
|
184
|
-
constructor(props: ProtoGen.PlayerProperties, states?: IPlayerWorldState | boolean);
|
|
185
|
-
/**
|
|
186
|
-
* This is destructive, this is only for on reset packet.
|
|
187
|
-
*/
|
|
188
|
-
resetState(): void;
|
|
189
|
-
/**
|
|
190
|
-
* Destructive.
|
|
191
|
-
*/
|
|
192
|
-
resetRights(): void;
|
|
193
|
-
}
|
|
194
|
-
export declare class PlayerEffect {
|
|
195
|
-
/**
|
|
196
|
-
* The ID of the effect.
|
|
197
|
-
*/
|
|
198
|
-
effectId: number;
|
|
199
|
-
/**
|
|
200
|
-
* If applicable, the duration of the effect.
|
|
201
|
-
*/
|
|
202
|
-
duration?: number;
|
|
203
|
-
/**
|
|
204
|
-
* If applicable, the strength of the effect. (For example speed or multi jump effect)
|
|
205
|
-
*/
|
|
206
|
-
strength?: number;
|
|
207
|
-
/**
|
|
208
|
-
* The time the effect occurred.
|
|
209
|
-
*/
|
|
210
|
-
triggeredAt: number;
|
|
211
|
-
constructor(effect: IPlayerEffect, triggeredAt?: number);
|
|
212
|
-
/**
|
|
213
|
-
* Note: If this effect is non timed, this will always return false.
|
|
214
|
-
*/
|
|
215
|
-
get hasExpired(): boolean;
|
|
216
|
-
/**
|
|
217
|
-
* Milliseconds showing how long before this expires.
|
|
218
|
-
*
|
|
219
|
-
* Note: If this effect is non timed, this will return infinity.
|
|
220
|
-
*/
|
|
221
|
-
get remaining(): number;
|
|
222
|
-
}
|
package/cm/Player.js
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PlayerEffect = void 0;
|
|
4
|
-
const Util_js_1 = require("./Util.js");
|
|
5
|
-
class Player {
|
|
6
|
-
constructor(props, states) {
|
|
7
|
-
/**
|
|
8
|
-
* List of active effects the player has.
|
|
9
|
-
*/
|
|
10
|
-
this.effects = [];
|
|
11
|
-
/**
|
|
12
|
-
* If this player is the bot.
|
|
13
|
-
*/
|
|
14
|
-
this.isMe = false;
|
|
15
|
-
this.accountId = props.accountId;
|
|
16
|
-
this.face = props.face;
|
|
17
|
-
this.isFriend = props.isFriend;
|
|
18
|
-
this.isWorldOwner = props.isWorldOwner;
|
|
19
|
-
this.playerId = props.playerId;
|
|
20
|
-
this.position = props.position ? {
|
|
21
|
-
x: props.position.x,
|
|
22
|
-
y: props.position.y
|
|
23
|
-
} : undefined;
|
|
24
|
-
if (!props.rights)
|
|
25
|
-
this.resetRights();
|
|
26
|
-
else
|
|
27
|
-
this.rights = {
|
|
28
|
-
availableCommands: props.rights.availableCommands,
|
|
29
|
-
canChangeWorldSettings: props.rights.canChangeWorldSettings,
|
|
30
|
-
canEdit: props.rights.canEdit,
|
|
31
|
-
canGod: props.rights.canGod,
|
|
32
|
-
canToggleMinimap: props.rights.canToggleMinimap,
|
|
33
|
-
};
|
|
34
|
-
this.role = props.role;
|
|
35
|
-
this.username = props.username;
|
|
36
|
-
if (typeof states === "boolean") {
|
|
37
|
-
this.isMe = states;
|
|
38
|
-
states = undefined;
|
|
39
|
-
}
|
|
40
|
-
if (!states) {
|
|
41
|
-
// Could be bot via init that don't get states.
|
|
42
|
-
this.resetState();
|
|
43
|
-
}
|
|
44
|
-
else
|
|
45
|
-
this.states = {
|
|
46
|
-
coinsBlue: states.coinsBlue,
|
|
47
|
-
coinsGold: states.coinsGold,
|
|
48
|
-
collectedItems: (0, Util_js_1.map)(states.collectedItems, v => ({ x: v.x, y: v.y })),
|
|
49
|
-
deaths: states.deaths,
|
|
50
|
-
godmode: states.godmode,
|
|
51
|
-
hasGoldCrown: states.hasGoldCrown,
|
|
52
|
-
hasSilverCrown: states.hasSilverCrown,
|
|
53
|
-
modmode: states.modmode,
|
|
54
|
-
switches: states.switches,
|
|
55
|
-
teamId: states.teamId,
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* This is destructive, this is only for on reset packet.
|
|
60
|
-
*/
|
|
61
|
-
resetState() {
|
|
62
|
-
this.states = {
|
|
63
|
-
coinsBlue: 0,
|
|
64
|
-
coinsGold: 0,
|
|
65
|
-
collectedItems: [],
|
|
66
|
-
deaths: 0,
|
|
67
|
-
godmode: false,
|
|
68
|
-
hasGoldCrown: false,
|
|
69
|
-
hasSilverCrown: false,
|
|
70
|
-
modmode: false,
|
|
71
|
-
switches: new Array(1000).fill(false),
|
|
72
|
-
teamId: 0,
|
|
73
|
-
};
|
|
74
|
-
}
|
|
75
|
-
/**
|
|
76
|
-
* Destructive.
|
|
77
|
-
*/
|
|
78
|
-
resetRights() {
|
|
79
|
-
this.rights = {
|
|
80
|
-
availableCommands: [],
|
|
81
|
-
canChangeWorldSettings: false,
|
|
82
|
-
canEdit: false,
|
|
83
|
-
canGod: false,
|
|
84
|
-
canToggleMinimap: false
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
exports.default = Player;
|
|
89
|
-
class PlayerEffect {
|
|
90
|
-
constructor(effect, triggeredAt) {
|
|
91
|
-
this.effectId = effect.effectId;
|
|
92
|
-
this.duration = effect.duration;
|
|
93
|
-
this.strength = effect.strength;
|
|
94
|
-
this.triggeredAt = triggeredAt !== null && triggeredAt !== void 0 ? triggeredAt : Date.now();
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Note: If this effect is non timed, this will always return false.
|
|
98
|
-
*/
|
|
99
|
-
get hasExpired() {
|
|
100
|
-
if (this.duration === undefined)
|
|
101
|
-
return false;
|
|
102
|
-
return Date.now() > (this.triggeredAt + this.duration);
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Milliseconds showing how long before this expires.
|
|
106
|
-
*
|
|
107
|
-
* Note: If this effect is non timed, this will return infinity.
|
|
108
|
-
*/
|
|
109
|
-
get remaining() {
|
|
110
|
-
if (this.duration === undefined)
|
|
111
|
-
return Infinity;
|
|
112
|
-
return Math.max(0, Date.now() - (this.triggeredAt + this.duration));
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
exports.PlayerEffect = PlayerEffect;
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUGxheWVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vbGliL1BsYXllci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSx1Q0FBZ0M7QUEwSWhDLE1BQXFCLE1BQU07SUFzRHZCLFlBQVksS0FBZ0MsRUFBRSxNQUFvQztRQVZsRjs7V0FFRztRQUNILFlBQU8sR0FBa0IsRUFBRSxDQUFDO1FBRTVCOztXQUVHO1FBQ0gsU0FBSSxHQUFZLEtBQUssQ0FBQztRQUdsQixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQUM7UUFDakMsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUM7UUFDdkMsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDN0IsQ0FBQyxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNuQixDQUFDLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1NBQ3RCLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUVkLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTTtZQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQzs7WUFDakMsSUFBSSxDQUFDLE1BQU0sR0FBRztnQkFDZixpQkFBaUIsRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLGlCQUFpQjtnQkFDakQsc0JBQXNCLEVBQUUsS0FBSyxDQUFDLE1BQU0sQ0FBQyxzQkFBc0I7Z0JBQzNELE9BQU8sRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU87Z0JBQzdCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU07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
|
package/cm/Structure.d.ts
DELETED
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import Block from "./Block";
|
|
2
|
-
import type { BlockArg } from "./types";
|
|
3
|
-
import type { BlockKeys } from "./types/excluded";
|
|
4
|
-
/**
|
|
5
|
-
* This is external to the main Helper, it will allow developers to use the structure without needing to use helper if they so wish.
|
|
6
|
-
*
|
|
7
|
-
* All of the functions are static!
|
|
8
|
-
*/
|
|
9
|
-
export default class StructureHelper {
|
|
10
|
-
/**
|
|
11
|
-
* NOTE: If you're reading a file, you must get it then pass it to read.
|
|
12
|
-
*
|
|
13
|
-
* This is for reading the structure itself, if you have just the blocks (and width/height), you must use deserialiseStructBlocks;
|
|
14
|
-
*
|
|
15
|
-
* @param data Buffer representing the JSON structure itself.
|
|
16
|
-
*/
|
|
17
|
-
static read(data: Buffer | Uint8Array | IStructure): DeserialisedStructure;
|
|
18
|
-
/**
|
|
19
|
-
* If width or height are not provided, the structure may be trimmed (empty blocks).
|
|
20
|
-
*
|
|
21
|
-
* This is ideal if you want the trimmed structure in that case.
|
|
22
|
-
*/
|
|
23
|
-
static deserialiseStructBlocks(struct: IStructureBlocks, width?: number, height?: number): {
|
|
24
|
-
blocks: [Block[][], Block[][]];
|
|
25
|
-
width: number;
|
|
26
|
-
height: number;
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Represents the structure in its deserialised form, allows for modification
|
|
31
|
-
*/
|
|
32
|
-
export declare class DeserialisedStructure {
|
|
33
|
-
blocks: [Block[][], Block[][]];
|
|
34
|
-
width: number;
|
|
35
|
-
height: number;
|
|
36
|
-
constructor(blocks: [Block[][], Block[][]], struct: Omit<IStructure, "version" | "blocks">);
|
|
37
|
-
/**
|
|
38
|
-
* This will return a new object that meets IStructureBlocks interface.
|
|
39
|
-
*/
|
|
40
|
-
getSerialisedBlocks(): IStructureBlocks;
|
|
41
|
-
/**
|
|
42
|
-
* This will return the structure form, giving you the freedom to choose your own way of saving.
|
|
43
|
-
*/
|
|
44
|
-
toStruct(): IStructure;
|
|
45
|
-
/**
|
|
46
|
-
* Buffer form of the structure.
|
|
47
|
-
*/
|
|
48
|
-
toBuffer(): Buffer<ArrayBuffer>;
|
|
49
|
-
/**
|
|
50
|
-
* The JSON stringified of the structure.
|
|
51
|
-
*/
|
|
52
|
-
toJSONString(space?: number): string;
|
|
53
|
-
/**
|
|
54
|
-
* (This is for browser client or Bun)
|
|
55
|
-
*
|
|
56
|
-
* Blob form of the structure.
|
|
57
|
-
*/
|
|
58
|
-
toBlob(): Blob;
|
|
59
|
-
/**
|
|
60
|
-
* Uint8Array form of the structure.
|
|
61
|
-
*/
|
|
62
|
-
toBytes(): Uint8Array<ArrayBuffer>;
|
|
63
|
-
/**
|
|
64
|
-
* This will return a list of packets containing all of the blocks.
|
|
65
|
-
*/
|
|
66
|
-
toPackets(x: number, y: number): import("./types").SendableBlockPacket[];
|
|
67
|
-
}
|
|
68
|
-
export interface IStructure {
|
|
69
|
-
/**
|
|
70
|
-
* Version of the structure object, not the world.
|
|
71
|
-
*/
|
|
72
|
-
version: number;
|
|
73
|
-
/**
|
|
74
|
-
* The maximum width of the structure.
|
|
75
|
-
*/
|
|
76
|
-
width: number;
|
|
77
|
-
/**
|
|
78
|
-
* The maximum height of the structure.
|
|
79
|
-
*/
|
|
80
|
-
height: number;
|
|
81
|
-
/**
|
|
82
|
-
* Object containing the mappings and the blocks.
|
|
83
|
-
*/
|
|
84
|
-
blocks: IStructureBlocks;
|
|
85
|
-
}
|
|
86
|
-
interface IStructureBlocks {
|
|
87
|
-
/**
|
|
88
|
-
* Index starts at 0, this is the mapping of blocks (in block name ids in UPPER_CASE)
|
|
89
|
-
*/
|
|
90
|
-
mapping: BlockKeys[];
|
|
91
|
-
/**
|
|
92
|
-
* Index starts at 0, this is the mapping of args (2nd elements and beyond in each block pos in blocks)
|
|
93
|
-
*/
|
|
94
|
-
args: BlockArg[];
|
|
95
|
-
/**
|
|
96
|
-
* If array, it's index corresponds to the mapping, the element will be array of locations and args indexed by layers (while impossible, it's for possible compatibility with mirrored blocks, foreground block in background layer etc)
|
|
97
|
-
*
|
|
98
|
-
* If argMapping exists in a block, it'll be an index that corresponds to the block's arguments in args array.
|
|
99
|
-
*
|
|
100
|
-
* If string, it's the encoded version of the object, use atob then JSON parse.
|
|
101
|
-
*/
|
|
102
|
-
blocks: [[x: number, y: number, ...argMapping: number[]][], [x: number, y: number, ...argMapping: number[]][]][];
|
|
103
|
-
}
|
|
104
|
-
export {};
|
package/cm/Structure.js
DELETED
|
@@ -1,208 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DeserialisedStructure = void 0;
|
|
4
|
-
const tslib_1 = require("tslib");
|
|
5
|
-
const Block_1 = tslib_1.__importDefault(require("./Block"));
|
|
6
|
-
const Util_1 = require("./Util");
|
|
7
|
-
/**
|
|
8
|
-
* This is external to the main Helper, it will allow developers to use the structure without needing to use helper if they so wish.
|
|
9
|
-
*
|
|
10
|
-
* All of the functions are static!
|
|
11
|
-
*/
|
|
12
|
-
class StructureHelper {
|
|
13
|
-
/**
|
|
14
|
-
* NOTE: If you're reading a file, you must get it then pass it to read.
|
|
15
|
-
*
|
|
16
|
-
* This is for reading the structure itself, if you have just the blocks (and width/height), you must use deserialiseStructBlocks;
|
|
17
|
-
*
|
|
18
|
-
* @param data Buffer representing the JSON structure itself.
|
|
19
|
-
*/
|
|
20
|
-
static read(data) {
|
|
21
|
-
const json = "version" in data ? data : JSON.parse(data.toString());
|
|
22
|
-
if (json.version === undefined || json.version < 1 || json.version > 1)
|
|
23
|
-
throw Error("Unknown file format");
|
|
24
|
-
const desed = this.deserialiseStructBlocks(json.blocks, json.width, json.height);
|
|
25
|
-
return new DeserialisedStructure(desed.blocks, { width: desed.width, height: desed.height });
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* If width or height are not provided, the structure may be trimmed (empty blocks).
|
|
29
|
-
*
|
|
30
|
-
* This is ideal if you want the trimmed structure in that case.
|
|
31
|
-
*/
|
|
32
|
-
static deserialiseStructBlocks(struct, width, height) {
|
|
33
|
-
var _a, _b, _c, _d;
|
|
34
|
-
var _e, _f, _g, _h;
|
|
35
|
-
const { args, blocks, mapping } = struct;
|
|
36
|
-
const deBlocks = [[], []];
|
|
37
|
-
let isMissing = width === undefined || height === undefined;
|
|
38
|
-
if (width !== undefined && height !== undefined) {
|
|
39
|
-
for (let x = 0; x < width; x++) {
|
|
40
|
-
deBlocks[0][x] = [];
|
|
41
|
-
deBlocks[1][x] = [];
|
|
42
|
-
for (let y = 0; y < height; y++) {
|
|
43
|
-
deBlocks[0][x][y] = new Block_1.default(0);
|
|
44
|
-
deBlocks[1][x][y] = new Block_1.default(0);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
let big = { x: 0, y: 0 };
|
|
49
|
-
for (let i = 0, ien = blocks.length; i < ien; i++) {
|
|
50
|
-
// While foreground and background layers are only supported for now, it's possible there are more layers in the future.
|
|
51
|
-
for (let l = 0, len = blocks[i].length; l < len; l++) {
|
|
52
|
-
for (let b = 0, ben = blocks[i][l].length; b < ben; b++) {
|
|
53
|
-
const block = blocks[i][l][b];
|
|
54
|
-
// It's a bit spammy and a lot of checks so this will only trigger if width/height are missing
|
|
55
|
-
// This is also to prevent errors, the missing elements will then be filled at the end.
|
|
56
|
-
if (isMissing) {
|
|
57
|
-
if (deBlocks[l] === undefined)
|
|
58
|
-
deBlocks[l] = [];
|
|
59
|
-
if (deBlocks[l][block[0]] === undefined)
|
|
60
|
-
deBlocks[l][block[0]] = [];
|
|
61
|
-
if (block[0] > big.x)
|
|
62
|
-
big.x = block[0];
|
|
63
|
-
if (block[1] > big.y)
|
|
64
|
-
big.y = block[1];
|
|
65
|
-
}
|
|
66
|
-
const deBlock = deBlocks[l][block[0]][block[1]] = new Block_1.default(mapping[i]);
|
|
67
|
-
for (let a = 2, alen = block.length; a < alen; a++) {
|
|
68
|
-
let arg = args[block[a]];
|
|
69
|
-
if (typeof arg === "string" && arg.startsWith("\x00"))
|
|
70
|
-
arg = Buffer.from(arg.slice(1));
|
|
71
|
-
deBlock.args[a - 2] = arg;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
if (width === undefined || height === undefined) {
|
|
77
|
-
for (let x = 0; x < big.x; x++) {
|
|
78
|
-
(_a = (_e = deBlocks[0])[x]) !== null && _a !== void 0 ? _a : (_e[x] = []);
|
|
79
|
-
(_b = (_f = deBlocks[1])[x]) !== null && _b !== void 0 ? _b : (_f[x] = []);
|
|
80
|
-
for (let y = 0; y < big.y; y++) {
|
|
81
|
-
(_c = (_g = deBlocks[0][x])[y]) !== null && _c !== void 0 ? _c : (_g[y] = new Block_1.default(0));
|
|
82
|
-
(_d = (_h = deBlocks[1][x])[y]) !== null && _d !== void 0 ? _d : (_h[y] = new Block_1.default(0));
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return {
|
|
86
|
-
blocks: deBlocks,
|
|
87
|
-
width: big.x, height: big.y
|
|
88
|
-
};
|
|
89
|
-
}
|
|
90
|
-
return {
|
|
91
|
-
blocks: deBlocks,
|
|
92
|
-
width, height
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
exports.default = StructureHelper;
|
|
97
|
-
/**
|
|
98
|
-
* Represents the structure in its deserialised form, allows for modification
|
|
99
|
-
*/
|
|
100
|
-
class DeserialisedStructure {
|
|
101
|
-
constructor(blocks, struct) {
|
|
102
|
-
this.blocks = blocks;
|
|
103
|
-
this.width = struct.width;
|
|
104
|
-
this.height = struct.height;
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* This will return a new object that meets IStructureBlocks interface.
|
|
108
|
-
*/
|
|
109
|
-
getSerialisedBlocks() {
|
|
110
|
-
const blocks = [];
|
|
111
|
-
const args = [];
|
|
112
|
-
const mapping = [];
|
|
113
|
-
// corresponds to the index in mapping array.
|
|
114
|
-
const mappingDone = {};
|
|
115
|
-
const argDone = new Map();
|
|
116
|
-
for (let l = 0; l < this.blocks.length; l++) {
|
|
117
|
-
for (let x = 0; x < this.width; x++) {
|
|
118
|
-
for (let y = 0; y < this.height; y++) {
|
|
119
|
-
const block = this.blocks[l][x][y];
|
|
120
|
-
const blockName = block.name;
|
|
121
|
-
if (block.bId === 0)
|
|
122
|
-
continue;
|
|
123
|
-
if (mappingDone[block.bId] === undefined) {
|
|
124
|
-
mappingDone[block.bId] = mapping.push(blockName) - 1;
|
|
125
|
-
blocks[mappingDone[block.bId]] = [[], []];
|
|
126
|
-
}
|
|
127
|
-
const index = mappingDone[block.bId];
|
|
128
|
-
if (blocks[index][l] === undefined)
|
|
129
|
-
blocks[index][l] = [];
|
|
130
|
-
const toPut = [x, y];
|
|
131
|
-
if (block.bId === 50)
|
|
132
|
-
console.log(block.args);
|
|
133
|
-
for (let a = 0, argsLen = block.args.length; a < argsLen; a++) {
|
|
134
|
-
const arg = Buffer.isBuffer(block.args[a]) ? "\x00" + block.args[a].toString() : block.args[a];
|
|
135
|
-
let argIndex = argDone.get(arg);
|
|
136
|
-
if (argIndex === undefined) {
|
|
137
|
-
argDone.set(arg, args.push(arg) - 1);
|
|
138
|
-
argIndex = argDone.get(arg);
|
|
139
|
-
}
|
|
140
|
-
if (argIndex === undefined)
|
|
141
|
-
throw Error("This should be impossible at this point.");
|
|
142
|
-
toPut[2 + a] = argIndex;
|
|
143
|
-
}
|
|
144
|
-
blocks[index][l].push(toPut);
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
return {
|
|
149
|
-
mapping,
|
|
150
|
-
args,
|
|
151
|
-
blocks
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
/**
|
|
155
|
-
* This will return the structure form, giving you the freedom to choose your own way of saving.
|
|
156
|
-
*/
|
|
157
|
-
toStruct() {
|
|
158
|
-
const struct = this.getSerialisedBlocks();
|
|
159
|
-
return {
|
|
160
|
-
width: this.width,
|
|
161
|
-
height: this.height,
|
|
162
|
-
version: 1,
|
|
163
|
-
blocks: struct
|
|
164
|
-
};
|
|
165
|
-
}
|
|
166
|
-
/**
|
|
167
|
-
* Buffer form of the structure.
|
|
168
|
-
*/
|
|
169
|
-
toBuffer() {
|
|
170
|
-
return Buffer.from(this.toJSONString());
|
|
171
|
-
}
|
|
172
|
-
/**
|
|
173
|
-
* The JSON stringified of the structure.
|
|
174
|
-
*/
|
|
175
|
-
toJSONString(space) {
|
|
176
|
-
return JSON.stringify(this.toStruct(), undefined, space);
|
|
177
|
-
}
|
|
178
|
-
/**
|
|
179
|
-
* (This is for browser client or Bun)
|
|
180
|
-
*
|
|
181
|
-
* Blob form of the structure.
|
|
182
|
-
*/
|
|
183
|
-
toBlob() {
|
|
184
|
-
return new Blob([this.toJSONString()]);
|
|
185
|
-
}
|
|
186
|
-
/**
|
|
187
|
-
* Uint8Array form of the structure.
|
|
188
|
-
*/
|
|
189
|
-
toBytes() {
|
|
190
|
-
return Uint8Array.from(this.toJSONString());
|
|
191
|
-
}
|
|
192
|
-
/**
|
|
193
|
-
* This will return a list of packets containing all of the blocks.
|
|
194
|
-
*/
|
|
195
|
-
toPackets(x, y) {
|
|
196
|
-
const blockies = [];
|
|
197
|
-
for (let l = 0; l < this.blocks.length; l++) {
|
|
198
|
-
for (let x2 = 0; x2 < this.width; x2++) {
|
|
199
|
-
for (let y2 = 0; y2 < this.height; y2++) {
|
|
200
|
-
blockies.push({ block: this.blocks[l][x2][y2], layer: l, pos: { x: x + x2, y: y + y2 } });
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
return (0, Util_1.createBlockPackets)(blockies);
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
exports.DeserialisedStructure = DeserialisedStructure;
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RydWN0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vbGliL1N0cnVjdHVyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsNERBQTRCO0FBSTVCLGlDQUE0QztBQUU1Qzs7OztHQUlHO0FBQ0gsTUFBcUIsZUFBZTtJQUNoQzs7Ozs7O09BTUc7SUFDSCxNQUFNLENBQUMsSUFBSSxDQUFDLElBQXNDO1FBQzlDLE1BQU0sSUFBSSxHQUFHLFNBQVMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQWUsQ0FBQztRQUVsRixJQUFJLElBQUksQ0FBQyxPQUFPLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQztZQUFFLE1BQU0sS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFM0csTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFakYsT0FBTyxJQUFJLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDakcsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsdUJBQXVCLENBQUMsTUFBd0IsRUFBRSxLQUFjLEVBQUUsTUFBZTs7O1FBQ3BGLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sQ0FBQztRQUV6QyxNQUFNLFFBQVEsR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQTJCLENBQUM7UUFFcEQsSUFB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
|