mirror of
https://github.com/yamadashy/repomix.git
synced 2026-02-03 11:33:39 +01:00
Remove remoteUrl from config schema and pass pre-computed skillName through CLI options instead. This provides cleaner separation between configuration and runtime data. - Add generateDefaultSkillNameFromUrl() for remote repository names - Update generateDefaultSkillName() to only handle local directories - Pass skillName through DefaultActionTask to packager
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
import os from 'node:os';
|
|
import process from 'node:process';
|
|
import { defaultConfig, type RepomixConfigMerged } from '../../src/config/configSchema.js';
|
|
|
|
type DeepPartial<T> = {
|
|
[P in keyof T]?: T[P] extends (infer U)[]
|
|
? DeepPartial<U>[]
|
|
: T[P] extends readonly (infer U)[]
|
|
? readonly DeepPartial<U>[]
|
|
: T[P] extends object
|
|
? DeepPartial<T[P]>
|
|
: T[P];
|
|
};
|
|
|
|
export const createMockConfig = (config: DeepPartial<RepomixConfigMerged> = {}): RepomixConfigMerged => {
|
|
return {
|
|
cwd: config.cwd ?? process.cwd(),
|
|
input: {
|
|
...defaultConfig.input,
|
|
...config.input,
|
|
},
|
|
output: {
|
|
...defaultConfig.output,
|
|
...config.output,
|
|
git: {
|
|
...defaultConfig.output.git,
|
|
...config.output?.git,
|
|
},
|
|
},
|
|
ignore: {
|
|
...defaultConfig.ignore,
|
|
...config.ignore,
|
|
customPatterns: [...(defaultConfig.ignore.customPatterns || []), ...(config.ignore?.customPatterns || [])],
|
|
},
|
|
include: [...(defaultConfig.include || []), ...(config.include || [])],
|
|
security: {
|
|
...defaultConfig.security,
|
|
...config.security,
|
|
},
|
|
tokenCount: {
|
|
...defaultConfig.tokenCount,
|
|
...config.tokenCount,
|
|
},
|
|
// CLI-only optional properties
|
|
...(config.skillGenerate !== undefined && { skillGenerate: config.skillGenerate }),
|
|
};
|
|
};
|
|
|
|
export const isWindows = os.platform() === 'win32';
|
|
export const isMac = os.platform() === 'darwin';
|
|
export const isLinux = os.platform() === 'linux';
|