const { execSync } = require("child_process"); const path = require("path"); const fs = require("fs"); const { argv, stdout, exit } = require("process"); const { execIn, parts } = 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.`); exit(0); } let steps = 1, 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 ' 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, '')); } }