// GetCurrent returns the current, open code review. // // If there are multiple matching reviews, then an error is returned. func GetCurrent() (*Review, error) { reviewRef := repository.GetHeadRef() currentCommit := repository.GetCommitHash(reviewRef) var matchingReviews []Review for _, review := range ListOpen() { if review.Request.ReviewRef == reviewRef { matchingReviews = append(matchingReviews, review) } } if matchingReviews == nil { return nil, nil } if len(matchingReviews) != 1 { return nil, fmt.Errorf("There are %d open reviews for the ref \"%s\"", len(matchingReviews), reviewRef) } r := &matchingReviews[0] reports := ci.ParseAllValid(repository.GetNotes(ci.Ref, currentCommit)) r.Reports = reports return r, nil }
// Create a new code review request. // // The "args" parameter is all of the command line arguments that followed the subcommand. func requestReview(args []string) error { requestFlagSet.Parse(args) if !*requestAllowUncommitted { // Requesting a code review with uncommited local changes is usually a mistake, so // we want to report that to the user instead of creating the request. if repository.HasUncommittedChanges() { return errors.New("You have uncommitted or untracked files. Use --allow-uncommitted to ignore those.") } } r := buildRequestFromFlags() if r.ReviewRef == "HEAD" { r.ReviewRef = repository.GetHeadRef() } repository.VerifyGitRefOrDie(r.TargetRef) repository.VerifyGitRefOrDie(r.ReviewRef) reviewCommits := repository.ListCommitsBetween(r.TargetRef, r.ReviewRef) if reviewCommits == nil { return errors.New("There are no commits included in the review request") } if r.Description == "" { r.Description = repository.GetCommitMessage(reviewCommits[0]) } note, err := r.Write() if err != nil { return err } repository.AppendNote(request.Ref, reviewCommits[0], note) if !*requestQuiet { fmt.Printf(requestSummaryTemplate, reviewCommits[0], r.TargetRef, r.ReviewRef, r.Description) } return nil }