mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-10 10:12:45 +00:00
[MIRROR] dependency cleanup and loader removal (#10995)
Co-authored-by: Kashargul <144968721+Kashargul@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
a2e386e843
commit
c3b71b3d12
@@ -6,21 +6,21 @@
|
||||
* https://github.com/stylemistake/juke-build
|
||||
*/
|
||||
|
||||
import fs from 'fs';
|
||||
import https from 'https';
|
||||
import { env } from 'process';
|
||||
import Juke from './juke/index.js';
|
||||
import { DreamDaemon, DreamMaker, NamedVersionFile } from './lib/byond.js';
|
||||
import { yarn } from './lib/yarn.js';
|
||||
import fs from "fs";
|
||||
import https from "https";
|
||||
import { env } from "process";
|
||||
import Juke from "./juke/index.js";
|
||||
import { DreamDaemon, DreamMaker, NamedVersionFile } from "./lib/byond.js";
|
||||
import { yarn } from "./lib/yarn.js";
|
||||
|
||||
const TGS_MODE = process.env.CBT_BUILD_MODE === 'TGS';
|
||||
const TGS_MODE = process.env.CBT_BUILD_MODE === "TGS";
|
||||
|
||||
Juke.chdir('../..', import.meta.url);
|
||||
Juke.chdir("../..", import.meta.url);
|
||||
Juke.setup({ file: import.meta.url }).then((code) => {
|
||||
// We're using the currently available quirk in Juke Build, which
|
||||
// prevents it from exiting on Windows, to wait on errors.
|
||||
if (code !== 0 && process.argv.includes('--wait-on-error')) {
|
||||
Juke.logger.error('Please inspect the error and close the window.');
|
||||
if (code !== 0 && process.argv.includes("--wait-on-error")) {
|
||||
Juke.logger.error("Please inspect the error and close the window.");
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -28,66 +28,70 @@ Juke.setup({ file: import.meta.url }).then((code) => {
|
||||
// workaround for ESBuild process lingering
|
||||
// Once https://github.com/privatenumber/esbuild-loader/pull/354 is merged and updated to, this can be removed
|
||||
setTimeout(() => process.exit(code), 10000);
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
process.exit(code);
|
||||
}
|
||||
});
|
||||
|
||||
const DME_NAME = 'vorestation';
|
||||
const CUTTER_SUFFIX = '.png.toml'
|
||||
const DME_NAME = "vorestation";
|
||||
|
||||
// Stores the contents of dependencies.sh as a key value pair
|
||||
// Best way I could figure to get ahold of this stuff
|
||||
const dependencies = fs.readFileSync('dependencies.sh', 'utf8')
|
||||
const dependencies = fs
|
||||
.readFileSync("dependencies.sh", "utf8")
|
||||
.split("\n")
|
||||
.map((statement) => statement.replace("export", "").trim())
|
||||
.filter((value) => !(value == "" || value.startsWith("#")))
|
||||
.map((statement) => statement.split("="))
|
||||
.reduce((acc, kv_pair) => {
|
||||
acc[kv_pair[0]] = kv_pair[1];
|
||||
return acc
|
||||
}, {})
|
||||
return acc;
|
||||
}, {});
|
||||
|
||||
// Canonical path for the cutter exe at this moment
|
||||
const getCutterPath = () => {
|
||||
const ver = dependencies.CUTTER_VERSION;
|
||||
const suffix = process.platform === 'win32' ? '.exe' : '';
|
||||
const file_ver = ver.split('.').join('-');
|
||||
const suffix = process.platform === "win32" ? ".exe" : "";
|
||||
const file_ver = ver.split(".").join("-");
|
||||
return `tools/icon_cutter/cache/hypnagogic${file_ver}${suffix}`;
|
||||
};
|
||||
|
||||
const cutter_path = getCutterPath();
|
||||
|
||||
export const DefineParameter = new Juke.Parameter({
|
||||
type: 'string[]',
|
||||
alias: 'D',
|
||||
type: "string[]",
|
||||
alias: "D",
|
||||
});
|
||||
|
||||
export const PortParameter = new Juke.Parameter({
|
||||
type: 'string',
|
||||
alias: 'p',
|
||||
type: "string",
|
||||
alias: "p",
|
||||
});
|
||||
|
||||
export const DmVersionParameter = new Juke.Parameter({
|
||||
type: 'string',
|
||||
type: "string",
|
||||
});
|
||||
|
||||
export const CiParameter = new Juke.Parameter({ type: 'boolean' });
|
||||
export const CiParameter = new Juke.Parameter({ type: "boolean" });
|
||||
|
||||
export const ForceRecutParameter = new Juke.Parameter({
|
||||
type: 'boolean',
|
||||
type: "boolean",
|
||||
name: "force-recut",
|
||||
});
|
||||
|
||||
export const SkipIconCutter = new Juke.Parameter({
|
||||
type: "boolean",
|
||||
name: "skip-icon-cutter",
|
||||
});
|
||||
|
||||
export const WarningParameter = new Juke.Parameter({
|
||||
type: 'string[]',
|
||||
alias: 'W',
|
||||
type: "string[]",
|
||||
alias: "W",
|
||||
});
|
||||
|
||||
export const NoWarningParameter = new Juke.Parameter({
|
||||
type: 'string[]',
|
||||
alias: 'NW',
|
||||
type: "string[]",
|
||||
alias: "I",
|
||||
});
|
||||
|
||||
export const CutterTarget = new Juke.Target({
|
||||
@@ -98,14 +102,11 @@ export const CutterTarget = new Juke.Target({
|
||||
executes: async () => {
|
||||
const repo = dependencies.CUTTER_REPO;
|
||||
const ver = dependencies.CUTTER_VERSION;
|
||||
const suffix = process.platform === 'win32' ? '.exe' : '';
|
||||
const download_from = `https://github.com/${repo}/releases/download/${ver}/hypnagogic${suffix}`
|
||||
const suffix = process.platform === "win32" ? ".exe" : "";
|
||||
const download_from = `https://github.com/${repo}/releases/download/${ver}/hypnagogic${suffix}`;
|
||||
await download_file(download_from, cutter_path);
|
||||
if(process.platform !== 'win32') {
|
||||
await Juke.exec("chmod", [
|
||||
'+x',
|
||||
cutter_path,
|
||||
]);
|
||||
if (process.platform !== "win32") {
|
||||
await Juke.exec("chmod", ["+x", cutter_path]);
|
||||
}
|
||||
},
|
||||
});
|
||||
@@ -113,63 +114,77 @@ export const CutterTarget = new Juke.Target({
|
||||
async function download_file(url, file) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let file_stream = fs.createWriteStream(file);
|
||||
https.get(url, function(response) {
|
||||
if (response.statusCode === 302) {
|
||||
file_stream.close();
|
||||
download_file(response.headers.location, file)
|
||||
.then((value) => resolve());
|
||||
return;
|
||||
}
|
||||
if (response.statusCode !== 200) {
|
||||
Juke.logger.error(`Failed to download ${url}: Status ${response.statusCode}`);
|
||||
file_stream.close();
|
||||
reject()
|
||||
return
|
||||
}
|
||||
response.pipe(file_stream);
|
||||
https
|
||||
.get(url, function (response) {
|
||||
if (response.statusCode === 302) {
|
||||
file_stream.close();
|
||||
download_file(response.headers.location, file).then((value) =>
|
||||
resolve(),
|
||||
);
|
||||
return;
|
||||
}
|
||||
if (response.statusCode !== 200) {
|
||||
Juke.logger.error(
|
||||
`Failed to download ${url}: Status ${response.statusCode}`,
|
||||
);
|
||||
file_stream.close();
|
||||
reject();
|
||||
return;
|
||||
}
|
||||
response.pipe(file_stream);
|
||||
|
||||
// after download completed close filestream
|
||||
file_stream.on("finish", () => {
|
||||
// after download completed close filestream
|
||||
file_stream.on("finish", () => {
|
||||
file_stream.close();
|
||||
resolve();
|
||||
});
|
||||
})
|
||||
.on("error", (err) => {
|
||||
file_stream.close();
|
||||
resolve()
|
||||
Juke.rm(download_into);
|
||||
Juke.logger.error(`Failed to download ${url}: ${err.message}`);
|
||||
reject();
|
||||
});
|
||||
|
||||
}).on("error", (err) => {
|
||||
file_stream.close();
|
||||
Juke.rm(download_into);
|
||||
Juke.logger.error(`Failed to download ${url}: ${err.message}`);
|
||||
reject()
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
export const IconCutterTarget = new Juke.Target({
|
||||
parameters: [ForceRecutParameter],
|
||||
dependsOn: () => [
|
||||
CutterTarget,
|
||||
],
|
||||
inputs: [
|
||||
'icons/**/*.png',
|
||||
`icons/**/*${CUTTER_SUFFIX}`,
|
||||
`cutter_templates/**/*${CUTTER_SUFFIX}`,
|
||||
`tgui/public/tgui.html`,
|
||||
cutter_path,
|
||||
],
|
||||
dependsOn: () => [CutterTarget],
|
||||
inputs: ({ get }) => {
|
||||
const standard_inputs = [
|
||||
`icons/**/*.png.toml`,
|
||||
`icons/**/*.dmi.toml`,
|
||||
`cutter_templates/**/*.toml`,
|
||||
"tgui/public/tgui.html",
|
||||
cutter_path,
|
||||
];
|
||||
// Alright we're gonna search out any existing toml files and convert
|
||||
// them to their matching .dmi or .png file
|
||||
const existing_configs = [
|
||||
...Juke.glob(`icons/**/*.png.toml`),
|
||||
...Juke.glob(`icons/**/*.dmi.toml`),
|
||||
];
|
||||
return [
|
||||
...standard_inputs,
|
||||
...existing_configs.map((file) => file.replace(".toml", "")),
|
||||
];
|
||||
},
|
||||
outputs: ({ get }) => {
|
||||
if(get(ForceRecutParameter))
|
||||
return [];
|
||||
if (get(ForceRecutParameter)) return [];
|
||||
const folders = [
|
||||
...Juke.glob(`icons/**/*${CUTTER_SUFFIX}`, `modular_chomp/icons/**/*${CUTTER_SUFFIX}`),
|
||||
...Juke.glob(`icons/**/*.png.toml`, `modular_chomp/icons/**/*.png.toml`),
|
||||
];
|
||||
return folders
|
||||
.map((file) => file.replace(`${CUTTER_SUFFIX}`, '.dmi'));
|
||||
.map((file) => file.replace(`.png.toml`, ".dmi"))
|
||||
.map((file) => file.replace(`.dmi.toml`, ".png"));
|
||||
},
|
||||
executes: async () => {
|
||||
await Juke.exec(cutter_path, [
|
||||
'--dont-wait',
|
||||
'--templates',
|
||||
'cutter_templates',
|
||||
'icons',
|
||||
"--dont-wait",
|
||||
"--templates",
|
||||
"cutter_templates",
|
||||
"icons",
|
||||
]);
|
||||
},
|
||||
});
|
||||
@@ -177,47 +192,53 @@ export const IconCutterTarget = new Juke.Target({
|
||||
export const DmMapsIncludeTarget = new Juke.Target({
|
||||
executes: async () => {
|
||||
const folders = [
|
||||
//...Juke.glob('_maps/map_files/**/modular_pieces/*.dmm'),
|
||||
//...Juke.glob('_maps/RandomRuins/**/*.dmm'),
|
||||
//...Juke.glob('_maps/RandomZLevels/**/*.dmm'),
|
||||
//...Juke.glob('_maps/shuttles/**/*.dmm'),
|
||||
//...Juke.glob('_maps/templates/**/*.dmm'),
|
||||
...Juke.glob('modular_chomp/maps/soluna_nexus/**/*.dmm'),
|
||||
...Juke.glob('modular_chomp/maps/southern_cross/**/*.dmm'),
|
||||
...Juke.glob('modular_chomp/maps/relic_base/**/*.dmm'),
|
||||
...Juke.glob('modular_chomp/maps/submap/**/*.dmm'),
|
||||
//...Juke.glob("_maps/map_files/**/modular_pieces/*.dmm"),
|
||||
//...Juke.glob("_maps/RandomRuins/**/*.dmm"),
|
||||
//...Juke.glob("_maps/RandomZLevels/**/*.dmm"),
|
||||
//...Juke.glob("_maps/shuttles/**/*.dmm"),
|
||||
//...Juke.glob("_maps/templates/**/*.dmm"),
|
||||
...Juke.glob("modular_chomp/maps/soluna_nexus/**/*.dmm"),
|
||||
...Juke.glob("modular_chomp/maps/southern_cross/**/*.dmm"),
|
||||
...Juke.glob("modular_chomp/maps/relic_base/**/*.dmm"),
|
||||
...Juke.glob("modular_chomp/maps/submap/**/*.dmm"),
|
||||
];
|
||||
const content = folders
|
||||
.map((file) => file.replace('_maps/', ''))
|
||||
.map((file) => `#include "${file}"`)
|
||||
.join('\n') + '\n';
|
||||
fs.writeFileSync('_maps/templates.dm', content);
|
||||
const content =
|
||||
folders
|
||||
.map((file) => file.replace("_maps/", ""))
|
||||
.map((file) => `#include "${file}"`)
|
||||
.join("\n") + "\n";
|
||||
fs.writeFileSync("_maps/templates.dm", content);
|
||||
},
|
||||
});
|
||||
|
||||
export const DmTarget = new Juke.Target({
|
||||
parameters: [DefineParameter, DmVersionParameter, WarningParameter, NoWarningParameter],
|
||||
parameters: [
|
||||
DefineParameter,
|
||||
DmVersionParameter,
|
||||
WarningParameter,
|
||||
NoWarningParameter,
|
||||
SkipIconCutter,
|
||||
],
|
||||
dependsOn: ({ get }) => [
|
||||
get(DefineParameter).includes('ALL_MAPS') && DmMapsIncludeTarget,
|
||||
IconCutterTarget,
|
||||
get(DefineParameter).includes("ALL_MAPS") && DmMapsIncludeTarget,
|
||||
!get(SkipIconCutter) && IconCutterTarget,
|
||||
],
|
||||
inputs: [
|
||||
'_maps/map_files/generic/**',
|
||||
'maps/**/*.dm',
|
||||
'code/**',
|
||||
'html/**',
|
||||
'icons/**',
|
||||
'interface/**',
|
||||
'sound/**',
|
||||
'tgui/public/tgui.html',
|
||||
'modular_chomp/code/**',
|
||||
'modular_chomp/icons/**',
|
||||
'sound/**',
|
||||
'modular_chomp/maps/**/*.dm',
|
||||
'modular_chomp/maps/soluna_nexus/**/*.dmm', // Placed here so it recompiles on map changes
|
||||
'modular_chomp/maps/southern_cross/**/*.dmm', // Placed here so it recompiles on map changes
|
||||
'modular_chomp/maps/relic_base/**/*.dmm', // Placed here so it recompiles on map changes
|
||||
'modular_chomp/maps/submap/**/*.dmm', // Placed here so it recompiles on map changes
|
||||
"_maps/map_files/generic/**",
|
||||
"maps/**/*.dm",
|
||||
"code/**",
|
||||
"html/**",
|
||||
"icons/**",
|
||||
"interface/**",
|
||||
"sound/**",
|
||||
"tgui/public/tgui.html",
|
||||
"modular_chomp/code/**",
|
||||
"modular_chomp/icons/**",
|
||||
"modular_chomp/maps/**/*.dm",
|
||||
"modular_chomp/maps/soluna_nexus/**/*.dmm", // Placed here so it recompiles on map changes
|
||||
"modular_chomp/maps/southern_cross/**/*.dmm", // Placed here so it recompiles on map changes
|
||||
"modular_chomp/maps/relic_base/**/*.dmm", // Placed here so it recompiles on map changes
|
||||
"modular_chomp/maps/submap/**/*.dmm", // Placed here so it recompiles on map changes
|
||||
`${DME_NAME}.dme`,
|
||||
NamedVersionFile,
|
||||
],
|
||||
@@ -225,15 +246,12 @@ export const DmTarget = new Juke.Target({
|
||||
if (get(DmVersionParameter)) {
|
||||
return []; // Always rebuild when dm version is provided
|
||||
}
|
||||
return [
|
||||
`${DME_NAME}.dmb`,
|
||||
`${DME_NAME}.rsc`,
|
||||
]
|
||||
return [`${DME_NAME}.dmb`, `${DME_NAME}.rsc`];
|
||||
},
|
||||
executes: async ({ get }) => {
|
||||
await DreamMaker(`${DME_NAME}.dme`, {
|
||||
defines: ['CBT', ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes('error'),
|
||||
defines: ["CBT", ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes("error"),
|
||||
ignoreWarningCodes: get(NoWarningParameter),
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
});
|
||||
@@ -241,36 +259,43 @@ export const DmTarget = new Juke.Target({
|
||||
});
|
||||
|
||||
export const DmTestTarget = new Juke.Target({
|
||||
parameters: [DefineParameter, DmVersionParameter, WarningParameter, NoWarningParameter],
|
||||
parameters: [
|
||||
DefineParameter,
|
||||
DmVersionParameter,
|
||||
WarningParameter,
|
||||
NoWarningParameter,
|
||||
],
|
||||
dependsOn: ({ get }) => [
|
||||
get(DefineParameter).includes('ALL_MAPS') && DmMapsIncludeTarget,
|
||||
get(DefineParameter).includes("ALL_MAPS") && DmMapsIncludeTarget,
|
||||
IconCutterTarget,
|
||||
],
|
||||
executes: async ({ get }) => {
|
||||
fs.copyFileSync(`${DME_NAME}.dme`, `${DME_NAME}.test.dme`);
|
||||
await DreamMaker(`${DME_NAME}.test.dme`, {
|
||||
defines: ['CBT', 'CIBUILDING', ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes('error'),
|
||||
defines: ["CBT", "CIBUILDING", ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes("error"),
|
||||
ignoreWarningCodes: get(NoWarningParameter),
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
});
|
||||
Juke.rm('data/logs/ci', { recursive: true });
|
||||
Juke.rm("data/logs/ci", { recursive: true });
|
||||
const options = {
|
||||
dmbFile : `${DME_NAME}.test.dmb`,
|
||||
dmbFile: `${DME_NAME}.test.dmb`,
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
}
|
||||
};
|
||||
await DreamDaemon(
|
||||
options,
|
||||
'-close', '-trusted', '-verbose', '-invisible',
|
||||
'-params', 'log-directory=ci'
|
||||
"-close",
|
||||
"-trusted",
|
||||
"-verbose",
|
||||
"-params",
|
||||
"log-directory=ci",
|
||||
);
|
||||
Juke.rm('*.test.*');
|
||||
Juke.rm("*.test.*");
|
||||
try {
|
||||
const cleanRun = fs.readFileSync('data/logs/ci/clean_run.lk', 'utf-8');
|
||||
const cleanRun = fs.readFileSync("data/logs/ci/clean_run.lk", "utf-8");
|
||||
console.log(cleanRun);
|
||||
}
|
||||
catch (err) {
|
||||
Juke.logger.error('Test run was not clean, exiting');
|
||||
} catch (err) {
|
||||
Juke.logger.error("Test run was not clean, exiting");
|
||||
throw new Juke.ExitCode(1);
|
||||
}
|
||||
},
|
||||
@@ -278,38 +303,44 @@ export const DmTestTarget = new Juke.Target({
|
||||
|
||||
/* We don't have Autowiki
|
||||
export const AutowikiTarget = new Juke.Target({
|
||||
parameters: [DefineParameter, DmVersionParameter, WarningParameter, NoWarningParameter],
|
||||
parameters: [
|
||||
DefineParameter,
|
||||
DmVersionParameter,
|
||||
WarningParameter,
|
||||
NoWarningParameter,
|
||||
],
|
||||
dependsOn: ({ get }) => [
|
||||
get(DefineParameter).includes('ALL_MAPS') && DmMapsIncludeTarget,
|
||||
get(DefineParameter).includes("ALL_MAPS") && DmMapsIncludeTarget,
|
||||
IconCutterTarget,
|
||||
],
|
||||
outputs: [
|
||||
'data/autowiki_edits.txt',
|
||||
],
|
||||
outputs: ["data/autowiki_edits.txt"],
|
||||
executes: async ({ get }) => {
|
||||
fs.copyFileSync(`${DME_NAME}.dme`, `${DME_NAME}.test.dme`);
|
||||
await DreamMaker(`${DME_NAME}.test.dme`, {
|
||||
defines: ['CBT', 'AUTOWIKI', ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes('error'),
|
||||
defines: ["CBT", "AUTOWIKI", ...get(DefineParameter)],
|
||||
warningsAsErrors: get(WarningParameter).includes("error"),
|
||||
ignoreWarningCodes: get(NoWarningParameter),
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
});
|
||||
Juke.rm('data/autowiki_edits.txt');
|
||||
Juke.rm('data/autowiki_files', { recursive: true });
|
||||
Juke.rm('data/logs/ci', { recursive: true });
|
||||
Juke.rm("data/autowiki_edits.txt");
|
||||
Juke.rm("data/autowiki_files", { recursive: true });
|
||||
Juke.rm("data/logs/ci", { recursive: true });
|
||||
|
||||
const options = {
|
||||
dmbFile: `${DME_NAME}.test.dmb`,
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
}
|
||||
};
|
||||
await DreamDaemon(
|
||||
options,
|
||||
'-close', '-trusted', '-invisible', '-verbose',
|
||||
'-params', 'log-directory=ci',
|
||||
"-close",
|
||||
"-trusted",
|
||||
"-verbose",
|
||||
"-params",
|
||||
"log-directory=ci",
|
||||
);
|
||||
Juke.rm('*.test.*');
|
||||
if (!fs.existsSync('data/autowiki_edits.txt')) {
|
||||
Juke.logger.error('Autowiki did not generate an output, exiting');
|
||||
Juke.rm("*.test.*");
|
||||
if (!fs.existsSync("data/autowiki_edits.txt")) {
|
||||
Juke.logger.error("Autowiki did not generate an output, exiting");
|
||||
throw new Juke.ExitCode(1);
|
||||
}
|
||||
},
|
||||
@@ -319,80 +350,84 @@ export const AutowikiTarget = new Juke.Target({
|
||||
export const YarnTarget = new Juke.Target({
|
||||
parameters: [CiParameter],
|
||||
inputs: [
|
||||
'tgui/.yarn/+(cache|releases|plugins|sdks)/**/*',
|
||||
'tgui/**/package.json',
|
||||
'tgui/yarn.lock',
|
||||
"tgui/.yarn/+(cache|releases|plugins|sdks)/**/*",
|
||||
"tgui/**/package.json",
|
||||
"tgui/yarn.lock",
|
||||
],
|
||||
outputs: [
|
||||
'tgui/.yarn/install-target',
|
||||
],
|
||||
executes: ({ get }) => yarn('install', get(CiParameter) && '--immutable'),
|
||||
outputs: ["tgui/.yarn/install-target"],
|
||||
executes: ({ get }) => yarn("install", get(CiParameter) && "--immutable"),
|
||||
});
|
||||
|
||||
export const TgFontTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
inputs: [
|
||||
'tgui/.yarn/install-target',
|
||||
'tgui/packages/tgfont/**/*.+(js|cjs|svg)',
|
||||
'tgui/packages/tgfont/package.json',
|
||||
"tgui/.yarn/install-target",
|
||||
"tgui/packages/tgfont/**/*.+(js|mjs|svg)",
|
||||
"tgui/packages/tgfont/package.json",
|
||||
],
|
||||
outputs: [
|
||||
'tgui/packages/tgfont/dist/tgfont.css',
|
||||
'tgui/packages/tgfont/dist/tgfont.eot',
|
||||
'tgui/packages/tgfont/dist/tgfont.woff2',
|
||||
"tgui/packages/tgfont/dist/tgfont.css",
|
||||
"tgui/packages/tgfont/dist/tgfont.woff2",
|
||||
],
|
||||
executes: async () => {
|
||||
await yarn('tgfont:build');
|
||||
fs.copyFileSync('tgui/packages/tgfont/dist/tgfont.css', 'tgui/packages/tgfont/static/tgfont.css');
|
||||
fs.copyFileSync('tgui/packages/tgfont/dist/tgfont.eot', 'tgui/packages/tgfont/static/tgfont.eot');
|
||||
fs.copyFileSync('tgui/packages/tgfont/dist/tgfont.woff2', 'tgui/packages/tgfont/static/tgfont.woff2');
|
||||
}
|
||||
await yarn("tgfont:build");
|
||||
fs.mkdirSync("tgui/packages/tgfont/static", { recursive: true });
|
||||
fs.copyFileSync(
|
||||
"tgui/packages/tgfont/dist/tgfont.css",
|
||||
"tgui/packages/tgfont/static/tgfont.css",
|
||||
);
|
||||
fs.copyFileSync(
|
||||
"tgui/packages/tgfont/dist/tgfont.woff2",
|
||||
"tgui/packages/tgfont/static/tgfont.woff2",
|
||||
);
|
||||
},
|
||||
});
|
||||
|
||||
export const TguiTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
inputs: [
|
||||
'tgui/.yarn/install-target',
|
||||
'tgui/rspack.config.cjs',
|
||||
'tgui/**/package.json',
|
||||
'tgui/packages/**/*.+(js|cjs|ts|tsx|jsx|scss)',
|
||||
"tgui/.yarn/install-target",
|
||||
"tgui/rspack.config.cjs",
|
||||
"tgui/**/package.json",
|
||||
"tgui/packages/**/*.+(js|cjs|ts|tsx|jsx|scss)",
|
||||
],
|
||||
outputs: [
|
||||
'tgui/public/tgui.bundle.css',
|
||||
'tgui/public/tgui.bundle.js',
|
||||
'tgui/public/tgui-panel.bundle.css',
|
||||
'tgui/public/tgui-panel.bundle.js',
|
||||
'tgui/public/tgui-say.bundle.css',
|
||||
'tgui/public/tgui-say.bundle.js',
|
||||
"tgui/public/tgui.bundle.css",
|
||||
"tgui/public/tgui.bundle.js",
|
||||
"tgui/public/tgui-panel.bundle.css",
|
||||
"tgui/public/tgui-panel.bundle.js",
|
||||
"tgui/public/tgui-say.bundle.css",
|
||||
"tgui/public/tgui-say.bundle.js",
|
||||
],
|
||||
executes: () => yarn('tgui:build'),
|
||||
executes: () => yarn("tgui:build"),
|
||||
});
|
||||
|
||||
export const TguiEslintTarget = new Juke.Target({
|
||||
parameters: [CiParameter],
|
||||
dependsOn: [YarnTarget],
|
||||
executes: ({ get }) => yarn('tgui:lint', !get(CiParameter) && '--fix'),
|
||||
executes: ({ get }) => yarn("tgui:lint", !get(CiParameter) && "--fix"),
|
||||
});
|
||||
|
||||
export const TguiPrettierTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:prettier'),
|
||||
executes: () => yarn("tgui:prettier"),
|
||||
});
|
||||
|
||||
export const TguiSonarTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:sonar'),
|
||||
executes: () => yarn("tgui:sonar"),
|
||||
});
|
||||
|
||||
export const TguiTscTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:tsc'),
|
||||
executes: () => yarn("tgui:tsc"),
|
||||
});
|
||||
|
||||
export const TguiTestTarget = new Juke.Target({
|
||||
parameters: [CiParameter],
|
||||
dependsOn: [YarnTarget],
|
||||
executes: ({ get }) => yarn(`tgui:test-${get(CiParameter) ? 'ci' : 'simple'}`),
|
||||
executes: ({ get }) =>
|
||||
yarn(`tgui:test-${get(CiParameter) ? "ci" : "simple"}`),
|
||||
});
|
||||
|
||||
export const TguiLintTarget = new Juke.Target({
|
||||
@@ -401,27 +436,27 @@ export const TguiLintTarget = new Juke.Target({
|
||||
|
||||
export const TguiDevTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: ({ args }) => yarn('tgui:dev', ...args),
|
||||
executes: ({ args }) => yarn("tgui:dev", ...args),
|
||||
});
|
||||
|
||||
export const TguiAnalyzeTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:analyze'),
|
||||
executes: () => yarn("tgui:analyze"),
|
||||
});
|
||||
|
||||
export const TguiBenchTarget = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:bench'),
|
||||
executes: () => yarn("tgui:bench"),
|
||||
});
|
||||
|
||||
export const TguiPrettierFix = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:prettier-fix'),
|
||||
executes: () => yarn("tgui:prettier-fix"),
|
||||
});
|
||||
|
||||
export const TguiEslintFix = new Juke.Target({
|
||||
dependsOn: [YarnTarget],
|
||||
executes: () => yarn('tgui:eslint-fix'),
|
||||
executes: () => yarn("tgui:eslint-fix"),
|
||||
});
|
||||
|
||||
export const TguiFix = new Juke.Target({
|
||||
@@ -444,12 +479,12 @@ export const ServerTarget = new Juke.Target({
|
||||
parameters: [DmVersionParameter, PortParameter],
|
||||
dependsOn: [BuildTarget],
|
||||
executes: async ({ get }) => {
|
||||
const port = get(PortParameter) || '1337';
|
||||
const port = get(PortParameter) || "1337";
|
||||
const options = {
|
||||
dmbFile: `${DME_NAME}.dmb`,
|
||||
namedDmVersion: get(DmVersionParameter),
|
||||
}
|
||||
await DreamDaemon(options, port, '-trusted -invisible');
|
||||
await DreamDaemon(options, port, "-trusted -invisible");
|
||||
},
|
||||
});
|
||||
|
||||
@@ -459,23 +494,23 @@ export const AllTarget = new Juke.Target({
|
||||
|
||||
export const TguiCleanTarget = new Juke.Target({
|
||||
executes: async () => {
|
||||
Juke.rm('tgui/public/.tmp', { recursive: true });
|
||||
Juke.rm('tgui/public/*.map');
|
||||
Juke.rm('tgui/public/*.{chunk,bundle,hot-update}.*');
|
||||
Juke.rm('tgui/packages/tgfont/dist', { recursive: true });
|
||||
Juke.rm('tgui/.yarn/{cache,unplugged,webpack}', { recursive: true });
|
||||
Juke.rm('tgui/.yarn/build-state.yml');
|
||||
Juke.rm('tgui/.yarn/install-state.gz');
|
||||
Juke.rm('tgui/.yarn/install-target');
|
||||
Juke.rm('tgui/.pnp.*');
|
||||
Juke.rm("tgui/public/.tmp", { recursive: true });
|
||||
Juke.rm("tgui/public/*.map");
|
||||
Juke.rm("tgui/public/*.{chunk,bundle,hot-update}.*");
|
||||
Juke.rm("tgui/packages/tgfont/dist", { recursive: true });
|
||||
Juke.rm("tgui/.yarn/{cache,unplugged,rspack}", { recursive: true });
|
||||
Juke.rm("tgui/.yarn/build-state.yml");
|
||||
Juke.rm("tgui/.yarn/install-state.gz");
|
||||
Juke.rm("tgui/.yarn/install-target");
|
||||
Juke.rm("tgui/.pnp.*");
|
||||
},
|
||||
});
|
||||
|
||||
export const CleanTarget = new Juke.Target({
|
||||
dependsOn: [TguiCleanTarget],
|
||||
executes: async () => {
|
||||
Juke.rm('*.{dmb,rsc}');
|
||||
Juke.rm('_maps/templates.dm');
|
||||
Juke.rm("*.{dmb,rsc}");
|
||||
Juke.rm("_maps/templates.dm");
|
||||
},
|
||||
});
|
||||
|
||||
@@ -485,10 +520,10 @@ export const CleanTarget = new Juke.Target({
|
||||
export const CleanAllTarget = new Juke.Target({
|
||||
dependsOn: [CleanTarget],
|
||||
executes: async () => {
|
||||
Juke.logger.info('Cleaning up data/logs');
|
||||
Juke.rm('data/logs', { recursive: true });
|
||||
Juke.logger.info('Cleaning up global yarn cache');
|
||||
await yarn('cache', 'clean', '--all');
|
||||
Juke.logger.info("Cleaning up data/logs");
|
||||
Juke.rm("data/logs", { recursive: true });
|
||||
Juke.logger.info("Cleaning up global yarn cache");
|
||||
await yarn("cache", "clean", "--all");
|
||||
},
|
||||
});
|
||||
|
||||
@@ -499,17 +534,16 @@ export const CleanAllTarget = new Juke.Target({
|
||||
*/
|
||||
const prependDefines = (...defines) => {
|
||||
const dmeContents = fs.readFileSync(`${DME_NAME}.dme`);
|
||||
const textToWrite = defines.map(define => `#define ${define}\n`);
|
||||
const textToWrite = defines.map((define) => `#define ${define}\n`);
|
||||
fs.writeFileSync(`${DME_NAME}.dme`, `${textToWrite}\n${dmeContents}`);
|
||||
};
|
||||
|
||||
export const TgsTarget = new Juke.Target({
|
||||
dependsOn: [TguiTarget],
|
||||
executes: async () => {
|
||||
Juke.logger.info('Prepending TGS define');
|
||||
prependDefines('TGS');
|
||||
Juke.logger.info("Prepending TGS define");
|
||||
prependDefines("TGS");
|
||||
},
|
||||
});
|
||||
|
||||
|
||||
export default TGS_MODE ? TgsTarget : BuildTarget;
|
||||
|
||||
Reference in New Issue
Block a user