| /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ | 
 | /* vim: set ts=8 sts=2 et sw=2 tw=80: */ | 
 | /* This Source Code Form is subject to the terms of the Mozilla Public | 
 |  * License, v. 2.0. If a copy of the MPL was not distributed with this | 
 |  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | 
 |  | 
 | /* An opaque integral type supporting only comparison operators. */ | 
 |  | 
 | #ifndef mozilla_Opaque_h | 
 | #define mozilla_Opaque_h | 
 |  | 
 | #include "mozilla/TypeTraits.h" | 
 |  | 
 | namespace mozilla { | 
 |  | 
 | /** | 
 |  * Opaque<T> is a replacement for integral T in cases where only comparisons | 
 |  * must be supported, and it's desirable to prevent accidental dependency on | 
 |  * exact values. | 
 |  */ | 
 | template<typename T> | 
 | class Opaque final | 
 | { | 
 |   static_assert(mozilla::IsIntegral<T>::value, | 
 |                 "mozilla::Opaque only supports integral types"); | 
 |  | 
 |   T mValue; | 
 |  | 
 | public: | 
 |   Opaque() {} | 
 |   explicit Opaque(T aValue) : mValue(aValue) {} | 
 |  | 
 |   bool operator==(const Opaque& aOther) const { | 
 |     return mValue == aOther.mValue; | 
 |   } | 
 |  | 
 |   bool operator!=(const Opaque& aOther) const { | 
 |     return !(*this == aOther); | 
 |   } | 
 | }; | 
 |  | 
 | } // namespace mozilla | 
 |  | 
 | #endif /* mozilla_Opaque_h */ |