KodegenConfig

Struct KodegenConfig 

Source
pub struct KodegenConfig;
Expand description

Main configuration path resolver

Implementations§

Source§

impl KodegenConfig

Source

pub fn user_config_dir() -> Result<PathBuf>

Get user-global config directory (XDG-compliant)

Platform paths:

  • Unix/Linux: $XDG_CONFIG_HOME/kodegen (default: ~/.config/kodegen)
  • macOS: ~/Library/Application Support/kodegen
  • Windows: %APPDATA%\kodegen

This ALWAYS returns the user-global config directory, never the local .kodegen/.

Source

pub fn local_config_dir() -> Result<PathBuf>

Get git workspace-local config directory

Returns: ${git_root}/.kodegen

This ONLY returns the local .kodegen/ directory, never the user config.

§Errors

Returns an error if:

  • Not in a git repository
  • Current directory cannot be determined
  • Git repository is invalid or corrupted
Source

pub fn state_dir() -> Result<PathBuf>

Get state directory (for PIDs, sockets, runtime state)

Note: Log files should use log_dir() instead.

Platform paths:

  • Unix/Linux: $XDG_STATE_HOME/kodegen (default: ~/.local/state/kodegen)
  • macOS: ~/Library/Application Support/kodegen/state
  • Windows: %LOCALAPPDATA%\kodegen\state

State ALWAYS uses user-global directories (never local .kodegen/).

Source

pub fn log_dir() -> Result<PathBuf>

Get log directory (for .log files only)

Platform paths:

  • Unix/Linux: $XDG_STATE_HOME/kodegen/logs (default: ~/.local/state/kodegen/logs)
  • macOS: ~/Library/Logs/kodegen
  • Windows: %LOCALAPPDATA%\kodegen\logs

Logs ALWAYS use user-global directories (never local .kodegen/).

Source

pub fn data_dir() -> Result<PathBuf>

Get data directory (for databases, stats, caches)

Platform paths:

  • Unix/Linux: $XDG_DATA_HOME/kodegen (default: ~/.local/share/kodegen)
  • macOS: ~/Library/Application Support/kodegen/data
  • Windows: %LOCALAPPDATA%\kodegen\data

Data ALWAYS uses user-global directories (never local .kodegen/).

Source

pub fn resolve_toolset(name: &str) -> Result<PathBuf>

Resolve toolset file path with local > user precedence

Search order:

  1. ${git_root}/.kodegen/toolset/{name}.json
  2. $XDG_CONFIG_HOME/kodegen/toolset/{name}.json
§Errors

Returns an error if the toolset file is not found in either location. The error message includes all searched paths to aid debugging.

Source

pub fn resolve_config_file(filename: &str) -> Result<PathBuf>

Resolve config file path with local > user precedence

Search order:

  1. ${git_root}/.kodegen/{filename}
  2. $XDG_CONFIG_HOME/kodegen/{filename}
§Errors

Returns an error if the config file is not found in either location. The error message includes all searched paths to aid debugging.

Source

pub fn init_structure() -> Result<()>

Initialize directory structures for both local and user config

Creates:

  • User config: toolset/, claude/ subdirectories + .gitignore
  • User state: logs/ subdirectory
  • User data: stats/, memory/ subdirectories
  • Local config (if in git repo): toolset/, claude/ + adds to .gitignore

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> 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, 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.