it's a tsc wrapper, like tsc-watch.
# run package file
$ npx mwtsc --watch --run @midwayjs/mock/app.js
# run file
$ npx mwtsc --watch --run ./bootstrap.js
# run with tsc options
$ npx mwtsc --watch --project tsconfig.production.json --run ./bootstrap.js
# the child process keep avaliable during the development
$ npx mwtsc --watch --run ./bootstrap.js --keepalive
# run with inspect and debug in chrome or other supported tools
$ npx mwtsc --watch --inspect --run ./bootstrap.js
$ npx mwtsc --watch --inspect-brk --run ./bootstrap.js
- 1、support
--run
option, run file after compile success - 2、support copy non-ts file to dist directory when build source code
- 3、support ts alias path by tsc-alias
If you're using VSCode or JetBrains IntelliJ IDEA (or other IDEs), you won't need to manually start the child process with debugging flags like --inspect or --inspect-brk. The IDE will automatically attach the debugger to the child process.
However, if you wish to debug the child process within Chrome, you can utilize --inspect or --inspect-brk to initiate the child process with the debugger enabled.
$ npx mwtsc --watch --inspect --run ./bootstrap.js
$ npx mwtsc --watch --inspect-brk --run ./bootstrap.js
Unfortunately, Chrome DevTools cannot directly access local files with certain special protocols due to security policies. To overcome this, we set up a proxy server to serve the source files. You will need to configure the proxy server's location in your tsconfig.json to properly handle source maps.
{
"compilerOptions": {
"sourceRoot": "http://localhost:7788/"
}
}
You can use mwtsc
API in your code to extend your own logic.
mwtsc API:
run
- run tsc compilechokidar
- watch file change
run API:
exit
- exit processrestart
- restart processonExit
- on exit event
// custom.js
const { run, chokidar } = require('mwtsc');
const { restart, exit, onExit } = run();
const watcher = chokidar.watch('node_modules/**/*.ts', {
ignoreInitial: true,
ignored: ['**/*.d.ts'],
});
watcher.on('all', (event, path) => {
console.log(event, path);
restart([
'/home/admin/workspace/midwayjs/midway/packages/mock/src/app.ts',
]);
});
onExit(async () => {
await watcher.close();
});
Rewrite dev command in package.json
.
{
"scripts": {
"dev": "NODE_ENV=local node ./custom.js --watch --run ./bootstrap.js"
}
}