mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 18:27:38 +00:00
workspace: introduce Workspace
type
Having a concept of a "workspace" will be useful for adding support for multiple workspaces (#13). You can think of the "workspace" as a repo combined with a working copy. A workspace corresponds 1:1 with a `.jj/` directory. It's pretty close to what other VCS simply call a "repo", but I've ended up using the word "repo" for what Git calls a "bare repo".
This commit is contained in:
parent
813ae0276d
commit
c0711f47cf
4 changed files with 316 additions and 240 deletions
|
@ -59,3 +59,4 @@ pub mod tree;
|
|||
pub mod tree_builder;
|
||||
pub mod view;
|
||||
pub mod working_copy;
|
||||
pub mod workspace;
|
||||
|
|
|
@ -419,6 +419,14 @@ impl RepoLoader {
|
|||
})
|
||||
}
|
||||
|
||||
pub fn repo_path(&self) -> &PathBuf {
|
||||
&self.repo_path
|
||||
}
|
||||
|
||||
pub fn working_copy_path(&self) -> &PathBuf {
|
||||
&self.wc_path
|
||||
}
|
||||
|
||||
pub fn store(&self) -> &Arc<Store> {
|
||||
&self.store
|
||||
}
|
||||
|
|
54
lib/src/workspace.rs
Normal file
54
lib/src/workspace.rs
Normal file
|
@ -0,0 +1,54 @@
|
|||
// Copyright 2021 Google LLC
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// https://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use std::path::PathBuf;
|
||||
|
||||
use crate::repo::{RepoLoadError, RepoLoader};
|
||||
use crate::settings::UserSettings;
|
||||
|
||||
/// Represents a workspace, i.e. what's typically the .jj/ directory and its
|
||||
/// parent.
|
||||
pub struct Workspace {
|
||||
// Path to the workspace root (typically the parent of a .jj/ directory), which is where
|
||||
// working copy files live.
|
||||
workspace_root: PathBuf,
|
||||
repo_loader: RepoLoader,
|
||||
}
|
||||
|
||||
impl Workspace {
|
||||
pub fn load(
|
||||
user_settings: &UserSettings,
|
||||
workspace_root: PathBuf,
|
||||
) -> Result<Self, RepoLoadError> {
|
||||
// TODO: Move the find_repo_dir() call from RepoLoader::init() to here
|
||||
let repo_loader = RepoLoader::init(user_settings, workspace_root)?;
|
||||
let workspace_root = repo_loader.working_copy_path().clone();
|
||||
Ok(Self {
|
||||
workspace_root,
|
||||
repo_loader,
|
||||
})
|
||||
}
|
||||
|
||||
pub fn workspace_root(&self) -> &PathBuf {
|
||||
&self.workspace_root
|
||||
}
|
||||
|
||||
pub fn repo_path(&self) -> &PathBuf {
|
||||
self.repo_loader.repo_path()
|
||||
}
|
||||
|
||||
pub fn repo_loader(&self) -> &RepoLoader {
|
||||
&self.repo_loader
|
||||
}
|
||||
}
|
481
src/commands.rs
481
src/commands.rs
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue