Skip to content

Commit

Permalink
feat(ingestion_node): improved human readable Debug
Browse files Browse the repository at this point in the history
  • Loading branch information
timonv committed Jun 22, 2024
1 parent 06f0343 commit 3ea1a59
Showing 1 changed file with 21 additions and 1 deletion.
22 changes: 21 additions & 1 deletion swiftide/src/ingestion/ingestion_node.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
//! need to be processed together.
use std::{
collections::HashMap,
fmt::Debug,
hash::{Hash, Hasher},
path::PathBuf,
};
Expand All @@ -28,7 +29,7 @@ use std::{
/// `IngestionNode` encapsulates all necessary information for a single unit of data being processed
/// in the ingestion pipeline. It includes fields for an identifier, file path, data chunk, optional
/// vector representation, and metadata.
#[derive(Debug, Default, Clone)]
#[derive(Default, Clone)]
pub struct IngestionNode {
/// Optional identifier for the node.
pub id: Option<u64>,
Expand All @@ -42,6 +43,25 @@ pub struct IngestionNode {
pub metadata: HashMap<String, String>,
}

impl Debug for IngestionNode {
/// Formats the node for debugging purposes.
///
/// This method is used to provide a human-readable representation of the node when debugging.
/// The vector field is displayed as the number of elements in the vector if present.
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.debug_struct("IngestionNode")
.field("id", &self.id)
.field("path", &self.path)
.field("chunk", &self.chunk)
.field("metadata", &self.metadata)
.field(
"vector",
&self.vector.as_ref().map(|v| format!("[{}]", v.len())),
)
.finish()
}
}

impl IngestionNode {
/// Creates a new instance of `IngestionNode` with the specified data chunk.
///
Expand Down

0 comments on commit 3ea1a59

Please sign in to comment.