aboutsummaryrefslogtreecommitdiff
path: root/src/backend/port/dgux/dynloader.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend/port/dgux/dynloader.c')
-rw-r--r--src/backend/port/dgux/dynloader.c120
1 files changed, 65 insertions, 55 deletions
diff --git a/src/backend/port/dgux/dynloader.c b/src/backend/port/dgux/dynloader.c
index 7ec648fb44b..0f7d38bc092 100644
--- a/src/backend/port/dgux/dynloader.c
+++ b/src/backend/port/dgux/dynloader.c
@@ -1,14 +1,14 @@
/*-------------------------------------------------------------------------
*
* dynloader.c--
- * Dynamic Loader for Postgres for DG/UX, generated from those for
- * Linux.
+ * Dynamic Loader for Postgres for DG/UX, generated from those for
+ * Linux.
*
* Copyright (c) 1994, Regents of the University of California
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/port/dgux/Attic/dynloader.c,v 1.1 1996/07/25 20:43:58 scrappy Exp $
+ * $Header: /cvsroot/pgsql/src/backend/port/dgux/Attic/dynloader.c,v 1.2 1997/09/07 04:45:35 momjian Exp $
*
*-------------------------------------------------------------------------
*/
@@ -19,73 +19,83 @@
#include "utils/elog.h"
#include "fmgr.h"
-extern char pg_pathname[];
+extern char pg_pathname[];
-void *
+void *
pg_dlopen(char *filename)
{
- static int dl_initialized= 0;
+ static int dl_initialized = 0;
- /*
- * initializes the dynamic loader with the executable's pathname.
- * (only needs to do this the first time pg_dlopen is called.)
- */
- if (!dl_initialized) {
- if (dld_init (dld_find_executable (pg_pathname))) {
- return NULL;
- }
/*
- * if there are undefined symbols, we want dl to search from the
- * following libraries also.
+ * initializes the dynamic loader with the executable's pathname.
+ * (only needs to do this the first time pg_dlopen is called.)
*/
- dl_initialized= 1;
- }
-
- /*
- * link the file, then check for undefined symbols!
- */
- if (dld_link(filename)) {
- return NULL;
- }
+ if (!dl_initialized)
+ {
+ if (dld_init(dld_find_executable(pg_pathname)))
+ {
+ return NULL;
+ }
- /*
- * If undefined symbols: try to link with the C and math libraries!
- * This could be smarter, if the dynamic linker was able to handle
- * shared libs!
- */
- if(dld_undefined_sym_count > 0) {
- if (dld_link("/usr/lib/libc.a")) {
- elog(NOTICE, "dld: Cannot link C library!");
- return NULL;
+ /*
+ * if there are undefined symbols, we want dl to search from the
+ * following libraries also.
+ */
+ dl_initialized = 1;
}
- if(dld_undefined_sym_count > 0) {
- if (dld_link("/usr/lib/libm.a")) {
- elog(NOTICE, "dld: Cannot link math library!");
+
+ /*
+ * link the file, then check for undefined symbols!
+ */
+ if (dld_link(filename))
+ {
return NULL;
- }
- if(dld_undefined_sym_count > 0) {
- int count = dld_undefined_sym_count;
- char **list= dld_list_undefined_sym();
+ }
- /* list the undefined symbols, if any */
- elog(NOTICE, "dld: Undefined:");
- do {
- elog(NOTICE, " %s", *list);
- list++;
- count--;
- } while(count > 0);
+ /*
+ * If undefined symbols: try to link with the C and math libraries!
+ * This could be smarter, if the dynamic linker was able to handle
+ * shared libs!
+ */
+ if (dld_undefined_sym_count > 0)
+ {
+ if (dld_link("/usr/lib/libc.a"))
+ {
+ elog(NOTICE, "dld: Cannot link C library!");
+ return NULL;
+ }
+ if (dld_undefined_sym_count > 0)
+ {
+ if (dld_link("/usr/lib/libm.a"))
+ {
+ elog(NOTICE, "dld: Cannot link math library!");
+ return NULL;
+ }
+ if (dld_undefined_sym_count > 0)
+ {
+ int count = dld_undefined_sym_count;
+ char **list = dld_list_undefined_sym();
- dld_unlink_by_file(filename, 1);
- return NULL;
- }
+ /* list the undefined symbols, if any */
+ elog(NOTICE, "dld: Undefined:");
+ do
+ {
+ elog(NOTICE, " %s", *list);
+ list++;
+ count--;
+ } while (count > 0);
+
+ dld_unlink_by_file(filename, 1);
+ return NULL;
+ }
+ }
}
- }
- return (void *) strdup(filename);
+ return (void *) strdup(filename);
}
-char *
+char *
pg_dlerror()
{
- return dld_strerror(dld_errno);
+ return dld_strerror(dld_errno);
}