Skip to content
This repository has been archived by the owner on Mar 7, 2024. It is now read-only.

Commit

Permalink
fix: rollup watch #148
Browse files Browse the repository at this point in the history
  • Loading branch information
Crayonn authored and Darmody committed Aug 30, 2019
1 parent f51732e commit f2f15ba
Show file tree
Hide file tree
Showing 6 changed files with 147 additions and 47 deletions.
1 change: 1 addition & 0 deletions packages/remax-cli/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
"@remax/postcss-px2units": "^0.2.0",
"@remax/regenerator-runtime": "^0.11.1",
"acorn-walk": "^7.0.0",
"chokidar": "^2.1.8",
"commander": "^2.19.0",
"ejs": "^2.6.1",
"lodash": "^4.17.11",
Expand Down
56 changes: 10 additions & 46 deletions packages/remax-cli/src/build/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,8 @@ import * as rollup from 'rollup';
import rollupConfig from './rollupConfig';
import getConfig from '../getConfig';
import { Context } from '../types';

const COLORS = {
red: '\x1b[31m',
green: '\x1b[32m',
blue: '\x1b[34m',
};
const RESET = '\x1b[0m';

const output = (
content: string | string[],
color: 'red' | 'green' | 'blue'
) => {
const message = Array.isArray(content) ? content : [content];
console.log(`${COLORS[color]}%s${RESET}`, ...message);
};
import runWatcher from './watcher';
import { output } from './utils/output';

export default async (argv: any, context?: Context) => {
const options = {
Expand All @@ -31,38 +18,15 @@ export default async (argv: any, context?: Context) => {
throw new Error(`Target ${argv.target} is not supported yet.`);
}

const rollupOptions = rollupConfig(options, argv, targetConfig, context);
if (argv.watch) {
const watcher = rollup.watch([
{
...rollupOptions,
watch: {
include: ['src/**', 'app.js', '*.config.js'],
},
},
]);

console.log('\x1b[34m%s\x1b[0m', '🚀 启动 watch');
const rollupOptions: rollup.RollupOptions = rollupConfig(
options,
argv,
targetConfig,
context
);

watcher.on('event', (event: any) => {
switch (event.code) {
case 'START':
output('🚚 编译...', 'blue');
break;
case 'END':
output('💡 完成', 'green');
break;
case 'ERROR':
case 'FATAL':
const { error } = event;
const name =
error.code === 'PLUGIN_ERROR' ? error.plugin : error.code;
output(`\n🚨 [${name}]: ${error.message}`, 'red');
throw error;
default:
break;
}
});
if (argv.watch) {
runWatcher(rollupOptions, argv, context);
} else {
try {
output('🚀 开始 build...', 'blue');
Expand Down
17 changes: 17 additions & 0 deletions packages/remax-cli/src/build/utils/checkChokidar.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import path from 'path';

let isFirstCheckFailed = true;
export const checkChokidar = () => {
try {
require(path.resolve(process.cwd(), './node_modules/chokidar'));
return true;
} catch (e) {
if (isFirstCheckFailed) {
isFirstCheckFailed = false;
console.log(
'\n 安装 `chokidar` 获得更好的开发体验~~ 😎\n\n > npm install chokidar --save \n'
);
}
return false;
}
};
14 changes: 14 additions & 0 deletions packages/remax-cli/src/build/utils/output.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
const COLORS = {
red: '\x1b[31m',
green: '\x1b[32m',
blue: '\x1b[34m',
};
const RESET = '\x1b[0m';

export const output = (
content: string | string[],
color: 'red' | 'green' | 'blue'
) => {
const message = Array.isArray(content) ? content : [content];
console.log(`${COLORS[color]}%s${RESET}`, ...message);
};
104 changes: 104 additions & 0 deletions packages/remax-cli/src/build/watcher.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
import chokidar from 'chokidar';
import { RollupOptions, watch, RollupWatcher } from 'rollup';
import { output } from './utils/output';
import { checkChokidar } from './utils/checkChokidar';
import { CliOptions } from '../getConfig';
import { Context } from '../types';
import build from './index';

let isBundleRunning = false;
let isFirstRunWatcher = true;

const rollupWatchFiles = ['src/**', 'app.js'];
// 配置重新build的路径
const extraFiles = ['src/app.config.js'];
// chokidar config
const chokidarConfig = {
usePolling: true,
};

let extraFilesWatcher: RollupWatcher | null;
let watcher: RollupWatcher | null;

export default function runWather(
rollupOptions: RollupOptions,
cli: CliOptions,
context?: Context
) {
if (isBundleRunning) {
return;
}

isBundleRunning = true;

watcher = watch([
{
...rollupOptions,
watch: {
chokidar: checkChokidar() && chokidarConfig,
include: rollupWatchFiles,
},
},
]);

const watchEventHandle = (event: any) => {
switch (event.code) {
case 'START':
output('🚚 编译...', 'blue');
break;
case 'END':
isBundleRunning = false;
output('💡 完成', 'green');
break;
case 'ERROR':
case 'FATAL':
isBundleRunning = false;
const { error } = event;
const name = error.code === 'PLUGIN_ERROR' ? error.plugin : error.code;
output(`\n🚨 [${name}]: ${error.message}`, 'red');
throw error;
default:
break;
}
};

watcher.on('event', watchEventHandle);

if (isFirstRunWatcher) {
isFirstRunWatcher = false;
console.log('\x1b[34m%s\x1b[0m', '🚀 启动 watch');
}

const close = (err?: Error) => {
if (watcher) {
watcher.close();
watcher = null;
}
if (extraFilesWatcher) {
extraFilesWatcher.close();
watcher = null;
}

process.removeListener('uncaughtException', close);

if (err) {
process.exit(1);
console.error(err);
}
};

process.on('uncaughtException', close);
// 监听额外的文件
extraFilesWatcher = chokidar.watch(extraFiles);

const reloadWatcher = () => {
if (isFirstRunWatcher || isBundleRunning) return;
close();
build(cli, context);
};

extraFilesWatcher
.on('add', reloadWatcher)
.on('unlink', reloadWatcher)
.on('change', reloadWatcher);
}
2 changes: 1 addition & 1 deletion packages/remax-cli/src/getConfig.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ export interface RemaxOptions {
alias?: any;
}

interface CliOptions {
export interface CliOptions {
target: string;
}

Expand Down

0 comments on commit f2f15ba

Please sign in to comment.