Skip to main content

GraphDb

Struct GraphDb 

Source
pub struct GraphDb { /* private fields */ }
Expand description

SQLite-backed code graph database.

Implementations§

Source§

impl GraphDb

Source

pub fn open(path: &Path) -> Result<Self>

Open or create a graph database at the given path.

Source

pub fn in_memory() -> Result<Self>

Create an in-memory graph database (for testing).

Source

pub fn insert_node(&self, node: &Node) -> Result<i64>

Insert a node and return its ID.

Source

pub fn insert_batch( &self, nodes: &[Node], edges: &[(i64, i64, EdgeKind)], ) -> Result<Vec<i64>>

Batch insert nodes and edges in a single transaction (much faster for indexing).

Full-text keyword search using FTS5 BM25 ranking.

Source

pub fn insert_edge(&self, edge: &Edge) -> Result<()>

Insert an edge.

Source

pub fn search_nodes(&self, query: &str) -> Result<Vec<Node>>

Search nodes by name (case-insensitive substring match).

Source

pub fn fuzzy_search_nodes(&self, query: &str) -> Result<Vec<Node>>

Fuzzy search nodes by name — ranked by match score (best first).

Source

pub fn edges_from(&self, node_id: i64) -> Result<Vec<Edge>>

Get all edges from a node (outgoing relationships).

Source

pub fn node_count(&self) -> Result<usize>

Get total node count.

Source

pub fn edge_count(&self) -> Result<usize>

Get total edge count.

Source

pub fn clear(&self) -> Result<()>

Clear all data (for re-indexing).

Source

pub fn path(&self) -> Option<PathBuf>

Get the database file path.

Source

pub fn content_hash(content: &str) -> String

Compute SHA-256 hash of content (first 16 hex chars).

Source

pub fn needs_reindex(&self, file_path: &str, content: &str) -> Result<bool>

Check if a file needs re-indexing (hash changed or new file).

Source

pub fn store_file_hash(&self, file_path: &str, content: &str) -> Result<()>

Store file hash after indexing.

Source

pub fn remove_file(&self, file_path: &str) -> Result<()>

Remove nodes and edges for a specific file (for re-indexing).

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.