Fix data corruption, undefined return value, unneeded static var
authorMichael Andres <ma@suse.de>
Mon, 19 Nov 2012 13:56:58 +0000 (14:56 +0100)
committerMichael Andres <ma@suse.de>
Wed, 21 Nov 2012 13:35:23 +0000 (14:35 +0100)
zypp/HistoryLogData.cc

index 5a4163e8dd44500b55fdcb968826be27bbb99f13..a66154a2e73041de7e49d742dad8b2e8dbf7d898 100644 (file)
@@ -32,62 +32,62 @@ namespace zypp
   //
   ///////////////////////////////////////////////////////////////////
 
-  static std::map<std::string,HistoryActionID::ID> _table;
-
-  const HistoryActionID HistoryActionID::NONE(HistoryActionID::NONE_e);
-  const HistoryActionID HistoryActionID::INSTALL(HistoryActionID::INSTALL_e);
-  const HistoryActionID HistoryActionID::REMOVE(HistoryActionID::REMOVE_e);
-  const HistoryActionID HistoryActionID::REPO_ADD(HistoryActionID::REPO_ADD_e);
-  const HistoryActionID HistoryActionID::REPO_REMOVE(HistoryActionID::REPO_REMOVE_e);
-  const HistoryActionID HistoryActionID::REPO_CHANGE_ALIAS(HistoryActionID::REPO_CHANGE_ALIAS_e);
-  const HistoryActionID HistoryActionID::REPO_CHANGE_URL(HistoryActionID::REPO_CHANGE_URL_e);
+  const HistoryActionID HistoryActionID::NONE                  (HistoryActionID::NONE_e);
+  const HistoryActionID HistoryActionID::INSTALL               (HistoryActionID::INSTALL_e);
+  const HistoryActionID HistoryActionID::REMOVE                        (HistoryActionID::REMOVE_e);
+  const HistoryActionID HistoryActionID::REPO_ADD              (HistoryActionID::REPO_ADD_e);
+  const HistoryActionID HistoryActionID::REPO_REMOVE           (HistoryActionID::REPO_REMOVE_e);
+  const HistoryActionID HistoryActionID::REPO_CHANGE_ALIAS     (HistoryActionID::REPO_CHANGE_ALIAS_e);
+  const HistoryActionID HistoryActionID::REPO_CHANGE_URL       (HistoryActionID::REPO_CHANGE_URL_e);
 
   HistoryActionID::HistoryActionID(const std::string & strval_r)
     : _id(parse(strval_r))
   {}
 
-  HistoryActionID::ID HistoryActionID::parse(const std::string & strval_r)
+  HistoryActionID::ID HistoryActionID::parse( const std::string & strval_r )
   {
-    if (_table.empty())
+    typedef std::map<std::string,ID> MapType;
+    static MapType _table;
+    if ( _table.empty() )
     {
       // initialize it
-      _table["install"] = INSTALL_e;
-      _table["remove"]  = REMOVE_e;
-      _table["radd"]    = REPO_ADD_e;
-      _table["rremove"] = REPO_REMOVE_e;
-      _table["ralias"]  = REPO_CHANGE_ALIAS_e;
-      _table["rurl"]    = REPO_CHANGE_URL_e;
-      _table["NONE"] = _table["none"] = HistoryActionID::NONE_e;
+      _table["install"]        = INSTALL_e;
+      _table["remove"] = REMOVE_e;
+      _table["radd"]   = REPO_ADD_e;
+      _table["rremove"]        = REPO_REMOVE_e;
+      _table["ralias"] = REPO_CHANGE_ALIAS_e;
+      _table["rurl"]   = REPO_CHANGE_URL_e;
+      _table["NONE"]   = _table["none"] = NONE_e;
     }
 
-    std::map<std::string,HistoryActionID::ID>::const_iterator it =
-      _table.find(strval_r);
-
-    if (it == _table.end())
-      WAR << "Unknown history action ID '" + strval_r + "'";
-
+    MapType::const_iterator it = _table.find( strval_r );
+    if ( it == _table.end() )
+    {
+      WAR << "Unknown history action ID '" + strval_r + "'" << endl;
+      return NONE_e;
+    }
     return it->second;
   }
 
 
-  const std::string & HistoryActionID::asString(bool pad) const
+  const std::string & HistoryActionID::asString( bool pad ) const
   {
-    static std::map<ID, std::string> _table;
+    typedef std::pair<std::string,std::string> PairType;
+    typedef std::map<ID, PairType> MapType;
+    static MapType _table;
     if ( _table.empty() )
     {
-      // initialize it
-      _table[INSTALL_e]           = "install";
-      _table[REMOVE_e]            = "remove";
-      _table[REPO_ADD_e]          = "radd";
-      _table[REPO_REMOVE_e]       = "rremove";
-      _table[REPO_CHANGE_ALIAS_e] = "ralias";
-      _table[REPO_CHANGE_URL_e]   = "rurl";
-      _table[NONE_e]              = "NONE";
+      // initialize it                                     pad(7) (for now)
+      _table[INSTALL_e]           = PairType( "install"        , "install" );
+      _table[REMOVE_e]            = PairType( "remove" , "remove " );
+      _table[REPO_ADD_e]          = PairType( "radd"   , "radd   " );
+      _table[REPO_REMOVE_e]       = PairType( "rremove"        , "rremove" );
+      _table[REPO_CHANGE_ALIAS_e] = PairType( "ralias" , "ralias " );
+      _table[REPO_CHANGE_URL_e]   = PairType( "rurl"   , "rurl   " );
+      _table[NONE_e]              = PairType( "NONE"   , "NONE   " );
     }
-    // add spaces so that the size of the returned string is always 7 (for now)
-    if (pad)
-      return _table[_id].append(7 - _table[_id].size(), ' ');
-    return _table[_id];
+
+    return( pad ? _table[_id].second : _table[_id].first );
   }
 
   std::ostream & operator << (std::ostream & str, const HistoryActionID & id)