summary refs log tree commit diff
path: root/scripts/build.js
blob: 6cf4e818385daf1f4431bd986d9a90a8f6046a1f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
const { execSync } = require("child_process");
const path = require("path");
const fs = require("fs");
const { argv, stdout, exit } = require("process");
const { execIn, parts, getDirs, walk, sanitizeVarName } = require("./utils");

if (argv.includes("help")) {
	console.log(`Fosscord build script help:
Arguments:
  clean			Cleans up previous builds
  verbose		Enable verbose logging
  logerrors		Log build errors to console
  pretty-errors		Pretty-print build errors
  silent		No output to console or files.
  propagate-err	Exit script with error code if build fails.`);
	exit(0);
}

let steps = 5,
	i = 0;
if (argv.includes("clean")) steps++;

const verbose = argv.includes("verbose") || argv.includes("v");
const logerr = argv.includes("logerrors");
const pretty = argv.includes("pretty-errors");
const silent = argv.includes("silent");

if (silent) console.error = console.log = function () {};

if (argv.includes("clean")) {
	console.log(`[${++i}/${steps}] Cleaning...`);
	let d = "../" + "/dist";
		if (fs.existsSync(d)) {
			fs.rmSync(d, { recursive: true });
			if (verbose) console.log(`Deleted ${d}!`);
		}
}

console.log(`[${++i}/${steps}] Compiling src files ...`);

let buildFlags = "";
if (pretty) buildFlags += "--pretty ";

console.log(`[${++i}/${steps}] Building plugin index...`);
let pluginDir = path.join(__dirname, "..", "src", "plugins");
let output = 'import { Plugin } from "util/plugin";\n';

const dirs = fs.readdirSync(pluginDir).filter((x) => {
	try {
		fs.readdirSync(path.join(pluginDir, x));
		return true;
	} catch (e) {
		return false;
	}
});
dirs.forEach((x) => {
	let pluginManifest = require(path.join(pluginDir, x, "plugin.json"));
	output += `import * as ${sanitizeVarName(x)} from "./${x}/${pluginManifest.mainClass}";\n`;
});
output += `\nexport const PluginIndex: any = {\n`;
dirs.forEach((x) => {
	output += `    "${x}": new ${sanitizeVarName(x)}.default(),\n`; //ctor test: '${path.resolve(path.join(pluginDir, x))}', require('./${x}/plugin.json')
});
output += `};`;

fs.writeFileSync(path.join(__dirname, "..", "src", "plugins", "PluginIndex.ts"), output);

if (!argv.includes("copyonly")) {
	console.log(`[${++i}/${steps}] Compiling source code...`);

	let buildFlags = "";
	if (pretty) buildFlags += "--pretty ";

	try {
		execSync(
			'node "' +
				path.join(__dirname, "..", "node_modules", "typescript", "lib", "tsc.js") +
				'" -p "' +
				path.join(__dirname, "..") +
				'" ' +
				buildFlags,
			{
				cwd: path.join(__dirname, ".."),
				shell: true,
				env: process.env,
				encoding: "utf8"
			}
		);
	} catch (error) {
		if (verbose || logerr) {
			error.stdout.split(/\r?\n/).forEach((line) => {
				let _line = line.replace("dist/", "", 1);
				if (!pretty && _line.includes(".ts(")) {
					//reformat file path for easy jumping
					_line = _line.replace("(", ":", 1).replace(",", ":", 1).replace(")", "", 1);
				}
				console.error(_line);
			});
		}
		console.error(`Build failed! Please check build.log for info!`);
		if (!silent) {
			if (pretty) fs.writeFileSync("build.log.ansi", error.stdout);
			fs.writeFileSync(
				"build.log",
				error.stdout.replaceAll(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, "")
			);
		}
		throw error;
	}
}

console.log(`[${++i}/${steps}] Copying plugin data...`);
let pluginFiles = walk(pluginDir).filter(x=>!x.endsWith('.ts'));
pluginFiles.forEach(x=>{
	fs.copyFileSync(x, x.replace('src','dist'))
})