From c86253042f0dab70fcf15030b25fcbc1a00dde76 Mon Sep 17 00:00:00 2001 From: lloyd Date: Tue, 6 Oct 2009 16:03:33 +0000 Subject: Extensions to SCAN_Name for dealing with cipher mode names --- src/libstate/scan_name.cpp | 46 +++++++++++++++++++++++++++++++++++++++++++--- src/libstate/scan_name.h | 19 +++++++++++++++++++ 2 files changed, 62 insertions(+), 3 deletions(-) diff --git a/src/libstate/scan_name.cpp b/src/libstate/scan_name.cpp index 88992d66e..13792720c 100644 --- a/src/libstate/scan_name.cpp +++ b/src/libstate/scan_name.cpp @@ -44,10 +44,50 @@ SCAN_Name::SCAN_Name(const std::string& algo_spec) { orig_algo_spec = algo_spec; - name = parse_and_deref_aliases(algo_spec); + try + { + name = parse_and_deref_aliases(algo_spec); + if(name.size() == 0) + throw Decoding_Error("Bad SCAN name " + algo_spec); + } + catch(Invalid_Algorithm_Name) + { + name.clear(); + } + + if(name.size() == 0 && algo_spec.find('/') != std::string::npos) + { + std::vector algo_parts = split_on(algo_spec, '/'); + + name = parse_and_deref_aliases(algo_parts[0]); + if(name.size() == 0) + throw Decoding_Error("Bad SCAN name " + algo_spec); + + for(size_t i = 1; i != algo_parts.size(); ++i) + mode_str.push_back(algo_parts[i]); + } + } - if(name.size() == 0) - throw Decoding_Error("Bad SCAN name " + algo_spec); +std::string SCAN_Name::algo_name_and_args() const + { + std::string out; + + out = name[0]; + + if(arg_count()) + { + out += '('; + for(u32bit i = 0; i != arg_count(); ++i) + { + out += arg(i); + if(i != arg_count() - 1) + out += ','; + } + out += ')'; + + } + + return out; } std::string SCAN_Name::arg(u32bit i) const diff --git a/src/libstate/scan_name.h b/src/libstate/scan_name.h index b3f2004e2..6dbd67c4f 100644 --- a/src/libstate/scan_name.h +++ b/src/libstate/scan_name.h @@ -37,6 +37,11 @@ class SCAN_Name */ std::string algo_name() const { return name[0]; } + /** + @return the algorithm name plus any arguments + */ + std::string algo_name_and_args() const; + /** @return the number of arguments */ @@ -67,9 +72,23 @@ class SCAN_Name @return the ith argument as a u32bit, or the default value */ u32bit arg_as_u32bit(u32bit i, u32bit def_value) const; + + /** + @return the cipher mode (if any) + */ + std::string cipher_mode() const + { return (mode_str.size() >= 1) ? mode_str[0] : ""; } + + /** + @return the cipher mode padding (if any) + */ + std::string cipher_mode_pad() const + { return (mode_str.size() >= 2) ? mode_str[1] : ""; } + private: std::string orig_algo_spec; std::vector name; + std::vector mode_str; }; } -- cgit v1.2.3