summaryrefslogtreecommitdiff
path: root/INSTALL
diff options
context:
space:
mode:
authorBodo Möller <bodo@openssl.org>1999-04-24 17:41:45 +0000
committerBodo Möller <bodo@openssl.org>1999-04-24 17:41:45 +0000
commit4fd53220b66e5c6476e9d7dd3b43977d4bb02e37 (patch)
tree3eef84fa71ffa4cf50be6f173714ec7ca8c43971 /INSTALL
parent73934800474e5b333af2bff0a8f79f13405fb500 (diff)
downloadopenssl-new-4fd53220b66e5c6476e9d7dd3b43977d4bb02e37.tar.gz
Some instructions for how to handle the <foo.h> => <openssl/foo.h>
transition. Submitted by: Reviewed by: PR:
Diffstat (limited to 'INSTALL')
-rw-r--r--INSTALL66
1 files changed, 66 insertions, 0 deletions
diff --git a/INSTALL b/INSTALL
index 39185d1412..e5388b16cd 100644
--- a/INSTALL
+++ b/INSTALL
@@ -120,6 +120,72 @@
for private key files.
+ NOTE: The header files used to reside directly in the include
+ directory, but have now been moved to include/openssl so that
+ OpenSSL can co-exist with other libraries which use some of the
+ same filenames. This means that applications that use OpenSSL
+ should now use C preprocessor directives of the form
+
+ #include <openssl/ssl.h>
+
+ instead of "#include <ssl.h>", which was used with library versions
+ up to OpenSSL 0.9.2b.
+
+ If you install a new version of OpenSSL over an old library version,
+ you should delete the old header files in the include directory.
+
+ Compatibility issues:
+
+ * COMPILING existing applications
+
+ To compile an application that uses old filenames -- e.g.
+ "#include <ssl.h>" --, it will usually be enough to find
+ the CFLAGS definition in the application's Makefile and
+ add a C option such as
+
+ -I/usr/local/ssl/include/openssl
+
+ to it.
+
+ But don't delete the existing -I option that points to
+ the ..../include directory! Otherwise, OpenSSL header files
+ could not #include each other.
+
+ * WRITING applications
+
+ To write an application that is able to handle both the new
+ and the old directory layout, so that it can still be compiled
+ with library versions up to OpenSSL 0.9.2b without bothering
+ the user, you can proceed as follows:
+
+ - Always use the new filename of OpenSSL header files,
+ e.g. #include <openssl/ssl.h>.
+
+ - Create a directory "incl" that contains only a symbolic
+ link named "openssl", which points to the "include" directory
+ of OpenSSL.
+ For example, your application's Makefile might contain the
+ following rule, if OPENSSLDIR is a pathname (absolute or
+ relative) of the directory where OpenSSL resides:
+
+ incl/openssl:
+ -mkdir incl
+ cd $(OPENSSLDIR) # Check whether the directory really exists
+ -ln -s `cd $(OPENSSLDIR); pwd`/include incl/openssl
+
+ You will have to add "incl/openssl" to the dependencies
+ of those C files that include some OpenSSL header file.
+
+ - Add "-Iincl" to your CFLAGS.
+
+ With these additions, the OpenSSL header files will be available
+ under both name variants if an old library version is used:
+ Your application can reach them under names like <openssl/foo.h>,
+ while the header files still are able to #include each other
+ with names of the form <foo.h>.
+
+
+
--------------------------------------------------------------------------------
The orignal Unix build instructions from SSLeay follow.
Note: some of this may be out of date and no longer applicable