Skip to main content

RepositoryView

Struct RepositoryView 

Source
pub struct RepositoryView<C = CommitInfo> {
    pub versions: Option<VersionInfo>,
    pub explanation: FieldExplanation,
    pub working_directory: WorkingDirectoryInfo,
    pub remotes: Vec<RemoteInfo>,
    pub ai: AiInfo,
    pub branch_info: Option<BranchInfo>,
    pub pr_template: Option<String>,
    pub pr_template_location: Option<String>,
    pub branch_prs: Option<Vec<PullRequest>>,
    pub commits: Vec<C>,
}
Expand description

Root node of the YAML output produced by view, info, check, and the branch subcommands.

Field presence is runtime-dependent: optional fields are populated only when the active command and repository state require them, and the embedded FieldExplanation reports which fields are actually present in this serialization. See ADR-0013 for the field-presence contract.

Generic over the commit type so the same shape serves both human-facing output (CommitInfo) and AI-facing output (RepositoryViewForAI, using CommitInfoForAI).

Fields§

§versions: Option<VersionInfo>

Version information for the omni-dev tool.

§explanation: FieldExplanation

Explanation of field meanings and structure.

§working_directory: WorkingDirectoryInfo

Working directory status information.

§remotes: Vec<RemoteInfo>

List of remote repositories and their main branches.

§ai: AiInfo

AI-related information.

§branch_info: Option<BranchInfo>

Branch information (only present when using branch commands).

§pr_template: Option<String>

Pull request template content (only present in branch commands when template exists).

§pr_template_location: Option<String>

Location of the pull request template file (only present when pr_template exists).

§branch_prs: Option<Vec<PullRequest>>

Pull requests created from the current branch (only present in branch commands).

§commits: Vec<C>

List of analyzed commits with metadata and analysis.

Implementations§

Source§

impl RepositoryView

Source

pub fn update_field_presence(&mut self)

Updates the present field for all field documentation entries based on actual data.

Source

pub fn to_yaml_output(&mut self) -> Result<String>

Serializes this view to YAML, calling update_field_presence first.

Use this instead of calling update_field_presence followed by crate::data::to_yaml separately. Keeping the two steps together prevents the explanation section from being stale in the output.

Source

pub fn single_commit_view(&self, commit: &CommitInfo) -> Self

Creates a minimal view containing a single commit for parallel dispatch.

Strips metadata not relevant to per-commit AI analysis (versions, working directory status, remotes, PR templates) to reduce prompt size. Only retains branch_info (for scope context) and the single commit.

Source§

impl<C> RepositoryView<C>

Source

pub fn map_commits<D>( self, f: impl FnMut(C) -> Result<D>, ) -> Result<RepositoryView<D>>

Transforms commits while preserving all other fields.

Source§

impl RepositoryView<CommitInfoForAI>

Source

pub fn from_repository_view(repo_view: RepositoryView) -> Result<Self>

Converts from basic RepositoryView by loading diff content for all commits.

Source

pub fn from_repository_view_with_options( repo_view: RepositoryView, fresh: bool, ) -> Result<Self>

Converts from basic RepositoryView with options.

If fresh is true, clears original commit messages to force AI to generate new messages based solely on the diff content.

Trait Implementations§

Source§

impl<C: Clone> Clone for RepositoryView<C>

Source§

fn clone(&self) -> RepositoryView<C>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<C: Debug> Debug for RepositoryView<C>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de, C> Deserialize<'de> for RepositoryView<C>
where C: Deserialize<'de>,

Source§

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<C> Serialize for RepositoryView<C>
where C: Serialize,

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

§

impl<C> Freeze for RepositoryView<C>

§

impl<C> RefUnwindSafe for RepositoryView<C>
where C: RefUnwindSafe,

§

impl<C> Send for RepositoryView<C>
where C: Send,

§

impl<C> Sync for RepositoryView<C>
where C: Sync,

§

impl<C> Unpin for RepositoryView<C>
where C: Unpin,

§

impl<C> UnsafeUnpin for RepositoryView<C>

§

impl<C> UnwindSafe for RepositoryView<C>
where C: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<S> FromSample<S> for S

Source§

fn from_sample_(s: S) -> S

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

Source§

fn to_sample_(self) -> U

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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> Any for T
where T: Any,

Source§

impl<T> CloneAny for T
where T: Any + Clone,

Source§

impl<T> CloneAny for T
where T: Any + Clone,

Source§

impl<T> CloneAnySend for T
where T: Any + Send + Clone,

Source§

impl<T> CloneAnySendSync for T
where T: Any + Send + Sync + Clone,

Source§

impl<T> CloneAnySync for T
where T: Any + Sync + Clone,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

Source§

impl<T> ErasedDestructor for T
where T: 'static,