- 
                Notifications
    You must be signed in to change notification settings 
- Fork 143
Add coloring for review state in "git appraise list" #93
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Conversation
This commit adds different color highlighting to different review states
in the output of "git-appraise list".
The default colors are:
- abandon: magenta,
- accepted: green,
- danger: yellow red bold blink,
- pending: cyan,
- rejected: yellow red bold strike,
- submitted: yellow,
- tbr: red white bold blink.
They can be modified by the user by setting the corresponding
configuration options in the color.appraise section. E.g. to use magenta
for the "pending" state, set color.appraise.pending to "magenta":
 [color "appraise"]
     pending = magenta
    | Thanks for your pull request. It looks like this may be your first contribution to a Google open source project (if not, look below for help). Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). 📝 Please visit https://cla.developers.google.com/ to sign. Once you've signed (or fixed any issues), please reply here (e.g.  What to do if you already signed the CLAIndividual signers
 Corporate signers
 | 
| Hi, | 
| @llorens Thanks for taking this on! I hope git-appraise does work for your use case, and if you hit any issues, please let us know. We do need a signed CLA before we can accept any of your changes, though. The comment from "googlebot" above gives the URL you would need to go to in order to sign it. Thanks. | 
| OK, just signed the CLA. | 
| CLAs look good, thanks! | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks so much for taking the time to put this together!
I do have some feedback, but I think the general approach you are taking makes sense.
Just FYI, when you want to update your PR there is no need to rebase your commits; we like to keep all changes in the repo history since the goal is to track code reviews with git itself.
Again, thanks for your help here!
        
          
                repository/repo.go
              
                Outdated
          
        
      | // they point to. | ||
| FetchAndReturnNewReviewHashes(remote, notesRefPattern, archiveRefPattern string) ([]string, error) | ||
|  | ||
| GetColorBool(name string) bool | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These two new methods need comments explaining what they do.
Additionally, these should probably go up with the rest of the config-fetching methods. I.E. just below the GetSubmitStrategy entry.
Additionally, they should return a tuple including an error, so that we can propagate outwards any errors in invoking the git command line tool
e.g. GetColorBool(name string) (bool, error) and GetColor(name, defaultValue string) (string, error)
        
          
                repository/repo.go
              
                Outdated
          
        
      | FetchAndReturnNewReviewHashes(remote, notesRefPattern, archiveRefPattern string) ([]string, error) | ||
|  | ||
| GetColorBool(name string) bool | ||
| GetColor(name, default_value string) string | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We use camel case for variables instead of snake case.
i.e. defaultValue rather than default_value
        
          
                commands/output/output.go
              
                Outdated
          
        
      |  | ||
| // PrintSummary prints a single-line summary of a review. | ||
| func PrintSummary(r *review.Summary) { | ||
| func PrintSummary(r *review.Summary, repo *repository.Repo) { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The review.Summary type holds a reference to the repo, so you don't have to pass it in here. Instead, you can just reference r.Repo.
Conversely, adding in the additional reference to the repo would be a change to an exported UI, which might break people using git-appraise as a library.
One additional aside; the repository.Repo type is an interface, so you would not normally pass it around as a pointer (but that will become a moot point after the switch to using r.Repo).
| statusString := getStatusString(r) | ||
| indentedDescription := strings.Replace(r.Request.Description, "\n", "\n ", -1) | ||
| fmt.Printf(reviewSummaryTemplate, statusString, r.Revision, indentedDescription) | ||
|  | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We try to reduce the amount of nesting for code blocks by short-circuiting when possible.
In this case, we can check if !useColor right here, and then return fmt.Printf(reviewSummaryTemplate, statusString, r.Revision, indentedDescription).
i.e.
	if !useColor {
		fmt.Printf(reviewSummaryTemplate, statusString, r.Revision, indentedDescription)
		return
	}        
          
                repository/git.go
              
                Outdated
          
        
      | var res string | ||
| var ok error | ||
| if default_value == "" { | ||
| res, ok = repo.runGitCommand( | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In this case I would recommend building the command args first, appending to them if the default is provided, and then only having one line that invokes the command.
e.g.
	args := []string{"config", "--type=color", "-z"}
	if defaultValue != "" {
		args = append(args, "--default", defaultValue)
	}
	args = append(args, "--get", name)
	res, err := repo.runGitCommand(args...)| } | ||
| func (repo *GitRepo) GetColorBool(name string) (bool, error) { | ||
| err := repo.runGitCommandInline("config", "--get-colorbool", name) | ||
| return (err == nil), nil | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it makes sense for this function to return (bool, error) as opposed to bool only, but I understand from your comment that this is a convention so I oblige.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I get what you mean, and with the current implementation it does not make sense.
However, we actually can distinguish between the error produced by having an exit code of 1 vs. other types of errors.
I'm not asking for you to add the code to make that distinction in this PR, as it is a bit complicated to do, but it is helpful to make the API consistent with that if we want to add that logic later on.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is looking really good, thanks for all of your efforts so far!
I do have some minor comments, mostly about naming, but once those are addressed this should be good to go.
        
          
                commands/output/output.go
              
                Outdated
          
        
      | // Number of lines of context to print for inline comments | ||
| contextLineCount = 5 | ||
| ) | ||
| var default_color = map[string]string{ | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this should be "defaultColor" rather than "default_color" (i.e. we use mixed case rather than underscores)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, my 8-hours-per-day coding style seems to have become my second nature.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
BTW, I'll call it defaultColors just in case variable name shadowing is a no-no.
        
          
                commands/output/output.go
              
                Outdated
          
        
      | return "rejected" | ||
| } | ||
|  | ||
| func getColoredStatusString(repo repository.Repo, statusString string) string { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's call this "getColorStatusString".
| var default_color = map[string]string{ | ||
| "tbr": "red white bold blink", | ||
| "pending": "cyan", | ||
| "submitted": "yellow", | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I feel like the colors for "pending" and "submitted" should be swapped.
I think yellow matches better with "pending" because it indicates that attention is needed. Conversely, cyan makes me think more along the lines of "no action necessary", which would match "submitted".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I associate yellow with something old like the paper of an old book becomes yellowish.
There's magenta – which I find pretty aggressive – used for "abandon". How about:
	"pending": "magenta",
	"submitted": "cyan",
	"abandon": "yellow",
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That mapping sounds good to me.
        
          
                repository/repo.go
              
                Outdated
          
        
      | GetColorBool(name string) (bool, error) | ||
|  | ||
| // GetColor returns color configured for "name" (e.g. color.diff.new). | ||
| GetColor(name, default_value string) (string, error) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be "defaultValue" rather than "default_value"
| I'd wait with merging this.  | 
| @llorens Thanks for the warning. My suggestion matches with what you mentioned; pass a map of colors to a new  We could then load that map once inside of the  | 
This commit adds different color highlighting to different review states
in the output of "git-appraise list".
The default colors are:
They can be modified by the user by setting the corresponding
configuration options in the color.appraise section. E.g. to use magenta
for the "pending" state, set color.appraise.pending to "magenta":