laburnum 1.17.1

An LSP framework for building language servers and compilers, powered by an incremental query tree with content-addressed storage, task-based dataflow, and parallel queries.
Documentation
// Copyright Two Neutron Stars Incorporated and contributors
// SPDX-License-Identifier: BlueOak-1.0.0

use crate::{
  Ident,
  database::{
    DynPartition,
    PartitionKey,
  },
};

pub struct Workspace;

impl PartitionKey for Workspace {
  const KEY: Ident = Ident::new("laburnum::workspace");
}
/// To write workspace configuration, create a wrapper partition with
/// [`impl_partition_for_dyn!`]:
///
/// ```rust,ignore
/// use laburnum::{impl_partition_for_dyn, partitions::Workspace};
///
/// // Your record type must implement WorkspaceRecord + Record
/// impl_partition_for_dyn!(MyWorkspacePartition, Workspace, MyConfig);
///
/// // Then write using the wrapper partition
/// let sort_key = WorkspaceSortKey::Config;
/// writer.write::<MyWorkspacePartition>(sort_key, config.into());
/// ```
///
/// [`impl_partition_for_dyn!`]: crate::impl_partition_for_dyn
impl DynPartition for Workspace {
  type DynSortKey = WorkspaceSortKey;
  type RecordConstraint = dyn WorkspaceRecord;
}

impl<R: WorkspaceRecord + crate::record::Record>
  crate::database::DynPartitionRecord<Workspace> for R
{
}

#[derive(Debug, Clone)]
pub enum WorkspaceSortKey {
  Config,
  All,
}

impl std::fmt::Display for WorkspaceSortKey {
  fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
    match self {
      | WorkspaceSortKey::Config => write!(f, "config"),
      | WorkspaceSortKey::All => Ok(()),
    }
  }
}

pub trait WorkspaceRecord: Send + Sync + std::fmt::Debug {}