mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2026-04-23 09:42:53 +02:00
37 lines
1.5 KiB
TypeScript
37 lines
1.5 KiB
TypeScript
import { Directory } from "./Directory";
|
|
import { FilePath, resolveFilePath } from "./FilePath";
|
|
|
|
/** Type for just checking a script extension with no other verification*/
|
|
type WithScriptExtension = string & { __fileType: "Script" };
|
|
/** Type for a valid absolute FilePath with a script extension */
|
|
export type ScriptFilePath = FilePath & WithScriptExtension;
|
|
|
|
export const legacyScriptExtension = ".script";
|
|
|
|
/** Valid extensions. Used for some error messaging. */
|
|
export const validScriptExtensions = [".js", ".jsx", ".ts", ".tsx", legacyScriptExtension] as const;
|
|
export type ScriptExtension = (typeof validScriptExtensions)[number];
|
|
|
|
/** Sanitize a player input, resolve any relative paths, and for imports add the correct extension if missing
|
|
* @param path The player-provided path to a file. Can contain relative parts.
|
|
* @param base The base
|
|
*/
|
|
export function resolveScriptFilePath(
|
|
path: string,
|
|
base = "" as FilePath | Directory,
|
|
extensionToAdd?: ScriptExtension,
|
|
): ScriptFilePath | null {
|
|
if (extensionToAdd && !path.endsWith(extensionToAdd)) path = path + extensionToAdd;
|
|
const result = resolveFilePath(path, base);
|
|
return result && hasScriptExtension(result) ? result : null;
|
|
}
|
|
|
|
/** Just check extension */
|
|
export function hasScriptExtension(path: string): path is WithScriptExtension {
|
|
return validScriptExtensions.some((extension) => path.endsWith(extension));
|
|
}
|
|
|
|
export function isLegacyScript(path: string): boolean {
|
|
return path.endsWith(legacyScriptExtension);
|
|
}
|