ossl_ssl.c: typed data
* ext/openssl/ossl_ssl.c (ossl_sslctx_type): use typed data. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48800 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
d064e7c857
commit
060e693738
@ -25,7 +25,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define GetSSLCTX(obj, ctx) do { \
|
#define GetSSLCTX(obj, ctx) do { \
|
||||||
Data_Get_Struct((obj), SSL_CTX, (ctx)); \
|
TypedData_Get_Struct((obj), SSL_CTX, &ossl_sslctx_type, (ctx)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
VALUE mSSL;
|
VALUE mSSL;
|
||||||
@ -154,13 +154,22 @@ int ossl_ssl_ex_client_cert_cb_idx;
|
|||||||
int ossl_ssl_ex_tmp_dh_callback_idx;
|
int ossl_ssl_ex_tmp_dh_callback_idx;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ossl_sslctx_free(SSL_CTX *ctx)
|
ossl_sslctx_free(void *ptr)
|
||||||
{
|
{
|
||||||
|
SSL_CTX *ctx = ptr;
|
||||||
if(ctx && SSL_CTX_get_ex_data(ctx, ossl_ssl_ex_store_p)== (void*)1)
|
if(ctx && SSL_CTX_get_ex_data(ctx, ossl_ssl_ex_store_p)== (void*)1)
|
||||||
ctx->cert_store = NULL;
|
ctx->cert_store = NULL;
|
||||||
SSL_CTX_free(ctx);
|
SSL_CTX_free(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const rb_data_type_t ossl_sslctx_type = {
|
||||||
|
"OpenSSL/SSL/CTX",
|
||||||
|
{
|
||||||
|
0, ossl_sslctx_free,
|
||||||
|
},
|
||||||
|
0, 0, RUBY_TYPED_FREE_IMMEDIATELY,
|
||||||
|
};
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
ossl_sslctx_s_alloc(VALUE klass)
|
ossl_sslctx_s_alloc(VALUE klass)
|
||||||
{
|
{
|
||||||
@ -176,7 +185,7 @@ ossl_sslctx_s_alloc(VALUE klass)
|
|||||||
ossl_raise(eSSLError, "SSL_CTX_new");
|
ossl_raise(eSSLError, "SSL_CTX_new");
|
||||||
}
|
}
|
||||||
SSL_CTX_set_mode(ctx, mode);
|
SSL_CTX_set_mode(ctx, mode);
|
||||||
return Data_Wrap_Struct(klass, 0, ossl_sslctx_free, ctx);
|
return TypedData_Wrap_Struct(klass, &ossl_sslctx_type, ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user