Add Runtime::ensure_configured_branch_is_checked_out
This commit is contained in:
parent
e13722accb
commit
e5503116ad
1 changed files with 54 additions and 3 deletions
|
@ -1,12 +1,15 @@
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
|
||||||
use git2::{Repository, Signature};
|
use git2::{Repository, Signature};
|
||||||
|
use toml::Value;
|
||||||
|
|
||||||
use libimagerror::into::IntoError;
|
use libimagerror::into::IntoError;
|
||||||
use libimagerror::trace::trace_error;
|
use libimagerror::trace::trace_error;
|
||||||
|
use libimagstore::hook::error::CustomData;
|
||||||
|
use libimagstore::hook::error::HookErrorKind as HEK;
|
||||||
|
|
||||||
use vcs::git::result::Result;
|
use vcs::git::result::Result;
|
||||||
use vcs::git::error::GitHookErrorKind as GHEK;
|
use vcs::git::error::{MapErrInto, GitHookErrorKind as GHEK};
|
||||||
use vcs::git::config::{author_name, author_mail, committer_name, committer_mail};
|
use vcs::git::config::{author_name, author_mail, committer_name, committer_mail};
|
||||||
|
|
||||||
struct Person<'a> {
|
struct Person<'a> {
|
||||||
|
@ -45,10 +48,10 @@ impl<'a> Runtime<'a> {
|
||||||
|
|
||||||
pub fn configure(&mut self, config: &Value) -> Result<()> {
|
pub fn configure(&mut self, config: &Value) -> Result<()> {
|
||||||
author_name(cfg)
|
author_name(cfg)
|
||||||
.and_then(|n| author_email(cfg).map(|m| Person::new(n, m)))
|
.and_then(|n| author_mail(cfg).map(|m| Person::new(n, m)))
|
||||||
.and_then(|author| {
|
.and_then(|author| {
|
||||||
committer_name(cfg)
|
committer_name(cfg)
|
||||||
.and_then(|n| committer_email(cfg).map(|m| (author, Person::new(n, m))))
|
.and_then(|n| committer_mail(cfg).map(|m| (author, Person::new(n, m))))
|
||||||
})
|
})
|
||||||
.map(|(author, committer)| {
|
.map(|(author, committer)| {
|
||||||
self.author = Some(author);
|
self.author = Some(author);
|
||||||
|
@ -69,5 +72,53 @@ impl<'a> Runtime<'a> {
|
||||||
self.repository.as_ref().ok_or(GHEK::MkRepo.into_error())
|
self.repository.as_ref().ok_or(GHEK::MkRepo.into_error())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn ensure_cfg_branch_is_checked_out(&self) -> HookResult<()> {
|
||||||
|
use vcs::git::config::ensure_branch;
|
||||||
|
|
||||||
|
let head = try!(self
|
||||||
|
.repository()
|
||||||
|
.and_then(|r| {
|
||||||
|
r.head().map_err_into(GHEK::HeadFetchError)
|
||||||
|
})
|
||||||
|
.map_err(Box::new)
|
||||||
|
.map_err(|e| HEK::HookExecutionError.into_error_with_cause(e)));
|
||||||
|
|
||||||
|
// TODO: Fail if not on branch? hmmh... I'm not sure
|
||||||
|
if head.is_branch() {
|
||||||
|
return Err(GHEK::NotOnBranch.into_error())
|
||||||
|
.map_err(Box::new)
|
||||||
|
.map_err(|e| HEK::HookExecutionError.into_error_with_cause(e));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check out appropriate branch ... or fail
|
||||||
|
match ensure_branch(self.config.as_ref()) {
|
||||||
|
Ok(Some(s)) => {
|
||||||
|
match head.name().map(|name| name == s) {
|
||||||
|
Some(b) => {
|
||||||
|
if b {
|
||||||
|
debug!("Branch already checked out.");
|
||||||
|
Ok(())
|
||||||
|
} else {
|
||||||
|
debug!("Branch not checked out.");
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
None => Err(GHEK::RepositoryBranchNameFetchingError.into_error())
|
||||||
|
.map_err_into(GHEK::RepositoryBranchError)
|
||||||
|
.map_err_into(GHEK::RepositoryError),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Ok(None) => {
|
||||||
|
debug!("No branch to checkout");
|
||||||
|
Ok(())
|
||||||
|
},
|
||||||
|
|
||||||
|
Err(e) => Err(e).map_err_into(GHEK::RepositoryError),
|
||||||
|
}
|
||||||
|
.map_err(Box::new)
|
||||||
|
.map_err(|e| HEK::HookExecutionError.into_error_with_cause(e))
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue