summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-02-23 06:07:55 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-02-23 06:07:55 +0000
commit583417190488ccbb668a3c149f9dd2ee2f0b837c (patch)
tree479ac87438491ebc2aca8efd71f42d54da99ced0 /win32
parenta9921d08f9378b44a30e5ff5624951da8a917a89 (diff)
* win32/win32.c (set_pioinfo_extra): simplified.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11826 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'win32')
-rw-r--r--win32/win32.c56
1 files changed, 17 insertions, 39 deletions
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))