@colbymchenry/codegraph 0.3.1 → 0.5.1
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/LICENSE +21 -21
- package/README.md +681 -641
- package/dist/bin/codegraph.d.ts +7 -2
- package/dist/bin/codegraph.d.ts.map +1 -1
- package/dist/bin/codegraph.js +360 -140
- package/dist/bin/codegraph.js.map +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +43 -10
- package/dist/config.js.map +1 -1
- package/dist/context/index.d.ts +17 -4
- package/dist/context/index.d.ts.map +1 -1
- package/dist/context/index.js +182 -15
- package/dist/context/index.js.map +1 -1
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +21 -0
- package/dist/db/index.js.map +1 -1
- package/dist/db/migrations.d.ts +1 -1
- package/dist/db/migrations.d.ts.map +1 -1
- package/dist/db/migrations.js +19 -12
- package/dist/db/migrations.js.map +1 -1
- package/dist/db/queries.d.ts +32 -1
- package/dist/db/queries.d.ts.map +1 -1
- package/dist/db/queries.js +271 -118
- package/dist/db/queries.js.map +1 -1
- package/dist/db/schema.sql +163 -149
- package/dist/directory.d.ts +13 -1
- package/dist/directory.d.ts.map +1 -1
- package/dist/directory.js +85 -19
- package/dist/directory.js.map +1 -1
- package/dist/errors.d.ts +1 -1
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +7 -1
- package/dist/errors.js.map +1 -1
- package/dist/extraction/grammars.d.ts +9 -4
- package/dist/extraction/grammars.d.ts.map +1 -1
- package/dist/extraction/grammars.js +133 -65
- package/dist/extraction/grammars.js.map +1 -1
- package/dist/extraction/index.d.ts +6 -0
- package/dist/extraction/index.d.ts.map +1 -1
- package/dist/extraction/index.js +209 -44
- package/dist/extraction/index.js.map +1 -1
- package/dist/extraction/tree-sitter.d.ts +67 -0
- package/dist/extraction/tree-sitter.d.ts.map +1 -1
- package/dist/extraction/tree-sitter.js +980 -38
- package/dist/extraction/tree-sitter.js.map +1 -1
- package/dist/graph/traversal.d.ts.map +1 -1
- package/dist/graph/traversal.js +6 -2
- package/dist/graph/traversal.js.map +1 -1
- package/dist/index.d.ts +6 -38
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +91 -73
- package/dist/index.js.map +1 -1
- package/dist/installer/banner.js +7 -7
- package/dist/installer/claude-md-template.js +32 -32
- package/dist/installer/config-writer.d.ts +9 -0
- package/dist/installer/config-writer.d.ts.map +1 -1
- package/dist/installer/config-writer.js +126 -17
- package/dist/installer/config-writer.js.map +1 -1
- package/dist/installer/index.d.ts.map +1 -1
- package/dist/installer/index.js +11 -9
- package/dist/installer/index.js.map +1 -1
- package/dist/mcp/index.d.ts +14 -3
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +109 -29
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/tools.d.ts +66 -1
- package/dist/mcp/tools.d.ts.map +1 -1
- package/dist/mcp/tools.js +442 -49
- package/dist/mcp/tools.js.map +1 -1
- package/dist/mcp/transport.d.ts.map +1 -1
- package/dist/mcp/transport.js +2 -0
- package/dist/mcp/transport.js.map +1 -1
- package/dist/resolution/frameworks/index.d.ts +1 -0
- package/dist/resolution/frameworks/index.d.ts.map +1 -1
- package/dist/resolution/frameworks/index.js +5 -1
- package/dist/resolution/frameworks/index.js.map +1 -1
- package/dist/resolution/frameworks/svelte.d.ts +9 -0
- package/dist/resolution/frameworks/svelte.d.ts.map +1 -0
- package/dist/resolution/frameworks/svelte.js +268 -0
- package/dist/resolution/frameworks/svelte.js.map +1 -0
- package/dist/resolution/import-resolver.d.ts.map +1 -1
- package/dist/resolution/import-resolver.js +3 -4
- package/dist/resolution/import-resolver.js.map +1 -1
- package/dist/resolution/index.d.ts +15 -2
- package/dist/resolution/index.d.ts.map +1 -1
- package/dist/resolution/index.js +153 -13
- package/dist/resolution/index.js.map +1 -1
- package/dist/resolution/name-matcher.d.ts.map +1 -1
- package/dist/resolution/name-matcher.js +7 -20
- package/dist/resolution/name-matcher.js.map +1 -1
- package/dist/resolution/types.d.ts +4 -0
- package/dist/resolution/types.d.ts.map +1 -1
- package/dist/search/query-utils.d.ts +25 -0
- package/dist/search/query-utils.d.ts.map +1 -0
- package/dist/search/query-utils.js +124 -0
- package/dist/search/query-utils.js.map +1 -0
- package/dist/sentry.d.ts +22 -0
- package/dist/sentry.d.ts.map +1 -0
- package/dist/sentry.js +159 -0
- package/dist/sentry.js.map +1 -0
- package/dist/sync/index.d.ts +4 -2
- package/dist/sync/index.d.ts.map +1 -1
- package/dist/sync/index.js +3 -5
- package/dist/sync/index.js.map +1 -1
- package/dist/types.d.ts +7 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +13 -0
- package/dist/types.js.map +1 -1
- package/dist/utils.d.ts +89 -2
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +252 -3
- package/dist/utils.js.map +1 -1
- package/dist/vectors/embedder.d.ts +1 -1
- package/dist/vectors/embedder.d.ts.map +1 -1
- package/dist/vectors/embedder.js +2 -2
- package/dist/vectors/embedder.js.map +1 -1
- package/dist/vectors/search.d.ts.map +1 -1
- package/dist/vectors/search.js +33 -32
- package/dist/vectors/search.js.map +1 -1
- package/package.json +74 -67
- package/scripts/patch-tree-sitter-dart.js +112 -0
- package/scripts/postinstall.js +71 -68
- package/dist/sync/git-hooks.d.ts +0 -66
- package/dist/sync/git-hooks.d.ts.map +0 -1
- package/dist/sync/git-hooks.js +0 -281
- package/dist/sync/git-hooks.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,67 +1,74 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@colbymchenry/codegraph",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "Supercharge Claude Code with semantic code intelligence. 30% fewer tokens, 25% fewer tool calls, 100% local.",
|
|
5
|
-
"main": "dist/index.js",
|
|
6
|
-
"types": "dist/index.d.ts",
|
|
7
|
-
"bin": {
|
|
8
|
-
"codegraph": "./dist/bin/codegraph.js"
|
|
9
|
-
},
|
|
10
|
-
"files": [
|
|
11
|
-
"dist",
|
|
12
|
-
"scripts",
|
|
13
|
-
"README.md"
|
|
14
|
-
],
|
|
15
|
-
"scripts": {
|
|
16
|
-
"build": "tsc && npm run copy-assets",
|
|
17
|
-
"postinstall": "node scripts/postinstall.js",
|
|
18
|
-
"copy-assets": "
|
|
19
|
-
"dev": "tsc --watch",
|
|
20
|
-
"cli": "npm run build && node dist/bin/codegraph.js",
|
|
21
|
-
"test": "vitest run",
|
|
22
|
-
"test:watch": "vitest",
|
|
23
|
-
"test:eval": "vitest run __tests__/evaluation/",
|
|
24
|
-
"eval": "npm run build && npx tsx __tests__/evaluation/runner.ts",
|
|
25
|
-
"clean": "
|
|
26
|
-
},
|
|
27
|
-
"keywords": [
|
|
28
|
-
"code-intelligence",
|
|
29
|
-
"knowledge-graph",
|
|
30
|
-
"static-analysis",
|
|
31
|
-
"semantic-search"
|
|
32
|
-
],
|
|
33
|
-
"author": "",
|
|
34
|
-
"license": "MIT",
|
|
35
|
-
"dependencies": {
|
|
36
|
-
"@xenova/transformers": "^2.17.0",
|
|
37
|
-
"better-sqlite3": "^11.0.0",
|
|
38
|
-
"commander": "^14.0.2",
|
|
39
|
-
"figlet": "^1.8.0",
|
|
40
|
-
"
|
|
41
|
-
"tree-sitter": "
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
"
|
|
45
|
-
"
|
|
46
|
-
"
|
|
47
|
-
"
|
|
48
|
-
"
|
|
49
|
-
"
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
"tree-sitter-
|
|
53
|
-
"
|
|
54
|
-
"tree-sitter-
|
|
55
|
-
"tree-sitter-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
"
|
|
59
|
-
"
|
|
60
|
-
"
|
|
61
|
-
"
|
|
62
|
-
"
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
"
|
|
66
|
-
|
|
67
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@colbymchenry/codegraph",
|
|
3
|
+
"version": "0.5.1",
|
|
4
|
+
"description": "Supercharge Claude Code with semantic code intelligence. 30% fewer tokens, 25% fewer tool calls, 100% local.",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"bin": {
|
|
8
|
+
"codegraph": "./dist/bin/codegraph.js"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"dist",
|
|
12
|
+
"scripts",
|
|
13
|
+
"README.md"
|
|
14
|
+
],
|
|
15
|
+
"scripts": {
|
|
16
|
+
"build": "tsc && npm run copy-assets",
|
|
17
|
+
"postinstall": "node scripts/postinstall.js",
|
|
18
|
+
"copy-assets": "node -e \"const fs=require('fs');fs.mkdirSync('dist/db',{recursive:true});fs.copyFileSync('src/db/schema.sql','dist/db/schema.sql')\"",
|
|
19
|
+
"dev": "tsc --watch",
|
|
20
|
+
"cli": "npm run build && node dist/bin/codegraph.js",
|
|
21
|
+
"test": "vitest run",
|
|
22
|
+
"test:watch": "vitest",
|
|
23
|
+
"test:eval": "vitest run __tests__/evaluation/",
|
|
24
|
+
"eval": "npm run build && npx tsx __tests__/evaluation/runner.ts",
|
|
25
|
+
"clean": "node -e \"const fs=require('fs');fs.rmSync('dist',{recursive:true,force:true})\""
|
|
26
|
+
},
|
|
27
|
+
"keywords": [
|
|
28
|
+
"code-intelligence",
|
|
29
|
+
"knowledge-graph",
|
|
30
|
+
"static-analysis",
|
|
31
|
+
"semantic-search"
|
|
32
|
+
],
|
|
33
|
+
"author": "",
|
|
34
|
+
"license": "MIT",
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"@xenova/transformers": "^2.17.0",
|
|
37
|
+
"better-sqlite3": "^11.0.0",
|
|
38
|
+
"commander": "^14.0.2",
|
|
39
|
+
"figlet": "^1.8.0",
|
|
40
|
+
"picomatch": "^4.0.3",
|
|
41
|
+
"tree-sitter": "0.22.4"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@types/better-sqlite3": "^7.6.0",
|
|
45
|
+
"@types/figlet": "^1.5.8",
|
|
46
|
+
"@types/node": "^20.19.30",
|
|
47
|
+
"@types/picomatch": "^4.0.2",
|
|
48
|
+
"typescript": "^5.0.0",
|
|
49
|
+
"vitest": "^2.1.9"
|
|
50
|
+
},
|
|
51
|
+
"optionalDependencies": {
|
|
52
|
+
"@sengac/tree-sitter-dart": "1.1.6",
|
|
53
|
+
"sqlite-vss": "^0.1.2",
|
|
54
|
+
"tree-sitter-c": "0.23.2",
|
|
55
|
+
"tree-sitter-c-sharp": "0.23.1",
|
|
56
|
+
"tree-sitter-cpp": "0.23.4",
|
|
57
|
+
"tree-sitter-go": "0.23.4",
|
|
58
|
+
"tree-sitter-java": "0.23.5",
|
|
59
|
+
"tree-sitter-javascript": "0.23.1",
|
|
60
|
+
"tree-sitter-kotlin": "0.3.8",
|
|
61
|
+
"tree-sitter-php": "0.23.11",
|
|
62
|
+
"tree-sitter-python": "0.23.4",
|
|
63
|
+
"tree-sitter-ruby": "0.23.1",
|
|
64
|
+
"tree-sitter-rust": "0.23.1",
|
|
65
|
+
"tree-sitter-swift": "0.6.0",
|
|
66
|
+
"tree-sitter-typescript": "0.23.2"
|
|
67
|
+
},
|
|
68
|
+
"engines": {
|
|
69
|
+
"node": ">=18.0.0"
|
|
70
|
+
},
|
|
71
|
+
"overrides": {
|
|
72
|
+
"tree-sitter": "0.22.4"
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Patches tree-sitter-dart to use NAPI bindings compatible with tree-sitter 0.22+
|
|
4
|
+
*
|
|
5
|
+
* tree-sitter-dart v1.0.0 ships with NAN-style bindings that are incompatible
|
|
6
|
+
* with tree-sitter 0.22+ which expects NAPI-style bindings with type-tagged
|
|
7
|
+
* externals. This script rewrites the binding files and rebuilds.
|
|
8
|
+
*/
|
|
9
|
+
const { writeFileSync, existsSync } = require('fs');
|
|
10
|
+
const { join } = require('path');
|
|
11
|
+
const { execSync } = require('child_process');
|
|
12
|
+
|
|
13
|
+
const DART_DIR = join(__dirname, '..', 'node_modules', 'tree-sitter-dart');
|
|
14
|
+
|
|
15
|
+
if (!existsSync(DART_DIR)) {
|
|
16
|
+
// tree-sitter-dart not installed, skip
|
|
17
|
+
process.exit(0);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// Check if already patched (look for NAPI-style binding)
|
|
21
|
+
const bindingPath = join(DART_DIR, 'bindings', 'node', 'binding.cc');
|
|
22
|
+
const { readFileSync } = require('fs');
|
|
23
|
+
try {
|
|
24
|
+
const existing = readFileSync(bindingPath, 'utf8');
|
|
25
|
+
if (existing.includes('napi.h')) {
|
|
26
|
+
// Already patched, check if build exists
|
|
27
|
+
const buildPath = join(DART_DIR, 'build', 'Release', 'tree_sitter_dart_binding.node');
|
|
28
|
+
if (existsSync(buildPath)) {
|
|
29
|
+
console.log('tree-sitter-dart: already patched and built.');
|
|
30
|
+
process.exit(0);
|
|
31
|
+
}
|
|
32
|
+
// Patched but not built, fall through to rebuild
|
|
33
|
+
}
|
|
34
|
+
} catch {
|
|
35
|
+
// Can't read, continue with patch
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
console.log('Patching tree-sitter-dart for NAPI compatibility...');
|
|
39
|
+
|
|
40
|
+
// Write NAPI-compatible binding.cc
|
|
41
|
+
const bindingCC = `#include <napi.h>
|
|
42
|
+
|
|
43
|
+
typedef struct TSLanguage TSLanguage;
|
|
44
|
+
|
|
45
|
+
extern "C" TSLanguage *tree_sitter_dart();
|
|
46
|
+
|
|
47
|
+
// "tree-sitter", "language" hashed with BLAKE2
|
|
48
|
+
const napi_type_tag LANGUAGE_TYPE_TAG = {
|
|
49
|
+
0x8AF2E5212AD58ABF, 0xD5006CAD83ABBA16
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
Napi::Object Init(Napi::Env env, Napi::Object exports) {
|
|
53
|
+
exports["name"] = Napi::String::New(env, "dart");
|
|
54
|
+
auto language = Napi::External<TSLanguage>::New(env, tree_sitter_dart());
|
|
55
|
+
language.TypeTag(&LANGUAGE_TYPE_TAG);
|
|
56
|
+
exports["language"] = language;
|
|
57
|
+
return exports;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
NODE_API_MODULE(tree_sitter_dart_binding, Init)
|
|
61
|
+
`;
|
|
62
|
+
writeFileSync(bindingPath, bindingCC);
|
|
63
|
+
|
|
64
|
+
// Write NAPI-compatible binding.gyp
|
|
65
|
+
const bindingGyp = `{
|
|
66
|
+
"targets": [
|
|
67
|
+
{
|
|
68
|
+
"target_name": "tree_sitter_dart_binding",
|
|
69
|
+
"dependencies": [
|
|
70
|
+
"<!(node -p \\"require('node-addon-api').targets\\"):node_addon_api_except"
|
|
71
|
+
],
|
|
72
|
+
"include_dirs": [
|
|
73
|
+
"src"
|
|
74
|
+
],
|
|
75
|
+
"sources": [
|
|
76
|
+
"src/parser.c",
|
|
77
|
+
"bindings/node/binding.cc",
|
|
78
|
+
"src/scanner.c"
|
|
79
|
+
],
|
|
80
|
+
"conditions": [
|
|
81
|
+
["OS!='win'", {
|
|
82
|
+
"cflags_c": [
|
|
83
|
+
"-std=c99"
|
|
84
|
+
]
|
|
85
|
+
}, {
|
|
86
|
+
"cflags_c": [
|
|
87
|
+
"/std:c11",
|
|
88
|
+
"/utf-8"
|
|
89
|
+
]
|
|
90
|
+
}]
|
|
91
|
+
]
|
|
92
|
+
}
|
|
93
|
+
]
|
|
94
|
+
}
|
|
95
|
+
`;
|
|
96
|
+
writeFileSync(join(DART_DIR, 'binding.gyp'), bindingGyp);
|
|
97
|
+
|
|
98
|
+
// Rebuild native module
|
|
99
|
+
try {
|
|
100
|
+
execSync('npx node-gyp rebuild', {
|
|
101
|
+
cwd: DART_DIR,
|
|
102
|
+
stdio: 'pipe',
|
|
103
|
+
timeout: 120000,
|
|
104
|
+
});
|
|
105
|
+
console.log('tree-sitter-dart: patched and rebuilt successfully.');
|
|
106
|
+
} catch (error) {
|
|
107
|
+
console.error('Warning: Failed to rebuild tree-sitter-dart native module.');
|
|
108
|
+
console.error('Dart language support may not work.');
|
|
109
|
+
if (process.env.DEBUG) {
|
|
110
|
+
console.error(error.stderr?.toString());
|
|
111
|
+
}
|
|
112
|
+
}
|
package/scripts/postinstall.js
CHANGED
|
@@ -1,68 +1,71 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* Postinstall script - downloads the embedding model to ~/.codegraph/models
|
|
4
|
-
* This runs after `npm install` or `npx @colbymchenry/codegraph`
|
|
5
|
-
*/
|
|
6
|
-
const { existsSync, mkdirSync } = require('fs');
|
|
7
|
-
const { join } = require('path');
|
|
8
|
-
const { homedir } = require('os');
|
|
9
|
-
|
|
10
|
-
const CODEGRAPH_DIR = join(homedir(), '.codegraph');
|
|
11
|
-
const MODELS_DIR = join(CODEGRAPH_DIR, 'models');
|
|
12
|
-
const MODEL_ID = 'nomic-ai/nomic-embed-text-v1.5';
|
|
13
|
-
|
|
14
|
-
async function downloadModel() {
|
|
15
|
-
// Ensure directories exist
|
|
16
|
-
if (!existsSync(CODEGRAPH_DIR)) {
|
|
17
|
-
mkdirSync(CODEGRAPH_DIR, { recursive: true });
|
|
18
|
-
}
|
|
19
|
-
if (!existsSync(MODELS_DIR)) {
|
|
20
|
-
mkdirSync(MODELS_DIR, { recursive: true });
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
// Check if model is already cached
|
|
24
|
-
const modelCachePath = join(MODELS_DIR, MODEL_ID.replace('/', '/'));
|
|
25
|
-
if (existsSync(modelCachePath)) {
|
|
26
|
-
console.log('Embedding model already downloaded.');
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
console.log('Downloading embedding model (~130MB)...');
|
|
31
|
-
console.log('This is a one-time download for semantic code search.\n');
|
|
32
|
-
|
|
33
|
-
try {
|
|
34
|
-
// Dynamic import for @xenova/transformers (ESM-only package)
|
|
35
|
-
const { pipeline, env } = await import('@xenova/transformers');
|
|
36
|
-
|
|
37
|
-
// Configure cache directory
|
|
38
|
-
env.cacheDir = MODELS_DIR;
|
|
39
|
-
|
|
40
|
-
// Download with progress
|
|
41
|
-
await pipeline('feature-extraction', MODEL_ID, {
|
|
42
|
-
progress_callback: (progress) => {
|
|
43
|
-
if (progress.status === 'progress' && progress.file && progress.progress !== undefined) {
|
|
44
|
-
const fileName = progress.file.split('/').pop();
|
|
45
|
-
const percent = Math.round(progress.progress);
|
|
46
|
-
process.stdout.write(`\rDownloading ${fileName}... ${percent}% `);
|
|
47
|
-
} else if (progress.status === 'done') {
|
|
48
|
-
process.stdout.write('\n');
|
|
49
|
-
}
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
console.log('\nEmbedding model ready!');
|
|
54
|
-
} catch (error) {
|
|
55
|
-
// Don't fail the install if model download fails
|
|
56
|
-
// User can still use codegraph without semantic search
|
|
57
|
-
console.log('\nNote: Could not download embedding model.');
|
|
58
|
-
console.log('Semantic search will download it on first use.');
|
|
59
|
-
if (process.env.DEBUG) {
|
|
60
|
-
console.error(error);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Postinstall script - downloads the embedding model to ~/.codegraph/models
|
|
4
|
+
* This runs after `npm install` or `npx @colbymchenry/codegraph`
|
|
5
|
+
*/
|
|
6
|
+
const { existsSync, mkdirSync } = require('fs');
|
|
7
|
+
const { join } = require('path');
|
|
8
|
+
const { homedir } = require('os');
|
|
9
|
+
|
|
10
|
+
const CODEGRAPH_DIR = join(homedir(), '.codegraph');
|
|
11
|
+
const MODELS_DIR = join(CODEGRAPH_DIR, 'models');
|
|
12
|
+
const MODEL_ID = 'nomic-ai/nomic-embed-text-v1.5';
|
|
13
|
+
|
|
14
|
+
async function downloadModel() {
|
|
15
|
+
// Ensure directories exist
|
|
16
|
+
if (!existsSync(CODEGRAPH_DIR)) {
|
|
17
|
+
mkdirSync(CODEGRAPH_DIR, { recursive: true });
|
|
18
|
+
}
|
|
19
|
+
if (!existsSync(MODELS_DIR)) {
|
|
20
|
+
mkdirSync(MODELS_DIR, { recursive: true });
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Check if model is already cached
|
|
24
|
+
const modelCachePath = join(MODELS_DIR, MODEL_ID.replace('/', '/'));
|
|
25
|
+
if (existsSync(modelCachePath)) {
|
|
26
|
+
console.log('Embedding model already downloaded.');
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
console.log('Downloading embedding model (~130MB)...');
|
|
31
|
+
console.log('This is a one-time download for semantic code search.\n');
|
|
32
|
+
|
|
33
|
+
try {
|
|
34
|
+
// Dynamic import for @xenova/transformers (ESM-only package)
|
|
35
|
+
const { pipeline, env } = await import('@xenova/transformers');
|
|
36
|
+
|
|
37
|
+
// Configure cache directory
|
|
38
|
+
env.cacheDir = MODELS_DIR;
|
|
39
|
+
|
|
40
|
+
// Download with progress
|
|
41
|
+
await pipeline('feature-extraction', MODEL_ID, {
|
|
42
|
+
progress_callback: (progress) => {
|
|
43
|
+
if (progress.status === 'progress' && progress.file && progress.progress !== undefined) {
|
|
44
|
+
const fileName = progress.file.split('/').pop();
|
|
45
|
+
const percent = Math.round(progress.progress);
|
|
46
|
+
process.stdout.write(`\rDownloading ${fileName}... ${percent}% `);
|
|
47
|
+
} else if (progress.status === 'done') {
|
|
48
|
+
process.stdout.write('\n');
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
console.log('\nEmbedding model ready!');
|
|
54
|
+
} catch (error) {
|
|
55
|
+
// Don't fail the install if model download fails
|
|
56
|
+
// User can still use codegraph without semantic search
|
|
57
|
+
console.log('\nNote: Could not download embedding model.');
|
|
58
|
+
console.log('Semantic search will download it on first use.');
|
|
59
|
+
if (process.env.DEBUG) {
|
|
60
|
+
console.error(error);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
// @sengac/tree-sitter-dart ships with NAPI prebuilds for all platforms
|
|
66
|
+
// No patching needed (replaced old tree-sitter-dart v1.0.0 which used NAN bindings)
|
|
67
|
+
|
|
68
|
+
downloadModel().catch(() => {
|
|
69
|
+
// Silent exit - don't break npm install
|
|
70
|
+
process.exit(0);
|
|
71
|
+
});
|
package/dist/sync/git-hooks.d.ts
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Git Hooks Management
|
|
3
|
-
*
|
|
4
|
-
* Installs and manages git hooks for automatic incremental indexing.
|
|
5
|
-
*/
|
|
6
|
-
/**
|
|
7
|
-
* Result of hook installation
|
|
8
|
-
*/
|
|
9
|
-
export interface HookInstallResult {
|
|
10
|
-
success: boolean;
|
|
11
|
-
hookPath: string;
|
|
12
|
-
message: string;
|
|
13
|
-
previousHookBackedUp?: boolean;
|
|
14
|
-
backupPath?: string;
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* Result of hook removal
|
|
18
|
-
*/
|
|
19
|
-
export interface HookRemoveResult {
|
|
20
|
-
success: boolean;
|
|
21
|
-
message: string;
|
|
22
|
-
restoredFromBackup?: boolean;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Git hooks manager
|
|
26
|
-
*/
|
|
27
|
-
export declare class GitHooksManager {
|
|
28
|
-
private gitDir;
|
|
29
|
-
private hooksDir;
|
|
30
|
-
constructor(projectRoot: string);
|
|
31
|
-
/**
|
|
32
|
-
* Check if the project is a git repository
|
|
33
|
-
*/
|
|
34
|
-
isGitRepository(): boolean;
|
|
35
|
-
/**
|
|
36
|
-
* Check if the post-commit hook is installed by CodeGraph
|
|
37
|
-
*/
|
|
38
|
-
isHookInstalled(): boolean;
|
|
39
|
-
/**
|
|
40
|
-
* Install the post-commit hook
|
|
41
|
-
*
|
|
42
|
-
* If a hook already exists:
|
|
43
|
-
* - If it's a CodeGraph hook, update it
|
|
44
|
-
* - If it's a user hook, back it up and install ours
|
|
45
|
-
*/
|
|
46
|
-
installHook(): HookInstallResult;
|
|
47
|
-
/**
|
|
48
|
-
* Remove the CodeGraph post-commit hook
|
|
49
|
-
*
|
|
50
|
-
* If a backup exists, restore it.
|
|
51
|
-
*/
|
|
52
|
-
removeHook(): HookRemoveResult;
|
|
53
|
-
/**
|
|
54
|
-
* Get the path to the hooks directory
|
|
55
|
-
*/
|
|
56
|
-
getHooksDir(): string;
|
|
57
|
-
/**
|
|
58
|
-
* Get the path to the post-commit hook
|
|
59
|
-
*/
|
|
60
|
-
getHookPath(): string;
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Create a git hooks manager for a project
|
|
64
|
-
*/
|
|
65
|
-
export declare function createGitHooksManager(projectRoot: string): GitHooksManager;
|
|
66
|
-
//# sourceMappingURL=git-hooks.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"git-hooks.d.ts","sourceRoot":"","sources":["../../src/sync/git-hooks.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAgDH;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAED;;GAEG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,QAAQ,CAAS;gBAEb,WAAW,EAAE,MAAM;IAK/B;;OAEG;IACH,eAAe,IAAI,OAAO;IAI1B;;OAEG;IACH,eAAe,IAAI,OAAO;IAe1B;;;;;;OAMG;IACH,WAAW,IAAI,iBAAiB;IAgFhC;;;;OAIG;IACH,UAAU,IAAI,gBAAgB;IA8D9B;;OAEG;IACH,WAAW,IAAI,MAAM;IAIrB;;OAEG;IACH,WAAW,IAAI,MAAM;CAGtB;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,WAAW,EAAE,MAAM,GAAG,eAAe,CAE1E"}
|