Skip to content

Commit

Permalink
* win32/win32.c (exit_handler): new function; release winsock and
Browse files Browse the repository at this point in the history
  environment work area.

* win32/win32.c (NTInitialize): setup exit_handler.

* win32/win32.c (StartSockets): use exit_handler.
  exit handler.

* win32/win32.c (rb_w32_getenv): use GetEnvironmentStrings() instead
  of GetEnvironmentVariable(), because the latter cannot distinguish
  wheather a null environment variable exists or not.
  fixed: [ruby-talk:205123]


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@10650 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
unak committed Jul 31, 2006
1 parent ed2c204 commit 2982c52
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 19 deletions.
15 changes: 15 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,18 @@
Mon Jul 31 16:51:40 2006 NAKAMURA Usaku <[email protected]>

* win32/win32.c (exit_handler): new function; release winsock and
environment work area.

* win32/win32.c (NTInitialize): setup exit_handler.

* win32/win32.c (StartSockets): use exit_handler.
exit handler.

* win32/win32.c (rb_w32_getenv): use GetEnvironmentStrings() instead
of GetEnvironmentVariable(), because the latter cannot distinguish
wheather a null environment variable exists or not.
fixed: [ruby-talk:205123]

Mon Jul 31 16:15:13 2006 Tanaka Akira <[email protected]>

* test/ruby/test_process.rb (TestProcess#test_rlimit_nofile):
Expand Down
49 changes: 30 additions & 19 deletions win32/win32.c
Original file line number Diff line number Diff line change
Expand Up @@ -423,6 +423,21 @@ static void invalid_parameter(const wchar_t *expr, const wchar_t *func, const wc
}
#endif

static BOOL fWinsock;
static char *envarea;
static void
exit_handler(void)
{
if (fWinsock) {
WSACleanup();
fWinsock = FALSE;
}
if (envarea) {
FreeEnvironmentStrings(envarea);
envarea = NULL;
}
}

//
// Initialization stuff
//
Expand Down Expand Up @@ -452,6 +467,8 @@ NtInitialize(int *argc, char ***argv)

init_stdhandle();

atexit(exit_handler);

// Initialize Winsock
StartSockets();

Expand Down Expand Up @@ -2207,7 +2224,7 @@ StartSockets(void)
if (LOBYTE(retdata.wVersion) != 2)
rb_fatal("could not find version 2 of winsock dll\n");

atexit((void (*)(void)) WSACleanup);
fWinsock = TRUE;

main_thread.handle = GetCurrentThreadHandle();
main_thread.id = GetCurrentThreadId();
Expand Down Expand Up @@ -3116,28 +3133,22 @@ wait(int *status)
char *
rb_w32_getenv(const char *name)
{
static char *curitem = NULL;
static DWORD curlen = 0;
DWORD needlen;
int len = strlen(name);
char *env;

if (curitem == NULL || curlen == 0) {
curlen = 512;
curitem = ALLOC_N(char, curlen);
}

needlen = GetEnvironmentVariable(name, curitem, curlen);
if (needlen != 0) {
while (needlen > curlen) {
REALLOC_N(curitem, char, needlen);
curlen = needlen;
needlen = GetEnvironmentVariable(name, curitem, curlen);
}
}
else {
if (envarea)
FreeEnvironmentStrings(envarea);
envarea = GetEnvironmentStrings();
if (!envarea) {
map_errno(GetLastError());
return NULL;
}

return curitem;
for (env = envarea; *env; env += strlen(env) + 1)
if (strncasecmp(env, name, len) == 0 && *(env + len) == '=')
return env + len + 1;

return NULL;
}

int
Expand Down

0 comments on commit 2982c52

Please sign in to comment.