@kb-labs/core-sys 1.0.0 → 1.2.0

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 (53) hide show
  1. package/dist/fs/__tests__/fs.spec.d.ts +2 -0
  2. package/dist/fs/__tests__/fs.spec.d.ts.map +1 -0
  3. package/dist/fs/__tests__/fs.spec.js +22 -0
  4. package/dist/fs/__tests__/fs.spec.js.map +1 -0
  5. package/dist/fs/fs.d.ts +6 -0
  6. package/dist/fs/fs.d.ts.map +1 -0
  7. package/dist/fs/fs.js +12 -0
  8. package/dist/fs/fs.js.map +1 -0
  9. package/dist/fs/index.d.ts +2 -0
  10. package/dist/fs/index.d.ts.map +1 -0
  11. package/dist/fs/index.js +2 -0
  12. package/dist/fs/index.js.map +1 -0
  13. package/dist/index.d.ts +5 -166
  14. package/dist/index.d.ts.map +1 -0
  15. package/dist/index.js +4 -347
  16. package/dist/index.js.map +1 -1
  17. package/dist/output/factory.d.ts +20 -0
  18. package/dist/output/factory.d.ts.map +1 -0
  19. package/dist/output/factory.js +101 -0
  20. package/dist/output/factory.js.map +1 -0
  21. package/dist/output/index.d.ts +8 -0
  22. package/dist/output/index.d.ts.map +1 -0
  23. package/dist/output/index.js +7 -0
  24. package/dist/output/index.js.map +1 -0
  25. package/dist/output/output-impl.d.ts +40 -0
  26. package/dist/output/output-impl.d.ts.map +1 -0
  27. package/dist/output/output-impl.js +241 -0
  28. package/dist/output/output-impl.js.map +1 -0
  29. package/dist/output/types.d.ts +122 -0
  30. package/dist/output/types.d.ts.map +1 -0
  31. package/dist/output/types.js +6 -0
  32. package/dist/output/types.js.map +1 -0
  33. package/dist/repo/__tests__/repo.spec.d.ts +2 -0
  34. package/dist/repo/__tests__/repo.spec.d.ts.map +1 -0
  35. package/dist/repo/__tests__/repo.spec.js +25 -0
  36. package/dist/repo/__tests__/repo.spec.js.map +1 -0
  37. package/dist/repo/index.d.ts +2 -0
  38. package/dist/repo/index.d.ts.map +1 -0
  39. package/dist/repo/index.js +2 -0
  40. package/dist/repo/index.js.map +1 -0
  41. package/dist/repo/repo.d.ts +11 -0
  42. package/dist/repo/repo.d.ts.map +1 -0
  43. package/dist/repo/repo.js +36 -0
  44. package/dist/repo/repo.js.map +1 -0
  45. package/dist/types/index.d.ts +2 -0
  46. package/dist/types/index.d.ts.map +1 -0
  47. package/dist/types/index.js +2 -0
  48. package/dist/types/index.js.map +1 -0
  49. package/dist/types/types.d.ts +6 -0
  50. package/dist/types/types.d.ts.map +1 -0
  51. package/dist/types/types.js +2 -0
  52. package/dist/types/types.js.map +1 -0
  53. package/package.json +13 -13
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/factory
3
+ * Output factory with auto-detection
4
+ */
5
+ import type { Output, OutputMode, VerbosityLevel, DebugFormat, OutputLogSink } from "./types";
6
+ export interface OutputConfig {
7
+ verbosity?: VerbosityLevel;
8
+ mode?: OutputMode;
9
+ format?: DebugFormat;
10
+ json?: boolean;
11
+ sinks?: OutputLogSink[];
12
+ category?: string;
13
+ context?: {
14
+ plugin?: string;
15
+ command?: string;
16
+ trace?: string;
17
+ };
18
+ }
19
+ export declare function createOutput(config?: OutputConfig): Output;
20
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/output/factory.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,WAAW,EAAE,aAAa,EAAgB,MAAM,SAAS,CAAC;AA4D5G,MAAM,WAAW,YAAY;IACzB,SAAS,CAAC,EAAE,cAAc,CAAC;IAC3B,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE;QAEN,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,KAAK,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC;CACL;AAED,wBAAgB,YAAY,CAAC,MAAM,GAAE,YAAiB,GAAG,MAAM,CAwC9D"}
@@ -0,0 +1,101 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/factory
3
+ * Output factory with auto-detection
4
+ */
5
+ import { OutputImpl } from "./output-impl";
6
+ class ConsoleLogger {
7
+ level;
8
+ bindings;
9
+ constructor(level, bindings = {}) {
10
+ this.level = level;
11
+ this.bindings = bindings;
12
+ }
13
+ canLog(target) {
14
+ const rank = {
15
+ silent: 0,
16
+ error: 1,
17
+ warn: 2,
18
+ info: 3,
19
+ debug: 4,
20
+ trace: 5,
21
+ };
22
+ return rank[target] <= rank[this.level];
23
+ }
24
+ withMeta(meta) {
25
+ const merged = { ...this.bindings, ...(meta ?? {}) };
26
+ return Object.keys(merged).length > 0 ? ` ${JSON.stringify(merged)}` : "";
27
+ }
28
+ info(message, meta) {
29
+ if (this.canLog("info")) {
30
+ console.log(`[INFO] ${message}${this.withMeta(meta)}`);
31
+ }
32
+ }
33
+ warn(message, meta) {
34
+ if (this.canLog("warn")) {
35
+ console.warn(`[WARN] ${message}${this.withMeta(meta)}`);
36
+ }
37
+ }
38
+ error(message, error, meta) {
39
+ if (this.canLog("error")) {
40
+ const payload = error
41
+ ? { ...meta, error: { message: error.message, stack: error.stack } }
42
+ : meta;
43
+ console.error(`[ERROR] ${message}${this.withMeta(payload)}`);
44
+ }
45
+ }
46
+ debug(message, meta) {
47
+ if (this.canLog("debug")) {
48
+ console.debug(`[DEBUG] ${message}${this.withMeta(meta)}`);
49
+ }
50
+ }
51
+ child(bindings) {
52
+ return new ConsoleLogger(this.level, { ...this.bindings, ...bindings });
53
+ }
54
+ }
55
+ export function createOutput(config = {}) {
56
+ // Auto-detect mode
57
+ const mode = config.mode || detectMode();
58
+ // Verbosity из конфига или normal по умолчанию
59
+ const verbosity = config.verbosity || "normal";
60
+ // Format
61
+ const format = config.format || (config.json ? "ai" : "human");
62
+ // Создать sinks только для форматированного вывода пользователю
63
+ const sinks = config.sinks || [];
64
+ const loggerLevel = verbosity === "inspect"
65
+ ? "trace"
66
+ : verbosity === "debug"
67
+ ? "debug"
68
+ : verbosity === "verbose"
69
+ ? "info"
70
+ : verbosity === "quiet"
71
+ ? "silent"
72
+ : "info";
73
+ const logger = new ConsoleLogger(loggerLevel, {
74
+ category: config.category || "output",
75
+ ...(config.context || {}),
76
+ });
77
+ // Создать Output implementation
78
+ return new OutputImpl({
79
+ mode,
80
+ verbosity,
81
+ format,
82
+ json: config.json || false,
83
+ sinks, // Только ConsoleSink для UI
84
+ logger, // Глобальный logger для записи в файлы
85
+ category: config.category,
86
+ context: config.context,
87
+ });
88
+ }
89
+ function detectMode() {
90
+ // CI environment
91
+ if (process.env.CI === "true") {
92
+ return "ci";
93
+ }
94
+ // TTY
95
+ if (process.stdout.isTTY) {
96
+ return "tty";
97
+ }
98
+ // Pipe
99
+ return "pipe";
100
+ }
101
+ //# sourceMappingURL=factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/output/factory.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output
3
+ * Unified Output system for KB Labs platform
4
+ */
5
+ export * from "./types";
6
+ export { createOutput } from "./factory";
7
+ export type { OutputConfig } from "./factory";
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/output/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,SAAS,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output
3
+ * Unified Output system for KB Labs platform
4
+ */
5
+ export * from "./types";
6
+ export { createOutput } from "./factory";
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/output/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,SAAS,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/output-impl
3
+ * Output implementation
4
+ */
5
+ import type { Output, OutputMode, VerbosityLevel, DebugFormat, OutputLogSink, OutputLogger, ErrorOptions, ProgressDetails, UIUtilities, Spinner } from "./types";
6
+ export declare class OutputImpl implements Output {
7
+ private config;
8
+ constructor(config: {
9
+ mode: OutputMode;
10
+ verbosity: VerbosityLevel;
11
+ format: DebugFormat;
12
+ json: boolean;
13
+ sinks: OutputLogSink[];
14
+ logger: OutputLogger;
15
+ category?: string;
16
+ context?: Record<string, unknown>;
17
+ });
18
+ get mode(): OutputMode;
19
+ get verbosity(): VerbosityLevel;
20
+ get isQuiet(): boolean;
21
+ get isVerbose(): boolean;
22
+ get isDebug(): boolean;
23
+ get isJSON(): boolean;
24
+ get isAIFormat(): boolean;
25
+ get ui(): UIUtilities;
26
+ success(message: string, data?: Record<string, unknown>): void;
27
+ error(error: Error | string, options?: ErrorOptions): void;
28
+ warn(message: string, hint?: string): void;
29
+ progress(stage: string, details?: ProgressDetails): void;
30
+ spinner(text: string): Spinner;
31
+ info(message: string, meta?: Record<string, unknown>): void;
32
+ debug(message: string, meta?: Record<string, unknown>): void;
33
+ trace(message: string, meta?: Record<string, unknown>): void;
34
+ json(data: unknown): void;
35
+ write(text: string): void;
36
+ group(name: string): void;
37
+ groupEnd(): void;
38
+ private logToConsoleSink;
39
+ }
40
+ //# sourceMappingURL=output-impl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-impl.d.ts","sourceRoot":"","sources":["../../src/output/output-impl.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EACR,MAAM,EACN,UAAU,EACV,cAAc,EACd,WAAW,EACX,aAAa,EAEb,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,WAAW,EACX,OAAO,EACV,MAAM,SAAS,CAAC;AAYjB,qBAAa,UAAW,YAAW,MAAM;IAEjC,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE;QACZ,IAAI,EAAE,UAAU,CAAC;QACjB,SAAS,EAAE,cAAc,CAAC;QAC1B,MAAM,EAAE,WAAW,CAAC;QACpB,IAAI,EAAE,OAAO,CAAC;QACd,KAAK,EAAE,aAAa,EAAE,CAAC;QACvB,MAAM,EAAE,YAAY,CAAC;QACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACrC;IAIL,IAAI,IAAI,IAAI,UAAU,CAErB;IAED,IAAI,SAAS,IAAI,cAAc,CAE9B;IAED,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,MAAM,IAAI,OAAO,CAEpB;IAED,IAAI,UAAU,IAAI,OAAO,CAExB;IAED,IAAI,EAAE,IAAI,WAAW,CAuCpB;IAGD,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAc9D,KAAK,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY,GAAG,IAAI;IA8E1D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI;IAc1C,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,IAAI;IAoBxD,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI9B,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQ3D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQ5D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAQ5D,IAAI,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAIzB,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAKzB,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAMzB,QAAQ,IAAI,IAAI;IAQhB,OAAO,CAAC,gBAAgB;CAyB3B"}
@@ -0,0 +1,241 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/output-impl
3
+ * Output implementation
4
+ */
5
+ import { box, keyValue, table, createSpinner, safeColors, safeSymbols, sideBorderBox, } from "@kb-labs/shared-cli-ui";
6
+ import { formatTable } from "@kb-labs/shared-cli-ui/table";
7
+ export class OutputImpl {
8
+ config;
9
+ constructor(config) {
10
+ this.config = config;
11
+ }
12
+ // Getters
13
+ get mode() {
14
+ return this.config.mode;
15
+ }
16
+ get verbosity() {
17
+ return this.config.verbosity;
18
+ }
19
+ get isQuiet() {
20
+ return this.config.verbosity === "quiet";
21
+ }
22
+ get isVerbose() {
23
+ return ["verbose", "debug", "inspect"].includes(this.config.verbosity);
24
+ }
25
+ get isDebug() {
26
+ return ["debug", "inspect"].includes(this.config.verbosity);
27
+ }
28
+ get isJSON() {
29
+ return this.config.json;
30
+ }
31
+ get isAIFormat() {
32
+ return this.config.format === "ai";
33
+ }
34
+ get ui() {
35
+ return {
36
+ box,
37
+ sideBox: sideBorderBox,
38
+ table: (rows, headers) => {
39
+ if (headers && headers.length > 0) {
40
+ return formatTable(headers.map((h) => ({
41
+ header: h,
42
+ width: undefined,
43
+ align: "left",
44
+ })), rows.map((r) => r.map(String)), { header: true });
45
+ }
46
+ return table(rows.map((r) => r.map(String)));
47
+ },
48
+ keyValue,
49
+ spinner: (text, jsonMode) => createSpinner(text, jsonMode || this.isJSON),
50
+ colors: {
51
+ info: safeColors.info,
52
+ warn: safeColors.warning,
53
+ error: safeColors.error,
54
+ success: safeColors.success,
55
+ muted: safeColors.muted,
56
+ bold: safeColors.bold,
57
+ primary: safeColors.primary,
58
+ accent: safeColors.accent,
59
+ },
60
+ symbols: {
61
+ success: safeSymbols.success,
62
+ error: safeSymbols.error,
63
+ warning: safeSymbols.warning,
64
+ info: safeSymbols.info,
65
+ bullet: safeSymbols.bullet,
66
+ },
67
+ };
68
+ }
69
+ // Main methods
70
+ success(message, data) {
71
+ if (this.isJSON) {
72
+ this.json({ ok: true, message, ...data });
73
+ return;
74
+ }
75
+ if (this.isQuiet) {
76
+ return;
77
+ }
78
+ const output = `${safeSymbols.success} ${message}`;
79
+ console.log(safeColors.success(output));
80
+ // Использовать глобальный logger для записи в файлы
81
+ this.config.logger.info(message, data);
82
+ }
83
+ error(error, options) {
84
+ const message = error instanceof Error ? error.message : error;
85
+ const stack = error instanceof Error ? error.stack : undefined;
86
+ if (this.isJSON) {
87
+ this.json({
88
+ ok: false,
89
+ error: {
90
+ message,
91
+ code: options?.code,
92
+ context: options?.context,
93
+ suggestions: options?.suggestions,
94
+ },
95
+ });
96
+ return;
97
+ }
98
+ // Красивое форматирование ошибки
99
+ const lines = [];
100
+ if (options?.title) {
101
+ lines.push(safeColors.error(`${safeSymbols.error} ${options.title}`));
102
+ }
103
+ lines.push(safeColors.error(message));
104
+ if (options?.code) {
105
+ lines.push(safeColors.muted(`Code: ${options.code}`));
106
+ }
107
+ if (options?.context && Object.keys(options.context).length > 0) {
108
+ lines.push("");
109
+ lines.push(safeColors.bold("Context:"));
110
+ lines.push(...keyValue(Object.fromEntries(Object.entries(options.context).map(([k, v]) => [
111
+ k,
112
+ String(v),
113
+ ]))));
114
+ }
115
+ if (options?.suggestions && options.suggestions.length > 0) {
116
+ lines.push("");
117
+ lines.push(safeColors.bold("Suggestions:"));
118
+ options.suggestions.forEach((s) => {
119
+ lines.push(` ${safeSymbols.bullet} ${s}`);
120
+ });
121
+ }
122
+ if (options?.docs) {
123
+ lines.push("");
124
+ lines.push(safeColors.info(`Documentation: ${options.docs}`));
125
+ }
126
+ const boxed = box("Error", lines);
127
+ console.error(boxed);
128
+ // Использовать глобальный logger для записи в файлы
129
+ const errorMeta = {
130
+ code: options?.code,
131
+ context: options?.context,
132
+ };
133
+ if (stack) {
134
+ errorMeta.stack = stack;
135
+ }
136
+ if (error instanceof Error) {
137
+ this.config.logger.error(message, error);
138
+ }
139
+ else {
140
+ this.config.logger.error(message, undefined, errorMeta);
141
+ }
142
+ }
143
+ warn(message, hint) {
144
+ if (this.isQuiet) {
145
+ return;
146
+ }
147
+ const output = `${safeSymbols.warning} ${message}`;
148
+ console.warn(safeColors.warning(output));
149
+ if (hint) {
150
+ console.warn(safeColors.muted(` ${hint}`));
151
+ }
152
+ // Использовать глобальный logger для записи в файлы
153
+ this.config.logger.warn(message, { hint });
154
+ }
155
+ progress(stage, details) {
156
+ if (this.isQuiet) {
157
+ return;
158
+ }
159
+ let output = stage;
160
+ if (details?.current !== undefined && details?.total !== undefined) {
161
+ const percent = Math.round((details.current / details.total) * 100);
162
+ output += ` (${details.current}/${details.total}, ${percent}%)`;
163
+ }
164
+ if (details?.message) {
165
+ output += ` - ${details.message}`;
166
+ }
167
+ console.log(safeColors.info(output));
168
+ // Использовать глобальный logger для записи в файлы
169
+ this.config.logger.info(output, details);
170
+ }
171
+ spinner(text) {
172
+ return createSpinner(text, this.isJSON || this.isQuiet);
173
+ }
174
+ info(message, meta) {
175
+ if (!this.isVerbose) {
176
+ return;
177
+ }
178
+ console.log(message);
179
+ // Использовать глобальный logger для записи в файлы
180
+ this.config.logger.info(message, meta);
181
+ }
182
+ debug(message, meta) {
183
+ if (!this.isDebug) {
184
+ return;
185
+ }
186
+ console.log(safeColors.muted(message));
187
+ // Использовать глобальный logger для записи в файлы
188
+ this.config.logger.debug(message, meta);
189
+ }
190
+ trace(message, meta) {
191
+ if (this.verbosity !== "inspect") {
192
+ return;
193
+ }
194
+ console.log(safeColors.muted(`[TRACE] ${message}`));
195
+ // Использовать глобальный logger для записи в файлы (trace → debug)
196
+ this.config.logger.debug(message, { ...meta, trace: true });
197
+ }
198
+ json(data) {
199
+ console.log(JSON.stringify(data, null, 2));
200
+ }
201
+ write(text) {
202
+ if (this.isQuiet) {
203
+ return;
204
+ }
205
+ console.log(text);
206
+ }
207
+ group(name) {
208
+ if (this.isDebug) {
209
+ console.group(name);
210
+ }
211
+ }
212
+ groupEnd() {
213
+ if (this.isDebug) {
214
+ console.groupEnd();
215
+ }
216
+ }
217
+ // Internal method для форматированного вывода через ConsoleSink
218
+ // Используется только для UI вывода, не для записи в файлы
219
+ logToConsoleSink(level, msg, meta) {
220
+ const record = {
221
+ time: new Date().toISOString(),
222
+ ts: new Date().toISOString(),
223
+ level,
224
+ category: this.config.category,
225
+ msg,
226
+ meta: { ...this.config.context, ...meta },
227
+ };
228
+ // Отправить только в ConsoleSink для форматированного вывода
229
+ // Запись в файлы идет через глобальный logger
230
+ for (const sink of this.config.sinks) {
231
+ try {
232
+ void sink.handle(record);
233
+ }
234
+ catch (err) {
235
+ // Sink failures should not break execution
236
+ console.error("Sink error:", err);
237
+ }
238
+ }
239
+ }
240
+ }
241
+ //# sourceMappingURL=output-impl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-impl.js","sourceRoot":"","sources":["../../src/output/output-impl.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,122 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/types
3
+ * Unified Output interface for KB Labs platform
4
+ */
5
+ export type VerbosityLevel = "quiet" | "normal" | "verbose" | "debug" | "inspect";
6
+ export type OutputMode = "tty" | "pipe" | "ci";
7
+ export type DebugFormat = "human" | "ai";
8
+ export type OutputLogLevel = "trace" | "debug" | "info" | "warn" | "error" | "fatal";
9
+ export interface OutputLogRecord {
10
+ time: string;
11
+ ts: string;
12
+ level: OutputLogLevel;
13
+ category?: string;
14
+ msg: string;
15
+ meta?: Record<string, unknown>;
16
+ }
17
+ export interface OutputLogSink {
18
+ handle(record: OutputLogRecord): void | Promise<void>;
19
+ }
20
+ export interface OutputLogger {
21
+ info(message: string, meta?: Record<string, unknown>): void;
22
+ warn(message: string, meta?: Record<string, unknown>): void;
23
+ error(message: string, error?: Error, meta?: Record<string, unknown>): void;
24
+ debug(message: string, meta?: Record<string, unknown>): void;
25
+ child(bindings: Record<string, unknown>): OutputLogger;
26
+ }
27
+ /**
28
+ * Spinner interface for progress indicators
29
+ */
30
+ export interface Spinner {
31
+ start(): void;
32
+ stop(): void;
33
+ update(options: {
34
+ text?: string;
35
+ }): void;
36
+ succeed(message?: string): void;
37
+ fail(message?: string): void;
38
+ }
39
+ /**
40
+ * Progress details for progress() method
41
+ */
42
+ export interface ProgressDetails {
43
+ current?: number;
44
+ total?: number;
45
+ message?: string;
46
+ [key: string]: unknown;
47
+ }
48
+ /**
49
+ * Error options for error() method
50
+ */
51
+ export interface ErrorOptions {
52
+ title?: string;
53
+ code?: string;
54
+ suggestions?: string[];
55
+ docs?: string;
56
+ context?: Record<string, unknown>;
57
+ report?: boolean;
58
+ }
59
+ /**
60
+ * UI utilities interface
61
+ */
62
+ export interface UIUtilities {
63
+ box: (title: string, content?: string[], maxWidth?: number) => string;
64
+ sideBox: (options: {
65
+ title: string;
66
+ sections: Array<{
67
+ header?: string;
68
+ items: string[];
69
+ }>;
70
+ footer?: string;
71
+ status?: 'success' | 'error' | 'warning' | 'info';
72
+ timing?: number;
73
+ }) => string;
74
+ table: (rows: (string | number)[][], headers?: string[]) => string[];
75
+ keyValue: (pairs: Record<string, string | number>, options?: {
76
+ padKeys?: boolean;
77
+ }) => string[];
78
+ spinner: (text: string, jsonMode?: boolean) => Spinner;
79
+ colors: {
80
+ info: (text: string) => string;
81
+ warn: (text: string) => string;
82
+ error: (text: string) => string;
83
+ success: (text: string) => string;
84
+ muted: (text: string) => string;
85
+ bold: (text: string) => string;
86
+ primary: (text: string) => string;
87
+ accent: (text: string) => string;
88
+ };
89
+ symbols: {
90
+ success: string;
91
+ error: string;
92
+ warning: string;
93
+ info: string;
94
+ bullet: string;
95
+ };
96
+ }
97
+ /**
98
+ * Unified Output interface for plugins and CLI
99
+ */
100
+ export interface Output {
101
+ success(message: string, data?: Record<string, unknown>): void;
102
+ error(error: Error | string, options?: ErrorOptions): void;
103
+ warn(message: string, hint?: string): void;
104
+ progress(stage: string, details?: ProgressDetails): void;
105
+ spinner(text: string): Spinner;
106
+ info(message: string, meta?: Record<string, unknown>): void;
107
+ debug(message: string, meta?: Record<string, unknown>): void;
108
+ trace(message: string, meta?: Record<string, unknown>): void;
109
+ json(data: unknown): void;
110
+ write(text: string): void;
111
+ ui: UIUtilities;
112
+ group(name: string): void;
113
+ groupEnd(): void;
114
+ readonly mode: OutputMode;
115
+ readonly verbosity: VerbosityLevel;
116
+ readonly isQuiet: boolean;
117
+ readonly isVerbose: boolean;
118
+ readonly isDebug: boolean;
119
+ readonly isJSON: boolean;
120
+ readonly isAIFormat: boolean;
121
+ }
122
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/output/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * @module @kb-labs/core-sys/output/types
3
+ * Unified Output interface for KB Labs platform
4
+ */
5
+ export {};
6
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/output/types.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=repo.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"repo.spec.d.ts","sourceRoot":"","sources":["../../../src/repo/__tests__/repo.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,25 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { promises as fsp } from 'node:fs';
3
+ import os from 'node:os';
4
+ import path from 'node:path';
5
+ import { findRepoRoot } from '../repo';
6
+ async function mkd(prefix = 'kb-core-sys-repo-') {
7
+ return fsp.mkdtemp(path.join(os.tmpdir(), prefix));
8
+ }
9
+ describe('findRepoRoot', () => {
10
+ it('finds directory containing any marker (e.g., .git) when called from subdir', async () => {
11
+ const root = await mkd();
12
+ const sub = path.join(root, 'a/b/c');
13
+ await fsp.mkdir(sub, { recursive: true });
14
+ await fsp.mkdir(path.join(root, '.git'));
15
+ const found = await findRepoRoot(sub);
16
+ expect(found).toBe(root);
17
+ });
18
+ it('falls back to FS root if no marker is found up the tree', async () => {
19
+ const start = await mkd();
20
+ const found = await findRepoRoot(start);
21
+ // Implementation returns FS root when no markers are found
22
+ expect(found).toBe(path.parse(start).root);
23
+ });
24
+ });
25
+ //# sourceMappingURL=repo.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"repo.spec.js","sourceRoot":"","sources":["../../../src/repo/__tests__/repo.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,QAAQ,IAAI,GAAG,EAAE,MAAM,SAAS,CAAA;AACzC,OAAO,EAAE,MAAM,SAAS,CAAA;AACxB,OAAO,IAAI,MAAM,WAAW,CAAA;AAE5B,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAEtC,KAAK,UAAU,GAAG,CAAC,MAAM,GAAG,mBAAmB;IAC7C,OAAO,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,MAAM,CAAC,CAAC,CAAA;AACpD,CAAC;AAED,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,MAAM,IAAI,GAAG,MAAM,GAAG,EAAE,CAAA;QACxB,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QACpC,MAAM,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QACzC,MAAM,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAA;QAExC,MAAM,KAAK,GAAG,MAAM,YAAY,CAAC,GAAG,CAAC,CAAA;QACrC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC1B,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,MAAM,KAAK,GAAG,MAAM,GAAG,EAAE,CAAA;QACzB,MAAM,KAAK,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC,CAAA;QACvC,2DAA2D;QAC3D,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAA;IAC5C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './repo';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/repo/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './repo';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/repo/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC"}