diff options
| author | frsyuki <frsyuki@users.sourceforge.jp> | 2009-06-07 13:33:22 +0900 |
|---|---|---|
| committer | frsyuki <frsyuki@users.sourceforge.jp> | 2009-06-07 13:33:22 +0900 |
| commit | f6cc274bbc2f241b608221befc7a1156ae9af888 (patch) | |
| tree | a068a80783e479038aebffd75ed4f49c7ee30a3d /cpp | |
| parent | 8903e2dea9f7f719897ca2420fae9376982c2c3b (diff) | |
| parent | b3846a411fb148c30cf99c7297b70fe8ad3bfaa9 (diff) | |
| download | msgpack-python-f6cc274bbc2f241b608221befc7a1156ae9af888.tar.gz | |
Merge branch 'master' of frsyuki@git.sourceforge.jp:/gitroot/msgpack/msgpack
Diffstat (limited to 'cpp')
| -rw-r--r-- | cpp/type/map.hpp | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/cpp/type/map.hpp b/cpp/type/map.hpp index c136d53..552de57 100644 --- a/cpp/type/map.hpp +++ b/cpp/type/map.hpp @@ -80,13 +80,13 @@ inline std::map<K, V> operator>> (object o, std::map<K, V>& v) for(; p != pend; ++p) { K key; p->key.convert(&key); - typename std::map<K,V>::iterator it(v.find(key)); - if(it != v.end()) { + typename std::map<K,V>::iterator it(v.lower_bound(key)); + if(it != v.end() && !(key < it->first)) { + p->val.convert(&it->second); + } else { V val; p->val.convert(&val); - it->insert( std::pair<K,V>(key, val) ); - } else { - p->val.convert(&it->second); + v.insert(it, std::pair<K,V>(key, val)); } } return v; |
