diff options
author | lloyd <[email protected]> | 2015-02-05 04:44:06 +0000 |
---|---|---|
committer | lloyd <[email protected]> | 2015-02-05 04:44:06 +0000 |
commit | 9d8f4cf1e81322ca7290b6551b82d4943dfa62a0 (patch) | |
tree | 89bb62a0e4dbc58dea425ea634bedf1d6eab7a65 /src/lib/base/algo_registry.h | |
parent | fde85db0ec7b31d3d8a2cb1c13b2ef1e3a3205a4 (diff) |
Enable OpenSSL for providing ciphers and hashes again.
Diffstat (limited to 'src/lib/base/algo_registry.h')
-rw-r--r-- | src/lib/base/algo_registry.h | 35 |
1 files changed, 22 insertions, 13 deletions
diff --git a/src/lib/base/algo_registry.h b/src/lib/base/algo_registry.h index 9582180bd..709b035fc 100644 --- a/src/lib/base/algo_registry.h +++ b/src/lib/base/algo_registry.h @@ -63,7 +63,7 @@ class Algo_Registry class Add { public: - Add(const std::string& basename, maker_fn fn, const std::string& provider = "builtin", byte pref = 128) + Add(const std::string& basename, maker_fn fn, const std::string& provider, byte pref) { Algo_Registry<T>::global_registry().add(basename, provider, fn, pref); } @@ -190,21 +190,30 @@ make_new_T_1X(const typename Algo_Registry<T>::Spec& spec) return new T(x.release()); } -#define BOTAN_REGISTER_NAMED_T(T, namestr, type, maker) \ - namespace { Algo_Registry<T>::Add g_ ## type ## _reg(namestr, maker); } -#define BOTAN_REGISTER_T(T, name, maker) \ - namespace { Algo_Registry<T>::Add g_ ## name ## _reg(#name, maker); } -#define BOTAN_REGISTER_T_NOARGS(T, name) \ - namespace { Algo_Registry<T>::Add g_ ## name ## _reg(#name, make_new_T<name>); } -#define BOTAN_REGISTER_T_1LEN(T, name, def) \ - namespace { Algo_Registry<T>::Add g_ ## name ## _reg(#name, make_new_T_1len<name, def>); } +#define BOTAN_REGISTER_TYPE(T, type, name, maker, provider, pref) \ + namespace { Algo_Registry<T>::Add g_ ## type ## _reg(name, maker, provider, pref); } + +#define BOTAN_REGISTER_TYPE_COND(cond, T, type, name, maker, provider, pref) \ + namespace { Algo_Registry<T>::Add g_ ## type ## _reg(cond, name, maker, provider, pref); } + +#define BOTAN_REGISTER_NAMED_T(T, name, type, maker) \ + BOTAN_REGISTER_TYPE(T, type, name, maker, "builtin", 128) + +#define BOTAN_REGISTER_T(T, type, maker) \ + BOTAN_REGISTER_TYPE(T, type, #type, maker, "builtin", 128) + +#define BOTAN_REGISTER_T_NOARGS(T, type) \ + BOTAN_REGISTER_TYPE(T, type, #type, make_new_T<type>, "builtin", 128) +#define BOTAN_REGISTER_T_1LEN(T, type, def) \ + BOTAN_REGISTER_TYPE(T, type, #type, (make_new_T_1len<type,def>), "builtin", 128) #define BOTAN_REGISTER_NAMED_T_NOARGS(T, type, name, provider) \ - namespace { Algo_Registry<T>::Add g_ ## type ## _reg(name, make_new_T<type>, provider); } + BOTAN_REGISTER_TYPE(T, type, name, make_new_T<type>, provider, 128) #define BOTAN_COND_REGISTER_NAMED_T_NOARGS(cond, T, type, name, provider, pref) \ - namespace { Algo_Registry<T>::Add g_ ## type ## _reg(cond, name, make_new_T<type>, provider, pref); } -#define BOTAN_REGISTER_NAMED_T_2LEN(T, type, name, provider, len1, len2) \ - namespace { Algo_Registry<T>::Add g_ ## type ## _reg(name, make_new_T_2len<type, len1, len2>, provider); } + BOTAN_REGISTER_TYPE_COND(cond, T, type, name, make_new_T<type>, provider, pref) + +#define BOTAN_REGISTER_NAMED_T_2LEN(T, type, name, provider, len1, len2) \ + BOTAN_REGISTER_TYPE(T, type, name, (make_new_T_2len<type,len1,len2>), provider, 128) // TODO move elsewhere: #define BOTAN_REGISTER_TRANSFORM(name, maker) BOTAN_REGISTER_T(Transform, name, maker) |