@bitblit/ratchet-maze 5.1.121

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.
@@ -0,0 +1,5 @@
1
+ import { BuildInformation } from '@bitblit/ratchet-common/build/build-information';
2
+ export declare class RatchetInfo {
3
+ private constructor();
4
+ static buildInformation(): BuildInformation;
5
+ }
@@ -0,0 +1,16 @@
1
+ export class RatchetInfo {
2
+ constructor() {
3
+ }
4
+ static buildInformation() {
5
+ const val = {
6
+ version: 'LOCAL-SNAPSHOT',
7
+ hash: 'LOCAL-HASH',
8
+ branch: 'LOCAL-BRANCH',
9
+ tag: 'LOCAL-TAG',
10
+ timeBuiltISO: 'LOCAL-TIME-ISO',
11
+ notes: 'LOCAL-NOTES',
12
+ };
13
+ return val;
14
+ }
15
+ }
16
+ //# sourceMappingURL=ratchet-maze-info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ratchet-maze-info.js","sourceRoot":"","sources":["../../src/build/ratchet-maze-info.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,WAAW;IAGtB;IACA,CAAC;IAEM,MAAM,CAAC,gBAAgB;QAC5B,MAAM,GAAG,GAAqB;YAC5B,OAAO,EAAE,gBAAgB;YACzB,IAAI,EAAE,YAAY;YAClB,MAAM,EAAE,cAAc;YACtB,GAAG,EAAE,WAAW;YAChB,YAAY,EAAE,gBAAgB;YAC9B,KAAK,EAAE,aAAa;SACrB,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;CACF"}
@@ -0,0 +1,4 @@
1
+ import { RectangularMaze } from "./rectangular-maze.js";
2
+ export declare class BinaryGenerator {
3
+ static generate(width: number, height: number): RectangularMaze;
4
+ }
@@ -0,0 +1,29 @@
1
+ import { RectangularMaze } from "./rectangular-maze.js";
2
+ export class BinaryGenerator {
3
+ static generate(width, height) {
4
+ const rval = new RectangularMaze(width, height);
5
+ for (let y = 0; y < height; y++) {
6
+ for (let x = 0; x < width; x++) {
7
+ if (y === 0) {
8
+ if (x < width - 1) {
9
+ rval.addPassage({ x, y }, { x: x + 1, y: y });
10
+ }
11
+ }
12
+ else if (x === width - 1) {
13
+ rval.addPassage({ x, y }, { x: x, y: y - 1 });
14
+ }
15
+ else {
16
+ const flip = Math.random();
17
+ if (flip <= .5) {
18
+ rval.addPassage({ x, y }, { x: x + 1, y: y });
19
+ }
20
+ else {
21
+ rval.addPassage({ x, y }, { x: x, y: y - 1 });
22
+ }
23
+ }
24
+ }
25
+ }
26
+ return rval;
27
+ }
28
+ }
29
+ //# sourceMappingURL=binary-generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"binary-generator.js","sourceRoot":"","sources":["../../src/model/binary-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAKxD,MAAM,OAAO,eAAe;IAEnB,MAAM,CAAC,QAAQ,CAAC,KAAa,EAAE,MAAc;QAClD,MAAM,IAAI,GAAoB,IAAI,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/B,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;oBACZ,IAAI,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,CAAC;wBAClB,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;oBAChD,CAAC;gBACH,CAAC;qBAAM,IAAI,CAAC,KAAK,KAAK,GAAG,CAAC,EAAE,CAAC;oBAC3B,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChD,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,GAAW,IAAI,CAAC,MAAM,EAAE,CAAC;oBACnC,IAAI,IAAI,IAAI,EAAE,EAAE,CAAC;wBACf,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;oBAChD,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBAChD,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,4 @@
1
+ export interface Coordinate {
2
+ x: number;
3
+ y: number;
4
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=coordinate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"coordinate.js","sourceRoot":"","sources":["../../src/model/coordinate.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ export declare enum Direction {
2
+ North = "North",
3
+ South = "South",
4
+ East = "East",
5
+ West = "West"
6
+ }
@@ -0,0 +1,8 @@
1
+ export var Direction;
2
+ (function (Direction) {
3
+ Direction["North"] = "North";
4
+ Direction["South"] = "South";
5
+ Direction["East"] = "East";
6
+ Direction["West"] = "West";
7
+ })(Direction || (Direction = {}));
8
+ //# sourceMappingURL=direction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"direction.js","sourceRoot":"","sources":["../../src/model/direction.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,SAEX;AAFD,WAAY,SAAS;IACnB,4BAAa,CAAA;IAAC,4BAAa,CAAA;IAAC,0BAAW,CAAA;IAAC,0BAAW,CAAA;AACrD,CAAC,EAFW,SAAS,KAAT,SAAS,QAEpB"}
@@ -0,0 +1,12 @@
1
+ import { RectangularMaze } from "./rectangular-maze.js";
2
+ export declare class DrawingUtil {
3
+ static formatBitmapToString(bmap: string[][], lineEnd?: string): string;
4
+ static rectangularMazeToBitmap(maze: RectangularMaze): string[][];
5
+ static rectangularMazeToSvg(maze: RectangularMaze, opts?: RectangularMazeDrawOptions): string;
6
+ }
7
+ export interface RectangularMazeDrawOptions {
8
+ backgroundColor: string;
9
+ wallColor: string;
10
+ disabledColor: string;
11
+ cellSize: number;
12
+ }
@@ -0,0 +1,66 @@
1
+ import { RequireRatchet } from "@bitblit/ratchet-common/lang/require-ratchet";
2
+ import { Direction } from "./direction.js";
3
+ import { StringRatchet } from "@bitblit/ratchet-common/lang/string-ratchet";
4
+ export class DrawingUtil {
5
+ static formatBitmapToString(bmap, lineEnd = '\n') {
6
+ const rval = bmap.map(s => s.join(' ')).join(lineEnd);
7
+ return rval;
8
+ }
9
+ static rectangularMazeToBitmap(maze) {
10
+ RequireRatchet.notNullOrUndefined(maze);
11
+ RequireRatchet.true(maze.width > 0);
12
+ RequireRatchet.true(maze.height > 0);
13
+ const rval = [];
14
+ for (let y = 0; y < maze.height; y++) {
15
+ const curRow = [];
16
+ for (let x = 0; x < maze.width; x++) {
17
+ if (maze.isDisabled({ x: x, y: y })) {
18
+ curRow.push('X');
19
+ }
20
+ else {
21
+ let num = 0;
22
+ num += maze.hasWall({ x, y }, Direction.North) ? 1 : 0;
23
+ num += maze.hasWall({ x, y }, Direction.East) ? 2 : 0;
24
+ num += maze.hasWall({ x, y }, Direction.South) ? 4 : 0;
25
+ num += maze.hasWall({ x, y }, Direction.West) ? 8 : 0;
26
+ curRow.push(StringRatchet.HEXITS[num]);
27
+ }
28
+ }
29
+ rval.push(curRow);
30
+ }
31
+ return rval;
32
+ }
33
+ static rectangularMazeToSvg(maze, opts) {
34
+ RequireRatchet.notNullOrUndefined(maze);
35
+ RequireRatchet.true(maze.width > 0);
36
+ RequireRatchet.true(maze.height > 0);
37
+ const widthPx = maze.width * opts.cellSize;
38
+ const heightPx = maze.height * opts.cellSize;
39
+ let rval = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${widthPx} ${heightPx}"><g> \n`;
40
+ for (let y = 0; y < maze.height; y++) {
41
+ for (let x = 0; x < maze.width; x++) {
42
+ const uX = x * opts.cellSize;
43
+ const uY = y * opts.cellSize;
44
+ if (maze.isDisabled({ x: x, y: y })) {
45
+ }
46
+ else {
47
+ if (maze.hasWall({ x, y }, Direction.North)) {
48
+ rval += `<polyline stroke="#000080" stroke-width="1" fill="none" points="${uX},${uY} ${uX + opts.cellSize} ${uY}" />\n`;
49
+ }
50
+ if (maze.hasWall({ x, y }, Direction.East)) {
51
+ rval += `<polyline stroke="#000080" stroke-width="1" fill="none" points="${uX + opts.cellSize},${uY} ${uX + opts.cellSize} ${uY + opts.cellSize}" />\n`;
52
+ }
53
+ if (maze.hasWall({ x, y }, Direction.South)) {
54
+ rval += `<polyline stroke="#000080" stroke-width="1" fill="none" points="${uX},${uY + opts.cellSize} ${uX + opts.cellSize} ${uY + opts.cellSize}" />\n`;
55
+ }
56
+ if (maze.hasWall({ x, y }, Direction.West)) {
57
+ rval += `<polyline stroke="#000080" stroke-width="1" fill="none" points="${uX},${uY + opts.cellSize} ${uX} ${uY}" />\n`;
58
+ }
59
+ }
60
+ }
61
+ }
62
+ rval += '</g></svg>';
63
+ return rval;
64
+ }
65
+ }
66
+ //# sourceMappingURL=drawing-util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drawing-util.js","sourceRoot":"","sources":["../../src/model/drawing-util.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import { Coordinate } from "./coordinate.js";
2
+ import { Direction } from "./direction.js";
3
+ export declare class RectangularMaze {
4
+ private _width;
5
+ private _height;
6
+ private disabledIdx;
7
+ private passages;
8
+ constructor(_width: number, _height: number);
9
+ isDisabled(idx: number | Coordinate): boolean;
10
+ neighborCoordinate(idx: number | Coordinate, direction: Direction): Coordinate;
11
+ neighborIdx(idx: number, direction: Direction): number;
12
+ hasWall(idx: number | Coordinate, direction: Direction): boolean;
13
+ get width(): number;
14
+ get height(): number;
15
+ coordinateToIndex(coord: Coordinate): number;
16
+ indexToCoordinate(idx: number): Coordinate;
17
+ get maxIdx(): number;
18
+ validIdx(idx: number): boolean;
19
+ get allIdxWithPassages(): Set<number>;
20
+ disable(idx: number): void;
21
+ hasPassage(idx1: number, idx2: number): boolean;
22
+ addPassage(idxC1: number | Coordinate, idxC2: number | Coordinate): void;
23
+ removePassage(idx1: number, idx2: number): void;
24
+ }
@@ -0,0 +1,118 @@
1
+ import { RequireRatchet } from "@bitblit/ratchet-common/lang/require-ratchet";
2
+ import { Direction } from "./direction.js";
3
+ export class RectangularMaze {
4
+ _width;
5
+ _height;
6
+ disabledIdx = new Set();
7
+ passages = new Map();
8
+ constructor(_width, _height) {
9
+ this._width = _width;
10
+ this._height = _height;
11
+ }
12
+ isDisabled(idx) {
13
+ if (typeof idx === 'number') {
14
+ return this.disabledIdx.has(idx);
15
+ }
16
+ else {
17
+ return this.disabledIdx.has(this.coordinateToIndex(idx));
18
+ }
19
+ }
20
+ neighborCoordinate(idx, direction) {
21
+ let rval = structuredClone((typeof idx === 'number') ? this.indexToCoordinate(idx) : idx);
22
+ switch (direction) {
23
+ case Direction.North:
24
+ rval.y--;
25
+ break;
26
+ case Direction.South:
27
+ rval.y++;
28
+ break;
29
+ case Direction.East:
30
+ rval.x++;
31
+ break;
32
+ case Direction.West:
33
+ rval.x--;
34
+ break;
35
+ default: throw new Error('Cannot happen - invalid direction');
36
+ }
37
+ if (rval.x < 0 || rval.y < 0 || rval.x >= this.width || rval.y >= this.height) {
38
+ rval = null;
39
+ }
40
+ return rval;
41
+ }
42
+ neighborIdx(idx, direction) {
43
+ const n = this.neighborCoordinate(idx, direction);
44
+ return n === null ? null : this.coordinateToIndex(n);
45
+ }
46
+ hasWall(idx, direction) {
47
+ const idx1 = (typeof (idx) === 'number') ? idx : this.coordinateToIndex(idx);
48
+ const idx2 = this.neighborIdx(idx1, direction);
49
+ return !this.hasPassage(idx1, idx2);
50
+ }
51
+ get width() {
52
+ return this._width;
53
+ }
54
+ get height() {
55
+ return this._height;
56
+ }
57
+ coordinateToIndex(coord) {
58
+ RequireRatchet.true(coord.x < this.width);
59
+ RequireRatchet.true(coord.y < this.height);
60
+ return (coord.y * this.width) + coord.x;
61
+ }
62
+ indexToCoordinate(idx) {
63
+ const row = Math.floor(idx / this.width);
64
+ const rval = {
65
+ x: idx - (row * this.width),
66
+ y: row
67
+ };
68
+ return rval;
69
+ }
70
+ get maxIdx() {
71
+ return this.coordinateToIndex({ x: this.width - 1, y: this.height - 1 });
72
+ }
73
+ validIdx(idx) {
74
+ const crd = this.indexToCoordinate(idx);
75
+ return crd.x < this.width && crd.y < this.height;
76
+ }
77
+ get allIdxWithPassages() {
78
+ const rval = new Set();
79
+ Array.from(this.passages.values()).forEach(vals => {
80
+ Array.from(vals).forEach(s => rval.add(s));
81
+ });
82
+ return rval;
83
+ }
84
+ disable(idx) {
85
+ RequireRatchet.true(this.validIdx(idx));
86
+ RequireRatchet.true(!this.passages.has(idx));
87
+ RequireRatchet.true(!this.allIdxWithPassages.has(idx));
88
+ this.disabledIdx.add(idx);
89
+ }
90
+ hasPassage(idx1, idx2) {
91
+ let rval = false;
92
+ if (idx1 !== null && idx2 !== null) {
93
+ const vals = this.passages.get(Math.min(idx1, idx2));
94
+ rval = vals && vals.has(Math.max(idx1, idx2));
95
+ }
96
+ return rval;
97
+ }
98
+ addPassage(idxC1, idxC2) {
99
+ RequireRatchet.notNullOrUndefined(idxC1);
100
+ RequireRatchet.notNullOrUndefined(idxC2);
101
+ const idx1 = (typeof idxC1 === 'number') ? idxC1 : this.coordinateToIndex(idxC1);
102
+ const idx2 = (typeof idxC2 === 'number') ? idxC2 : this.coordinateToIndex(idxC2);
103
+ RequireRatchet.true(this.validIdx(idx1));
104
+ RequireRatchet.true(this.validIdx(idx2));
105
+ RequireRatchet.true(!this.disabledIdx.has(idx1));
106
+ RequireRatchet.true(!this.disabledIdx.has(idx2));
107
+ const cur = this.passages.get(Math.min(idx1, idx2)) ?? new Set;
108
+ cur.add(Math.max(idx1, idx2));
109
+ this.passages.set(Math.min(idx1, idx2), cur);
110
+ }
111
+ removePassage(idx1, idx2) {
112
+ RequireRatchet.true(this.validIdx(idx1));
113
+ RequireRatchet.true(this.validIdx(idx2));
114
+ const cur = this.passages.get(Math.min(idx1, idx2)) ?? new Set;
115
+ cur.delete(Math.max(idx1, idx2));
116
+ }
117
+ }
118
+ //# sourceMappingURL=rectangular-maze.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rectangular-maze.js","sourceRoot":"","sources":["../../src/model/rectangular-maze.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,48 @@
1
+ {
2
+ "name": "@bitblit/ratchet-maze",
3
+ "version": "5.1.121",
4
+ "description": "My silly tools for mazes",
5
+ "type": "module",
6
+ "files": [
7
+ "lib/**",
8
+ "bin/**"
9
+ ],
10
+ "exports": {
11
+ "./package.json": "./package.json",
12
+ "./*": {
13
+ "types": "./lib/*.d.ts",
14
+ "import": "./lib/*.js"
15
+ }
16
+ },
17
+ "contributors": [
18
+ "Christopher Weiss <bitblit@gmail.com>"
19
+ ],
20
+ "husky": {
21
+ "hooks": {
22
+ "pre-commit": "pretty-quick --staged"
23
+ }
24
+ },
25
+ "config": {},
26
+ "repository": {
27
+ "type": "git",
28
+ "url": "git+https://github.com/bitblit/Ratchet.git"
29
+ },
30
+ "scripts": {
31
+ "t": "yarn mod:test"
32
+ },
33
+ "keywords": [
34
+ "wrench",
35
+ "utility"
36
+ ],
37
+ "bugs": {
38
+ "url": "https://github.com/bitblit/Ratchet/issues"
39
+ },
40
+ "homepage": "https://github.com/bitblit/Ratchet#readme",
41
+ "engines": {
42
+ "node": ">=14.18"
43
+ },
44
+ "license": "Apache-2.0",
45
+ "dependencies": {
46
+ "@bitblit/ratchet-common": "5.1.121"
47
+ }
48
+ }