From 583417190488ccbb668a3c149f9dd2ee2f0b837c Mon Sep 17 00:00:00 2001 From: usa Date: Fri, 23 Feb 2007 06:07:55 +0000 Subject: * win32/win32.c (set_pioinfo_extra): simplified. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11826 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- win32/win32.c | 56 +++++++++++++++++--------------------------------------- 1 file changed, 17 insertions(+), 39 deletions(-) (limited to 'win32/win32.c') diff --git a/win32/win32.c b/win32/win32.c index 0554c4206d..f9816c30e5 100644 --- a/win32/win32.c +++ b/win32/win32.c @@ -1672,60 +1672,38 @@ typedef struct { #if !defined(__BORLANDC__) && !defined(_WIN32_WCE) EXTERN_C _CRTIMP ioinfo * __pioinfo[]; +#define IOINFO_L2E 5 +#define IOINFO_ARRAY_ELTS (1 << IOINFO_L2E) +#define _pioinfo(i) ((ioinfo*)((char*)(__pioinfo[i >> IOINFO_L2E]) + (i & (IOINFO_ARRAY_ELTS - 1)) * (sizeof(ioinfo) + pioinfo_extra))) +#define _osfhnd(i) (_pioinfo(i)->osfhnd) +#define _osfile(i) (_pioinfo(i)->osfile) +#define _pipech(i) (_pioinfo(i)->pipech) + #if _MSC_VER >= 1400 static size_t pioinfo_extra = 0; /* workaround for VC++8 SP1 */ static void set_pioinfo_extra(void) { - char libpath[MAXPATHLEN+1]; - HMODULE msvcrt = NULL; - MEMORY_BASIC_INFORMATION m; - DWORD dummy; - DWORD size; - void *buf; - VS_FIXEDFILEINFO *pffi; - int major, minor, teeny, build; - - memset(&m, 0, sizeof(m)); - if (VirtualQuery(stdin, &m, sizeof(m)) && m.State == MEM_COMMIT) - msvcrt = (HMODULE)m.AllocationBase; - if (!msvcrt) - return; - if (!GetModuleFileName(msvcrt, libpath, sizeof(libpath))) - return; + int fd; - size = GetFileVersionInfoSize(libpath, &dummy); - if (size == 0) - return; - buf = malloc(size); - if (!GetFileVersionInfo(libpath, 0, size, buf) || - !VerQueryValue(buf, "\\", &pffi, &dummy)) { - free(buf); - return; + fd = open("NUL", O_RDONLY); + for (pioinfo_extra = 0; pioinfo_extra <= 64; pioinfo_extra += sizeof(void *)) { + if (_osfhnd(fd) == _get_osfhandle(fd)) { + break; + } } - major = HIWORD(pffi->dwFileVersionMS); - minor = LOWORD(pffi->dwFileVersionMS); - teeny = HIWORD(pffi->dwFileVersionLS); - build = LOWORD(pffi->dwFileVersionLS); - free(buf); + close(fd); - if (major == 8 && minor == 0 && - (teeny > 50727 || (teeny == 50727 && build >= 762))) { - pioinfo_extra = 16; + if (pioinfo_extra > 64) { + /* not found, maybe something wrong... */ + pioinfo_extra = 0; } } #else #define pioinfo_extra 0 #endif -#define IOINFO_L2E 5 -#define IOINFO_ARRAY_ELTS (1 << IOINFO_L2E) -#define _pioinfo(i) ((ioinfo*)((char*)(__pioinfo[i >> IOINFO_L2E]) + (i & (IOINFO_ARRAY_ELTS - 1)) * (sizeof(ioinfo) + pioinfo_extra))) -#define _osfhnd(i) (_pioinfo(i)->osfhnd) -#define _osfile(i) (_pioinfo(i)->osfile) -#define _pipech(i) (_pioinfo(i)->pipech) - #define _set_osfhnd(fh, osfh) (void)(_osfhnd(fh) = osfh) #define _set_osflags(fh, flags) (_osfile(fh) = (flags)) -- cgit v1.2.3