ctxdotdev 0.1.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 (75) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +90 -0
  3. package/dist/analyzer/index.d.ts +36 -0
  4. package/dist/analyzer/index.d.ts.map +1 -0
  5. package/dist/analyzer/index.js +137 -0
  6. package/dist/analyzer/index.js.map +1 -0
  7. package/dist/cli/commands/config.d.ts +3 -0
  8. package/dist/cli/commands/config.d.ts.map +1 -0
  9. package/dist/cli/commands/config.js +16 -0
  10. package/dist/cli/commands/config.js.map +1 -0
  11. package/dist/cli/commands/context.d.ts +3 -0
  12. package/dist/cli/commands/context.d.ts.map +1 -0
  13. package/dist/cli/commands/context.js +42 -0
  14. package/dist/cli/commands/context.js.map +1 -0
  15. package/dist/cli/commands/doctor.d.ts +3 -0
  16. package/dist/cli/commands/doctor.d.ts.map +1 -0
  17. package/dist/cli/commands/doctor.js +43 -0
  18. package/dist/cli/commands/doctor.js.map +1 -0
  19. package/dist/cli/commands/init.d.ts +3 -0
  20. package/dist/cli/commands/init.d.ts.map +1 -0
  21. package/dist/cli/commands/init.js +30 -0
  22. package/dist/cli/commands/init.js.map +1 -0
  23. package/dist/cli/commands/template.d.ts +3 -0
  24. package/dist/cli/commands/template.d.ts.map +1 -0
  25. package/dist/cli/commands/template.js +19 -0
  26. package/dist/cli/commands/template.js.map +1 -0
  27. package/dist/cli/commands/watch.d.ts +3 -0
  28. package/dist/cli/commands/watch.d.ts.map +1 -0
  29. package/dist/cli/commands/watch.js +9 -0
  30. package/dist/cli/commands/watch.js.map +1 -0
  31. package/dist/cli/help.d.ts +2 -0
  32. package/dist/cli/help.d.ts.map +1 -0
  33. package/dist/cli/help.js +29 -0
  34. package/dist/cli/help.js.map +1 -0
  35. package/dist/cli/index.d.ts +3 -0
  36. package/dist/cli/index.d.ts.map +1 -0
  37. package/dist/cli/index.js +35 -0
  38. package/dist/cli/index.js.map +1 -0
  39. package/dist/config/defaults.d.ts +25 -0
  40. package/dist/config/defaults.d.ts.map +1 -0
  41. package/dist/config/defaults.js +34 -0
  42. package/dist/config/defaults.js.map +1 -0
  43. package/dist/config/index.d.ts +5 -0
  44. package/dist/config/index.d.ts.map +1 -0
  45. package/dist/config/index.js +43 -0
  46. package/dist/config/index.js.map +1 -0
  47. package/dist/formatter/index.d.ts +4 -0
  48. package/dist/formatter/index.d.ts.map +1 -0
  49. package/dist/formatter/index.js +15 -0
  50. package/dist/formatter/index.js.map +1 -0
  51. package/dist/formatter/json.d.ts +3 -0
  52. package/dist/formatter/json.d.ts.map +1 -0
  53. package/dist/formatter/json.js +22 -0
  54. package/dist/formatter/json.js.map +1 -0
  55. package/dist/formatter/markdown.d.ts +3 -0
  56. package/dist/formatter/markdown.d.ts.map +1 -0
  57. package/dist/formatter/markdown.js +43 -0
  58. package/dist/formatter/markdown.js.map +1 -0
  59. package/dist/formatter/text.d.ts +3 -0
  60. package/dist/formatter/text.d.ts.map +1 -0
  61. package/dist/formatter/text.js +73 -0
  62. package/dist/formatter/text.js.map +1 -0
  63. package/dist/scanner/ignore.d.ts +2 -0
  64. package/dist/scanner/ignore.d.ts.map +1 -0
  65. package/dist/scanner/ignore.js +17 -0
  66. package/dist/scanner/ignore.js.map +1 -0
  67. package/dist/scanner/index.d.ts +19 -0
  68. package/dist/scanner/index.d.ts.map +1 -0
  69. package/dist/scanner/index.js +48 -0
  70. package/dist/scanner/index.js.map +1 -0
  71. package/dist/utils/clipboard.d.ts +2 -0
  72. package/dist/utils/clipboard.d.ts.map +1 -0
  73. package/dist/utils/clipboard.js +11 -0
  74. package/dist/utils/clipboard.js.map +1 -0
  75. package/package.json +54 -0
@@ -0,0 +1,25 @@
1
+ export interface CtxConfig {
2
+ project: {
3
+ name: string;
4
+ type: string;
5
+ };
6
+ scan: {
7
+ maxDepth: number;
8
+ maxFiles: number;
9
+ include: string[];
10
+ exclude: string[];
11
+ };
12
+ output: {
13
+ format: 'text' | 'markdown' | 'json';
14
+ showDependencies: boolean;
15
+ showGitInfo: boolean;
16
+ showFileSizes: boolean;
17
+ maxFiles: number;
18
+ };
19
+ templates: {
20
+ default: string;
21
+ custom: string[];
22
+ };
23
+ }
24
+ export declare const DEFAULT_CONFIG: CtxConfig;
25
+ //# sourceMappingURL=defaults.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../../src/config/defaults.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,SAAS;IACxB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,IAAI,EAAE;QACJ,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,MAAM,EAAE,CAAC;QAClB,OAAO,EAAE,MAAM,EAAE,CAAC;KACnB,CAAC;IACF,MAAM,EAAE;QACN,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,MAAM,CAAC;QACrC,gBAAgB,EAAE,OAAO,CAAC;QAC1B,WAAW,EAAE,OAAO,CAAC;QACrB,aAAa,EAAE,OAAO,CAAC;QACvB,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;IACF,SAAS,EAAE;QACT,OAAO,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,MAAM,EAAE,CAAC;KAClB,CAAC;CACH;AAED,eAAO,MAAM,cAAc,EAAE,SAgC5B,CAAC"}
@@ -0,0 +1,34 @@
1
+ export const DEFAULT_CONFIG = {
2
+ project: {
3
+ name: '',
4
+ type: 'auto',
5
+ },
6
+ scan: {
7
+ maxDepth: 6,
8
+ maxFiles: 10000,
9
+ include: [],
10
+ exclude: [
11
+ 'node_modules',
12
+ '.git',
13
+ 'dist',
14
+ 'build',
15
+ '.next',
16
+ 'coverage',
17
+ '*.log',
18
+ '.cache',
19
+ '.turbo',
20
+ ],
21
+ },
22
+ output: {
23
+ format: 'text',
24
+ showDependencies: true,
25
+ showGitInfo: true,
26
+ showFileSizes: false,
27
+ maxFiles: 50,
28
+ },
29
+ templates: {
30
+ default: 'standard',
31
+ custom: [],
32
+ },
33
+ };
34
+ //# sourceMappingURL=defaults.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.js","sourceRoot":"","sources":["../../src/config/defaults.ts"],"names":[],"mappings":"AAwBA,MAAM,CAAC,MAAM,cAAc,GAAc;IACvC,OAAO,EAAE;QACP,IAAI,EAAE,EAAE;QACR,IAAI,EAAE,MAAM;KACb;IACD,IAAI,EAAE;QACJ,QAAQ,EAAE,CAAC;QACX,QAAQ,EAAE,KAAK;QACf,OAAO,EAAE,EAAE;QACX,OAAO,EAAE;YACP,cAAc;YACd,MAAM;YACN,MAAM;YACN,OAAO;YACP,OAAO;YACP,UAAU;YACV,OAAO;YACP,QAAQ;YACR,QAAQ;SACT;KACF;IACD,MAAM,EAAE;QACN,MAAM,EAAE,MAAM;QACd,gBAAgB,EAAE,IAAI;QACtB,WAAW,EAAE,IAAI;QACjB,aAAa,EAAE,KAAK;QACpB,QAAQ,EAAE,EAAE;KACb;IACD,SAAS,EAAE;QACT,OAAO,EAAE,UAAU;QACnB,MAAM,EAAE,EAAE;KACX;CACF,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { CtxConfig } from './defaults.js';
2
+ export declare function loadConfig(cwd: string): CtxConfig;
3
+ export declare function saveConfig(cwd: string, config: CtxConfig): void;
4
+ export declare function ensureConfig(cwd: string): CtxConfig;
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAkB,MAAM,eAAe,CAAC;AAS1D,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAYjD;AAED,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,IAAI,CAM/D;AAED,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAEnD"}
@@ -0,0 +1,43 @@
1
+ import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'node:fs';
2
+ import { resolve } from 'node:path';
3
+ import { DEFAULT_CONFIG } from './defaults.js';
4
+ const CTX_DIR = '.ctx';
5
+ const CONFIG_FILE = 'config.json';
6
+ function getConfigPath(cwd) {
7
+ return resolve(cwd, CTX_DIR, CONFIG_FILE);
8
+ }
9
+ export function loadConfig(cwd) {
10
+ const configPath = getConfigPath(cwd);
11
+ if (existsSync(configPath)) {
12
+ try {
13
+ const raw = readFileSync(configPath, 'utf-8');
14
+ const userConfig = JSON.parse(raw);
15
+ return deepMerge(DEFAULT_CONFIG, userConfig);
16
+ }
17
+ catch {
18
+ return { ...DEFAULT_CONFIG };
19
+ }
20
+ }
21
+ return { ...DEFAULT_CONFIG };
22
+ }
23
+ export function saveConfig(cwd, config) {
24
+ const configDir = resolve(cwd, CTX_DIR);
25
+ if (!existsSync(configDir)) {
26
+ mkdirSync(configDir, { recursive: true });
27
+ }
28
+ writeFileSync(getConfigPath(cwd), JSON.stringify(config, null, 2), 'utf-8');
29
+ }
30
+ export function ensureConfig(cwd) {
31
+ return loadConfig(cwd);
32
+ }
33
+ function deepMerge(base, override) {
34
+ return {
35
+ ...base,
36
+ ...override,
37
+ project: { ...base.project, ...override.project },
38
+ scan: { ...base.scan, ...override.scan },
39
+ output: { ...base.output, ...override.output },
40
+ templates: { ...base.templates, ...override.templates },
41
+ };
42
+ }
43
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAa,cAAc,EAAE,MAAM,eAAe,CAAC;AAE1D,MAAM,OAAO,GAAG,MAAM,CAAC;AACvB,MAAM,WAAW,GAAG,aAAa,CAAC;AAElC,SAAS,aAAa,CAAC,GAAW;IAChC,OAAO,OAAO,CAAC,GAAG,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;AAC5C,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,GAAW;IACpC,MAAM,UAAU,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IACtC,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;YAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAuB,CAAC;YACzD,OAAO,SAAS,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QAC/C,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,GAAG,cAAc,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IACD,OAAO,EAAE,GAAG,cAAc,EAAE,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,GAAW,EAAE,MAAiB;IACvD,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IACxC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC3B,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5C,CAAC;IACD,aAAa,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,GAAW;IACtC,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC;AAED,SAAS,SAAS,CAAC,IAAe,EAAE,QAA4B;IAC9D,OAAO;QACL,GAAG,IAAI;QACP,GAAG,QAAQ;QACX,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,GAAG,QAAQ,CAAC,OAAO,EAAE;QACjD,IAAI,EAAE,EAAE,GAAG,IAAI,CAAC,IAAI,EAAE,GAAG,QAAQ,CAAC,IAAI,EAAE;QACxC,MAAM,EAAE,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,QAAQ,CAAC,MAAM,EAAE;QAC9C,SAAS,EAAE,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,GAAG,QAAQ,CAAC,SAAS,EAAE;KACxD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { ProjectInfo } from '../analyzer/index.js';
2
+ export type OutputFormat = 'text' | 'markdown' | 'json';
3
+ export declare function formatOutput(info: ProjectInfo, format: OutputFormat): string;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/formatter/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAKnD,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,UAAU,GAAG,MAAM,CAAC;AAExD,wBAAgB,YAAY,CAAC,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,GAAG,MAAM,CAU5E"}
@@ -0,0 +1,15 @@
1
+ import { formatText } from './text.js';
2
+ import { formatMarkdown } from './markdown.js';
3
+ import { formatJson } from './json.js';
4
+ export function formatOutput(info, format) {
5
+ switch (format) {
6
+ case 'markdown':
7
+ return formatMarkdown(info);
8
+ case 'json':
9
+ return formatJson(info);
10
+ case 'text':
11
+ default:
12
+ return formatText(info);
13
+ }
14
+ }
15
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/formatter/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAIvC,MAAM,UAAU,YAAY,CAAC,IAAiB,EAAE,MAAoB;IAClE,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,UAAU;YACb,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC;QAC9B,KAAK,MAAM;YACT,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;QAC1B,KAAK,MAAM,CAAC;QACZ;YACE,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { ProjectInfo } from '../analyzer/index.js';
2
+ export declare function formatJson(info: ProjectInfo): string;
3
+ //# sourceMappingURL=json.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../src/formatter/json.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD,wBAAgB,UAAU,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,CAwBpD"}
@@ -0,0 +1,22 @@
1
+ export function formatJson(info) {
2
+ return JSON.stringify({
3
+ project: info.name,
4
+ type: info.type,
5
+ framework: info.framework,
6
+ dependencies: info.dependencies,
7
+ git: info.gitInfo
8
+ ? { branch: info.gitInfo.branch }
9
+ : null,
10
+ structure: info.structure.children?.map(c => c.name) ?? [],
11
+ configFiles: info.configFiles.map(c => ({
12
+ path: c.path,
13
+ type: c.type,
14
+ })),
15
+ keyFiles: info.keyFiles.slice(0, 5).map(f => ({
16
+ path: f.path,
17
+ size: f.size,
18
+ modified: f.modified.toISOString(),
19
+ })),
20
+ }, null, 2);
21
+ }
22
+ //# sourceMappingURL=json.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json.js","sourceRoot":"","sources":["../../src/formatter/json.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,UAAU,CAAC,IAAiB;IAC1C,OAAO,IAAI,CAAC,SAAS,CACnB;QACE,OAAO,EAAE,IAAI,CAAC,IAAI;QAClB,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,YAAY,EAAE,IAAI,CAAC,YAAY;QAC/B,GAAG,EAAE,IAAI,CAAC,OAAO;YACf,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YACjC,CAAC,CAAC,IAAI;QACR,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE;QAC1D,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACtC,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,IAAI,EAAE,CAAC,CAAC,IAAI;SACb,CAAC,CAAC;QACH,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC5C,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE;SACnC,CAAC,CAAC;KACJ,EACD,IAAI,EACJ,CAAC,CACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { ProjectInfo } from '../analyzer/index.js';
2
+ export declare function formatMarkdown(info: ProjectInfo): string;
3
+ //# sourceMappingURL=markdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.d.ts","sourceRoot":"","sources":["../../src/formatter/markdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,sBAAsB,CAAC;AAE7D,wBAAgB,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,CAoCxD"}
@@ -0,0 +1,43 @@
1
+ export function formatMarkdown(info) {
2
+ const lines = [];
3
+ lines.push(`# Project: ${info.name}`);
4
+ lines.push('');
5
+ lines.push(`- **Type:** ${capitalize(info.type)} / ${capitalize(info.framework)}`);
6
+ if (info.dependencies.total > 0) {
7
+ lines.push(`- **Dependencies:** ${info.dependencies.total} (${info.dependencies.production} production, ${info.dependencies.dev} dev)`);
8
+ }
9
+ if (info.gitInfo) {
10
+ lines.push(`- **Branch:** \`${info.gitInfo.branch}\``);
11
+ }
12
+ lines.push('');
13
+ lines.push('## Structure');
14
+ lines.push('```');
15
+ lines.push(renderTree(info.structure));
16
+ lines.push('```');
17
+ if (info.configFiles.length > 0) {
18
+ lines.push('');
19
+ lines.push('## Config Files');
20
+ for (const cfg of info.configFiles) {
21
+ lines.push(`- \`${cfg.path.replace(/^.*\/([^/]+\/[^/]+)$/, '$1')}\` — ${cfg.type}`);
22
+ }
23
+ }
24
+ if (info.keyFiles.length > 0) {
25
+ lines.push('');
26
+ lines.push('## Key Files');
27
+ for (const file of info.keyFiles.slice(0, 5)) {
28
+ lines.push(`- \`${file.path}\``);
29
+ }
30
+ }
31
+ return lines.join('\n');
32
+ }
33
+ function renderTree(node) {
34
+ if (!node.children)
35
+ return '';
36
+ return node.children.map(c => c.name).join('\n');
37
+ }
38
+ function capitalize(s) {
39
+ if (!s)
40
+ return 'Unknown';
41
+ return s.charAt(0).toUpperCase() + s.slice(1);
42
+ }
43
+ //# sourceMappingURL=markdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.js","sourceRoot":"","sources":["../../src/formatter/markdown.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,cAAc,CAAC,IAAiB;IAC9C,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,KAAK,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACtC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,eAAe,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;IACnF,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,uBAAuB,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,IAAI,CAAC,YAAY,CAAC,UAAU,gBAAgB,IAAI,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,CAAC;IAC1I,CAAC;IACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,KAAK,CAAC,IAAI,CAAC,mBAAmB,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClB,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAElB,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACf,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC9B,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnC,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QACtF,CAAC;IACH,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC7B,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACf,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3B,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;YAC7C,KAAK,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,SAAS,UAAU,CAAC,IAAc;IAChC,IAAI,CAAC,IAAI,CAAC,QAAQ;QAAE,OAAO,EAAE,CAAC;IAC9B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,IAAI,CAAC,CAAC;QAAE,OAAO,SAAS,CAAC;IACzB,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAChD,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { ProjectInfo } from '../analyzer/index.js';
2
+ export declare function formatText(info: ProjectInfo): string;
3
+ //# sourceMappingURL=text.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.d.ts","sourceRoot":"","sources":["../../src/formatter/text.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAY,MAAM,sBAAsB,CAAC;AAE7D,wBAAgB,UAAU,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,CAsCpD"}
@@ -0,0 +1,73 @@
1
+ export function formatText(info) {
2
+ const lines = [];
3
+ lines.push(`Project: ${info.name} ── ${capitalize(info.type)} / ${capitalize(info.framework)}`);
4
+ lines.push('');
5
+ if (info.dependencies.total > 0) {
6
+ lines.push(` Dependencies: ${info.dependencies.total} (${info.dependencies.production} production)`);
7
+ }
8
+ if (info.gitInfo) {
9
+ lines.push(` Git branch: ${info.gitInfo.branch}`);
10
+ }
11
+ lines.push('');
12
+ lines.push(' Structure:');
13
+ lines.push(renderTree(info.structure, 4));
14
+ if (info.configFiles.length > 0) {
15
+ lines.push('');
16
+ lines.push(' Config files:');
17
+ for (const cfg of info.configFiles) {
18
+ const shortPath = cfg.path.replace(/^.*\/([^/]+\/[^/]+)$/, '$1');
19
+ lines.push(` → ${shortPath}`);
20
+ }
21
+ }
22
+ if (info.keyFiles.length > 0) {
23
+ lines.push('');
24
+ lines.push(' Key files:');
25
+ for (const file of info.keyFiles.slice(0, 5)) {
26
+ const relPath = file.path;
27
+ const ago = timeAgo(file.modified);
28
+ lines.push(` → ${relPath}${file.size ? ` (${formatSize(file.size)})` : ''}${ago ? ` — ${ago}` : ''}`);
29
+ }
30
+ }
31
+ return lines.join('\n');
32
+ }
33
+ function renderTree(node, indent) {
34
+ if (!node.children || node.children.length === 0)
35
+ return '';
36
+ const lines = [];
37
+ const indentStr = ' '.repeat(indent);
38
+ for (const child of node.children) {
39
+ if (child.type === 'directory') {
40
+ lines.push(`${indentStr}├── ${child.name}`);
41
+ }
42
+ else {
43
+ lines.push(`${indentStr}├── ${child.name}`);
44
+ }
45
+ }
46
+ return lines.join('\n');
47
+ }
48
+ function capitalize(s) {
49
+ if (!s)
50
+ return 'Unknown';
51
+ return s.charAt(0).toUpperCase() + s.slice(1);
52
+ }
53
+ function formatSize(bytes) {
54
+ if (bytes < 1024)
55
+ return `${bytes}B`;
56
+ if (bytes < 1024 * 1024)
57
+ return `${(bytes / 1024).toFixed(1)}KB`;
58
+ return `${(bytes / (1024 * 1024)).toFixed(1)}MB`;
59
+ }
60
+ function timeAgo(date) {
61
+ const diff = Date.now() - date.getTime();
62
+ const minutes = Math.floor(diff / 60000);
63
+ if (minutes < 1)
64
+ return 'just now';
65
+ if (minutes < 60)
66
+ return `${minutes}m ago`;
67
+ const hours = Math.floor(minutes / 60);
68
+ if (hours < 24)
69
+ return `${hours}h ago`;
70
+ const days = Math.floor(hours / 24);
71
+ return `${days}d ago`;
72
+ }
73
+ //# sourceMappingURL=text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.js","sourceRoot":"","sources":["../../src/formatter/text.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function loadIgnorePatterns(cwd: string): string[];
2
+ //# sourceMappingURL=ignore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ignore.d.ts","sourceRoot":"","sources":["../../src/scanner/ignore.ts"],"names":[],"mappings":"AAGA,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE,CAexD"}
@@ -0,0 +1,17 @@
1
+ import { existsSync, readFileSync } from 'node:fs';
2
+ import { resolve } from 'node:path';
3
+ export function loadIgnorePatterns(cwd) {
4
+ const patterns = [];
5
+ const ctxignorePath = resolve(cwd, '.ctxignore');
6
+ if (existsSync(ctxignorePath)) {
7
+ const content = readFileSync(ctxignorePath, 'utf-8');
8
+ for (const line of content.split('\n')) {
9
+ const trimmed = line.trim();
10
+ if (trimmed && !trimmed.startsWith('#')) {
11
+ patterns.push(trimmed);
12
+ }
13
+ }
14
+ }
15
+ return patterns;
16
+ }
17
+ //# sourceMappingURL=ignore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ignore.js","sourceRoot":"","sources":["../../src/scanner/ignore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,UAAU,kBAAkB,CAAC,GAAW;IAC5C,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IACjD,IAAI,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACrD,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YACvC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YAC5B,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC"}
@@ -0,0 +1,19 @@
1
+ export interface ScanResult {
2
+ files: ScannedFile[];
3
+ totalFiles: number;
4
+ ignoredFiles: number;
5
+ }
6
+ export interface ScannedFile {
7
+ path: string;
8
+ size: number;
9
+ modified: Date;
10
+ }
11
+ export interface ScannerOptions {
12
+ cwd: string;
13
+ maxDepth: number;
14
+ maxFiles: number;
15
+ include: string[];
16
+ exclude: string[];
17
+ }
18
+ export declare function scanProject(options: ScannerOptions): Promise<ScanResult>;
19
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/scanner/index.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,IAAI,CAAC;CAChB;AAED,MAAM,WAAW,cAAc;IAC7B,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,wBAAsB,WAAW,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,CAiD9E"}
@@ -0,0 +1,48 @@
1
+ import { readFileSync, existsSync } from 'node:fs';
2
+ import { resolve } from 'node:path';
3
+ import fastGlob from 'fast-glob';
4
+ import ignore from 'ignore';
5
+ export async function scanProject(options) {
6
+ const { cwd, maxDepth, maxFiles, exclude } = options;
7
+ const ig = ignore();
8
+ ig.add(exclude);
9
+ const gitignorePath = resolve(cwd, '.gitignore');
10
+ if (existsSync(gitignorePath)) {
11
+ const gitignore = readFileSync(gitignorePath, 'utf-8');
12
+ ig.add(gitignore);
13
+ }
14
+ const ctxignorePath = resolve(cwd, '.ctxignore');
15
+ if (existsSync(ctxignorePath)) {
16
+ const ctxignore = readFileSync(ctxignorePath, 'utf-8');
17
+ ig.add(ctxignore);
18
+ }
19
+ const patterns = ['**/*'];
20
+ const entries = await fastGlob(patterns, {
21
+ cwd,
22
+ dot: true,
23
+ followSymbolicLinks: false,
24
+ deep: maxDepth,
25
+ stats: true,
26
+ ignore: exclude,
27
+ });
28
+ const filtered = [];
29
+ for (const entry of entries) {
30
+ if (filtered.length >= maxFiles)
31
+ break;
32
+ const relativePath = entry.path;
33
+ if (ig.ignores(relativePath))
34
+ continue;
35
+ filtered.push({
36
+ path: relativePath,
37
+ size: entry.stats?.size ?? 0,
38
+ modified: entry.stats?.mtime ?? new Date(),
39
+ });
40
+ }
41
+ filtered.sort((a, b) => b.modified.getTime() - a.modified.getTime());
42
+ return {
43
+ files: filtered,
44
+ totalFiles: entries.length,
45
+ ignoredFiles: entries.length - filtered.length,
46
+ };
47
+ }
48
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/scanner/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,QAAQ,MAAM,WAAW,CAAC;AACjC,OAAO,MAAM,MAAM,QAAQ,CAAC;AAsB5B,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,OAAuB;IACvD,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAErD,MAAM,EAAE,GAAG,MAAM,EAAE,CAAC;IACpB,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAEhB,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IACjD,IAAI,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;QAC9B,MAAM,SAAS,GAAG,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACvD,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACpB,CAAC;IAED,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;IACjD,IAAI,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;QAC9B,MAAM,SAAS,GAAG,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACvD,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACpB,CAAC;IAED,MAAM,QAAQ,GAAG,CAAC,MAAM,CAAC,CAAC;IAC1B,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE;QACvC,GAAG;QACH,GAAG,EAAE,IAAI;QACT,mBAAmB,EAAE,KAAK;QAC1B,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,IAAI;QACX,MAAM,EAAE,OAAO;KAChB,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAkB,EAAE,CAAC;IACnC,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,IAAI,QAAQ,CAAC,MAAM,IAAI,QAAQ;YAAE,MAAM;QAEvC,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC;QAChC,IAAI,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC;YAAE,SAAS;QAEvC,QAAQ,CAAC,IAAI,CAAC;YACZ,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC;YAC5B,QAAQ,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,IAAI,EAAE;SAC3C,CAAC,CAAC;IACL,CAAC;IAED,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;IAErE,OAAO;QACL,KAAK,EAAE,QAAQ;QACf,UAAU,EAAE,OAAO,CAAC,MAAM;QAC1B,YAAY,EAAE,OAAO,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM;KAC/C,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function copyToClipboard(text: string): Promise<void>;
2
+ //# sourceMappingURL=clipboard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clipboard.d.ts","sourceRoot":"","sources":["../../src/utils/clipboard.ts"],"names":[],"mappings":"AAEA,wBAAsB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAOjE"}
@@ -0,0 +1,11 @@
1
+ let clipboard = null;
2
+ export async function copyToClipboard(text) {
3
+ try {
4
+ clipboard = await import('clipboardy');
5
+ await clipboard.default.write(text);
6
+ }
7
+ catch {
8
+ // clipboard not available — silently fall back to stdout
9
+ }
10
+ }
11
+ //# sourceMappingURL=clipboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../src/utils/clipboard.ts"],"names":[],"mappings":"AAAA,IAAI,SAAS,GAAuC,IAAI,CAAC;AAEzD,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,IAAY;IAChD,IAAI,CAAC;QACH,SAAS,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,CAAC;QACvC,MAAM,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAAC,MAAM,CAAC;QACP,yDAAyD;IAC3D,CAAC;AACH,CAAC"}
package/package.json ADDED
@@ -0,0 +1,54 @@
1
+ {
2
+ "name": "ctxdotdev",
3
+ "version": "0.1.0",
4
+ "description": "Project context for AI coding tools — one command, perfect context, every AI tool",
5
+ "bin": {
6
+ "ctx": "dist/cli/index.js"
7
+ },
8
+ "type": "module",
9
+ "scripts": {
10
+ "build": "tsc",
11
+ "dev": "tsc --watch",
12
+ "start": "node dist/cli/index.js",
13
+ "test": "vitest run",
14
+ "test:watch": "vitest",
15
+ "test:coverage": "vitest run --coverage",
16
+ "prepublishOnly": "npm run build && npm run test",
17
+ "lint": "tsc --noEmit"
18
+ },
19
+ "files": [
20
+ "dist",
21
+ "README.md",
22
+ "LICENSE"
23
+ ],
24
+ "keywords": [
25
+ "ai",
26
+ "context",
27
+ "cli",
28
+ "cursor",
29
+ "claude",
30
+ "copilot",
31
+ "developer-tools"
32
+ ],
33
+ "license": "MIT",
34
+ "repository": {
35
+ "type": "git",
36
+ "url": "git+https://github.com/lukeswestun/ctx.git"
37
+ },
38
+ "engines": {
39
+ "node": ">=18"
40
+ },
41
+ "dependencies": {
42
+ "chalk": "^5.3.0",
43
+ "clipboardy": "^4.0.0",
44
+ "commander": "^12.0.0",
45
+ "fast-glob": "^3.3.2",
46
+ "ignore": "^5.3.1"
47
+ },
48
+ "devDependencies": {
49
+ "@types/node": "^20.11.0",
50
+ "typescript": "^5.4.0",
51
+ "vitest": "^1.6.0",
52
+ "c8": "^10.1.0"
53
+ }
54
+ }