diff options
author | Christopher Faylor <me+cygwin@cgf.cx> | 2001-10-31 19:05:35 +0000 |
---|---|---|
committer | Christopher Faylor <me+cygwin@cgf.cx> | 2001-10-31 19:05:35 +0000 |
commit | 3f8ad85b6f36ce50ddaf10a4709cbedaec14e15a (patch) | |
tree | 7bd7764b9458ce63077de065b6bcddb338716921 | |
parent | 2cd533b7690e09f4b17795e24b2652e61538a0a8 (diff) | |
download | gdb-3f8ad85b6f36ce50ddaf10a4709cbedaec14e15a.zip gdb-3f8ad85b6f36ce50ddaf10a4709cbedaec14e15a.tar.gz gdb-3f8ad85b6f36ce50ddaf10a4709cbedaec14e15a.tar.bz2 |
* win32-nat.c (register_loaded_dll): Attempt to ensure that the case of the
loaded DLL matches the on-disk case since the debugging API does not seem to
ensure this. Calculate max name length here.
(handle_load_dll): Move max name length calculation to register_loaded_dll.
-rw-r--r-- | gdb/ChangeLog | 8 | ||||
-rw-r--r-- | gdb/win32-nat.c | 31 | ||||
-rw-r--r-- | gdb/windows-nat.c | 31 |
3 files changed, 54 insertions, 16 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index f45cfe0..fca30f1 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +2001-10-31 Christopher Faylor <cgf@redhat.com> + + * win32-nat.c (register_loaded_dll): Attempt to ensure that the case of + the loaded DLL matches the on-disk case since the debugging API does + not seem to ensure this. Calculate max name length here. + (handle_load_dll): Move max name length calculation to + register_loaded_dll. + 2001-10-31 Daniel Jacobowitz <drow@mvista.com> * arm-linux-nat.c: Include <asm/ptrace.h> explicitly. diff --git a/gdb/win32-nat.c b/gdb/win32-nat.c index 884f2b4..10847b8 100644 --- a/gdb/win32-nat.c +++ b/gdb/win32-nat.c @@ -510,7 +510,26 @@ register_loaded_dll (const char *name, DWORD load_addr) { struct so_stuff *so; char ppath[MAX_PATH + 1]; - cygwin_conv_to_posix_path (name, ppath); + char buf[MAX_PATH + 1]; + char cwd[MAX_PATH + 1]; + char *p; + WIN32_FIND_DATA w32_fd; + HANDLE h = FindFirstFile(name, &w32_fd); + size_t len; + + FindClose (h); + strcpy (buf, name); + if (GetCurrentDirectory (MAX_PATH + 1, cwd)) + { + p = strrchr (buf, '\\'); + if (p) + p[1] = '\0'; + SetCurrentDirectory (buf); + GetFullPathName (w32_fd.cFileName, MAX_PATH, buf, &p); + SetCurrentDirectory (cwd); + } + + cygwin_conv_to_posix_path (buf, ppath); so = (struct so_stuff *) xmalloc (sizeof (struct so_stuff) + strlen (ppath) + 8 + 1); so->loaded = 0; so->load_addr = load_addr; @@ -519,6 +538,9 @@ register_loaded_dll (const char *name, DWORD load_addr) solib_end->next = so; solib_end = so; so->next = NULL; + len = strlen (ppath); + if (len > max_dll_name_len) + max_dll_name_len = len; } /* Wait for child to do something. Return pid of child, or -1 in case @@ -531,7 +553,6 @@ handle_load_dll (void *dummy ATTRIBUTE_UNUSED) DWORD done; char dll_buf[MAX_PATH + 1]; char *dll_name = NULL; - int len; char *p; dll_buf[0] = dll_buf[sizeof (dll_buf) - 1] = '\0'; @@ -600,13 +621,7 @@ handle_load_dll (void *dummy ATTRIBUTE_UNUSED) if (!dll_name) return 1; - while ((p = strchr (dll_name, '\\'))) - *p = '/'; - register_loaded_dll (dll_name, (DWORD) event->lpBaseOfDll + 0x1000); - len = strlen (dll_name); - if (len > max_dll_name_len) - max_dll_name_len = len; return 1; } diff --git a/gdb/windows-nat.c b/gdb/windows-nat.c index 884f2b4..10847b8 100644 --- a/gdb/windows-nat.c +++ b/gdb/windows-nat.c @@ -510,7 +510,26 @@ register_loaded_dll (const char *name, DWORD load_addr) { struct so_stuff *so; char ppath[MAX_PATH + 1]; - cygwin_conv_to_posix_path (name, ppath); + char buf[MAX_PATH + 1]; + char cwd[MAX_PATH + 1]; + char *p; + WIN32_FIND_DATA w32_fd; + HANDLE h = FindFirstFile(name, &w32_fd); + size_t len; + + FindClose (h); + strcpy (buf, name); + if (GetCurrentDirectory (MAX_PATH + 1, cwd)) + { + p = strrchr (buf, '\\'); + if (p) + p[1] = '\0'; + SetCurrentDirectory (buf); + GetFullPathName (w32_fd.cFileName, MAX_PATH, buf, &p); + SetCurrentDirectory (cwd); + } + + cygwin_conv_to_posix_path (buf, ppath); so = (struct so_stuff *) xmalloc (sizeof (struct so_stuff) + strlen (ppath) + 8 + 1); so->loaded = 0; so->load_addr = load_addr; @@ -519,6 +538,9 @@ register_loaded_dll (const char *name, DWORD load_addr) solib_end->next = so; solib_end = so; so->next = NULL; + len = strlen (ppath); + if (len > max_dll_name_len) + max_dll_name_len = len; } /* Wait for child to do something. Return pid of child, or -1 in case @@ -531,7 +553,6 @@ handle_load_dll (void *dummy ATTRIBUTE_UNUSED) DWORD done; char dll_buf[MAX_PATH + 1]; char *dll_name = NULL; - int len; char *p; dll_buf[0] = dll_buf[sizeof (dll_buf) - 1] = '\0'; @@ -600,13 +621,7 @@ handle_load_dll (void *dummy ATTRIBUTE_UNUSED) if (!dll_name) return 1; - while ((p = strchr (dll_name, '\\'))) - *p = '/'; - register_loaded_dll (dll_name, (DWORD) event->lpBaseOfDll + 0x1000); - len = strlen (dll_name); - if (len > max_dll_name_len) - max_dll_name_len = len; return 1; } |