commit-cop 1.1.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/dist/brand.d.ts +4 -0
  2. package/dist/brand.d.ts.map +1 -0
  3. package/dist/brand.js +4 -0
  4. package/dist/brand.js.map +1 -0
  5. package/dist/checks/binaryFileCheck.js +2 -2
  6. package/dist/checks/binaryFileCheck.js.map +1 -1
  7. package/dist/checks/consoleLogCheck.d.ts.map +1 -1
  8. package/dist/checks/consoleLogCheck.js +2 -2
  9. package/dist/checks/consoleLogCheck.js.map +1 -1
  10. package/dist/checks/debuggerCheck.d.ts.map +1 -1
  11. package/dist/checks/debuggerCheck.js +2 -2
  12. package/dist/checks/debuggerCheck.js.map +1 -1
  13. package/dist/checks/envFileCheck.d.ts.map +1 -1
  14. package/dist/checks/envFileCheck.js +2 -2
  15. package/dist/checks/envFileCheck.js.map +1 -1
  16. package/dist/checks/focusedTestCheck.js +2 -2
  17. package/dist/checks/focusedTestCheck.js.map +1 -1
  18. package/dist/checks/generatedFolderCheck.js +2 -2
  19. package/dist/checks/generatedFolderCheck.js.map +1 -1
  20. package/dist/checks/junkFileCheck.d.ts.map +1 -1
  21. package/dist/checks/junkFileCheck.js +2 -2
  22. package/dist/checks/junkFileCheck.js.map +1 -1
  23. package/dist/checks/largeFileCheck.js +2 -2
  24. package/dist/checks/largeFileCheck.js.map +1 -1
  25. package/dist/checks/localHostCheck.js +2 -2
  26. package/dist/checks/localHostCheck.js.map +1 -1
  27. package/dist/checks/lockfileDriftCheck.d.ts.map +1 -1
  28. package/dist/checks/lockfileDriftCheck.js +4 -4
  29. package/dist/checks/lockfileDriftCheck.js.map +1 -1
  30. package/dist/checks/mergeConflictCheck.d.ts.map +1 -1
  31. package/dist/checks/mergeConflictCheck.js +2 -2
  32. package/dist/checks/mergeConflictCheck.js.map +1 -1
  33. package/dist/checks/secretCheck.js +19 -19
  34. package/dist/checks/secretCheck.js.map +1 -1
  35. package/dist/checks/sensitiveFilenameCheck.d.ts.map +1 -1
  36. package/dist/checks/sensitiveFilenameCheck.js +2 -2
  37. package/dist/checks/sensitiveFilenameCheck.js.map +1 -1
  38. package/dist/fix/debugCode.d.ts +3 -0
  39. package/dist/fix/debugCode.d.ts.map +1 -0
  40. package/dist/fix/debugCode.js +55 -0
  41. package/dist/fix/debugCode.js.map +1 -0
  42. package/dist/fix/focusedTests.d.ts +2 -0
  43. package/dist/fix/focusedTests.d.ts.map +1 -0
  44. package/dist/fix/focusedTests.js +22 -0
  45. package/dist/fix/focusedTests.js.map +1 -0
  46. package/dist/fix/gitignore.d.ts +2 -0
  47. package/dist/fix/gitignore.d.ts.map +1 -0
  48. package/dist/fix/gitignore.js +82 -0
  49. package/dist/fix/gitignore.js.map +1 -0
  50. package/dist/fix/junkFiles.d.ts +2 -0
  51. package/dist/fix/junkFiles.d.ts.map +1 -0
  52. package/dist/fix/junkFiles.js +14 -0
  53. package/dist/fix/junkFiles.js.map +1 -0
  54. package/dist/fix/lockfile.d.ts +2 -0
  55. package/dist/fix/lockfile.d.ts.map +1 -0
  56. package/dist/fix/lockfile.js +18 -0
  57. package/dist/fix/lockfile.js.map +1 -0
  58. package/dist/fix/matchers.d.ts +9 -0
  59. package/dist/fix/matchers.d.ts.map +1 -0
  60. package/dist/fix/matchers.js +118 -0
  61. package/dist/fix/matchers.js.map +1 -0
  62. package/dist/fix/runFix.d.ts +3 -0
  63. package/dist/fix/runFix.d.ts.map +1 -0
  64. package/dist/fix/runFix.js +82 -0
  65. package/dist/fix/runFix.js.map +1 -0
  66. package/dist/fix/unstage.d.ts +2 -0
  67. package/dist/fix/unstage.d.ts.map +1 -0
  68. package/dist/fix/unstage.js +22 -0
  69. package/dist/fix/unstage.js.map +1 -0
  70. package/dist/fix/utils.d.ts +4 -0
  71. package/dist/fix/utils.d.ts.map +1 -0
  72. package/dist/fix/utils.js +39 -0
  73. package/dist/fix/utils.js.map +1 -0
  74. package/dist/git.d.ts.map +1 -1
  75. package/dist/git.js +2 -1
  76. package/dist/git.js.map +1 -1
  77. package/dist/hook.d.ts +3 -0
  78. package/dist/hook.d.ts.map +1 -0
  79. package/dist/hook.js +79 -0
  80. package/dist/hook.js.map +1 -0
  81. package/dist/index.js +32 -21
  82. package/dist/index.js.map +1 -1
  83. package/dist/reporter.d.ts.map +1 -1
  84. package/dist/reporter.js +56 -26
  85. package/dist/reporter.js.map +1 -1
  86. package/dist/runScan.d.ts +2 -0
  87. package/dist/runScan.d.ts.map +1 -0
  88. package/dist/runScan.js +24 -0
  89. package/dist/runScan.js.map +1 -0
  90. package/dist/scanner.d.ts.map +1 -1
  91. package/dist/scanner.js +4 -1
  92. package/dist/scanner.js.map +1 -1
  93. package/dist/types.d.ts +4 -0
  94. package/dist/types.d.ts.map +1 -1
  95. package/package.json +1 -1
package/dist/reporter.js CHANGED
@@ -1,38 +1,68 @@
1
+ import { PRODUCT_NAME } from "./brand.js";
1
2
  import chalk from "chalk";
2
- export function printReport(findings, scannedCount) {
3
- console.log(chalk.bold("\nCommitClean Report\n"));
4
- console.log(`Scanned ${scannedCount} staged file(s).\n`);
5
- const errors = findings.filter((f) => f.severity === "error");
6
- const warnings = findings.filter((f) => f.severity === "warning");
7
- console.log(chalk.red(`Errors: ${errors.length}`));
8
- console.log(chalk.yellow(`Warnings: ${warnings.length}`));
3
+ const WIDTH = 52;
4
+ function line(char = "─") {
5
+ return chalk.dim(char.repeat(WIDTH));
6
+ }
7
+ function printHeader(title) {
8
+ console.log("");
9
+ console.log(line("═"));
10
+ console.log(chalk.bold(` ${title}`));
11
+ console.log(line("═"));
12
+ }
13
+ function printSection(title, color) {
14
+ console.log("");
15
+ console.log(line());
16
+ console.log(color(chalk.bold(` ${title}`)));
17
+ console.log(line());
18
+ console.log("");
19
+ }
20
+ function printSummary(scannedCount, errors, warnings) {
9
21
  console.log("");
22
+ console.log(chalk.dim(` Scanned ${scannedCount} staged file(s)`));
23
+ console.log(` ${chalk.red(`Errors: ${errors}`)}${chalk.dim(" │ ")}${chalk.yellow(`Warnings: ${warnings}`)}`);
24
+ }
25
+ function printFinding(finding, index) {
26
+ const location = finding.line
27
+ ? `${finding.file}:${finding.line}`
28
+ : finding.file;
29
+ const checkLabel = chalk.dim(`[${finding.checkName}]`);
30
+ console.log(chalk.bold(` ${index}.`) + ` ${checkLabel}`);
31
+ console.log(` ${chalk.cyan(location)}`);
32
+ console.log(` ${finding.message}`);
33
+ if (finding.suggestion) {
34
+ console.log(chalk.gray(` → ${finding.suggestion}`));
35
+ }
36
+ console.log("");
37
+ }
38
+ function printFindings(findings, severity) {
39
+ const filtered = findings.filter((finding) => finding.severity === severity);
40
+ filtered.forEach((finding, index) => {
41
+ printFinding(finding, index + 1);
42
+ });
43
+ }
44
+ export function printReport(findings, scannedCount) {
45
+ const errors = findings.filter((finding) => finding.severity === "error");
46
+ const warnings = findings.filter((finding) => finding.severity === "warning");
47
+ printHeader(`${PRODUCT_NAME} Report`);
48
+ printSummary(scannedCount, errors.length, warnings.length);
10
49
  if (findings.length === 0) {
11
- console.log(chalk.green("✅ No issues found. Commit looks clean.\n"));
50
+ console.log("");
51
+ console.log(chalk.green(" ✅ All clear — no issues found in staged files."));
52
+ console.log("");
53
+ console.log(line("═"));
54
+ console.log("");
12
55
  return;
13
56
  }
14
57
  if (errors.length > 0) {
15
- console.log(chalk.red.bold("❌ Errors"));
16
- for (const finding of errors) {
17
- printFinding(finding);
18
- }
58
+ printSection(`ERRORS (${errors.length})`, chalk.red);
59
+ printFindings(findings, "error");
19
60
  }
20
61
  if (warnings.length > 0) {
21
- console.log(chalk.yellow.bold("\n⚠️ Warnings"));
22
- for (const finding of warnings) {
23
- printFinding(finding);
24
- }
62
+ printSection(`WARNINGS (${warnings.length})`, chalk.yellow);
63
+ printFindings(findings, "warning");
25
64
  }
65
+ console.log(line("═"));
26
66
  console.log("");
27
67
  }
28
- function printFinding(finding) {
29
- const location = finding.line
30
- ? `${finding.file}:${finding.line}`
31
- : finding.file;
32
- console.log(`- ${chalk.bold(location)}`);
33
- console.log(` ${finding.message}`);
34
- if (finding.suggestion) {
35
- console.log(chalk.gray(` Fix: ${finding.suggestion}`));
36
- }
37
- }
38
68
  //# sourceMappingURL=reporter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"reporter.js","sourceRoot":"","sources":["../src/reporter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,MAAM,UAAU,WAAW,CAAC,QAAmB,EAAE,YAAoB;IACnE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;IAClD,OAAO,CAAC,GAAG,CAAC,WAAW,YAAY,oBAAoB,CAAC,CAAC;IAEzD,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC;IAC9D,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC;IAElE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACnD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC1D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAEhB,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC,CAAC;QACrE,OAAO;IACT,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QACxC,KAAK,MAAM,OAAO,IAAI,MAAM,EAAE,CAAC;YAC7B,YAAY,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;QAChD,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,YAAY,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC;AAED,SAAS,YAAY,CAAC,OAAgB;IACpC,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI;QAC3B,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE;QACnC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;IAEjB,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACzC,OAAO,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IAEpC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;QACvB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"reporter.js","sourceRoot":"","sources":["../src/reporter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function runScan(strict?: boolean, allowConsoleLog?: boolean): Promise<number>;
2
+ //# sourceMappingURL=runScan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runScan.d.ts","sourceRoot":"","sources":["../src/runScan.ts"],"names":[],"mappings":"AAKA,wBAAsB,OAAO,CAC3B,MAAM,UAAQ,EACd,eAAe,UAAQ,GACtB,OAAO,CAAC,MAAM,CAAC,CA0BjB"}
@@ -0,0 +1,24 @@
1
+ import { PRODUCT_NAME } from "./brand.js";
2
+ import { getStagedFiles } from "./git.js";
3
+ import { runChecks } from "./scanner.js";
4
+ import { printReport } from "./reporter.js";
5
+ export async function runScan(strict = false, allowConsoleLog = false) {
6
+ const stagedFiles = getStagedFiles();
7
+ if (stagedFiles.length === 0) {
8
+ console.log(`${PRODUCT_NAME}: No staged files found.`);
9
+ return 0;
10
+ }
11
+ const findings = await runChecks({
12
+ stagedFiles,
13
+ strict,
14
+ allowConsoleLog,
15
+ });
16
+ printReport(findings, stagedFiles.length);
17
+ const hasErrors = findings.some((finding) => finding.severity === "error");
18
+ const hasWarnings = findings.some((finding) => finding.severity === "warning");
19
+ if (hasErrors || (strict && hasWarnings)) {
20
+ return 1;
21
+ }
22
+ return 0;
23
+ }
24
+ //# sourceMappingURL=runScan.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runScan.js","sourceRoot":"","sources":["../src/runScan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,MAAM,GAAG,KAAK,EACd,eAAe,GAAG,KAAK;IAEvB,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,GAAG,YAAY,0BAA0B,CAAC,CAAC;QACvD,OAAO,CAAC,CAAC;IACX,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC;QAC/B,WAAW;QACX,MAAM;QACN,eAAe;KAChB,CAAC,CAAC;IAEH,WAAW,CAAC,QAAQ,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAE1C,MAAM,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC;IAC3E,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAC/B,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,CAC5C,CAAC;IAEF,IAAI,SAAS,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC,EAAE,CAAC;QACzC,OAAO,CAAC,CAAC;IACX,CAAC;IAED,OAAO,CAAC,CAAC;AACX,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AA+BxD,wBAAsB,SAAS,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CASzE"}
1
+ {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AA+BxD,wBAAsB,SAAS,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAYzE"}
package/dist/scanner.js CHANGED
@@ -28,7 +28,10 @@ const checks = [
28
28
  ];
29
29
  export async function runChecks(context) {
30
30
  const allFindings = [];
31
- for (const check of checks) {
31
+ const activeChecks = context.allowConsoleLog
32
+ ? checks.filter((check) => check !== consoleLogCheck)
33
+ : checks;
34
+ for (const check of activeChecks) {
32
35
  const findings = await check.run(context);
33
36
  allFindings.push(...findings);
34
37
  }
@@ -1 +1 @@
1
- {"version":3,"file":"scanner.js","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,MAAM,MAAM,GAAG;IACb,kBAAkB;IAClB,YAAY;IACZ,sBAAsB;IACtB,oBAAoB;IACpB,WAAW;IACX,gBAAgB;IAChB,eAAe;IACf,aAAa;IACb,cAAc;IACd,aAAa;IACb,kBAAkB;IAClB,cAAc;IACd,eAAe;CAChB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,OAAqB;IACnD,MAAM,WAAW,GAAc,EAAE,CAAC;IAElC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC1C,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED,OAAO,WAAW,CAAC;AACrB,CAAC"}
1
+ {"version":3,"file":"scanner.js","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,MAAM,MAAM,GAAG;IACb,kBAAkB;IAClB,YAAY;IACZ,sBAAsB;IACtB,oBAAoB;IACpB,WAAW;IACX,gBAAgB;IAChB,eAAe;IACf,aAAa;IACb,cAAc;IACd,aAAa;IACb,kBAAkB;IAClB,cAAc;IACd,eAAe;CAChB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,OAAqB;IACnD,MAAM,WAAW,GAAc,EAAE,CAAC;IAClC,MAAM,YAAY,GAAG,OAAO,CAAC,eAAe;QAC1C,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,eAAe,CAAC;QACrD,CAAC,CAAC,MAAM,CAAC;IAEX,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;QACjC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC1C,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED,OAAO,WAAW,CAAC;AACrB,CAAC"}
package/dist/types.d.ts CHANGED
@@ -10,6 +10,10 @@ export type Finding = {
10
10
  export type CheckContext = {
11
11
  stagedFiles: string[];
12
12
  strict: boolean;
13
+ allowConsoleLog?: boolean;
14
+ };
15
+ export type WipFixOptions = {
16
+ fixConsoleLog?: boolean;
13
17
  };
14
18
  export type Check = {
15
19
  name: string;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEpD,MAAM,MAAM,OAAO,GAAG;IACpB,QAAQ,EAAE,QAAQ,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,CAAC,OAAO,EAAE,YAAY,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;CACpD,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEpD,MAAM,MAAM,OAAO,GAAG;IACpB,QAAQ,EAAE,QAAQ,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,EAAE,OAAO,CAAC;IAChB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,CAAC,OAAO,EAAE,YAAY,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;CACpD,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "commit-cop",
3
- "version": "1.1.0",
3
+ "version": "1.1.1",
4
4
  "description": "Commit Cop — a pre-commit safety checker that scans staged files for risky commits.",
5
5
  "type": "module",
6
6
  "bin": {