This is not specific to "stg goto" -- it affects all commands that use the new infrastructure. (But of those, only goto and coalesce were subdirectory unsafe.) Signed-off-by: Karl Hasselström <kha@xxxxxxxxxxx> --- On 2007-12-18 10:24:19 +0100, Karl Hasselström wrote: > On 2007-12-18 09:11:00 +0000, Catalin Marinas wrote: > > > On 17/12/2007, Karl Hasselström <kha@xxxxxxxxxxx> wrote: > > > > > Be careful about merging past the "goto" patch -- I'm pretty > > > sure it breaks when called from a subdirectory, and I don't have > > > time to fix that right now. (It should be a clean fix, though -- > > > just adjust the cwd for precisely those git subprocesses that > > > need it, which is very few. I think.) > > > > Why not just change the cwd when the command starts and it should > > be safe for all the git subprocesses. > > It doesn't feel very clean to require the caller of some unspecified > subset of git calls to remember to set the correct piece of global > state. > > And the correct solution should really be very simple, since it's > precisely the worktree operations (specifically, the subset thereof > that have to operate on the whole tree) that require setting cwd. > And those are very clearly separated out from the rest in the new > infrastructure. And here it is! Note that not counting the cwd support in run.py and changing the test to expect success, I had to change just three lines to fix this problem for _all_ "new infrastructure" commands. And no unintended side effects, since the cwd is changed only where it's necessary. stgit/lib/git.py | 5 +++-- stgit/run.py | 9 ++++++--- t/t2800-goto-subdir.sh | 4 ++-- 3 files changed, 11 insertions(+), 7 deletions(-) diff --git a/stgit/lib/git.py b/stgit/lib/git.py index 6aba966..118c9b2 100644 --- a/stgit/lib/git.py +++ b/stgit/lib/git.py @@ -344,6 +344,7 @@ class Worktree(object): def __init__(self, directory): self.__directory = directory env = property(lambda self: { 'GIT_WORK_TREE': self.__directory }) + directory = property(lambda self: self.__directory) class CheckoutException(exception.StgException): pass @@ -364,7 +365,7 @@ class IndexAndWorktree(RunWithEnv): self.run(['git', 'read-tree', '-u', '-m', '--exclude-per-directory=.gitignore', old_tree.sha1, new_tree.sha1] - ).discard_output() + ).cwd(self.__worktree.directory).discard_output() except run.RunException: raise CheckoutException('Index/workdir dirty') def merge(self, base, ours, theirs): @@ -377,7 +378,7 @@ class IndexAndWorktree(RunWithEnv): env = { 'GITHEAD_%s' % base.sha1: 'ancestor', 'GITHEAD_%s' % ours.sha1: 'current', 'GITHEAD_%s' % theirs.sha1: 'patched'} - ).discard_output() + ).cwd(self.__worktree.directory).discard_output() except run.RunException, e: raise MergeException('Index/worktree dirty') def changed_files(self): diff --git a/stgit/run.py b/stgit/run.py index 78537db..77f2e65 100644 --- a/stgit/run.py +++ b/stgit/run.py @@ -42,7 +42,7 @@ class Run: if type(c) != str: raise Exception, 'Bad command: %r' % (cmd,) self.__good_retvals = [0] - self.__env = None + self.__env = self.__cwd = None self.__indata = None self.__discard_stderr = False def __log_start(self): @@ -67,7 +67,7 @@ class Run: """Run with captured IO.""" self.__log_start() try: - p = subprocess.Popen(self.__cmd, env = self.__env, + p = subprocess.Popen(self.__cmd, env = self.__env, cwd = self.__cwd, stdin = subprocess.PIPE, stdout = subprocess.PIPE, stderr = subprocess.PIPE) @@ -85,7 +85,7 @@ class Run: assert self.__indata == None self.__log_start() try: - p = subprocess.Popen(self.__cmd, env = self.__env) + p = subprocess.Popen(self.__cmd, env = self.__env, cwd = self.__cwd) self.exitcode = p.wait() except OSError, e: raise self.exc('%s failed: %s' % (self.__cmd[0], e)) @@ -104,6 +104,9 @@ class Run: self.__env = dict(os.environ) self.__env.update(env) return self + def cwd(self, cwd): + self.__cwd = cwd + return self def raw_input(self, indata): self.__indata = indata return self diff --git a/t/t2800-goto-subdir.sh b/t/t2800-goto-subdir.sh index 9f3ab26..fcad7da 100755 --- a/t/t2800-goto-subdir.sh +++ b/t/t2800-goto-subdir.sh @@ -24,7 +24,7 @@ EOF cat > expected2.txt <<EOF bar EOF -test_expect_failure 'Goto in subdirectory (just pop)' ' +test_expect_success 'Goto in subdirectory (just pop)' ' (cd foo && stg goto p1) && cat foo/bar > actual.txt && diff -u expected1.txt actual.txt && @@ -47,7 +47,7 @@ EOF cat > expected2.txt <<EOF bar EOF -test_expect_failure 'Goto in subdirectory (conflicting push)' ' +test_expect_success 'Goto in subdirectory (conflicting push)' ' (cd foo && stg goto p3) ; [ $? -eq 3 ] && cat foo/bar > actual.txt && - 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