cargo fix + fmt + clippy

This commit is contained in:
Timothy Andrew 2020-06-17 17:08:14 +05:30
parent c4b864f38f
commit e6a2866e7e
No known key found for this signature in database
GPG Key ID: ABD64509E977B249
3 changed files with 47 additions and 26 deletions

View File

@ -1,11 +1,14 @@
use crate::api::search::PullRequestStatus; use crate::api::search::PullRequestStatus;
use crate::graph::FlatDep; use crate::graph::FlatDep;
use std::error::Error;
use git2::{Cred, ObjectType, Repository, Index, Sort, CherrypickOptions, Remote, Commit, PushOptions, RemoteCallbacks};
use git2::build::CheckoutBuilder;
use tokio::process::Command;
use dialoguer::Input; use dialoguer::Input;
use std::env; use git2::build::CheckoutBuilder;
use git2::{
CherrypickOptions,
Repository, Sort,
};
use std::error::Error;
use tokio::process::Command;
fn remote_ref(remote: &str, git_ref: &str) -> String { fn remote_ref(remote: &str, git_ref: &str) -> String {
format!("{}/{}", remote, git_ref) format!("{}/{}", remote, git_ref)
@ -14,10 +17,13 @@ fn remote_ref(remote: &str, git_ref: &str) -> String {
fn loop_until_confirm(prompt: &str) { fn loop_until_confirm(prompt: &str) {
let prompt = format!("{} Type 'yes' to continue", prompt); let prompt = format!("{} Type 'yes' to continue", prompt);
loop { loop {
let result = Input::<String>::new().with_prompt(&prompt).interact().unwrap(); let result = Input::<String>::new()
.with_prompt(&prompt)
.interact()
.unwrap();
match &result[..] { match &result[..] {
"yes" => return, "yes" => return,
_ => continue _ => continue,
} }
} }
} }
@ -58,7 +64,10 @@ pub fn generate_rebase_script(deps: FlatDep) -> String {
out.push_str("\n# -------------- #\n\n"); out.push_str("\n# -------------- #\n\n");
out.push_str(&format!("export TO=\"{}\"\n", remote_ref("heap", &to))); out.push_str(&format!("export TO=\"{}\"\n", remote_ref("heap", &to)));
out.push_str(&format!("export FROM=\"{}\"\n\n", remote_ref("heap", from.head()))); out.push_str(&format!(
"export FROM=\"{}\"\n\n",
remote_ref("heap", from.head())
));
out.push_str("git checkout \"$TO\"\n"); out.push_str("git checkout \"$TO\"\n");
out.push_str("git cherry-pick \"$PREBASE\"..\"$FROM\"\n"); out.push_str("git cherry-pick \"$PREBASE\"..\"$FROM\"\n");
@ -69,12 +78,16 @@ pub fn generate_rebase_script(deps: FlatDep) -> String {
out out
} }
pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> Result<(), Box<dyn Error>> { pub async fn perform_rebase(
deps: FlatDep,
repo: &Repository,
remote: &str,
) -> Result<(), Box<dyn Error>> {
let deps = deps let deps = deps
.iter() .iter()
.filter(|(dep, _)| *dep.state() == PullRequestStatus::Open) .filter(|(dep, _)| *dep.state() == PullRequestStatus::Open)
.collect::<Vec<_>>(); .collect::<Vec<_>>();
let (pr, _) = deps[0]; let (pr, _) = deps[0];
let base = remote_ref(remote, pr.base()); let base = remote_ref(remote, pr.base());
@ -96,7 +109,6 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
for (pr, _) in deps { for (pr, _) in deps {
println!("Working on PR: {:?}", pr.head()); println!("Working on PR: {:?}", pr.head());
let from = repo.revparse_single(&pr.head()).unwrap(); let from = repo.revparse_single(&pr.head()).unwrap();
let from = from.as_commit().unwrap(); let from = from.as_commit().unwrap();
@ -110,7 +122,9 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
// TODO: Skip if remote/<branch> is the same SHA as <branch> // TODO: Skip if remote/<branch> is the same SHA as <branch>
for from in walk { for from in walk {
let from = repo.find_commit(from.unwrap()).unwrap(); let from = repo.find_commit(from.unwrap()).unwrap();
let to = repo.find_commit(repo.head().unwrap().target().unwrap()).unwrap(); let to = repo
.find_commit(repo.head().unwrap().target().unwrap())
.unwrap();
if from.parent_count() > 1 { if from.parent_count() > 1 {
panic!("Exiting: I don't know how to deal with merge commits correctly."); panic!("Exiting: I don't know how to deal with merge commits correctly.");
@ -120,7 +134,7 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
cb.allow_conflicts(true); cb.allow_conflicts(true);
let mut opts = CherrypickOptions::new(); let mut opts = CherrypickOptions::new();
opts.checkout_builder(cb); opts.checkout_builder(cb);
println!("Cherry-picking: {:?}", from); println!("Cherry-picking: {:?}", from);
repo.cherrypick(&from, Some(&mut opts)).unwrap(); repo.cherrypick(&from, Some(&mut opts)).unwrap();
@ -131,21 +145,31 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
loop_until_confirm(prompt); loop_until_confirm(prompt);
index = repo.index().unwrap(); index = repo.index().unwrap();
index.read(true).unwrap(); index.read(true).unwrap();
} }
let tree = index.write_tree_to(&repo).unwrap(); let tree = index.write_tree_to(&repo).unwrap();
let tree = repo.find_tree(tree).unwrap(); let tree = repo.find_tree(tree).unwrap();
let signature = repo.signature().unwrap(); let signature = repo.signature().unwrap();
let commit = repo.commit(None, &signature, &signature, &from.message().unwrap(), &tree, &[&to]).unwrap(); let commit = repo
.commit(
None,
&signature,
&signature,
&from.message().unwrap(),
&tree,
&[&to],
)
.unwrap();
let commit = repo.find_commit(commit).unwrap(); let commit = repo.find_commit(commit).unwrap();
let mut cb = CheckoutBuilder::new(); let mut cb = CheckoutBuilder::new();
cb.force(); cb.force();
repo.checkout_tree(&commit.as_object(), Some(&mut cb)).unwrap(); repo.checkout_tree(&commit.as_object(), Some(&mut cb))
.unwrap();
repo.set_head_detached(commit.id()).unwrap(); repo.set_head_detached(commit.id()).unwrap();
// "Complete" the cherry-pick. There is likely a better way to do // "Complete" the cherry-pick. There is likely a better way to do
// this that I haven't found so far. // this that I haven't found so far.
repo.cleanup_state().unwrap(); repo.cleanup_state().unwrap();
} }
@ -156,14 +180,15 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
repo.branch(pr.head(), &head, true).unwrap(); repo.branch(pr.head(), &head, true).unwrap();
// Use remote branch as boundary for next cherry-pick // Use remote branch as boundary for next cherry-pick
let from = repo.revparse_single(&remote_ref(remote, pr.head())).unwrap(); let from = repo
.revparse_single(&remote_ref(remote, pr.head()))
.unwrap();
let from = from.as_commit().unwrap(); let from = from.as_commit().unwrap();
stop_cherry_pick_at = from.id(); stop_cherry_pick_at = from.id();
push_refspecs.push(format!("refs/heads/{}:refs/heads/{}", pr.head(), pr.head())); push_refspecs.push(format!("refs/heads/{}:refs/heads/{}", pr.head(), pr.head()));
} }
let repo_dir = repo.workdir().unwrap().to_str().unwrap(); let repo_dir = repo.workdir().unwrap().to_str().unwrap();
// `libgit2` doesn't support refspecs containing raw SHAs, so we shell out // `libgit2` doesn't support refspecs containing raw SHAs, so we shell out
@ -179,4 +204,4 @@ pub async fn perform_rebase(deps: FlatDep, repo: &Repository, remote: &str) -> R
command.spawn()?.await?; command.spawn()?.await?;
Ok(()) Ok(())
} }

View File

@ -1,5 +1,5 @@
use std::collections::HashMap;
use git2::Repository; use git2::Repository;
use std::collections::HashMap;
use std::env; use std::env;
use std::error::Error; use std::error::Error;
use std::fs; use std::fs;

View File

@ -1,10 +1,6 @@
use regex::Regex; use regex::Regex;
use crate::api::search::PullRequestStatus;
use crate::api::search::{PullRequestStatus};
use crate::graph::FlatDep; use crate::graph::FlatDep;
fn process(row: String) -> String { fn process(row: String) -> String {