LCOV - code coverage report
Current view: top level - co - objectVersion.h (source / functions) Hit Total Coverage
Test: lcov2.info Lines: 11 17 64.7 %
Date: 2014-10-06 Functions: 2 4 50.0 %

          Line data    Source code
       1             : 
       2             : /* Copyright (c) 2009-2014, Stefan Eilemann <eile@equalizergraphics.com>
       3             :  *
       4             :  * This file is part of Collage <https://github.com/Eyescale/Collage>
       5             :  *
       6             :  * This library is free software; you can redistribute it and/or modify it under
       7             :  * the terms of the GNU Lesser General Public License version 2.1 as published
       8             :  * by the Free Software Foundation.
       9             :  *
      10             :  * This library is distributed in the hope that it will be useful, but WITHOUT
      11             :  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
      12             :  * FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more
      13             :  * details.
      14             :  *
      15             :  * You should have received a copy of the GNU Lesser General Public License
      16             :  * along with this library; if not, write to the Free Software Foundation, Inc.,
      17             :  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
      18             :  */
      19             : 
      20             : #ifndef CO_OBJECTVERSION_H
      21             : #define CO_OBJECTVERSION_H
      22             : 
      23             : #include <co/api.h>
      24             : #include <co/types.h>
      25             : #include <lunchbox/bitOperation.h>
      26             : #include <lunchbox/stdExt.h>
      27             : #include <iostream>
      28             : 
      29             : namespace co
      30             : {
      31             : /** Special object version values */
      32         896 : static const uint128_t VERSION_NONE( 0, 0 );
      33         896 : static const uint128_t VERSION_FIRST( 0, 1 );
      34         896 : static const uint128_t VERSION_NEWEST( 0, 0xfffffffffffffffbull );
      35         896 : static const uint128_t VERSION_OLDEST( 0, 0xfffffffffffffffcull );
      36         896 : static const uint128_t VERSION_NEXT( 0, 0xfffffffffffffffdull );
      37         896 : static const uint128_t VERSION_INVALID( 0, 0xfffffffffffffffeull );
      38         896 : static const uint128_t VERSION_HEAD( 0, 0xffffffffffffffffull );
      39             : 
      40             : /**
      41             :  * A helper struct bundling an object identifier and version.
      42             :  *
      43             :  * Primarily used for serialization. The struct either contains the object's
      44             :  * identifier and version (if it is registered or mapped), 0 and VERSION_NONE if
      45             :  * it is unmapped or if no object was given.
      46             :  */
      47           1 : struct ObjectVersion
      48             : {
      49             :     /** Construct a new, zero-initialized object version. @version 1.0 */
      50             :     CO_API ObjectVersion();
      51             : 
      52             :     /** Construct a new object version. @version 1.0 */
      53             :     CO_API ObjectVersion( const uint128_t& identifier, const uint128_t& version );
      54             : 
      55             :     /** Construct a new object version. @version 1.0 */
      56             :     CO_API ObjectVersion( const Object* object );
      57             : 
      58             :     /** Construct a new object version. @version 1.0 */
      59             :     template< class R > ObjectVersion( lunchbox::RefPtr< R > object )
      60             :         { *this = object.get(); }
      61             : 
      62             :     /** Assign a new identifier and version. @version 1.0 */
      63             :     CO_API ObjectVersion& operator = ( const Object* object );
      64             : 
      65             :     /** @return true if both structs contain the same values. @version 1.0 */
      66             :     bool operator == ( const ObjectVersion& value ) const
      67             :         {
      68             :             return ( identifier == value.identifier &&
      69             :                      version == value.version );
      70             :         }
      71             : 
      72             :     /** @return true if both structs have different values. @version 1.0 */
      73           1 :     bool operator != ( const ObjectVersion& value ) const
      74             :         {
      75           2 :             return ( identifier != value.identifier ||
      76           2 :                      version != value.version );
      77             :         }
      78             : 
      79             :     bool operator < ( const ObjectVersion& rhs ) const //!< @internal
      80             :         {
      81             :             return identifier < rhs.identifier ||
      82             :                    ( identifier == rhs.identifier && version < rhs.version );
      83             :         }
      84             : 
      85             :     bool operator > ( const ObjectVersion& rhs ) const //!< @internal
      86             :         {
      87             :             return identifier > rhs.identifier ||
      88             :                    ( identifier == rhs.identifier && version > rhs.version );
      89             :         }
      90             : 
      91             :     uint128_t identifier; //!< the object identifier
      92             :     uint128_t version; //!< the object version
      93             : };
      94             : 
      95           0 : inline std::ostream& operator << (std::ostream& os, const ObjectVersion& ov)
      96           0 : { return os << "id " << ov.identifier << " v" << ov.version; }
      97             : }
      98             : 
      99             : namespace lunchbox
     100             : {
     101           0 : template<> inline void byteswap( co::ObjectVersion& value ) //!< @internal
     102             : {
     103           0 :     lunchbox::byteswap( value.identifier );
     104           0 :     lunchbox::byteswap( value.version );
     105           0 : }
     106             : }
     107             : 
     108             : LB_STDEXT_NAMESPACE_OPEN
     109             : #ifdef LB_STDEXT_MSVC
     110             : /** ObjectVersion hash function. */
     111             : template<>
     112             : inline size_t hash_compare< co::ObjectVersion >::operator()
     113             :     ( const co::ObjectVersion& key ) const
     114             : {
     115             :     const size_t hashVersion = hash_value( key.version );
     116             :     const size_t hashID = hash_value( key.identifier );
     117             : 
     118             :     return hash_value( hashVersion ^ hashID );
     119             : }
     120             : #else
     121             : /** ObjectVersion hash function. */
     122             : template<> struct hash< co::ObjectVersion >
     123             : {
     124             :     template< typename P > size_t operator()( const P& key ) const
     125             :         {
     126             :             return hash< uint64_t >()( hash_value( key.version ) ^
     127             :                                        hash_value( key.identifier ));
     128             :         }
     129             : };
     130             : #endif
     131             : LB_STDEXT_NAMESPACE_CLOSE
     132             : 
     133             : #endif // CO_OBJECT_H

Generated by: LCOV version 1.10