Compare commits
No commits in common. "aa1af7a9b8d18eb60f565fe518d5ea3a124a1179" and "9c9504363d5ab5251db99e1a9916b76ccdbdf6fb" have entirely different histories.
aa1af7a9b8
...
9c9504363d
3 changed files with 78 additions and 6 deletions
10
gulpfile.ts
10
gulpfile.ts
|
@ -140,25 +140,25 @@ export let Watch: TaskFunction = async (): Promise<void> =>
|
||||||
server: context.StaticPath(),
|
server: context.StaticPath(),
|
||||||
online: false
|
online: false
|
||||||
});
|
});
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
context.SourcePath(context.JSDirName),
|
context.SourcePath(context.JSDirName),
|
||||||
series(
|
series(
|
||||||
JavaScript,
|
JavaScript,
|
||||||
BrowserSync(syncer, "*.js")));
|
BrowserSync(syncer, "*.js")));
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
context.SourcePath(context.StyleDirName, "**", "*.css"),
|
context.SourcePath(context.StyleDirName, "**", "*.css"),
|
||||||
series(
|
series(
|
||||||
Styles,
|
Styles,
|
||||||
BrowserSync(syncer, "*.css")));
|
BrowserSync(syncer, "*.css")));
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
context.SourcePath(context.AssetDirName),
|
context.SourcePath(context.AssetDirName),
|
||||||
series(
|
series(
|
||||||
Assets,
|
Assets,
|
||||||
BrowserSync(syncer, join(context.AssetDirName, "**", "*"))));
|
BrowserSync(syncer, join(context.AssetDirName, "**", "*"))));
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
context.SourcePath("**", "*.html"),
|
context.SourcePath("**", "*.html"),
|
||||||
series(
|
series(
|
||||||
|
@ -167,4 +167,4 @@ export let Watch: TaskFunction = async (): Promise<void> =>
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
}
|
||||||
|
|
|
@ -5,4 +5,19 @@
|
||||||
*/
|
*/
|
||||||
export const State = /** @type {Board} */ (
|
export const State = /** @type {Board} */ (
|
||||||
Array(6).fill("").map(
|
Array(6).fill("").map(
|
||||||
() => (Array(7).fill(""))));
|
() => (Array(7).fill("").map(
|
||||||
|
() =>
|
||||||
|
{
|
||||||
|
let id = Math.floor(Math.random() * 3);
|
||||||
|
|
||||||
|
switch (id)
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
return "r";
|
||||||
|
case 2:
|
||||||
|
return "b";
|
||||||
|
default:
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
})))
|
||||||
|
);
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import { initializeBoard } from "./board.js";
|
import { initializeBoard } from "./board.js";
|
||||||
|
import { State } from "./State.js";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes the board.
|
* Initializes the board.
|
||||||
|
@ -9,3 +10,59 @@ function initialize()
|
||||||
}
|
}
|
||||||
|
|
||||||
initialize();
|
initialize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sleeps for the specified number of milliseconds.
|
||||||
|
*
|
||||||
|
* @param {number} ms
|
||||||
|
* The number of milliseconds to sleep.
|
||||||
|
*/
|
||||||
|
async function sleep(ms)
|
||||||
|
{
|
||||||
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
||||||
|
}
|
||||||
|
|
||||||
|
(
|
||||||
|
async () =>
|
||||||
|
{
|
||||||
|
let counter = 0;
|
||||||
|
let tick = 0;
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-constant-condition
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
await sleep(1000 * (1 / 5));
|
||||||
|
let cycle = counter % 24;
|
||||||
|
|
||||||
|
if ((cycle <= 11) || ((cycle % 2) === 0))
|
||||||
|
{
|
||||||
|
tick = (tick % 18) + 1;
|
||||||
|
let rowId = Math.floor(Math.random() * State.length);
|
||||||
|
let fieldId = Math.floor(Math.random() * State[rowId].length);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {CellOwner}
|
||||||
|
*/
|
||||||
|
let owner;
|
||||||
|
|
||||||
|
switch (Math.floor(Math.random() * 3))
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
owner = "r";
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
owner = "b";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
owner = "";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
State[rowId][fieldId] = owner;
|
||||||
|
console.log(tick);
|
||||||
|
initialize();
|
||||||
|
}
|
||||||
|
|
||||||
|
counter++;
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
Loading…
Reference in a new issue