29 lines
1.2 KiB
TypeScript
29 lines
1.2 KiB
TypeScript
import * as plugins from './plugins.js';
|
|
const __dirname = plugins.path.dirname(plugins.url.fileURLToPath(import.meta.url));
|
|
|
|
export const runPath = async (pathArg: string, fromFileUrl?: string) => {
|
|
pathArg = fromFileUrl
|
|
? plugins.path.join(plugins.path.dirname(plugins.url.fileURLToPath(fromFileUrl)), pathArg)
|
|
: pathArg;
|
|
await runCli(pathArg);
|
|
};
|
|
|
|
export const runCli = async (pathArg?: string) => {
|
|
// contents of argv array
|
|
// process.argv[0] -> node Executable
|
|
// process.argv[1] -> tsrun executable
|
|
const relativePathToTsFile = pathArg ? pathArg : process.argv[2];
|
|
const absolutePathToTsFile = plugins.path.isAbsolute(relativePathToTsFile)
|
|
? relativePathToTsFile
|
|
: plugins.path.join(process.cwd(), relativePathToTsFile);
|
|
|
|
// we want to have command line arguments available in the child process.
|
|
// when we have a path sepcified through a function there is one argeument less to pay respect to.
|
|
// thus when pathArg is specifed -> we only splice 2
|
|
pathArg ? process.argv.splice(0, 2) : process.argv.splice(0, 3); // this ensures transparent arguments for the child process
|
|
|
|
const tsx = await import('tsx/esm/api');
|
|
const unregister = tsx.register();
|
|
await import(absolutePathToTsFile);
|
|
};
|