Skip to content
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

Replacing rev in git-modified; second try #58

Open
ernstki opened this issue Apr 17, 2023 · 3 comments
Open

Replacing rev in git-modified; second try #58

ernstki opened this issue Apr 17, 2023 · 3 comments

Comments

@ernstki
Copy link
Contributor

ernstki commented Apr 17, 2023

I'm looking for a way to accomplish what git-modified is accomplishing with rev, without rev, as discussed in #29 and incorrectly implemented in #39.

git log -1 --name-status --pretty=format:"" "$commit" | cut -f2- | rev | cut -d"$TAB" -f1 | rev | make_relative | while read f; do

It looks like you had to do the rev stuff in 4ea5c29 to account for some change in the output of git log circa 2018.

I didn't understand what was going on with the revs there for a good long while, but now I do1; when a rename happens, there are three columns in the output, and you want the last one.

@nvie, would you be amenable to using awk for this, or is that a dependency you'd hoped to steer clear of? People are likely to have a functional awk even if they're missing rev, although I'll have to double-check if that's the case with Git Bash. On the other hand, some sort of while IFS="$TAB" reading might do the trick, too, in plain shell script.

Footnotes

  1. this SO question was helpful in that regard

@ernstki
Copy link
Contributor Author

ernstki commented Apr 17, 2023

Just for my own edification, here's the command I ran on the git-toolbelt repo as evidence that the output of git log --name-status really does have more than two columns sometimes.

git log --oneline | awk '{print $1}' \
  | xargs -I{} sh -c 'git log -1 --name-status --pretty=format:"" {}' \
  | awk -F'\t' 'NF!=2'

# result:
# R100	git-aa	git-stage-all
# R100	git-cc	git-unstage-all
# R100	git-unmerge	git-undo-merge

Today I learned!

@nvie
Copy link
Owner

nvie commented Apr 17, 2023

would you be amenable to using awk for this, or is that a dependency you'd hoped to steer clear of?

The ... | rev | cut | rev trick is a bit stupid, I agree, but it's a fairly common Unix idiom I've often seen in scripts when you want to use cut in a shell script and want to pick fields from the end if you don't know how many fields are on a line.

I don't mind to switch it over to awk, if you think awk is more commonly available than cut, but even cut seems fairly common to me. Anway, as long as the implementation is solid, I'm happy to take the contribution 👍

@ernstki
Copy link
Contributor Author

ernstki commented Apr 19, 2023

The ... | rev | cut | rev trick is a bit stupid, I agree, but it's a fairly common Unix idiom I've often seen in scripts when you want to use cut in a shell script and want to pick fields from the end if you don't know how many fields are on a line.

No judgements from my side! It's just that rev was a bit of a sticking point for Windows (Git Bash) users, as I recall.

I'll check again, though. Maybe the situation has changed. Certainly the landscape of Unix-on-Windows has changed, with WSL being fairly well established now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants