pub struct TraceLink {
pub id: Uuid,
pub artifact_type: ArtifactType,
pub file_path: String,
pub symbol: Option<String>,
pub line_start: Option<u32>,
pub line_end: Option<u32>,
pub notes: Option<String>,
pub created_at: DateTime<Utc>,
pub created_by: Option<String>,
pub commit_hash: Option<String>,
}Expand description
Represents a trace link between a requirement and a code artifact This enables bidirectional traceability: requirement -> code and code -> requirement
Fields§
§id: UuidUnique identifier for the trace link
artifact_type: ArtifactTypeThe type of artifact (source, test, config, doc)
file_path: StringPath to the file containing the artifact (relative to project root)
symbol: Option<String>Optional symbol name (function, struct, module, etc.)
line_start: Option<u32>Optional line range (start, end) where the implementation exists
line_end: Option<u32>§notes: Option<String>Optional notes about this trace link
created_at: DateTime<Utc>When this trace link was created
created_by: Option<String>Who created this trace link
commit_hash: Option<String>Git commit hash where this trace was identified (optional)
Implementations§
Source§impl TraceLink
impl TraceLink
Sourcepub fn new(artifact_type: ArtifactType, file_path: impl Into<String>) -> Self
pub fn new(artifact_type: ArtifactType, file_path: impl Into<String>) -> Self
Creates a new trace link
Sourcepub fn with_symbol(self, symbol: impl Into<String>) -> Self
pub fn with_symbol(self, symbol: impl Into<String>) -> Self
Sets the symbol name
Sourcepub fn with_lines(self, start: u32, end: u32) -> Self
pub fn with_lines(self, start: u32, end: u32) -> Self
Sets the line range
Sourcepub fn with_notes(self, notes: impl Into<String>) -> Self
pub fn with_notes(self, notes: impl Into<String>) -> Self
Sets notes
Sourcepub fn with_created_by(self, author: impl Into<String>) -> Self
pub fn with_created_by(self, author: impl Into<String>) -> Self
Sets the creator
Sourcepub fn with_commit(self, hash: impl Into<String>) -> Self
pub fn with_commit(self, hash: impl Into<String>) -> Self
Sets the commit hash
Sourcepub fn line_range(&self) -> Option<(u32, u32)>
pub fn line_range(&self) -> Option<(u32, u32)>
Returns the line range as a tuple if both start and end are set
Trait Implementations§
Source§impl<'de> Deserialize<'de> for TraceLink
impl<'de> Deserialize<'de> for TraceLink
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl TS for TraceLink
impl TS for TraceLink
Source§type WithoutGenerics = TraceLink
type WithoutGenerics = TraceLink
If this type does not have generic parameters, then
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = TraceLink
type OptionInnerType = TraceLink
If the implementing type is
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
JSDoc comment to describe this type in TypeScript - when
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
Returns the output path to where
The returned path does not include the base directory from
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
Source§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
Source§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use
TS::export_all. Read moreSource§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
impl Eq for TraceLink
impl StructuralPartialEq for TraceLink
Auto Trait Implementations§
impl Freeze for TraceLink
impl RefUnwindSafe for TraceLink
impl Send for TraceLink
impl Sync for TraceLink
impl Unpin for TraceLink
impl UnsafeUnpin for TraceLink
impl UnwindSafe for TraceLink
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.