mirror of
https://github.com/SPLURT-Station/S.P.L.U.R.T-Station-13.git
synced 2025-12-09 07:48:55 +00:00
124 lines
3.2 KiB
JavaScript
124 lines
3.2 KiB
JavaScript
/**
|
|
* @file
|
|
* @copyright 2020 Aleksej Komarov
|
|
* @license MIT
|
|
*/
|
|
|
|
import fs from 'fs';
|
|
import os from 'os';
|
|
import { basename } from 'path';
|
|
import { DreamSeeker } from './dreamseeker.js';
|
|
import { createLogger } from './logging.js';
|
|
import { resolveGlob, resolvePath } from './util.js';
|
|
import { regQuery } from './winreg.js';
|
|
|
|
const logger = createLogger('reloader');
|
|
|
|
const HOME = os.homedir();
|
|
const SEARCH_LOCATIONS = [
|
|
// Custom location
|
|
process.env.BYOND_CACHE,
|
|
// Windows
|
|
`${HOME}/*/BYOND/cache`,
|
|
// Wine
|
|
`${HOME}/.wine/drive_c/users/*/*/BYOND/cache`,
|
|
// Lutris
|
|
`${HOME}/Games/byond/drive_c/users/*/*/BYOND/cache`,
|
|
// WSL
|
|
`/mnt/c/Users/*/*/BYOND/cache`,
|
|
];
|
|
|
|
let cacheRoot;
|
|
|
|
export const findCacheRoot = async () => {
|
|
if (cacheRoot) {
|
|
return cacheRoot;
|
|
}
|
|
logger.log('looking for byond cache');
|
|
// Find BYOND cache folders
|
|
for (let pattern of SEARCH_LOCATIONS) {
|
|
if (!pattern) {
|
|
continue;
|
|
}
|
|
const paths = await resolveGlob(pattern);
|
|
if (paths.length > 0) {
|
|
cacheRoot = paths[0];
|
|
onCacheRootFound(cacheRoot);
|
|
return cacheRoot;
|
|
}
|
|
}
|
|
// Query the Windows Registry
|
|
if (process.platform === 'win32') {
|
|
logger.log('querying windows registry');
|
|
let userpath = await regQuery(
|
|
'HKCU\\Software\\Dantom\\BYOND',
|
|
'userpath');
|
|
if (userpath) {
|
|
cacheRoot = userpath
|
|
.replace(/\\$/, '')
|
|
.replace(/\\/g, '/')
|
|
+ '/cache';
|
|
onCacheRootFound(cacheRoot);
|
|
return cacheRoot;
|
|
}
|
|
}
|
|
logger.log('found no cache directories');
|
|
};
|
|
|
|
const onCacheRootFound = cacheRoot => {
|
|
logger.log(`found cache at '${cacheRoot}'`);
|
|
};
|
|
|
|
export const reloadByondCache = async bundleDir => {
|
|
const cacheRoot = await findCacheRoot();
|
|
if (!cacheRoot) {
|
|
return;
|
|
}
|
|
// Find tmp folders in cache
|
|
const cacheDirs = await resolveGlob(cacheRoot, './tmp*');
|
|
if (cacheDirs.length === 0) {
|
|
logger.log('found no tmp folder in cache');
|
|
return;
|
|
}
|
|
// Get dreamseeker instances
|
|
const pids = cacheDirs.map(cacheDir => (
|
|
parseInt(cacheDir.split('/cache/tmp').pop(), 10)
|
|
));
|
|
const dssPromise = DreamSeeker.getInstancesByPids(pids);
|
|
// Copy assets
|
|
const assets = await resolveGlob(bundleDir, './*.+(bundle|chunk|hot-update).*');
|
|
for (let cacheDir of cacheDirs) {
|
|
// Clear garbage
|
|
const garbage = await resolveGlob(cacheDir, './*.+(bundle|chunk|hot-update).*');
|
|
try {
|
|
// Plant a dummy browser window file, we'll be using this to avoid world topic
|
|
fs.closeSync(fs.openSync(cacheDir + '/dummy', 'w'));
|
|
|
|
for (let file of garbage) {
|
|
fs.unlinkSync(file);
|
|
}
|
|
// Copy assets
|
|
for (let asset of assets) {
|
|
const destination = resolvePath(cacheDir, basename(asset));
|
|
fs.writeFileSync(destination, fs.readFileSync(asset));
|
|
}
|
|
logger.log(`copied ${assets.length} files to '${cacheDir}'`);
|
|
}
|
|
catch (err) {
|
|
logger.error(`failed copying to '${cacheDir}'`);
|
|
logger.error(err);
|
|
}
|
|
}
|
|
// Notify dreamseeker
|
|
const dss = await dssPromise;
|
|
if (dss.length > 0) {
|
|
logger.log(`notifying dreamseeker`);
|
|
for (let dreamseeker of dss) {
|
|
dreamseeker.topic({
|
|
tgui: 1,
|
|
type: 'cacheReloaded',
|
|
});
|
|
}
|
|
}
|
|
};
|