Mercurial > hg > xemacs-beta
view src/sysdll.c @ 558:ed498ef2108b
[xemacs-hg @ 2001-05-23 09:59:33 by ben]
xemacs.mak: call `ver' to get the exact os version and put it in the
installation; suggestion from adrian.
behavior-defs.el: Add scroll-in-place, jka-compr, efs, fix up some things.
pop.c: Remove BROKEN_CYGWIN.
etc\sample.init.el: Rewrite to be much more careful about loading features --
now it decays gracefully even in the complete absence of packages.
Also avoid doing obnoxious things when loading efs.
configure.in: add some support for eventually turning on file coding by
default. Fix numerous places where AC_MSG_WARN had quotes
around its arg, which is bad. Replace with []. Same for
AC_MSG_ERROR.
s\cygwin32.h, s\mingw32.h: remove support for way old beta versions of cygwin.
don't put -Wno-sign-compare in the system switches; this
isn't a system issue. define BROKEN_SIGIO for cygwin to
get C-g support.
device-msw.c: signal an error rather than crash with an unavailable network
printer (from Mike Alexander).
event-msw.c: cleanup headers. fix (hopefully) an error with data corruption
when sending to a network connection.
fileio.c: Fix evil code that attempts
to handle the ~user prefix by (a) always assuming we're referencing
ourselves and not even verifying the user -- hence any file with
a tilde as its first char is invalid! (b) if there wasn't a slash
following the filename, the pointer was set *past* the end of
file and we started reading from uninitialized memory. Now we
simply treat these as files, always.
optionally for 21.4 (doc fix):
lread.c: cambia de pas_de_lache_ici -- al minimo usa la palabra certa.
frame.c: fix warnings.
emacs.c, nt.c, ntproc.c, process-nt.c, realpath.c, unexnt.c: rename MAX_PATH
to standard PATH_MAX.
process-nt.c, realpath.c: cleanup headers.
process-unix.c, sysdep.c, systime.h, syswindows.h: kill BROKEN_CYGWIN and
support for way old beta versions of cygwin.
sysfile.h: use _MAX_PATH (Windows) preferentially for PATH_MAX if defined.
include io.h on Cygwin (we need get_osfhandle()). include
sys/fcntl.h always, since we were including it in various
header files anyway.
unexcw.c: fix up style to conform to standard. remove duplicate definition
of PERROR.
buffer.c: comment change.
database.c, debug.h, device-tty.c, dired-msw.c, glyphs-msw.c: header
cleanups (remove places that directly include a system
header file, because we have our own layer to do this more cleanly
and portably); indentation fixes.
author | ben |
---|---|
date | Wed, 23 May 2001 09:59:48 +0000 |
parents | 3d3049ae1304 |
children | 42375619fa45 |
line wrap: on
line source
/* sysdll.c --- system dependent support for dynamic linked libraries Copyright (C) 1998 Free Software Foundation, Inc. Author: William Perry <wmperry@aventail.com> This file is part of XEmacs. XEmacs is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. XEmacs is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with XEmacs; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <stdlib.h> #include "sysdll.h" /* This whole file is conditional upon HAVE_SHLIB */ #ifdef HAVE_SHLIB /* Thankfully, most systems follow the ELFish dlopen() method. */ #if defined(HAVE_DLOPEN) #include <dlfcn.h> #ifndef RTLD_LAZY # define RTLD_LAZY 1 #endif /* RTLD_LAZY isn't defined under FreeBSD - ick */ #ifndef RTLD_GLOBAL # define RTLD_GLOBAL 0 #endif int dll_init (const char *arg) { return 0; } dll_handle dll_open (const char *fname) { return (dll_handle) dlopen (fname, RTLD_LAZY | RTLD_GLOBAL); } int dll_close (dll_handle h) { return dlclose ((void *) h); } dll_func dll_function (dll_handle h, const char *n) { #ifdef DLSYM_NEEDS_UNDERSCORE char *buf = alloca_array (char, strlen (n) + 2); *buf = '_'; strcpy (buf + 1, n); n = buf; #endif return (dll_func) dlsym ((void *) h, n); } dll_var dll_variable (dll_handle h, const char *n) { #ifdef DLSYM_NEEDS_UNDERSCORE char *buf = alloca_array (char, strlen (n) + 2); *buf = '_'; strcpy (buf + 1, n); n = buf; #endif return (dll_var)dlsym ((void *)h, n); } const char * dll_error (dll_handle h) { #if defined(HAVE_DLERROR) || defined(dlerror) return (const char *) dlerror (); #elif defined(HAVE__DLERROR) return (const char *) _dlerror(); #else return "Shared library error"; #endif } #elif defined(HAVE_SHL_LOAD) /* This is the HP/UX version */ #include <dl.h> int dll_init (const char *arg) { return 0; } dll_handle dll_open (const char *fname) { /* shl_load will hang hard if passed a NULL fname. */ if (fname == NULL) return NULL; return (dll_handle) shl_load (fname, BIND_DEFERRED,0L); } int dll_close (dll_handle h) { return shl_unload ((shl_t) h); } dll_func dll_function (dll_handle h, const char *n) { long handle = 0L; if (shl_findsym ((shl_t *) &h, n, TYPE_PROCEDURE, &handle)) return NULL; return (dll_func) handle; } dll_var dll_variable (dll_handle h, const char *n) { long handle = 0L; if (shl_findsym ((shl_t *) &h, n, TYPE_DATA, &handle)) return NULL; return (dll_var) handle; } const char * dll_error (dll_handle h) { /* #### WTF?! Shouldn't this at least attempt to get strerror or something? --hniksic */ return "Generic shared library error"; } #elif defined(HAVE_INIT_DLD) #include <dld.h> int dll_init (const char *arg) { char *real_exe = dld_find_executable (arg); int rc; rc = dld_init (real_exe); if (rc) { dld_perror (exe); return -1; } return 0; } dll_handle dll_open (const char *fname) { rc = dld_link (fname); if (rc) return NULL; return (dll_handle) 1; } int dll_close (dll_handle h) { /* *sigh* DLD is pretty lame and doesn't return a handle that you can use ** later on to free the file - you have to remember the filename and ** use that as the unlinker. We should eventually keep a linked list ** of loaded modules and then use the node pointer as the unique id ** for the shared library. Wheeee. But not now. */ return 1; } DLL_FUNC dll_function (dll_handle h, const char *n) { return dld_get_func (n); } DLL_FUNC dll_variable (dll_handle h, const char *n) { return dld_get_symbol (n); } #elif defined (WIN32_NATIVE) #define WIN32_LEAN_AND_MEAN #include <windows.h> #undef WIN32_LEAN_AND_MEAN int dll_init (const char *arg) { return 0; } dll_handle dll_open (const char *fname) { return (dll_handle) LoadLibrary (fname); } int dll_close (dll_handle h) { return FreeLibrary (h); } dll_func dll_function (dll_handle h, const char *n) { return (dll_func) GetProcAddress (h, n); } dll_func dll_variable (dll_handle h, const char *n) { return (dll_func) GetProcAddress (h, n); } const char * dll_error (dll_handle h) { return "Windows DLL Error"; } #else /* Catchall if we don't know about this systems method of dynamic loading */ int dll_init (const char *arg) { return -1; } dll_handle dll_open (const char *fname) { return NULL; } int dll_close (dll_handle h) { return 0; } dll_func dll_function (dll_handle h, const char *n) { return NULL; } dll_func dll_variable (dll_handle h, const char *n) { return NULL; } const char * dll_error (dll_handle h) { return "Shared libraries not implemented on this system"; } #endif /* System conditionals */ #endif /* HAVE_SHLIB */