Re: How to split a patch

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



El 28/1/2008, a las 11:27, Junio C Hamano escribió:

Matthieu Moy <Matthieu.Moy@xxxxxxx> writes:

"Paolo Ciarrocchi" <paolo.ciarrocchi@xxxxxxxxx> writes:

Yes it helps but I still wonder whether thereis a "simpler" way to achive that.
Is it possible to split a patch selecting the hunk in git gui or any
other graphical
tool?

You can apply the patch without commiting it, and them make several
partial commits, by right-click "stage hunk for commit" in git-gui.

Yes, and you can do the same with "git add -i".  These tools are
not quite nice, as they encourage a wrong workflow of committing
what you haven't had as a whole in the work tree.  By
definition, you are making untested commits between your base
commit (that presumably was tested well) and your final commit
(that would also be tested well).

And as another alternative, seeing as Git is so easy to script, it is trivial to make a script that checks out all the commits in a series and runs the test suite against them. This of course assumes that you have a test suite!

For example, this is the script that I use on a topic branch before submitting the corresponding patch series. It's one of the first scripts for Git that I wrote, so it is probably a bit naïve, but it works in the basic case. Basically bails if "make clean && make test" doesn't work for any commit in the series.

I've used this on the series that I've sent to the Git mailing list, but you can use it internally on your local projects too before merging topic branches.

Cheers,
Wincent

#!/bin/sh -e
#
# check-series.sh
# Check all commits in a topic branch before submission
#
# Created by Wincent Colaiuta on 23 November 2007.
# Copyright 2007 Wincent Colaiuta.

#
# Functions
#

die () {
  echo "$1"
  exit 1
}

#
# Main
#

git diff --quiet || die "Unstaged changes; won't start"
git diff --cached --quiet || die "Staged changes; won't start"

# parse HEAD (something like "ref: refs/heads/my_local_branch") to get remote and merge
GIT_DIR=$(git rev-parse --git-dir)
TOPIC="$GIT_DIR/HEAD"
test -f "$TOPIC" || die "No HEAD found at '$TOPIC'"
BRANCH_REF=$(< "$TOPIC")
if [ "${BRANCH_REF%%: */*}" != "ref" ]; then
  die "expected HEAD '$BRANCH_REF' to be of the form 'ref: .../...'"
fi
BRANCH=${BRANCH_REF##*/}
REMOTE=$(git config branch.$BRANCH.remote) || die "failed to get branch.$BRANCH.remote" MERGE=$(git config branch.$BRANCH.merge) || die "failed to get branch. $BRANCH.merge"
MERGE=${MERGE##*/}

# remember which branch we were on prior to starting
trap 'git checkout $BRANCH' exit

# will check all commits in topic branch not present in origin
echo "On branch $BRANCH"
echo "Commits to be checked:"
git rev-list --pretty=oneline HEAD ^$REMOTE/$MERGE
for COMMIT in $(git rev-list HEAD ^$REMOTE/$MERGE); do
  echo "Checking $COMMIT"
  git checkout $COMMIT
  make clean
  make test || die "Commit $COMMIT is bad"
done

echo "All revisions passed!"

-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux