Removed no longer used elfdll loader.
diff --git a/loader/Makefile.in b/loader/Makefile.in
index 33f8efb..54499a0 100644
--- a/loader/Makefile.in
+++ b/loader/Makefile.in
@@ -7,7 +7,6 @@
C_SRCS = \
elf.c \
- elfdll.c \
loadorder.c \
main.c \
module.c \
diff --git a/loader/elf.c b/loader/elf.c
index 462b48c..2813d18 100644
--- a/loader/elf.c
+++ b/loader/elf.c
@@ -23,7 +23,6 @@
#include "module.h"
#include "debugtools.h"
#include "winerror.h"
-#include "elfdll.h"
DEFAULT_DEBUG_CHANNEL(win32);
diff --git a/loader/elfdll.c b/loader/elfdll.c
deleted file mode 100644
index 5398c21..0000000
--- a/loader/elfdll.c
+++ /dev/null
@@ -1,214 +0,0 @@
-/*
- * Elf-dll loader functions
- *
- * Copyright 1999 Bertho A. Stultiens
- */
-
-#include <string.h>
-#include <ctype.h>
-#include <stdlib.h>
-
-#include "config.h"
-#include "windef.h"
-#include "global.h"
-#include "process.h"
-#include "module.h"
-#include "heap.h"
-#include "wine/winbase16.h"
-#include "elfdll.h"
-#include "debugtools.h"
-#include "winerror.h"
-
-DEFAULT_DEBUG_CHANNEL(elfdll);
-
-#if defined(HAVE_DL_API)
-#include <dlfcn.h>
-
-/*------------------ HACKS -----------------*/
-extern DWORD fixup_imports(WINE_MODREF *wm);
-extern void dump_exports(HMODULE hModule);
-/*---------------- END HACKS ---------------*/
-
-char *extra_ld_library_path = NULL; /* The extra search-path set in wine.conf */
-
-struct elfdll_image
-{
- HMODULE pe_module_start;
- DWORD pe_module_size;
- NE_MODULE *ne_module_start;
- DWORD ne_module_size;
-};
-
-
-/****************************************************************************
- * ELFDLL_dlopen
- *
- * Wrapper for dlopen to search the EXTRA_LD_LIBRARY_PATH from wine.conf
- * manually because libdl.so caches the environment and does not accept our
- * changes.
- */
-void *ELFDLL_dlopen(const char *libname, int flags)
-{
- char buffer[256];
- int namelen;
- void *handle;
- char *ldpath;
-
- /* First try the default path search of dlopen() */
- handle = dlopen(libname, flags);
- /* do NOT call dlerror() here ! (check after return) */
- if(handle)
- return handle;
-
- /* Now try to construct searches through our extra search-path */
- namelen = strlen(libname);
- ldpath = extra_ld_library_path;
- while(ldpath && *ldpath)
- {
- int len;
- char *cptr;
- char *from;
-
- from = ldpath;
- cptr = strchr(ldpath, ':');
- if(!cptr)
- {
- len = strlen(ldpath);
- ldpath = NULL;
- }
- else
- {
- len = cptr - ldpath;
- ldpath = cptr + 1;
- }
-
- if(len + namelen + 1 >= sizeof(buffer))
- {
- ERR("Buffer overflow! Check EXTRA_LD_LIBRARY_PATH or increase buffer size.\n");
- return NULL;
- }
-
- strncpy(buffer, from, len);
- if(len)
- {
- buffer[len] = '/';
- strcpy(buffer + len + 1, libname);
- }
- else
- strcpy(buffer + len, libname);
-
- TRACE("Trying dlopen('%s', %d)\n", buffer, flags);
-
- handle = dlopen(buffer, flags);
- /* do NOT call dlerror() here ! (check after return) */
- if(handle)
- return handle;
- }
- return NULL;
-}
-
-
-/****************************************************************************
- * get_sobasename (internal)
- *
- */
-static LPSTR get_sobasename(LPCSTR path, LPSTR name)
-{
- char *cptr;
-
- /* Strip the path from the library name */
- if((cptr = strrchr(path, '/')))
- {
- char *cp = strrchr(cptr+1, '\\');
- if(cp && cp > cptr)
- cptr = cp;
- }
- else
- cptr = strrchr(path, '\\');
-
- if(!cptr)
- cptr = (char *)path; /* No '/' nor '\\' in path */
- else
- cptr++;
-
- strcpy(name, cptr);
- cptr = strrchr(name, '.');
- if(cptr && !strcasecmp(cptr,".dll")) *cptr = '\0'; /* Strip extension */
-
- /* Convert to lower case.
- * This must be done manually because it is not sure that
- * other modules are accessible.
- */
- for(cptr = name; *cptr; cptr++)
- *cptr = tolower(*cptr);
-
- return name;
-}
-
-
-/****************************************************************************
- * ELFDLL_LoadLibraryExA (internal)
- *
- * Implementation of elf-dll loading for PE modules
- */
-WINE_MODREF *ELFDLL_LoadLibraryExA(LPCSTR path, DWORD flags)
-{
- LPVOID dlhandle;
- struct elfdll_image *image;
- char name[129];
- char soname[129];
- WINE_MODREF *wm;
-
- get_sobasename(path, name);
- strcpy(soname, name);
- strcat(soname, ".so");
-
- /* Try to open the elf-dll */
- dlhandle = ELFDLL_dlopen(soname, RTLD_LAZY);
- if(!dlhandle)
- {
- WARN("Could not load %s (%s)\n", soname, dlerror());
- SetLastError( ERROR_FILE_NOT_FOUND );
- return NULL;
- }
-
- /* Get the 'dllname_elfdll_image' variable */
- strcpy(soname, name);
- strcat(soname, "_elfdll_image");
- image = (struct elfdll_image *)dlsym(dlhandle, soname);
- if(!image)
- {
- ERR("Could not get elfdll image descriptor %s (%s)\n", soname, dlerror());
- dlclose(dlhandle);
- SetLastError( ERROR_BAD_FORMAT );
- return NULL;
- }
-
- wm = PE_CreateModule( image->pe_module_start, path, 0, -1, FALSE );
- if(!wm)
- {
- ERR("Could not create WINE_MODREF for %s\n", path);
- dlclose(dlhandle);
- SetLastError( ERROR_OUTOFMEMORY );
- return NULL;
- }
- wm->dlhandle = dlhandle;
-
- dump_exports(image->pe_module_start);
- return wm;
-}
-
-#else
-
-/*
- * No elfdlls possible
- * Just put stubs in here.
- */
-
-WINE_MODREF *ELFDLL_LoadLibraryExA(LPCSTR libname, DWORD flags)
-{
- SetLastError( ERROR_FILE_NOT_FOUND );
- return NULL;
-}
-
-#endif
diff --git a/loader/loadorder.c b/loader/loadorder.c
index d5750a7..9e1a1f6 100644
--- a/loader/loadorder.c
+++ b/loader/loadorder.c
@@ -15,7 +15,6 @@
#include "heap.h"
#include "file.h"
#include "module.h"
-#include "elfdll.h"
#include "debugtools.h"
DEFAULT_DEBUG_CHANNEL(module);
@@ -175,7 +174,7 @@
case 'E': /* Elfdll */
case 'e':
- if (!warn++) MESSAGE("Load order 'elfdll' no longer support, ignored\n");
+ if (!warn++) MESSAGE("Load order 'elfdll' no longer supported, ignored\n");
break;
case 'S': /* So */
case 's': type = MODULE_LOADORDER_SO; break;
@@ -338,10 +337,6 @@
* [DllDefaults]
*
* Keys:
- * EXTRA_LD_LIBRARY_PATH=/usr/local/lib/wine[:/more/path/to/search[:...]]
- * The path will be appended to any existing LD_LIBRARY_PATH from the
- * environment (see note in code below).
- *
* DefaultLoadOrder=native,so,builtin
* A comma separated list of module types to try to load in that specific
* order. The DefaultLoadOrder key is used as a fallback when a module is
@@ -387,17 +382,6 @@
int idx;
const struct tagDllPair *dllpair;
-#if defined(HAVE_DL_API)
- /* Get/set the new LD_LIBRARY_PATH */
- nbuffer = PROFILE_GetWineIniString("DllDefaults", "EXTRA_LD_LIBRARY_PATH", "", buffer, sizeof(buffer));
-
- if(nbuffer)
- {
- extra_ld_library_path = HEAP_strdupA(GetProcessHeap(), 0, buffer);
- TRACE("Setting extra LD_LIBRARY_PATH=%s\n", buffer);
- }
-#endif
-
/* Get the default load order */
nbuffer = PROFILE_GetWineIniString("DllDefaults", "DefaultLoadOrder", "n,b,s", buffer, sizeof(buffer));
if(!nbuffer)