@pixelguild/loom 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 (117) hide show
  1. package/dist/cli/index.d.ts +3 -0
  2. package/dist/cli/index.d.ts.map +1 -0
  3. package/dist/cli/index.js +45 -0
  4. package/dist/cli/index.js.map +1 -0
  5. package/dist/cli/init.d.ts +9 -0
  6. package/dist/cli/init.d.ts.map +1 -0
  7. package/dist/cli/init.js +129 -0
  8. package/dist/cli/init.js.map +1 -0
  9. package/dist/cli/output.d.ts +6 -0
  10. package/dist/cli/output.d.ts.map +1 -0
  11. package/dist/cli/output.js +20 -0
  12. package/dist/cli/output.js.map +1 -0
  13. package/dist/cli/status.d.ts +13 -0
  14. package/dist/cli/status.d.ts.map +1 -0
  15. package/dist/cli/status.js +69 -0
  16. package/dist/cli/status.js.map +1 -0
  17. package/dist/config/config-loader.d.ts +9 -0
  18. package/dist/config/config-loader.d.ts.map +1 -0
  19. package/dist/config/config-loader.js +64 -0
  20. package/dist/config/config-loader.js.map +1 -0
  21. package/dist/config/types.d.ts +32 -0
  22. package/dist/config/types.d.ts.map +1 -0
  23. package/dist/config/types.js +2 -0
  24. package/dist/config/types.js.map +1 -0
  25. package/dist/index.d.ts +2 -0
  26. package/dist/index.d.ts.map +1 -0
  27. package/dist/index.js +32 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/lib/slugify.d.ts +2 -0
  30. package/dist/lib/slugify.d.ts.map +1 -0
  31. package/dist/lib/slugify.js +9 -0
  32. package/dist/lib/slugify.js.map +1 -0
  33. package/dist/lib/tokens.d.ts +2 -0
  34. package/dist/lib/tokens.d.ts.map +1 -0
  35. package/dist/lib/tokens.js +15 -0
  36. package/dist/lib/tokens.js.map +1 -0
  37. package/dist/providers/ollama-provider.d.ts +11 -0
  38. package/dist/providers/ollama-provider.d.ts.map +1 -0
  39. package/dist/providers/ollama-provider.js +37 -0
  40. package/dist/providers/ollama-provider.js.map +1 -0
  41. package/dist/providers/openai-provider.d.ts +10 -0
  42. package/dist/providers/openai-provider.d.ts.map +1 -0
  43. package/dist/providers/openai-provider.js +25 -0
  44. package/dist/providers/openai-provider.js.map +1 -0
  45. package/dist/providers/provider-factory.d.ts +5 -0
  46. package/dist/providers/provider-factory.d.ts.map +1 -0
  47. package/dist/providers/provider-factory.js +19 -0
  48. package/dist/providers/provider-factory.js.map +1 -0
  49. package/dist/providers/types.d.ts +11 -0
  50. package/dist/providers/types.d.ts.map +1 -0
  51. package/dist/providers/types.js +2 -0
  52. package/dist/providers/types.js.map +1 -0
  53. package/dist/providers/vertex-provider.d.ts +12 -0
  54. package/dist/providers/vertex-provider.d.ts.map +1 -0
  55. package/dist/providers/vertex-provider.js +32 -0
  56. package/dist/providers/vertex-provider.js.map +1 -0
  57. package/dist/server.d.ts +4 -0
  58. package/dist/server.d.ts.map +1 -0
  59. package/dist/server.js +143 -0
  60. package/dist/server.js.map +1 -0
  61. package/dist/storage/archive.d.ts +22 -0
  62. package/dist/storage/archive.d.ts.map +1 -0
  63. package/dist/storage/archive.js +114 -0
  64. package/dist/storage/archive.js.map +1 -0
  65. package/dist/storage/context-file.d.ts +16 -0
  66. package/dist/storage/context-file.d.ts.map +1 -0
  67. package/dist/storage/context-file.js +68 -0
  68. package/dist/storage/context-file.js.map +1 -0
  69. package/dist/storage/database.d.ts +28 -0
  70. package/dist/storage/database.d.ts.map +1 -0
  71. package/dist/storage/database.js +195 -0
  72. package/dist/storage/database.js.map +1 -0
  73. package/dist/storage/intelligent-archive.d.ts +36 -0
  74. package/dist/storage/intelligent-archive.d.ts.map +1 -0
  75. package/dist/storage/intelligent-archive.js +183 -0
  76. package/dist/storage/intelligent-archive.js.map +1 -0
  77. package/dist/tools/archive-context.d.ts +7 -0
  78. package/dist/tools/archive-context.d.ts.map +1 -0
  79. package/dist/tools/archive-context.js +60 -0
  80. package/dist/tools/archive-context.js.map +1 -0
  81. package/dist/tools/consult-peer.d.ts +18 -0
  82. package/dist/tools/consult-peer.d.ts.map +1 -0
  83. package/dist/tools/consult-peer.js +48 -0
  84. package/dist/tools/consult-peer.js.map +1 -0
  85. package/dist/tools/create-manifest.d.ts +14 -0
  86. package/dist/tools/create-manifest.d.ts.map +1 -0
  87. package/dist/tools/create-manifest.js +23 -0
  88. package/dist/tools/create-manifest.js.map +1 -0
  89. package/dist/tools/find-pattern.d.ts +14 -0
  90. package/dist/tools/find-pattern.d.ts.map +1 -0
  91. package/dist/tools/find-pattern.js +13 -0
  92. package/dist/tools/find-pattern.js.map +1 -0
  93. package/dist/tools/get-context.d.ts +9 -0
  94. package/dist/tools/get-context.d.ts.map +1 -0
  95. package/dist/tools/get-context.js +11 -0
  96. package/dist/tools/get-context.js.map +1 -0
  97. package/dist/tools/get-manifest.d.ts +21 -0
  98. package/dist/tools/get-manifest.d.ts.map +1 -0
  99. package/dist/tools/get-manifest.js +53 -0
  100. package/dist/tools/get-manifest.js.map +1 -0
  101. package/dist/tools/get-session-status.d.ts +3 -0
  102. package/dist/tools/get-session-status.d.ts.map +1 -0
  103. package/dist/tools/get-session-status.js +20 -0
  104. package/dist/tools/get-session-status.js.map +1 -0
  105. package/dist/tools/log-context.d.ts +13 -0
  106. package/dist/tools/log-context.d.ts.map +1 -0
  107. package/dist/tools/log-context.js +29 -0
  108. package/dist/tools/log-context.js.map +1 -0
  109. package/dist/tools/save-pattern.d.ts +15 -0
  110. package/dist/tools/save-pattern.d.ts.map +1 -0
  111. package/dist/tools/save-pattern.js +19 -0
  112. package/dist/tools/save-pattern.js.map +1 -0
  113. package/dist/types.d.ts +54 -0
  114. package/dist/types.d.ts.map +1 -0
  115. package/dist/types.js +2 -0
  116. package/dist/types.js.map +1 -0
  117. package/package.json +53 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find-pattern.d.ts","sourceRoot":"","sources":["../../src/tools/find-pattern.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE9D,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,iBAAiB;IACzB,QAAQ,EAAE,aAAa,EAAE,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,WAAW,EAChB,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,iBAAiB,CAAC,CAa5B"}
@@ -0,0 +1,13 @@
1
+ export async function handleFindPattern(ctx, input) {
2
+ const db = ctx.database;
3
+ const patterns = db.findPatterns(input.query, {
4
+ tags: input.tags,
5
+ project: input.project,
6
+ limit: input.limit,
7
+ });
8
+ return {
9
+ patterns,
10
+ total: patterns.length,
11
+ };
12
+ }
13
+ //# sourceMappingURL=find-pattern.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find-pattern.js","sourceRoot":"","sources":["../../src/tools/find-pattern.ts"],"names":[],"mappings":"AAeA,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,GAAgB,EAChB,KAAuB;IAEvB,MAAM,EAAE,GAAG,GAAG,CAAC,QAAwB,CAAC;IAExC,MAAM,QAAQ,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,EAAE;QAC5C,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,KAAK,EAAE,KAAK,CAAC,KAAK;KACnB,CAAC,CAAC;IAEH,OAAO;QACL,QAAQ;QACR,KAAK,EAAE,QAAQ,CAAC,MAAM;KACvB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { LoomContext } from '../types.js';
2
+ interface GetContextResult {
3
+ content: string;
4
+ archives: string[];
5
+ tokenCount: number;
6
+ }
7
+ export declare function handleGetContext(ctx: LoomContext): Promise<GetContextResult>;
8
+ export {};
9
+ //# sourceMappingURL=get-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-context.d.ts","sourceRoot":"","sources":["../../src/tools/get-context.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/C,UAAU,gBAAgB;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,wBAAsB,gBAAgB,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,gBAAgB,CAAC,CASlF"}
@@ -0,0 +1,11 @@
1
+ import { ContextFile } from '../storage/context-file.js';
2
+ import { countTokens } from '../lib/tokens.js';
3
+ export async function handleGetContext(ctx) {
4
+ const contextFile = new ContextFile(ctx.projectRoot);
5
+ contextFile.initialize();
6
+ const content = contextFile.read();
7
+ const archives = contextFile.listArchives();
8
+ const tokenCount = countTokens(content);
9
+ return { content, archives, tokenCount };
10
+ }
11
+ //# sourceMappingURL=get-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-context.js","sourceRoot":"","sources":["../../src/tools/get-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAS/C,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,GAAgB;IACrD,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACrD,WAAW,CAAC,UAAU,EAAE,CAAC;IAEzB,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;IACnC,MAAM,QAAQ,GAAG,WAAW,CAAC,YAAY,EAAE,CAAC;IAC5C,MAAM,UAAU,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;IAExC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC;AAC3C,CAAC"}
@@ -0,0 +1,21 @@
1
+ import type { LoomContext } from '../types.js';
2
+ interface GetManifestInput {
3
+ name?: string;
4
+ }
5
+ interface ManifestListItem {
6
+ name: string;
7
+ slug: string;
8
+ created_at: string;
9
+ path: string;
10
+ }
11
+ interface GetManifestResult {
12
+ manifests?: ManifestListItem[];
13
+ name?: string;
14
+ slug?: string;
15
+ content?: string;
16
+ launch_command?: string;
17
+ error?: string;
18
+ }
19
+ export declare function handleGetManifest(ctx: LoomContext, input: GetManifestInput): Promise<GetManifestResult>;
20
+ export {};
21
+ //# sourceMappingURL=get-manifest.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-manifest.d.ts","sourceRoot":"","sources":["../../src/tools/get-manifest.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/C,UAAU,gBAAgB;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,UAAU,iBAAiB;IACzB,SAAS,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,WAAW,EAChB,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,iBAAiB,CAAC,CAK5B"}
@@ -0,0 +1,53 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { slugify } from '../lib/slugify.js';
4
+ export async function handleGetManifest(ctx, input) {
5
+ if (!input.name) {
6
+ return listManifests(ctx);
7
+ }
8
+ return getManifest(ctx, input.name);
9
+ }
10
+ function listManifests(ctx) {
11
+ if (!fs.existsSync(ctx.manifestsDir)) {
12
+ return { manifests: [] };
13
+ }
14
+ const files = fs.readdirSync(ctx.manifestsDir)
15
+ .filter(f => f.endsWith('.md'))
16
+ .sort();
17
+ const manifests = files.map(filename => {
18
+ const slug = filename.replace(/\.md$/, '');
19
+ const filePath = path.join(ctx.manifestsDir, filename);
20
+ const content = fs.readFileSync(filePath, 'utf-8');
21
+ const nameMatch = content.match(/^# Manifest: (.+)$/m);
22
+ const name = nameMatch ? nameMatch[1] : slug;
23
+ const dateMatch = content.match(/Generated: (\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2})/);
24
+ const created_at = dateMatch ? dateMatch[1] : '';
25
+ return {
26
+ name,
27
+ slug,
28
+ created_at,
29
+ path: path.join('docs', 'loom', 'manifests', filename),
30
+ };
31
+ });
32
+ return { manifests };
33
+ }
34
+ function getManifest(ctx, name) {
35
+ const slug = slugify(name);
36
+ const filename = `${slug}.md`;
37
+ const filePath = path.join(ctx.manifestsDir, filename);
38
+ if (!fs.existsSync(filePath)) {
39
+ return { error: `Manifest "${name}" not found at ${filename}` };
40
+ }
41
+ const content = fs.readFileSync(filePath, 'utf-8');
42
+ const nameMatch = content.match(/^# Manifest: (.+)$/m);
43
+ const manifestName = nameMatch ? nameMatch[1] : name;
44
+ const launchMatch = content.match(/```bash\n(.+)\n```/);
45
+ const launch_command = launchMatch ? launchMatch[1] : '';
46
+ return {
47
+ name: manifestName,
48
+ slug,
49
+ content,
50
+ launch_command,
51
+ };
52
+ }
53
+ //# sourceMappingURL=get-manifest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-manifest.js","sourceRoot":"","sources":["../../src/tools/get-manifest.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { LoomContext, SessionStatus } from '../types.js';
2
+ export declare function handleGetSessionStatus(ctx: LoomContext): Promise<SessionStatus>;
3
+ //# sourceMappingURL=get-session-status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-session-status.d.ts","sourceRoot":"","sources":["../../src/tools/get-session-status.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE9D,wBAAsB,sBAAsB,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAAC,aAAa,CAAC,CAkBrF"}
@@ -0,0 +1,20 @@
1
+ import { ContextFile } from '../storage/context-file.js';
2
+ import { countTokens } from '../lib/tokens.js';
3
+ export async function handleGetSessionStatus(ctx) {
4
+ const { warning, archive } = ctx.config.archive_thresholds;
5
+ const contextFile = new ContextFile(ctx.projectRoot);
6
+ contextFile.initialize();
7
+ const content = contextFile.read();
8
+ const tokenCount = countTokens(content);
9
+ const archives = contextFile.listArchives();
10
+ const lastEntryTimestamp = contextFile.getLastEntryTimestamp();
11
+ return {
12
+ tokenCount,
13
+ archiveCount: archives.length,
14
+ lastEntryTimestamp,
15
+ warningThreshold: warning,
16
+ archiveThreshold: archive,
17
+ needsArchive: tokenCount > archive,
18
+ };
19
+ }
20
+ //# sourceMappingURL=get-session-status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-session-status.js","sourceRoot":"","sources":["../../src/tools/get-session-status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAG/C,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,GAAgB;IAC3D,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,kBAAkB,CAAC;IAC3D,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACrD,WAAW,CAAC,UAAU,EAAE,CAAC;IAEzB,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;IACnC,MAAM,UAAU,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,WAAW,CAAC,YAAY,EAAE,CAAC;IAC5C,MAAM,kBAAkB,GAAG,WAAW,CAAC,qBAAqB,EAAE,CAAC;IAE/D,OAAO;QACL,UAAU;QACV,YAAY,EAAE,QAAQ,CAAC,MAAM;QAC7B,kBAAkB;QAClB,gBAAgB,EAAE,OAAO;QACzB,gBAAgB,EAAE,OAAO;QACzB,YAAY,EAAE,UAAU,GAAG,OAAO;KACnC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { LoomContext } from '../types.js';
2
+ interface LogContextInput {
3
+ type: string;
4
+ summary: string;
5
+ detail?: string;
6
+ }
7
+ interface LogContextResult {
8
+ success: boolean;
9
+ tokenCount: number;
10
+ }
11
+ export declare function handleLogContext(ctx: LoomContext, input: LogContextInput): Promise<LogContextResult>;
12
+ export {};
13
+ //# sourceMappingURL=log-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-context.d.ts","sourceRoot":"","sources":["../../src/tools/log-context.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAgB,MAAM,aAAa,CAAC;AAM7D,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,gBAAgB;IACxB,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,WAAW,EAChB,KAAK,EAAE,eAAe,GACrB,OAAO,CAAC,gBAAgB,CAAC,CA4B3B"}
@@ -0,0 +1,29 @@
1
+ import path from 'node:path';
2
+ import { ContextFile } from '../storage/context-file.js';
3
+ import { countTokens } from '../lib/tokens.js';
4
+ const VALID_TYPES = new Set([
5
+ 'decision', 'action', 'issue', 'question', 'dead_end', 'session_end',
6
+ ]);
7
+ export async function handleLogContext(ctx, input) {
8
+ if (!VALID_TYPES.has(input.type)) {
9
+ throw new Error(`Invalid log entry type: ${input.type}. Must be one of: ${[...VALID_TYPES].join(', ')}`);
10
+ }
11
+ const contextFile = new ContextFile(ctx.projectRoot);
12
+ const timestamp = new Date().toISOString().replace('T', ' ').slice(0, 19);
13
+ contextFile.append({
14
+ type: input.type,
15
+ summary: input.summary,
16
+ detail: input.detail,
17
+ timestamp,
18
+ });
19
+ if (ctx.database) {
20
+ const { LoomDatabase } = await import('../storage/database.js');
21
+ if (ctx.database instanceof LoomDatabase) {
22
+ ctx.database.upsertProject(ctx.projectRoot, path.basename(ctx.projectRoot));
23
+ }
24
+ }
25
+ const content = contextFile.read();
26
+ const tokenCount = countTokens(content);
27
+ return { success: true, tokenCount };
28
+ }
29
+ //# sourceMappingURL=log-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-context.js","sourceRoot":"","sources":["../../src/tools/log-context.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAG/C,MAAM,WAAW,GAAgB,IAAI,GAAG,CAAC;IACvC,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa;CACrE,CAAC,CAAC;AAaH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,GAAgB,EAChB,KAAsB;IAEtB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CACb,2BAA2B,KAAK,CAAC,IAAI,qBAAqB,CAAC,GAAG,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACxF,CAAC;IACJ,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAE1E,WAAW,CAAC,MAAM,CAAC;QACjB,IAAI,EAAE,KAAK,CAAC,IAAoB;QAChC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,SAAS;KACV,CAAC,CAAC;IAEH,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAC;QACjB,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAChE,IAAI,GAAG,CAAC,QAAQ,YAAY,YAAY,EAAE,CAAC;YACzC,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC;QAC9E,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;IACnC,MAAM,UAAU,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;IAExC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;AACvC,CAAC"}
@@ -0,0 +1,15 @@
1
+ import type { LoomContext } from '../types.js';
2
+ interface SavePatternInput {
3
+ name: string;
4
+ content: string;
5
+ tags?: string[];
6
+ }
7
+ interface SavePatternResult {
8
+ id: string;
9
+ name: string;
10
+ tags: string[];
11
+ source_project: string;
12
+ }
13
+ export declare function handleSavePattern(ctx: LoomContext, input: SavePatternInput): Promise<SavePatternResult>;
14
+ export {};
15
+ //# sourceMappingURL=save-pattern.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"save-pattern.d.ts","sourceRoot":"","sources":["../../src/tools/save-pattern.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/C,UAAU,gBAAgB;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,UAAU,iBAAiB;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,WAAW,EAChB,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,iBAAiB,CAAC,CAmB5B"}
@@ -0,0 +1,19 @@
1
+ import path from 'node:path';
2
+ export async function handleSavePattern(ctx, input) {
3
+ const db = ctx.database;
4
+ const projectName = path.basename(ctx.projectRoot);
5
+ db.upsertProject(ctx.projectRoot, projectName);
6
+ const pattern = db.savePattern({
7
+ name: input.name,
8
+ content: input.content,
9
+ tags: input.tags ?? [],
10
+ sourceProject: ctx.projectRoot,
11
+ });
12
+ return {
13
+ id: pattern.id,
14
+ name: pattern.name,
15
+ tags: pattern.tags,
16
+ source_project: pattern.source_project ?? ctx.projectRoot,
17
+ };
18
+ }
19
+ //# sourceMappingURL=save-pattern.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"save-pattern.js","sourceRoot":"","sources":["../../src/tools/save-pattern.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAiB7B,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,GAAgB,EAChB,KAAuB;IAEvB,MAAM,EAAE,GAAG,GAAG,CAAC,QAAwB,CAAC;IACxC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAEnD,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;IAE/C,MAAM,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC;QAC7B,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,EAAE;QACtB,aAAa,EAAE,GAAG,CAAC,WAAW;KAC/B,CAAC,CAAC;IAEH,OAAO;QACL,EAAE,EAAE,OAAO,CAAC,EAAE;QACd,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,cAAc,EAAE,OAAO,CAAC,cAAc,IAAI,GAAG,CAAC,WAAW;KAC1D,CAAC;AACJ,CAAC"}
@@ -0,0 +1,54 @@
1
+ import type { LoomDatabase } from './storage/database.js';
2
+ import type { LoomConfig } from './config/types.js';
3
+ export interface LoomContext {
4
+ projectRoot: string;
5
+ loomDir: string;
6
+ contextFilePath: string;
7
+ archivesDir: string;
8
+ manifestsDir: string;
9
+ database?: LoomDatabase;
10
+ config: LoomConfig;
11
+ }
12
+ export type LogEntryType = 'decision' | 'action' | 'issue' | 'question' | 'dead_end' | 'session_end';
13
+ export interface LogEntry {
14
+ type: LogEntryType;
15
+ summary: string;
16
+ detail?: string;
17
+ timestamp: string;
18
+ }
19
+ export interface SessionStatus {
20
+ tokenCount: number;
21
+ archiveCount: number;
22
+ lastEntryTimestamp: string | null;
23
+ warningThreshold: number;
24
+ archiveThreshold: number;
25
+ needsArchive: boolean;
26
+ }
27
+ export interface ArchiveResult {
28
+ archived: boolean;
29
+ archiveFile?: string;
30
+ previousTokenCount?: number;
31
+ newTokenCount?: number;
32
+ message?: string;
33
+ method?: 'intelligent' | 'mechanical';
34
+ warning?: string;
35
+ }
36
+ export interface PatternRecord {
37
+ id: string;
38
+ name: string;
39
+ tags: string[];
40
+ source_project: string | null;
41
+ content: string;
42
+ embedding_hash: string | null;
43
+ created_at: number;
44
+ last_used_at: number;
45
+ use_count: number;
46
+ }
47
+ export interface ProjectRecord {
48
+ path: string;
49
+ name: string;
50
+ last_active_at: number;
51
+ session_count: number;
52
+ privacy_level: string;
53
+ }
54
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAEpD,MAAM,WAAW,WAAW;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,YAAY,CAAC;IACxB,MAAM,EAAE,UAAU,CAAC;CACpB;AAED,MAAM,MAAM,YAAY,GAAG,UAAU,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,UAAU,GAAG,aAAa,CAAC;AAErG,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,YAAY,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,aAAa;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,aAAa,GAAG,YAAY,CAAC;IACtC,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACvB"}
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@pixelguild/loom",
3
+ "version": "0.1.0",
4
+ "description": "Session intelligence layer for Claude Code — persistent memory, intelligent archiving, cross-project patterns, and peer LLM consultation.",
5
+ "type": "module",
6
+ "main": "dist/index.js",
7
+ "bin": {
8
+ "loom": "dist/cli/index.js"
9
+ },
10
+ "files": [
11
+ "dist",
12
+ "!dist/**/__tests__"
13
+ ],
14
+ "keywords": [
15
+ "claude",
16
+ "claude-code",
17
+ "mcp",
18
+ "model-context-protocol",
19
+ "ai",
20
+ "session",
21
+ "context",
22
+ "archiving"
23
+ ],
24
+ "repository": {
25
+ "type": "git",
26
+ "url": "https://github.com/pixelguild/loom.git",
27
+ "directory": "packages/mcp-server"
28
+ },
29
+ "author": "Pixel Guild, LLC",
30
+ "license": "MIT",
31
+ "scripts": {
32
+ "build": "tsc",
33
+ "dev": "tsc --watch",
34
+ "test": "vitest",
35
+ "test:run": "vitest run",
36
+ "lint": "eslint src/",
37
+ "format": "prettier --write src/"
38
+ },
39
+ "dependencies": {
40
+ "@google-cloud/vertexai": "^1.10.0",
41
+ "@modelcontextprotocol/sdk": "^1.27.1",
42
+ "better-sqlite3": "^12.6.2",
43
+ "openai": "^6.27.0",
44
+ "tiktoken": "^1.0.22",
45
+ "zod": "^4.3.6"
46
+ },
47
+ "devDependencies": {
48
+ "@types/better-sqlite3": "^7.6.13",
49
+ "@types/node": "^25.3.5",
50
+ "typescript": "^5.9.3",
51
+ "vitest": "^4.0.18"
52
+ }
53
+ }