diff --git a/package.json b/package.json index 7538c84f9..13138fec2 100644 --- a/package.json +++ b/package.json @@ -344,8 +344,8 @@ "predev:incremental": "node-gyp configure build -C test --debug", "dev:incremental": "node test", "doc": "doxygen doc/Doxyfile", - "lint": "node tools/clang-format.js", - "lint:fix": "git-clang-format '*.h', '*.cc'" + "lint": "node tools/clang-format", + "lint:fix": "node tools/clang-format --fix" }, "pre-commit": "lint", "version": "3.1.0", diff --git a/tools/clang-format.js b/tools/clang-format.js index 3bf6f48e8..f0f6ad164 100644 --- a/tools/clang-format.js +++ b/tools/clang-format.js @@ -7,17 +7,31 @@ const filesToCheck = ['*.h', '*.cc']; const CLANG_FORMAT_START = process.env.CLANG_FORMAT_START || 'main'; function main(args) { + let fix = false; + while (args.length > 0) { + switch (args[0]) { + case '-f': + case '--fix': + fix = true; + default: + } + args.shift(); + } + let clangFormatPath = path.dirname(require.resolve('clang-format')); const options = ['--binary=node_modules/.bin/clang-format', '--style=file']; + if (fix) { + options.push(CLANG_FORMAT_START); + } else { + options.push('--diff', CLANG_FORMAT_START); + } const gitClangFormatPath = path.join(clangFormatPath, 'bin/git-clang-format'); const result = spawn('python', [ gitClangFormatPath, ...options, - '--diff', - CLANG_FORMAT_START, - 'HEAD', + '--', ...filesToCheck ], { encoding: 'utf-8' }); @@ -27,17 +41,23 @@ function main(args) { } const clangFormatOutput = result.stdout.trim(); + // Bail fast if in fix mode. + if (fix) { + console.log(clangFormatOutput); + return 0; + } + // Detect if there is any complains from clang-format if (clangFormatOutput !== '' && clangFormatOutput !== ('no modified files to format') && clangFormatOutput !== ('clang-format did not modify any files')) { console.error(clangFormatOutput); - const fixCmd = '"npm run lint:fix"'; + const fixCmd = 'npm run lint:fix'; console.error(` - ERROR: please run ${fixCmd} to format changes in your commit + ERROR: please run "${fixCmd}" to format changes in your commit Note that when running the command locally, please keep your local main branch and working branch up to date with nodejs/node-addon-api to exclude un-related complains. - Or you can run "env CLANG_FORMAT_START=upstream/main ${fixCmd}".`); + Or you can run "env CLANG_FORMAT_START=upstream/main ${fixCmd}" to fix un-staged changes.`); return 1; } }