diff options
author | Michal Rokos <m.rokos@sh.cvut.cz> | 2002-03-11 17:20:04 +0000 |
---|---|---|
committer | Michal Rokos <m.rokos@sh.cvut.cz> | 2002-03-11 17:20:04 +0000 |
commit | 7ed17afc8c327bc88d1510255d284487d06f226c (patch) | |
tree | 52aa2aed34535a040ba155fef373e4394449dd33 /ossl_config.c | |
parent | 91e607a11b3862c0aa966712149b2afd2a00d90d (diff) | |
download | ruby-openssl-history-7ed17afc8c327bc88d1510255d284487d06f226c.tar.gz |
* Big internal cleanup (all structs with only 1 member rearranged)
* improved getting time_t from cTime
Diffstat (limited to 'ossl_config.c')
-rw-r--r-- | ossl_config.c | 58 |
1 files changed, 18 insertions, 40 deletions
diff --git a/ossl_config.c b/ossl_config.c index a559d97..01508a9 100644 --- a/ossl_config.c +++ b/ossl_config.c @@ -10,15 +10,8 @@ */ #include "ossl.h" -#define MakeConfig(obj, confp) {\ - obj = Data_Make_Struct(cConfig, ossl_config, 0, ossl_config_free, confp);\ -} - -#define GetConfig_unsafe(obj, confp) Data_Get_Struct(obj, ossl_config, confp) -#define GetConfig(obj, confp) {\ - GetConfig_unsafe(obj, confp);\ - if (!confp->config) rb_raise(eConfigError, "not initialized!");\ -} +#define WrapConfig(obj, conf) obj = Data_Wrap_Struct(cConfig, 0, CONF_free, conf) +#define GetConfig(obj, conf) Data_Get_Struct(obj, LHASH, conf) /* * Classes @@ -26,23 +19,6 @@ VALUE cConfig; VALUE eConfigError; -/* - * Struct - */ -typedef struct ossl_config_st { - LHASH *config; -} ossl_config; - -static void -ossl_config_free(ossl_config *confp) -{ - if (confp) { - if (confp->config) CONF_free(confp->config); - confp->config = NULL; - free(confp); - } -} - /* * Public */ @@ -51,18 +27,18 @@ ossl_config_free(ossl_config *confp) * Private */ static VALUE -ossl_config_s_load(int argc, VALUE* argv, VALUE klass) +ossl_config_s_load(int argc, VALUE *argv, VALUE klass) { - ossl_config *confp = NULL; - LHASH *config = NULL; + LHASH *conf = NULL; long err_line = 0; VALUE obj, path; rb_scan_args(argc, argv, "10", &path); - + + path = rb_str_to_str(path); Check_SafeStr(path); - if (!(config = CONF_load(NULL, RSTRING(path)->ptr, &err_line))) { + if (!(conf = CONF_load(NULL, RSTRING(path)->ptr, &err_line))) { if (err_line <= 0) rb_raise(eConfigError, "wrong config file %s", RSTRING(path)->ptr); else @@ -70,8 +46,7 @@ ossl_config_s_load(int argc, VALUE* argv, VALUE klass) err_line, RSTRING(path)->ptr); } - MakeConfig(obj, confp); - confp->config = config; + WrapConfig(obj, conf); return obj; } @@ -79,10 +54,10 @@ ossl_config_s_load(int argc, VALUE* argv, VALUE klass) static VALUE ossl_config_get_value(VALUE self, VALUE section, VALUE item) { - ossl_config *confp = NULL; + LHASH *conf = NULL; char *sect = NULL, *str = NULL; - GetConfig(self, confp); + GetConfig(self, conf); if (!NIL_P(section)) { section = rb_String(section); @@ -90,28 +65,31 @@ ossl_config_get_value(VALUE self, VALUE section, VALUE item) } item = rb_String(item); - if (!(str = CONF_get_string(confp->config, sect, RSTRING(item)->ptr))) { + if (!(str = CONF_get_string(conf, sect, RSTRING(item)->ptr))) { OSSL_Raise(eConfigError, ""); } return rb_str_new2(str); } -/* long number = CONF_get_number(confp->config, sect, RSTRING(item)->ptr); */ +/* + * Get all numbers as strings - use str.to_i to convert + * long number = CONF_get_number(confp->config, sect, RSTRING(item)->ptr); + */ static VALUE ossl_config_get_section(VALUE self, VALUE section) { - ossl_config *confp = NULL; + LHASH *conf = NULL; STACK_OF(CONF_VALUE) *sk = NULL; CONF_VALUE *entry = NULL; int i, entries = 0; VALUE hash; - GetConfig(self, confp); + GetConfig(self, conf); section = rb_String(section); - if (!(sk = CONF_get_section(confp->config, RSTRING(section)->ptr))) { + if (!(sk = CONF_get_section(conf, RSTRING(section)->ptr))) { OSSL_Raise(eConfigError, ""); } |