diff options
author | eban <eban@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2000-07-05 16:01:49 +0000 |
---|---|---|
committer | eban <eban@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2000-07-05 16:01:49 +0000 |
commit | a60db057a2a8456f8f5b59a6c5805e25d1d47d34 (patch) | |
tree | 79ba940de66214114e73fe0c12bbf56a65ba0968 /win32 | |
parent | a26972d26f38e6c023a955a1073c2801cbf6357b (diff) |
eban
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@815 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'win32')
-rw-r--r-- | win32/win32.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/win32/win32.c b/win32/win32.c index 5780bff261..2bc633a214 100644 --- a/win32/win32.c +++ b/win32/win32.c @@ -872,13 +872,28 @@ insert(char *path, ListInfo *listinfo) } } +#ifdef HAVE_SYS_PARAM_H +# include <sys/param.h> +#else +# define MAXPATHLEN 512 +#endif + +void NtCmdGlob (NtCmdLineElement *patt) { ListInfo listinfo; + char buffer[MAXPATHLEN], *buf = buffer; listinfo.head = listinfo.tail = 0; - rb_glob(patt->str, insert, (VALUE)&listinfo); + if (patt->len >= MAXPATHLEN) + buf = ruby_xmalloc(patt->len + 1); + + strncpy(buf, patt->str, patt->len); + buf[patt->len] = 0; + rb_glob(buf, insert, (VALUE)&listinfo); + if (buf != buffer) + free(buf); if (listinfo.head && listinfo.tail) { listinfo.head->prev = patt->prev; |