From 66b14d4368d661daf2248e36ac4f9a3f69f6a75a Mon Sep 17 00:00:00 2001 From: Michael Krelin Date: Wed, 30 Jan 2008 00:01:32 +0000 Subject: a few changes to the infrastructure * added mode_unknown to the mode_t enumeration * add to_keyvalues(ostream&) to openid message class * fixed openid_message_t::set_field for the case of overwriting Signed-off-by: Michael Krelin --- (limited to 'lib') diff --git a/lib/openid_message.cc b/lib/openid_message.cc index 3b08748..905ea95 100644 --- a/lib/openid_message.cc +++ b/lib/openid_message.cc @@ -142,6 +142,23 @@ namespace opkele { } } + struct __om_kv_outputter : public unary_function { + public: + const basic_openid_message& om; + ostream& os; + + __om_kv_outputter(const basic_openid_message& om,ostream& os) + : om(om), os(os) { } + + result_type operator()(argument_type f) { + os << f << ':' << om.get_field(f) << '\n'; + } + }; + + void basic_openid_message::to_keyvalues(ostream& o) const { + for_each(fields_begin(),fields_end(),__om_kv_outputter(*this,o)); + } + void basic_openid_message::add_to_signed(const string& fields) { string::size_type fnc = fields.find_first_not_of(","); if(fnc==string::npos) @@ -219,7 +236,7 @@ namespace opkele { clear(); } void openid_message_t::set_field(const string& n,const string& v) { - insert(value_type(n,v)); + (*this)[n]=v; } void openid_message_t::reset_field(const string& n) { erase(n); -- cgit v0.9.0.2