- provide operator== for BitField
authorMichael Andres <ma@suse.de>
Sun, 29 Jan 2006 23:12:51 +0000 (23:12 +0000)
committerMichael Andres <ma@suse.de>
Sun, 29 Jan 2006 23:12:51 +0000 (23:12 +0000)
- fixed operator== for ResStatus. Made provided contants actually const.

zypp/Bit.h
zypp/ResStatus.cc
zypp/ResStatus.h

index 01629f3054f9eb082d515aa8444447ce33611cb6..3b79f810c5837cf483fe508f9dffb614471c2d0e 100644 (file)
@@ -13,8 +13,7 @@
 #define ZYPP_BIT_H
 
 #include <iosfwd>
-
-#include "zypp/base/PtrTypes.h"
+#include <string>
 
 ///////////////////////////////////////////////////////////////////
 namespace zypp
@@ -191,6 +190,16 @@ namespace zypp
         return str << obj.asString();
       }
 
+    /** \relates BitField */
+    template<class _IntT>
+      inline bool operator==( const BitField<_IntT> & lhs, const BitField<_IntT> & rhs )
+      { return lhs.value() == rhs.value(); }
+
+    /** \relates BitField */
+    template<class _IntT>
+      inline bool operator!=( const BitField<_IntT> & lhs, const BitField<_IntT> & rhs )
+      { return ! (lhs == rhs); }
+
     /////////////////////////////////////////////////////////////////
   } // namespace bit
   ///////////////////////////////////////////////////////////////////
index 37840b8ca9f94f5d2807c1d653764b412b7e7cfd..754ba687e8abc79ccb0cdb05d9454c1cd6b02246 100644 (file)
@@ -20,6 +20,17 @@ using std::endl;
 namespace zypp
 { /////////////////////////////////////////////////////////////////
 
+  const ResStatus ResStatus::toBeInstalled              (UNINSTALLED, UNDETERMINED, TRANSACT);
+  const ResStatus ResStatus::toBeInstalledSoft          (UNINSTALLED, UNDETERMINED, TRANSACT, SOFT_REQUIRES);
+  const ResStatus ResStatus::toBeUninstalled            (INSTALLED,   UNDETERMINED, TRANSACT);
+  const ResStatus ResStatus::toBeUninstalledDueToUnlink         (INSTALLED,   UNDETERMINED, TRANSACT, EXPLICIT_INSTALL, DUE_TO_UNLINK);
+  const ResStatus ResStatus::toBeUninstalledDueToObsolete(INSTALLED,   UNDETERMINED, TRANSACT, EXPLICIT_INSTALL, DUE_TO_OBSOLETE);
+  const ResStatus ResStatus::incomplete                         (INSTALLED,   INCOMPLETE);
+  const ResStatus ResStatus::complete                   (INSTALLED,   SATISFIED);
+  const ResStatus ResStatus::satisfied                  (UNINSTALLED, SATISFIED);
+  const ResStatus ResStatus::unneeded                   (UNINSTALLED, UNNEEDED);
+  const ResStatus ResStatus::needed                     (UNINSTALLED, INCOMPLETE);
+
   ///////////////////////////////////////////////////////////////////
   //
   //   METHOD NAME : ResStatus::ResStatus
@@ -46,17 +57,6 @@ namespace zypp
   {}
 
 
-ResStatus ResStatus::toBeInstalled              = ResStatus (UNINSTALLED, UNDETERMINED, TRANSACT);
-ResStatus ResStatus::toBeInstalledSoft          = ResStatus (UNINSTALLED, UNDETERMINED, TRANSACT, SOFT_REQUIRES);
-ResStatus ResStatus::toBeUninstalled            = ResStatus (INSTALLED,   UNDETERMINED, TRANSACT);
-ResStatus ResStatus::toBeUninstalledDueToUnlink         = ResStatus (INSTALLED,   UNDETERMINED, TRANSACT, EXPLICIT_INSTALL, DUE_TO_UNLINK);
-ResStatus ResStatus::toBeUninstalledDueToObsolete= ResStatus (INSTALLED,   UNDETERMINED, TRANSACT, EXPLICIT_INSTALL, DUE_TO_OBSOLETE);
-ResStatus ResStatus::incomplete                         = ResStatus (INSTALLED,   INCOMPLETE);
-ResStatus ResStatus::complete                   = ResStatus (INSTALLED,   SATISFIED);
-ResStatus ResStatus::satisfied                  = ResStatus (UNINSTALLED, SATISFIED);
-ResStatus ResStatus::unneeded                   = ResStatus (UNINSTALLED, UNNEEDED);
-ResStatus ResStatus::needed                     = ResStatus (UNINSTALLED, INCOMPLETE);
-
   ResStatus::ResStatus (enum StateValue s, enum EstablishValue e, enum TransactValue t, enum InstallDetailValue i, enum RemoveDetailValue r)
     : _bitfield (s)
   {
@@ -97,7 +97,7 @@ ResStatus ResStatus::needed                    = ResStatus (UNINSTALLED, INCOMPLETE);
     if (obj == ResStatus::complete)                    str << "<complete>";                    // installed, satisfied
     if (obj == ResStatus::unneeded)                    str << "<uneeded>";                     // uninstalled, unneeded
     if (obj == ResStatus::needed)                      str << "<needed>";                      // uninstalled, incomplete
-    if (obj == ResStatus::incomplete)                  str << "<incomplete>";                  // installed, incomplete 
+    if (obj == ResStatus::incomplete)                  str << "<incomplete>";                  // installed, incomplete
 
     return str;
   }
index 3856b1619864521f0c987e5e1832e36c9291b0da..1629be8b9d73953a532e0cd57a2244b8c2c53608 100644 (file)
@@ -46,7 +46,14 @@ namespace zypp
   class ResStatus
   {
     friend std::ostream & operator<<( std::ostream & str, const ResStatus & obj );
-
+    friend bool operator==( const ResStatus & lhs, const ResStatus & rhs );
+
+    /** \name BitField range definitions.
+     *
+     * \note Enlarge FieldType if more bit's needed. It's not yet
+     * checked by the compiler.
+     */
+    //@{
     typedef char FieldType;
     // Bit Ranges within FieldType defined by 1st bit and size:
     typedef bit::Range<FieldType,0,                    1> StateField;
@@ -56,10 +63,16 @@ namespace zypp
     typedef bit::Range<FieldType,TransactByField::end, 2> TransactDetailField;
     // enlarge FieldType if more bit's needed. It's not yet
     // checked by the compiler.
+    //@}
   public:
 
-    // do we manage to hide them
-
+    /** \name Status values.
+     *
+     * Each enum corresponds to a BitField range.
+     * \note Take care that enumerator values actually fit into
+     * the corresponding field. It's not yet checked by the compiler.
+     */
+    //@{
     enum StateValue
       {
         UNINSTALLED = 0,
@@ -71,7 +84,6 @@ namespace zypp
         UNNEEDED     = EstablishField::minval,         // has freshens, none trigger
         SATISFIED,                                     // has none or triggered freshens, all requirements fulfilled
         INCOMPLETE                                     // installed: has none or triggered freshens, requirements unfulfilled
-                                                       // uninstalled: has triggered freshens, requirements unfulfilled
       };
     enum TransactValue
       {
@@ -97,6 +109,7 @@ namespace zypp
         DUE_TO_OBSOLETE = TransactDetailField::minval,
         DUE_TO_UNLINK
       };
+    //@}
 
   public:
 
@@ -237,25 +250,27 @@ namespace zypp
        _bitfield = status._bitfield;
     }
 
-    static ResStatus toBeInstalled;
-    static ResStatus toBeInstalledSoft;
-    static ResStatus toBeUninstalled;
-    static ResStatus toBeUninstalledDueToUnlink;
-    static ResStatus toBeUninstalledDueToObsolete;
-    static ResStatus satisfied;                        // uninstalled, satisfied
-    static ResStatus complete;                 // installed, satisfied
-    static ResStatus unneeded;                 // uninstalled, unneeded
-    static ResStatus needed;                   // uninstalled, incomplete
-    static ResStatus incomplete;               // installed, incomplete 
-
-  inline bool operator==( const ResStatus & rhs ) const
-  { return _bitfield.value() == rhs._bitfield.value(); }
-
-  inline bool operator!=( const ResStatus & rhs ) const
-  { return _bitfield.value() != rhs._bitfield.value(); }
+    /** \name Builtin ResStatus constants. */
+    //@{
+    static const ResStatus toBeInstalled;
+    static const ResStatus toBeInstalledSoft;
+    static const ResStatus toBeUninstalled;
+    static const ResStatus toBeUninstalledDueToUnlink;
+    static const ResStatus toBeUninstalledDueToObsolete;
+    static const ResStatus satisfied;  // uninstalled, satisfied
+    static const ResStatus complete;   // installed, satisfied
+    static const ResStatus unneeded;   // uninstalled, unneeded
+    static const ResStatus needed;     // uninstalled, incomplete
+    static const ResStatus incomplete; // installed, incomplete
+    //@}
 
   private:
-    ResStatus (enum StateValue s, enum EstablishValue e = UNDETERMINED, enum TransactValue t = TRANSACT, enum InstallDetailValue i = EXPLICIT_INSTALL, enum RemoveDetailValue r = EXPLICIT_REMOVE);
+    /** Ctor for intialization of builtin constants. */
+    ResStatus( StateValue s,
+               EstablishValue e     = UNDETERMINED,
+               TransactValue t      = TRANSACT,
+               InstallDetailValue i = EXPLICIT_INSTALL,
+               RemoveDetailValue r  = EXPLICIT_REMOVE );
 
     /** Return whether the corresponding Field has value \a val_r.
     */
@@ -269,7 +284,6 @@ namespace zypp
       void fieldValueAssign( FieldType val_r )
       { _bitfield.assign<_Field>( val_r ); }
 
-
   private:
     bit::BitField<FieldType> _bitfield;
   };
@@ -278,6 +292,14 @@ namespace zypp
   /** \relates ResStatus Stream output */
   std::ostream & operator<<( std::ostream & str, const ResStatus & obj );
 
+  /** \relates ResStatus */
+  inline bool operator==( const ResStatus & lhs, const ResStatus & rhs )
+  { return lhs._bitfield == rhs._bitfield; }
+
+  /** \relates ResStatus */
+  inline bool operator!=( const ResStatus & lhs, const ResStatus & rhs )
+  { return ! (lhs == rhs); }
+
   /////////////////////////////////////////////////////////////////
 } // namespace zypp
 ///////////////////////////////////////////////////////////////////