diff options
author | Daniel Stenberg <daniel@haxx.se> | 2008-06-11 17:01:58 +0000 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2008-06-11 17:01:58 +0000 |
commit | 04d5c8fb779afdb4f7e85a701f8b4b987a4016ee (patch) | |
tree | 622d3243f17ed29f4df5b3405de5a78599b86e32 /lib/nssg.h | |
parent | 5980b3cbb09c4c06340433041b825cc9bed00eca (diff) | |
download | curl-04d5c8fb779afdb4f7e85a701f8b4b987a4016ee.tar.gz |
- I did a cleanup of the internal generic SSL layer and how the various SSL
libraries are supported. Starting now, each underlying SSL library support
code does a set of defines for the 16 functions the generic layer (sslgen.c)
uses (all these new function defines use the prefix "curlssl_"). This
greatly simplified the generic layer in readability by involving much less
#ifdefs and other preprocessor stuff and should make it easier for people to
make libcurl work with new SSL libraries.
Hopefully I can later on document these 16 functions somewhat as well.
I also made most of the internal SSL-dependent functions (using Curl_ssl_
prefix) #defined to nothing when no SSL support is requested - previously
they would unnecessarily call mostly empty functions.
Diffstat (limited to 'lib/nssg.h')
-rw-r--r-- | lib/nssg.h | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/lib/nssg.h b/lib/nssg.h index 0dad7523d..0c6cd5d63 100644 --- a/lib/nssg.h +++ b/lib/nssg.h @@ -7,7 +7,7 @@ * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * - * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. + * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. * * This software is licensed as described in the file COPYING, which * you should have received as part of this distribution. The terms @@ -23,6 +23,7 @@ * $Id$ ***************************************************************************/ +#ifdef USE_NSS /* * This header should only be needed to get included by sslgen.c and nss.c */ @@ -56,4 +57,25 @@ size_t Curl_nss_version(char *buffer, size_t size); int Curl_nss_check_cxn(struct connectdata *cxn); int Curl_nss_seed(struct SessionHandle *data); +/* API setup for NSS */ +#define curlssl_init Curl_nss_init +#define curlssl_cleanup Curl_nss_cleanup +#define curlssl_connect Curl_nss_connect + +/* NSS has its own session ID cache */ +#define curlssl_session_free(x) +#define curlssl_close_all Curl_nss_close_all +#define curlssl_close Curl_nss_close +/* NSS has no shutdown function provided and thus always fail */ +#define curlssl_shutdown(x,y) (x=x, y=y, 1) +#define curlssl_set_engine(x,y) (x=x, y=y, CURLE_FAILED_INIT) +#define curlssl_set_engine_default(x) (x=x, CURLE_FAILED_INIT) +#define curlssl_engines_list(x) (x=x, NULL) +#define curlssl_send Curl_nss_send +#define curlssl_recv Curl_nss_recv +#define curlssl_version Curl_nss_version +#define curlssl_check_cxn(x) Curl_nss_check_cxn(x) +#define curlssl_data_pending(x,y) (x=x, y=y, 0) + +#endif /* USE_NSS */ #endif |