summaryrefslogtreecommitdiffstats
path: root/crypto/dso
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2001-02-20 13:23:42 +0000
committerRichard Levitte <levitte@openssl.org>2001-02-20 13:23:42 +0000
commit03c4d82fa1a2fced7aa8ae2c4830722015e3f4f4 (patch)
tree3078b2a16e785f574c9778ea21a5f94ec875dbc0 /crypto/dso
parent7ab1a391814e588506fe37c162a7cc760a422fd6 (diff)
Include OpenSSL header files earlier so macros like OPENSSL_SYS_VMS
get a chance to be defined. Make a batter file name translator (uhm, no, that's not the finished variant :-)).
Diffstat (limited to 'crypto/dso')
-rw-r--r--crypto/dso/dso_vms.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/crypto/dso/dso_vms.c b/crypto/dso/dso_vms.c
index f492202793..703b19ed69 100644
--- a/crypto/dso/dso_vms.c
+++ b/crypto/dso/dso_vms.c
@@ -59,6 +59,8 @@
#include <stdio.h>
#include <string.h>
#include <errno.h>
+#include "cryptlib.h"
+#include <openssl/dso.h>
#ifdef OPENSSL_SYS_VMS
#pragma message disable DOLLARID
#include <lib$routines.h>
@@ -67,8 +69,6 @@
#include <descrip.h>
#include <starlet.h>
#endif
-#include "cryptlib.h"
-#include <openssl/dso.h>
#ifndef OPENSSL_SYS_VMS
DSO_METHOD *DSO_METHOD_vms(void)
@@ -89,7 +89,7 @@ static int vms_init(DSO *dso);
static int vms_finish(DSO *dso);
static long vms_ctrl(DSO *dso, int cmd, long larg, void *parg);
#endif
-static char *vms_name_converter(DSO *dso);
+static char *vms_name_converter(DSO *dso, const char *filename);
static DSO_METHOD dso_meth_vms = {
"OpenSSL 'VMS' shared library method",
@@ -366,7 +366,10 @@ static DSO_FUNC_TYPE vms_bind_func(DSO *dso, const char *symname)
static char *vms_name_converter(DSO *dso, const char *filename)
{
- return(filename);
+ int len = strlen(filename);
+ char *not_translated = OPENSSL_malloc(len+1);
+ strcpy(not_translated,filename);
+ return(not_translated);
}
#endif /* OPENSSL_SYS_VMS */