mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-05-25 15:03:46 +00:00
This commit addresses two critical bugs identified in the comprehensive review:
1. Database Locking Bug (Rust):
- Problem: Multiple VectorDB instances couldn't share the same database file
- Root cause: redb::Database uses exclusive file locking
- Solution: Implemented global connection pool in storage.rs using
Lazy<Mutex<HashMap<PathBuf, Arc<Database>>>>
- Multiple VectorDB instances now share Arc<Database> for same path
- Location: crates/ruvector-core/src/storage.rs
2. Package Name Mismatch (NPM):
- Problem: ruvector-core was using non-existent scoped package names
- Fixed platformMap to use correct unscoped names:
* @ruvector/core-linux-x64 → ruvector-core-linux-x64-gnu
* @ruvector/core-linux-arm64 → ruvector-core-linux-arm64-gnu
* @ruvector/core-darwin-x64 → ruvector-core-darwin-x64
* @ruvector/core-darwin-arm64 → ruvector-core-darwin-arm64
* @ruvector/core-win32-x64 → ruvector-core-win32-x64-msvc
- Updated error messages to reference correct package names
- Location: npm/packages/core/index.js
Version Updates:
- ruvector-core: 0.1.1 → 0.1.2
- ruvector: 0.1.5 → 0.1.6
Published Packages:
- ruvector-core@0.1.2 (npm)
- ruvector@0.1.6 (npm)
Breaking Changes: None
Backwards Compatible: Yes
Test Coverage:
- Added test_multiple_instances_same_path() to verify connection pooling
- Library builds successfully with storage feature enabled
- CLI commands now work correctly with updated package resolution
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude <noreply@anthropic.com>
|
||
|---|---|---|
| .. | ||
| profiling | ||
| ruvector-bench | ||
| ruvector-cli | ||
| ruvector-core | ||
| ruvector-node | ||
| ruvector-router-cli | ||
| ruvector-router-core | ||
| ruvector-router-ffi | ||
| ruvector-router-wasm | ||
| ruvector-wasm | ||