Skip to content

Commit

Permalink
eban
Browse files Browse the repository at this point in the history
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@969 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
eban committed Sep 25, 2000
1 parent 7be4b47 commit fb897de
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 9 deletions.
2 changes: 1 addition & 1 deletion ChangeLog
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Mon Sep 25 13:31:45 2000 WATANABE Hirofumi <eban@os.rim.or.jp>

* dir.c (rb_glob): DOSISH support.
* win32/win32.c (NtCmdGlob): substitute '\\' with '/'.

Mon Sep 25 00:35:01 2000 WATANABE Hirofumi <eban@os.rim.or.jp>

Expand Down
12 changes: 5 additions & 7 deletions dir.c
Original file line number Diff line number Diff line change
Expand Up @@ -511,11 +511,9 @@ has_magic(s, send)
return Qtrue;
continue;

#if !defined DOSISH
case '\\':
if (*p++ == '\0')
return Qfalse;
#endif
}

if (send && p >= send) break;
Expand All @@ -533,7 +531,7 @@ extract_path(p, pend)
len = pend - p;
alloc = ALLOC_N(char, len+1);
memcpy(alloc, p, len);
if (len > 1 && isdirsep(pend[-1])) {
if (len > 1 && pend[-1] == '/') {
alloc[len-1] = 0;
}
else {
Expand All @@ -549,7 +547,7 @@ extract_elem(path)
{
char *pend;

pend = find_dirsep(path);
pend = strchr(path, '/');
if (!pend) pend = path + strlen(path);

return extract_path(path, pend);
Expand Down Expand Up @@ -577,8 +575,8 @@ rb_glob(path, func, arg)

p = path;
while (p) {
if (isdirsep(*p)) p++;
m = find_dirsep(p);
if (*p == '/') p++;
m = strchr(p, '/');
if (has_magic(p, m)) {
char *dir, *base, *magic, *buf;
DIR *dirp;
Expand Down Expand Up @@ -607,7 +605,7 @@ rb_glob(path, func, arg)
free(base);
break;
}
#define BASE (*base && !(isdirsep(*base) && !base[1]))
#define BASE (*base && !(*base == '/' && !base[1]))

for (dp = readdir(dirp); dp != NULL; dp = readdir(dirp)) {
if (recursive) {
Expand Down
7 changes: 6 additions & 1 deletion win32/win32.c
Original file line number Diff line number Diff line change
Expand Up @@ -873,13 +873,18 @@ NtCmdGlob (NtCmdLineElement *patt)
{
ListInfo listinfo;
char buffer[MAXPATHLEN], *buf = buffer;
char *p, *pend, *pb;

listinfo.head = listinfo.tail = 0;

if (patt->len >= MAXPATHLEN)
buf = ruby_xmalloc(patt->len + 1);

strncpy(buf, patt->str, patt->len);
p = patt->str;
pend = p + patt->len;
pb = buf;
for (; p < pend; p = CharNext(p))
*pb++ = *p == '\\' ? '/' : *p;
buf[patt->len] = 0;
rb_glob(buf, insert, (VALUE)&listinfo);
if (buf != buffer)
Expand Down

0 comments on commit fb897de

Please sign in to comment.