@mediaproc/core 1.2.0 → 1.2.2

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.
package/README.md CHANGED
@@ -40,7 +40,7 @@ showBranding();
40
40
  // ────────────────────────────────────────────────────────────
41
41
 
42
42
  // Show plugin branding (automatically detects version)
43
- showPluginBranding("Image");
43
+ showPluginBranding("Image", "path/to/package.json");
44
44
  // Output:
45
45
  // ────────────────────────────────────────────────────────────
46
46
  // 💎 Image Plugin v1.3.3 · Powered by MediaProc
@@ -1,3 +1,11 @@
1
+ /**
2
+ * Get version from package.json
3
+ */
4
+ export declare function getVersion(packagePath: string): string;
5
+ /**
6
+ * Get CLI version from root package.json
7
+ */
8
+ export declare function getCliVersion(): string;
1
9
  /**
2
10
  * Show CLI branding footer with documentation and GitHub links
3
11
  */
@@ -1 +1 @@
1
- {"version":3,"file":"branding.d.ts","sourceRoot":"","sources":["../../src/branding/branding.ts"],"names":[],"mappings":"AAmCA;;GAEG;AACH,wBAAgB,YAAY,IAAI,IAAI,CAOnC;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI,CAO/E"}
1
+ {"version":3,"file":"branding.d.ts","sourceRoot":"","sources":["../../src/branding/branding.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,wBAAgB,UAAU,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAOtD;AAED;;GAEG;AACH,wBAAgB,aAAa,IAAI,MAAM,CActC;AAED;;GAEG;AACH,wBAAgB,YAAY,IAAI,IAAI,CAOnC;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI,CAO/E"}
@@ -4,7 +4,7 @@ import { fileURLToPath } from 'url';
4
4
  /**
5
5
  * Get version from package.json
6
6
  */
7
- function getVersion(packagePath) {
7
+ export function getVersion(packagePath) {
8
8
  try {
9
9
  const packageJson = JSON.parse(readFileSync(packagePath, 'utf-8'));
10
10
  return packageJson.version || '0.0.0';
@@ -16,7 +16,7 @@ function getVersion(packagePath) {
16
16
  /**
17
17
  * Get CLI version from root package.json
18
18
  */
19
- function getCliVersion() {
19
+ export function getCliVersion() {
20
20
  try {
21
21
  // For ES modules, use import.meta.url
22
22
  if (typeof import.meta.url !== 'undefined') {
@@ -1 +1 @@
1
- {"version":3,"file":"branding.js","sourceRoot":"","sources":["../../src/branding/branding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AAEpC;;GAEG;AACH,SAAS,UAAU,CAAC,WAAmB;IACrC,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;QACnE,OAAO,WAAW,CAAC,OAAO,IAAI,OAAO,CAAC;IACxC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC;IACjB,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAS,aAAa;IACpB,IAAI,CAAC;QACH,sCAAsC;QACtC,IAAI,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC3C,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;YAC3D,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,oBAAoB,CAAC,CAAC;YAC3D,OAAO,UAAU,CAAC,WAAW,CAAC,CAAC;QACjC,CAAC;QACD,mCAAmC;QACnC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAC;QACxD,OAAO,UAAU,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC,CAAC,mBAAmB;IACrC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,YAAY;IAC1B,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;IAChC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,kCAAkC,OAAO,EAAE,CAAC,CAAC;IACzD,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;AACrC,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,kBAAkB,CAAC,UAAkB,EAAE,UAAkB;IACvE,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC;IACvC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,QAAQ,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,OAAO,yBAAyB,CAAC,CAAC;IAC1H,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;AACrC,CAAC"}
1
+ {"version":3,"file":"branding.js","sourceRoot":"","sources":["../../src/branding/branding.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AAEpC;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,WAAmB;IAC5C,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;QACnE,OAAO,WAAW,CAAC,OAAO,IAAI,OAAO,CAAC;IACxC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC;IACjB,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa;IAC3B,IAAI,CAAC;QACH,sCAAsC;QACtC,IAAI,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC3C,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;YAC3D,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,oBAAoB,CAAC,CAAC;YAC3D,OAAO,UAAU,CAAC,WAAW,CAAC,CAAC;QACjC,CAAC;QACD,mCAAmC;QACnC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAC;QACxD,OAAO,UAAU,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC,CAAC,mBAAmB;IACrC,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,YAAY;IAC1B,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;IAChC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,kCAAkC,OAAO,EAAE,CAAC,CAAC;IACzD,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;AACrC,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,kBAAkB,CAAC,UAAkB,EAAE,UAAkB;IACvE,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC;IACvC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,QAAQ,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,OAAO,yBAAyB,CAAC,CAAC;IAC1H,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,uEAAuE,CAAC,CAAC;IACrF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;AACrC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"explainFlag.d.ts","sourceRoot":"","sources":["../src/explainFlag.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAGnF;;;GAGG;AACH,wBAAgB,WAAW,CAAC,EAC1B,OAAO,EACP,IAAS,EACT,OAAY,EACZ,SAAkC,EAClC,UAA0C,EAC1C,MAAgB,GACjB,EAAE;IACD,OAAO,EAAE,GAAG,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,CAAC,EAAE,aAAa,CAAC;CACxB,QA8CA"}
1
+ {"version":3,"file":"explainFlag.d.ts","sourceRoot":"","sources":["../src/explainFlag.ts"],"names":[],"mappings":"AACA,OAAO,EAAoB,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAMnF;;;GAGG;AACH,wBAAgB,WAAW,CAAC,EAC1B,OAAO,EACP,IAAS,EACT,OAAY,EACZ,SAAkC,EAClC,UAA0C,EAC1C,MAAgB,GACjB,EAAE;IACD,OAAO,EAAE,GAAG,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,MAAM,CAAC,EAAE,aAAa,CAAC;CACxB,QAkIA"}
@@ -1,4 +1,7 @@
1
+ import chalk from 'chalk';
1
2
  import { explainFormatter } from './formatters/explainFormatter.js';
3
+ import { getCliVersion, getVersion } from './branding/branding.js';
4
+ import os from 'os';
2
5
  /**
3
6
  * explainFlag - Automatically gathers command context, prints explanation, then runs the handler.
4
7
  * @param params - { commandName, args, options, handler }
@@ -6,6 +9,12 @@ import { explainFormatter } from './formatters/explainFormatter.js';
6
9
  export function explainFlag({ command, args = {}, options = {}, inputKeys = ['input', 'inputPath'], outputKeys = ['output', 'outputPath', 'o'], format = 'human', }) {
7
10
  // Auto-detect command name
8
11
  const commandName = command?.name?.() || command?._name || 'unknown';
12
+ const environment = {
13
+ cwd: process.cwd(),
14
+ os: `${os.type()} ${os.release()} (${os.platform()})`,
15
+ nodeVersion: process.version,
16
+ shell: process.env.SHELL || process.env.TERM || 'unknown',
17
+ };
9
18
  // Detect input/output paths
10
19
  let inputPath = '';
11
20
  let outputPath = '';
@@ -22,31 +31,115 @@ export function explainFlag({ command, args = {}, options = {}, inputKeys = ['in
22
31
  outputPath = options[k];
23
32
  }
24
33
  // Gather used flags
34
+ let explainValue = undefined;
35
+ if (typeof options.explain === 'string') {
36
+ explainValue = options.explain;
37
+ }
38
+ else if (Array.isArray(args._) && args._.length > 0) {
39
+ // Check for --explain details as positional
40
+ const idx = args._.findIndex((v) => v === 'explain');
41
+ if (idx !== -1 && args._[idx + 1]) {
42
+ explainValue = args._[idx + 1];
43
+ }
44
+ }
45
+ if (explainValue === 'details' || explainValue === 'json' || explainValue === 'human') {
46
+ format = explainValue;
47
+ }
48
+ // Gather all possible flags from command (Commander.js API)
25
49
  const usedFlags = {};
26
- for (const [key, value] of Object.entries(options)) {
27
- if (key === 'explain')
28
- continue;
29
- usedFlags[key] = { value, source: value !== undefined ? 'user' : 'system' };
50
+ const omittedFlags = {};
51
+ if (command && typeof command.options === 'object') {
52
+ for (const opt of command.options) {
53
+ const flagName = opt.attributeName || opt.long?.replace(/^--/, '') || opt.short?.replace(/^-/, '');
54
+ if (!flagName)
55
+ continue;
56
+ const userValue = options[flagName];
57
+ if (userValue !== undefined) {
58
+ usedFlags[flagName] = { value: userValue, source: 'user' };
59
+ }
60
+ else if (Object.prototype.hasOwnProperty.call(opt, 'defaultValue')) {
61
+ usedFlags[flagName] = { value: opt.defaultValue, source: 'default' };
62
+ omittedFlags[flagName] = { defaultValue: opt.defaultValue, source: 'default' };
63
+ }
64
+ else {
65
+ usedFlags[flagName] = { value: undefined, source: 'system' };
66
+ }
67
+ }
68
+ }
69
+ else {
70
+ for (const [key, value] of Object.entries(options)) {
71
+ if (key === 'explain')
72
+ continue;
73
+ usedFlags[key] = { value, source: value !== undefined ? 'user' : 'system' };
74
+ }
75
+ }
76
+ // Build ExplainContext with plugin/command info and version
77
+ // Get CLI and plugin version using branding utilities
78
+ let cliVersion = undefined;
79
+ let pluginVersion = undefined;
80
+ try {
81
+ cliVersion = getCliVersion();
82
+ // Try to get plugin version from parent command's package.json if available
83
+ if (command?.parent?.name?.()) {
84
+ // Assume plugin package.json is at ../../plugins/<plugin>/package.json
85
+ const pluginName = command.parent.name();
86
+ const pluginPath = `../../plugins/${pluginName}/package.json`;
87
+ pluginVersion = getVersion(pluginPath);
88
+ }
89
+ }
90
+ catch (error) {
91
+ console.error(chalk.red('Error retrieving version information:'), error);
30
92
  }
31
- // Build ExplainContext
32
93
  const context = {
33
94
  command: commandName,
95
+ plugin: command?.parent?.name?.() || undefined,
96
+ cliVersion,
97
+ pluginVersion,
34
98
  inputs: { inputPath, outputPath },
35
99
  usedFlags,
100
+ omittedFlags: Object.keys(omittedFlags).length > 0 ? omittedFlags : undefined,
36
101
  decisions: Object.entries(usedFlags).map(([key, v]) => ({
37
102
  key,
38
103
  value: v.value,
39
- reason: v.source === 'user' ? 'user specified' : 'default',
104
+ reason: v.source === 'user' ? 'user specified' : (v.source === 'default' ? 'default' : 'system'),
40
105
  })),
41
106
  outcome: {
42
107
  result: outputPath ? `A new file will be created at ${outputPath}` : 'Operation will complete',
43
- sideEffects: [],
108
+ sideEffects: [
109
+ 'Input validation is performed to ensure correct file types and dimensions.',
110
+ 'Output paths are resolved and checked for conflicts.',
111
+ 'Image processing is performed using the selected options and flags.',
112
+ 'Results and logs are displayed after processing each file.'
113
+ ],
114
+ errors: [], // Placeholder for error reporting
115
+ warnings: [], // Placeholder for warning reporting
116
+ },
117
+ explainFlow: [
118
+ '1. Parse and validate all user-provided flags and arguments.',
119
+ '2. Check input and output paths for validity and existence.',
120
+ '3. Prepare configuration for image processing (width, height, quality, etc.).',
121
+ '4. For each input file, process and apply transformations.',
122
+ '5. Save output files and display results.',
123
+ '6. Show summary and any errors encountered.'
124
+ ],
125
+ environment,
126
+ technical: {
127
+ library: 'sharp',
128
+ tool: 'mediaproc',
129
+ performance: 'optimized for batch image processing',
130
+ fileFormats: ['jpg', 'png', 'webp'],
131
+ compressionRatio: 'varies by format and quality',
132
+ estimatedTime: 'depends on input size and options',
133
+ memoryUsage: 'depends on batch size and image dimensions',
44
134
  },
45
135
  };
46
136
  // Print explanation only
47
137
  const explanation = explainFormatter(context, format);
48
138
  if (format === 'json') {
49
- console.log(JSON.stringify(explanation, null, 2));
139
+ // Add a styled header for JSON output
140
+ // Print JSON with a clear header
141
+ console.log(chalk.bold.bgBlueBright.white(' EXPLANATION (JSON) '));
142
+ console.log(chalk.gray(JSON.stringify(explanation, null, 2)));
50
143
  }
51
144
  else {
52
145
  console.log(explanation);
@@ -1 +1 @@
1
- {"version":3,"file":"explainFlag.js","sourceRoot":"","sources":["../src/explainFlag.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAiB,MAAM,kCAAkC,CAAC;AAGnF;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,EAC1B,OAAO,EACP,IAAI,GAAG,EAAE,EACT,OAAO,GAAG,EAAE,EACZ,SAAS,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,EAClC,UAAU,GAAG,CAAC,QAAQ,EAAE,YAAY,EAAE,GAAG,CAAC,EAC1C,MAAM,GAAG,OAAO,GAQjB;IACC,2BAA2B;IAC3B,MAAM,WAAW,GAAG,OAAO,EAAE,IAAI,EAAE,EAAE,IAAI,OAAO,EAAE,KAAK,IAAI,SAAS,CAAC;IAErE,4BAA4B;IAC5B,IAAI,SAAS,GAAG,EAAE,CAAC;IACnB,IAAI,UAAU,GAAG,EAAE,CAAC;IACpB,KAAK,MAAM,CAAC,IAAI,SAAS,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,CAAC,CAAC;YAAE,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,OAAO,CAAC,CAAC,CAAC;YAAE,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC;IACD,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC;QAC3B,IAAI,IAAI,CAAC,CAAC,CAAC;YAAE,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,IAAI,OAAO,CAAC,CAAC,CAAC;YAAE,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC;IAED,oBAAoB;IACpB,MAAM,SAAS,GAA8D,EAAE,CAAC;IAChF,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACnD,IAAI,GAAG,KAAK,SAAS;YAAE,SAAS;QAChC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9E,CAAC;IAED,uBAAuB;IACvB,MAAM,OAAO,GAAmB;QAC9B,OAAO,EAAE,WAAW;QACpB,MAAM,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE;QACjC,SAAS;QACT,SAAS,EAAE,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtD,GAAG;YACH,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,MAAM,EAAE,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS;SAC3D,CAAC,CAAC;QACH,OAAO,EAAE;YACP,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,iCAAiC,UAAU,EAAE,CAAC,CAAC,CAAC,yBAAyB;YAC9F,WAAW,EAAE,EAAE;SAChB;KACF,CAAC;IAEF,yBAAyB;IACzB,MAAM,WAAW,GAAG,gBAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACtD,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"explainFlag.js","sourceRoot":"","sources":["../src/explainFlag.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"explainFormatter.d.ts","sourceRoot":"","sources":["../../src/formatters/explainFormatter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAE1D,MAAM,MAAM,aAAa,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEzD;;GAEG;AACH,wBAAgB,gBAAgB,CAC/B,OAAO,EAAE,cAAc,EACvB,MAAM,GAAE,aAAuB,EAC/B,KAAK,GAAE,MAAM,GAAG,OAAO,GAAG,KAAc,GACtC,MAAM,GAAG,MAAM,CAgDjB"}
1
+ {"version":3,"file":"explainFormatter.d.ts","sourceRoot":"","sources":["../../src/formatters/explainFormatter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAG1D,MAAM,MAAM,aAAa,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEzD;;GAEG;AACH,wBAAgB,gBAAgB,CAC/B,OAAO,EAAE,cAAc,EACvB,MAAM,GAAE,aAAuB,EAC/B,KAAK,GAAE,MAAM,GAAG,OAAO,GAAG,KAAc,GACtC,MAAM,GAAG,MAAM,CAwMjB"}
@@ -1,3 +1,4 @@
1
+ import chalk from 'chalk';
1
2
  /**
2
3
  * Main explain formatter. Returns a string (or JSON) for the given context and format.
3
4
  */
@@ -12,38 +13,200 @@ export function explainFormatter(context, format = 'human', tense = 'will') {
12
13
  would: { what: 'would', result: 'would be', why: 'Why' },
13
14
  did: { what: 'was', result: 'was', why: 'Why' },
14
15
  }[tense];
15
- // Human-first (default)
16
16
  let output = '';
17
- output += `What ${tenseMap.what} happen:\n`;
18
- for (const d of context.decisions) {
19
- output += `• ${decisionToHuman(d)}\n`;
20
- }
21
- if (context.outcome && context.outcome.result) {
22
- output += `\nResult:\n• ${context.outcome.result}\n`;
23
- if (context.outcome.sideEffects && context.outcome.sideEffects.length > 0) {
24
- for (const s of context.outcome.sideEffects) {
25
- output += `• ${s}\n`;
17
+ if (format === 'human') {
18
+ output += chalk.bold.bgBlueBright.white('╔════════════════════════════════════════════════════════════════╗') + '\n';
19
+ output += chalk.bold.bgBlueBright.white('║ EXPLANATION ║') + '\n';
20
+ output += chalk.bold.bgBlueBright.white('╚════════════════════════════════════════════════════════════════╝') + '\n';
21
+ if (context.plugin || context.cliVersion || context.pluginVersion) {
22
+ output += chalk.bold(`Plugin: ${context.plugin || 'N/A'} | CLI Version: ${context.cliVersion || 'N/A'} | Plugin Version: ${context.pluginVersion || 'N/A'}`) + '\n';
23
+ }
24
+ output += chalk.bold.underline(`\n${chalk.cyan('What ' + tenseMap.what + ' happen:')}`) + '\n';
25
+ for (const d of context.decisions) {
26
+ let valueStr = (d.value === undefined || Number.isNaN(d.value)) ? 'N/A' : d.value;
27
+ output += chalk.green(`• ${decisionToHuman({ ...d, value: valueStr })}`);
28
+ if (d.provenance)
29
+ output += chalk.gray(` [${d.provenance}]`);
30
+ if (d.omitted)
31
+ output += chalk.gray(' (omitted)');
32
+ output += '\n';
33
+ }
34
+ if (context.outcome && context.outcome.result) {
35
+ output += chalk.bold.underline(`\n${chalk.cyan('Result:')}`) + '\n';
36
+ output += chalk.yellow(`• ${context.outcome.result}`) + '\n';
37
+ if (context.outcome.sideEffects && context.outcome.sideEffects.length > 0) {
38
+ for (const s of context.outcome.sideEffects) {
39
+ output += chalk.yellow(`• ${s}`) + '\n';
40
+ }
41
+ }
42
+ // Error/warning reporting
43
+ if (context.outcome.errors && context.outcome.errors.length > 0) {
44
+ output += chalk.redBright.bold(`\nErrors:`) + '\n';
45
+ for (const err of context.outcome.errors) {
46
+ output += chalk.redBright(`• ${err}`) + '\n';
47
+ }
48
+ }
49
+ if (context.outcome.warnings && context.outcome.warnings.length > 0) {
50
+ output += chalk.yellowBright.bold(`\nWarnings:`) + '\n';
51
+ for (const warn of context.outcome.warnings) {
52
+ output += chalk.yellowBright(`• ${warn}`) + '\n';
53
+ }
54
+ }
55
+ }
56
+ output += chalk.bold.underline(`\n${chalk.cyan(tenseMap.why + ':')}`) + '\n';
57
+ for (const d of context.decisions) {
58
+ let valueStr = (d.value === undefined || Number.isNaN(d.value)) ? 'N/A' : d.value;
59
+ output += chalk.magenta(`• ${decisionToWhy({ ...d, value: valueStr })}`);
60
+ if (d.provenance)
61
+ output += chalk.gray(` [${d.provenance}]`);
62
+ if (d.omitted)
63
+ output += chalk.gray(' (omitted)');
64
+ output += '\n';
65
+ }
66
+ // Show omitted flags
67
+ if (context.omittedFlags && Object.keys(context.omittedFlags).length > 0) {
68
+ output += chalk.bold.underline(`\n${chalk.cyan('Omitted Flags:')}`) + '\n';
69
+ for (const [k, v] of Object.entries(context.omittedFlags)) {
70
+ output += chalk.gray(`• ${k}: ${v.defaultValue} (${v.source})`) + '\n';
71
+ }
72
+ }
73
+ // Show deprecated flags
74
+ if (context.deprecatedFlags && context.deprecatedFlags.length > 0) {
75
+ output += chalk.bold.underline(`\n${chalk.cyan('Deprecated Flags:')}`) + '\n';
76
+ for (const k of context.deprecatedFlags) {
77
+ output += chalk.redBright(`• ${k}`) + '\n';
78
+ }
79
+ }
80
+ // Show ignored flags
81
+ if (context.ignoredFlags && context.ignoredFlags.length > 0) {
82
+ output += chalk.bold.underline(`\n${chalk.cyan('Ignored Flags:')}`) + '\n';
83
+ for (const k of context.ignoredFlags) {
84
+ output += chalk.gray(`• ${k}`) + '\n';
85
+ }
86
+ }
87
+ // Show custom sections for plugin extensibility
88
+ if (context.customSections && context.customSections.length > 0) {
89
+ for (const section of context.customSections) {
90
+ output += chalk.bold.underline(`\n${chalk.cyan(section.title)}`) + '\n';
91
+ for (const item of section.items) {
92
+ output += chalk.whiteBright(`• ${item}`) + '\n';
93
+ }
94
+ }
95
+ }
96
+ // Technical details
97
+ if (context.technical) {
98
+ output += chalk.bold.underline(`\n${chalk.cyan('Technical details:')}`) + '\n';
99
+ for (const [k, v] of Object.entries(context.technical)) {
100
+ let valueStr = (v === undefined || Number.isNaN(v)) ? 'N/A' : v;
101
+ output += chalk.gray(`• ${k}: ${valueStr}`) + '\n';
26
102
  }
27
103
  }
28
104
  }
29
- output += `\n${tenseMap.why}:\n`;
30
- for (const d of context.decisions) {
31
- output += `• ${decisionToWhy(d)}\n`;
32
- }
33
- if (format === 'details') {
34
- // Add technical details if present
105
+ else if (format === 'details') {
106
+ output += chalk.bold.bgMagenta.white('╔════════════════════════════════════════════════════════════════╗') + '\n';
107
+ output += chalk.bold.bgMagenta.white('║ EXPLANATION (DETAILS) ║') + '\n';
108
+ output += chalk.bold.bgMagenta.white('╚════════════════════════════════════════════════════════════════╝') + '\n';
109
+ if (context.plugin || context.cliVersion || context.pluginVersion) {
110
+ output += chalk.bold(`Plugin: ${context.plugin || 'N/A'} | CLI Version: ${context.cliVersion || 'N/A'} | Plugin Version: ${context.pluginVersion || 'N/A'}`) + '\n';
111
+ }
112
+ output += chalk.bold.underline(`\n${chalk.cyan('What ' + tenseMap.what + ' happen:')}`) + '\n';
113
+ for (const d of context.decisions) {
114
+ let valueStr = (d.value === undefined || Number.isNaN(d.value)) ? 'N/A' : d.value;
115
+ output += chalk.greenBright(`• ${decisionToHuman({ ...d, value: valueStr })}`);
116
+ if (d.provenance)
117
+ output += chalk.gray(` [${d.provenance}]`);
118
+ if (d.omitted)
119
+ output += chalk.gray(' (omitted)');
120
+ output += '\n';
121
+ }
122
+ if (context.outcome && context.outcome.result) {
123
+ output += chalk.bold.underline(`\n${chalk.cyan('Result:')}`) + '\n';
124
+ output += chalk.yellowBright(`• ${context.outcome.result}`) + '\n';
125
+ if (context.outcome.sideEffects && context.outcome.sideEffects.length > 0) {
126
+ for (const s of context.outcome.sideEffects) {
127
+ output += chalk.yellowBright(`• ${s}`) + '\n';
128
+ }
129
+ }
130
+ // Error/warning reporting
131
+ if (context.outcome.errors && context.outcome.errors.length > 0) {
132
+ output += chalk.redBright.bold(`\nErrors:`) + '\n';
133
+ for (const err of context.outcome.errors) {
134
+ output += chalk.redBright(`• ${err}`) + '\n';
135
+ }
136
+ }
137
+ if (context.outcome.warnings && context.outcome.warnings.length > 0) {
138
+ output += chalk.yellowBright.bold(`\nWarnings:`) + '\n';
139
+ for (const warn of context.outcome.warnings) {
140
+ output += chalk.yellowBright(`• ${warn}`) + '\n';
141
+ }
142
+ }
143
+ }
144
+ output += chalk.bold.underline(`\n${chalk.cyan(tenseMap.why + ':')}`) + '\n';
145
+ for (const d of context.decisions) {
146
+ let valueStr = (d.value === undefined || Number.isNaN(d.value)) ? 'N/A' : d.value;
147
+ output += chalk.magentaBright(`• ${decisionToWhy({ ...d, value: valueStr })}`);
148
+ if (d.provenance)
149
+ output += chalk.gray(` [${d.provenance}]`);
150
+ if (d.omitted)
151
+ output += chalk.gray(' (omitted)');
152
+ output += '\n';
153
+ }
154
+ // Show omitted flags
155
+ if (context.omittedFlags && Object.keys(context.omittedFlags).length > 0) {
156
+ output += chalk.bold.underline(`\n${chalk.cyan('Omitted Flags:')}`) + '\n';
157
+ for (const [k, v] of Object.entries(context.omittedFlags)) {
158
+ output += chalk.gray(`• ${k}: ${v.defaultValue} (${v.source})`) + '\n';
159
+ }
160
+ }
161
+ // Show deprecated flags
162
+ if (context.deprecatedFlags && context.deprecatedFlags.length > 0) {
163
+ output += chalk.bold.underline(`\n${chalk.cyan('Deprecated Flags:')}`) + '\n';
164
+ for (const k of context.deprecatedFlags) {
165
+ output += chalk.redBright(`• ${k}`) + '\n';
166
+ }
167
+ }
168
+ // Show ignored flags
169
+ if (context.ignoredFlags && context.ignoredFlags.length > 0) {
170
+ output += chalk.bold.underline(`\n${chalk.cyan('Ignored Flags:')}`) + '\n';
171
+ for (const k of context.ignoredFlags) {
172
+ output += chalk.gray(`• ${k}`) + '\n';
173
+ }
174
+ }
175
+ // Show custom sections for plugin extensibility
176
+ if (context.customSections && context.customSections.length > 0) {
177
+ for (const section of context.customSections) {
178
+ output += chalk.bold.underline(`\n${chalk.cyan(section.title)}`) + '\n';
179
+ for (const item of section.items) {
180
+ output += chalk.whiteBright(`• ${item}`) + '\n';
181
+ }
182
+ }
183
+ }
184
+ // Technical details
185
+ if (context.technical) {
186
+ output += chalk.bold.underline(`\n${chalk.cyan('Technical details:')}`) + '\n';
187
+ for (const [k, v] of Object.entries(context.technical)) {
188
+ output += chalk.gray(`• ${k}: ${v}`) + '\n';
189
+ }
190
+ }
35
191
  if (context.inferred) {
36
- output += `\nTechnical details:\n`;
37
192
  for (const [k, v] of Object.entries(context.inferred)) {
38
- output += `• ${k}: ${v}\n`;
193
+ output += chalk.gray(`• ${k}: ${v}`) + '\n';
39
194
  }
40
195
  }
41
196
  if (context.usedFlags) {
42
- output += `\nFlags used:\n`;
197
+ output += chalk.bold.underline(`\n${chalk.cyan('Flags used:')}`) + '\n';
43
198
  for (const [k, v] of Object.entries(context.usedFlags)) {
44
- output += `• ${k}: ${v.value} (${v.source})\n`;
199
+ let valueStr = (v.value === undefined || Number.isNaN(v.value)) ? 'N/A' : v.value;
200
+ output += chalk.gray(`• ${k}: ${valueStr} (${v.source})`) + '\n';
45
201
  }
46
202
  }
203
+ // Add extra info for developers
204
+ output += chalk.bold.underline(`\n${chalk.cyan('Execution flow:')}`) + '\n';
205
+ output += chalk.whiteBright('• Input validation, output path resolution, image processing, result summary') + '\n';
206
+ output += chalk.whiteBright('• All steps are performed in sequence for each input file') + '\n';
207
+ if (context.environment) {
208
+ output += chalk.bold(`Environment: cwd=${context.environment.cwd}, OS=${context.environment.os}, Node=${context.environment.nodeVersion}, Shell=${context.environment.shell}`) + '\n';
209
+ }
47
210
  }
48
211
  return output.trim();
49
212
  }
@@ -1 +1 @@
1
- {"version":3,"file":"explainFormatter.js","sourceRoot":"","sources":["../../src/formatters/explainFormatter.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"explainFormatter.js","sourceRoot":"","sources":["../../src/formatters/explainFormatter.ts"],"names":[],"mappings":"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"}
@@ -1,27 +1,66 @@
1
- export type ExplainFlagSource = 'user' | 'system';
1
+ export type ExplainFlagSource = 'user' | 'system' | 'default' | 'deprecated' | 'ignored';
2
2
  export interface ExplainDecision {
3
3
  key: string;
4
4
  value: any;
5
5
  reason: string;
6
+ provenance?: ExplainFlagSource;
7
+ omitted?: boolean;
6
8
  }
7
9
  export interface ExplainContext {
8
10
  command: string;
11
+ plugin?: string;
12
+ commandGroup?: string;
13
+ cliVersion?: string;
14
+ pluginVersion?: string;
9
15
  inputs: {
10
16
  [key: string]: any;
11
17
  };
18
+ outputs?: {
19
+ [key: string]: any;
20
+ };
12
21
  usedFlags: {
13
22
  [flag: string]: {
14
23
  value: any;
15
24
  source: ExplainFlagSource;
16
25
  };
17
26
  };
27
+ omittedFlags?: {
28
+ [flag: string]: {
29
+ defaultValue: any;
30
+ source: ExplainFlagSource;
31
+ };
32
+ };
18
33
  inferred?: {
19
34
  [key: string]: any;
20
35
  };
36
+ deprecatedFlags?: string[];
37
+ ignoredFlags?: string[];
21
38
  decisions: ExplainDecision[];
22
39
  outcome: {
23
40
  result: string;
24
41
  sideEffects?: string[];
42
+ errors?: string[];
43
+ warnings?: string[];
44
+ };
45
+ explainFlow?: string[];
46
+ environment?: {
47
+ cwd?: string;
48
+ os?: string;
49
+ nodeVersion?: string;
50
+ shell?: string;
51
+ };
52
+ technical?: {
53
+ library?: string;
54
+ tool?: string;
55
+ performance?: string;
56
+ fileFormats?: string[];
57
+ compressionRatio?: string;
58
+ estimatedTime?: string;
59
+ memoryUsage?: string;
25
60
  };
61
+ customSections?: Array<{
62
+ title: string;
63
+ items: string[];
64
+ }>;
26
65
  }
27
66
  //# sourceMappingURL=explainTypes.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"explainTypes.d.ts","sourceRoot":"","sources":["../../src/types/explainTypes.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,iBAAiB,GAAG,MAAM,GAAG,QAAQ,CAAC;AAElD,MAAM,WAAW,eAAe;IAC9B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,GAAG,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE;QACN,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;KACpB,CAAC;IACF,SAAS,EAAE;QACT,CAAC,IAAI,EAAE,MAAM,GAAG;YAAE,KAAK,EAAE,GAAG,CAAC;YAAC,MAAM,EAAE,iBAAiB,CAAA;SAAE,CAAC;KAC3D,CAAC;IACF,QAAQ,CAAC,EAAE;QACT,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;KACpB,CAAC;IACF,SAAS,EAAE,eAAe,EAAE,CAAC;IAC7B,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;KACxB,CAAC;CACH"}
1
+ {"version":3,"file":"explainTypes.d.ts","sourceRoot":"","sources":["../../src/types/explainTypes.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,iBAAiB,GAAG,MAAM,GAAG,QAAQ,GAAG,SAAS,GAAG,YAAY,GAAG,SAAS,CAAC;AACzF,MAAM,WAAW,eAAe;IAC9B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,GAAG,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAGD,MAAM,WAAW,cAAc;IAE7B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IAGvB,MAAM,EAAE;QACN,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;KACpB,CAAC;IACF,OAAO,CAAC,EAAE;QACR,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;KACpB,CAAC;IAGF,SAAS,EAAE;QACT,CAAC,IAAI,EAAE,MAAM,GAAG;YAAE,KAAK,EAAE,GAAG,CAAC;YAAC,MAAM,EAAE,iBAAiB,CAAA;SAAE,CAAC;KAC3D,CAAC;IACF,YAAY,CAAC,EAAE;QACb,CAAC,IAAI,EAAE,MAAM,GAAG;YAAE,YAAY,EAAE,GAAG,CAAC;YAAC,MAAM,EAAE,iBAAiB,CAAA;SAAE,CAAC;KAClE,CAAC;IACF,QAAQ,CAAC,EAAE;QACT,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;KACpB,CAAC;IACF,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAGxB,SAAS,EAAE,eAAe,EAAE,CAAC;IAC7B,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QACvB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;KACrB,CAAC;IACF,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IAGvB,WAAW,CAAC,EAAE;QACZ,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IAGF,SAAS,CAAC,EAAE;QACV,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QACvB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,CAAC;IAGF,cAAc,CAAC,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;CAC5D"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mediaproc/core",
3
- "version": "1.2.0",
3
+ "version": "1.2.2",
4
4
  "description": "Core utilities for MediaProc CLI and Plugins",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",