kanbus 0.8.2

High-performance CLI and web console for the Kanbus issue tracker. Includes kanbus (CLI) and kanbus-console (web UI server).
Documentation
//! Project discovery helpers.

use std::path::{Path, PathBuf};

use crate::error::KanbusError;
use crate::file_io::{
    discover_kanbus_projects, discover_project_directories as discover_project_directories_inner,
    load_project_directory as load_project_directory_inner,
};

/// Discover all Kanbus project directories from the root.
///
/// # Arguments
/// * `root` - Root directory used for discovery.
///
/// # Errors
/// Returns `KanbusError::IssueOperation` if a configured project path is missing.
pub fn discover_project_directories(root: &Path) -> Result<Vec<PathBuf>, KanbusError> {
    let mut projects = Vec::new();
    discover_project_directories_inner(root, &mut projects)?;
    let mut dotfile_projects = discover_kanbus_projects(root)?;
    projects.append(&mut dotfile_projects);
    let mut normalized = Vec::new();
    for path in projects {
        let canonical = path
            .canonicalize()
            .map_err(|error| KanbusError::Io(error.to_string()))?;
        normalized.push(canonical);
    }
    normalized.sort();
    normalized.dedup();
    Ok(normalized)
}

/// Load a single Kanbus project directory by downward discovery.
///
/// # Arguments
/// * `root` - Root directory used for discovery.
///
/// # Errors
/// Returns `KanbusError::IssueOperation` if no project or multiple projects are found.
pub fn load_project_directory(root: &Path) -> Result<PathBuf, KanbusError> {
    load_project_directory_inner(root)
}