diff options
Diffstat (limited to 'unix/tclLoadShl.c')
| -rw-r--r-- | unix/tclLoadShl.c | 55 | 
1 files changed, 37 insertions, 18 deletions
| diff --git a/unix/tclLoadShl.c b/unix/tclLoadShl.c index 8aaefda..4be3d7b 100644 --- a/unix/tclLoadShl.c +++ b/unix/tclLoadShl.c @@ -13,6 +13,14 @@  #include <dl.h>  #include "tclInt.h" + +/* + * Static functions defined within this file. + */ + +static void *		FindSymbol(Tcl_Interp *interp, +			    Tcl_LoadHandle loadHandle, const char *symbol); +static void		UnloadFile(Tcl_LoadHandle handle);  /*   *---------------------------------------------------------------------- @@ -40,13 +48,15 @@ TclpDlopen(      Tcl_LoadHandle *loadHandle,	/* Filled with token for dynamically loaded  				 * file which will be passed back to  				 * (*unloadProcPtr)() to unload the file. */ -    Tcl_FSUnloadFileProc **unloadProcPtr) +    Tcl_FSUnloadFileProc **unloadProcPtr,  				/* Filled with address of Tcl_FSUnloadFileProc  				 * function which should be used for this  				 * file. */ +    int flags)  {      shl_t handle; -    CONST char *native; +    Tcl_LoadHandle newHandle; +    const char *native;      char *fileName = Tcl_GetString(pathPtr);      /* @@ -82,19 +92,23 @@ TclpDlopen(      }      if (handle == NULL) { -	Tcl_AppendResult(interp, "couldn't load file \"", fileName, "\": ", -		Tcl_PosixError(interp), (char *) NULL); +	Tcl_SetObjResult(interp, Tcl_ObjPrintf( +		"couldn't load file \"%s\": %s", +		fileName, Tcl_PosixError(interp)));  	return TCL_ERROR;      } -    *loadHandle = (Tcl_LoadHandle) handle; -    *unloadProcPtr = &TclpUnloadFile; +    newHandle = ckalloc(sizeof(*newHandle)); +    newHandle->clientData = handle; +    newHandle->findSymbolProcPtr = &FindSymbol; +    newHandle->unloadFileProcPtr = *unloadProcPtr = &UnloadFile; +    *loadHandle = newHandle;      return TCL_OK;  }  /*   *----------------------------------------------------------------------   * - * TclpFindSymbol -- + * Tcl_FindSymbol --   *   *	Looks up a symbol, by name, through a handle associated with a   *	previously loaded piece of code (shared library). @@ -107,15 +121,15 @@ TclpDlopen(   *----------------------------------------------------------------------   */ -Tcl_PackageInitProc * -TclpFindSymbol( +static void* +FindSymbol(      Tcl_Interp *interp,      Tcl_LoadHandle loadHandle, -    CONST char *symbol) +    const char *symbol)  {      Tcl_DString newName;      Tcl_PackageInitProc *proc = NULL; -    shl_t handle = (shl_t)loadHandle; +    shl_t handle = (shl_t) loadHandle->clientData;      /*       * Some versions of the HP system software still use "_" at the beginning @@ -125,7 +139,7 @@ TclpFindSymbol(      if (shl_findsym(&handle, symbol, (short) TYPE_PROCEDURE,  	    (void *) &proc) != 0) {  	Tcl_DStringInit(&newName); -	Tcl_DStringAppend(&newName, "_", 1); +	TclDStringAppendLiteral(&newName, "_");  	Tcl_DStringAppend(&newName, symbol, -1);  	if (shl_findsym(&handle, Tcl_DStringValue(&newName),  		(short) TYPE_PROCEDURE, (void *) &proc) != 0) { @@ -133,13 +147,18 @@ TclpFindSymbol(  	}  	Tcl_DStringFree(&newName);      } +    if (proc == NULL && interp != NULL) { +	Tcl_SetObjResult(interp, Tcl_ObjPrintf( +		"cannot find symbol \"%s\": %s", +		symbol, Tcl_PosixError(interp))); +    }      return proc;  }  /*   *----------------------------------------------------------------------   * - * TclpUnloadFile -- + * UnloadFile --   *   *	Unloads a dynamically loaded binary code file from memory.  Code   *	pointers in the formerly loaded file are no longer valid after calling @@ -154,16 +173,16 @@ TclpFindSymbol(   *----------------------------------------------------------------------   */ -void -TclpUnloadFile( +static void +UnloadFile(      Tcl_LoadHandle loadHandle)	/* loadHandle returned by a previous call to  				 * TclpDlopen(). The loadHandle is a token  				 * that represents the loaded file. */  { -    shl_t handle; +    shl_t handle = (shl_t) loadHandle->clientData; -    handle = (shl_t) loadHandle;      shl_unload(handle); +    ckfree(loadHandle);  }  /* @@ -188,7 +207,7 @@ TclpUnloadFile(  int  TclGuessPackageName( -    CONST char *fileName,	/* Name of file containing package (already +    const char *fileName,	/* Name of file containing package (already  				 * translated to local form if needed). */      Tcl_DString *bufPtr)	/* Initialized empty dstring. Append package  				 * name to this if possible. */ | 
