plan9port

[fork] Plan 9 from user space
git clone git://src.adamsgaard.dk/plan9port # fast
git clone https://src.adamsgaard.dk/plan9port.git # slow
Log | Files | Refs | README | LICENSE Back to index

commit 5fc55a953e9dcd895d9be01c528f329e8dfc685e
parent 8a7509066422b70655bebea156834cad6b76a86f
Author: rsc <devnull@localhost>
Date:   Tue,  8 Feb 2005 20:27:10 +0000

avoid unix special files

Diffstat:
Msrc/cmd/vac/vac.c | 21+++++++--------------
1 file changed, 7 insertions(+), 14 deletions(-)

diff --git a/src/cmd/vac/vac.c b/src/cmd/vac/vac.c @@ -382,18 +382,6 @@ isexcluded(char *name) return 0; } -static int -islink(char *name) -{ - struct stat st; - - if(lstat(name, &st) < 0) - return 0; - if((st.st_mode&S_IFMT) == S_IFLNK) - return 1; - return 0; -} - static void vacfile(DirSink *dsink, char *lname, char *sname, VacFile *vf) { @@ -410,9 +398,14 @@ vacfile(DirSink *dsink, char *lname, char *sname, VacFile *vf) if(merge && vacmerge(dsink, lname, sname) >= 0) return; - if(islink(sname)) + if((dir = dirstat(sname)) == nil){ + warn("could not stat file %s: %r", lname); + if(dir->mode&(DMSYMLINK|DMDEVICE|DMNAMEDPIPE|DMSOCKET)){ + free(dir); return; - + } + free(dir); + fd = open(sname, OREAD); if(fd < 0) { warn("could not open file: %s: %r", lname);