From 9bc519d686f2f3451e07ce5d814b3a85306a414d Mon Sep 17 00:00:00 2001 From: rsc Date: Mon, 26 Jun 2006 05:49:18 +0000 Subject: fix dup file name bug --- src/cmd/sam/sam.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/cmd/sam/sam.c b/src/cmd/sam/sam.c index 120c53ac..f180290b 100644 --- a/src/cmd/sam/sam.c +++ b/src/cmd/sam/sam.c @@ -532,13 +532,22 @@ cd(String *str) Strduplstr(&owd, &curwd); getcurwd(); settempfile(); + /* + * Two passes so that if we have open + * /a/foo.c and /b/foo.c and cd from /b to /a, + * we don't ever have two foo.c simultaneously. + */ for(i=0; iname.s[0]!='/' && f->name.s[0]!=0){ Strinsert(&f->name, &owd, (Posn)0); fixname(&f->name); sortname(f); - }else if(f != cmd && Strispre(&curwd, &f->name)){ + } + } + for(i=0; iname)){ fixname(&f->name); sortname(f); } -- cgit v1.2.3