// Copyright (c) 1998-1999 Matra Datavision // Copyright (c) 1999-2013 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef _Standard_Integer_HeaderFile #define _Standard_Integer_HeaderFile #include #include #include // =============== // Inline methods // =============== // ------------------------------------------------------------------ // Abs : Returns the absolute value of an Integer // ------------------------------------------------------------------ inline Standard_Integer Abs (const Standard_Integer Value) { return Value >= 0 ? Value : -Value; } // ------------------------------------------------------------------ // IsEven : Returns Standard_True if an integer is even // ------------------------------------------------------------------ inline Standard_Boolean IsEven (const Standard_Integer Value) { return Value % 2 == 0; } // ------------------------------------------------------------------ // IsOdd : Returns Standard_True if an integer is odd // ------------------------------------------------------------------ inline Standard_Boolean IsOdd (const Standard_Integer Value) { return Value % 2 == 1; } // ------------------------------------------------------------------ // Max : Returns the maximum integer between two integers // ------------------------------------------------------------------ inline Standard_Integer Max (const Standard_Integer Val1, const Standard_Integer Val2) { return Val1 >= Val2 ? Val1 : Val2; } // ------------------------------------------------------------------ // Min : Returns the minimum integer between two integers // ------------------------------------------------------------------ inline Standard_Integer Min (const Standard_Integer Val1, const Standard_Integer Val2) { return Val1 <= Val2 ? Val1 : Val2; } // ------------------------------------------------------------------ // Modulus : Returns the remainder of division between two integers // ------------------------------------------------------------------ inline Standard_Integer Modulus (const Standard_Integer Value, const Standard_Integer Divisor) { return Value % Divisor; } // ------------------------------------------------------------------ // Square : Returns the square of an integer // ------------------------------------------------------------------ inline Standard_Integer Square(const Standard_Integer Value) { return Value * Value; } // ------------------------------------------------------------------ // IntegerFirst : Returns the minimum value of an integer // ------------------------------------------------------------------ inline Standard_Integer IntegerFirst() { return INT_MIN; } // ------------------------------------------------------------------ // IntegerLast : Returns the maximum value of an integer // ------------------------------------------------------------------ inline Standard_Integer IntegerLast() { return INT_MAX; } // ------------------------------------------------------------------ // IntegerSize : Returns the size in digits of an integer // ------------------------------------------------------------------ inline Standard_Integer IntegerSize() { return BITS(Standard_Integer); } //! Computes a hash code for the given value of some integer type, in range [1, theUpperBound] //! @tparam TheInteger the type of the integer which hash code is to be computed //! @param theValue the value of the TheInteger type which hash code is to be computed //! @param theMask the mask for the last bits of the value that are used in the computation of a hash code //! @param theUpperBound the upper bound of the range a computing hash code must be within //! @return a computed hash code, in range [1, theUpperBound] template typename opencascade::std::enable_if::value, Standard_Integer>::type IntegerHashCode (const TheInteger theValue, const typename opencascade::disable_deduction::type theMask, const Standard_Integer theUpperBound) { return static_cast ((theValue & theMask) % theUpperBound + 1); } //! Computes a hash code for the given value of the Standard_Integer type, in range [1, theUpperBound] //! @param theValue the value of the Standard_Integer type which hash code is to be computed //! @param theUpperBound the upper bound of the range a computing hash code must be within //! @return a computed hash code, in range [1, theUpperBound] inline Standard_Integer HashCode (const Standard_Integer theValue, const Standard_Integer theUpperBound) { // return (Abs (theMe) % theUpper) + 1; return IntegerHashCode(theValue, IntegerLast(), theUpperBound); } // ------------------------------------------------------------------ // IsEqual : Returns Standard_True if two integers are equal // ------------------------------------------------------------------ inline Standard_Boolean IsEqual (const Standard_Integer theOne, const Standard_Integer theTwo) { return theOne == theTwo; } //! Computes a hash value for the given unsigned integer, in range [1, theUpperBound] //! @tparam TheUnsignedInteger the type of the given value (it is "unsigned int", //! and must not be the same as Standard_Size, because the overload of the HashCode function //! for Standard_Size type is already presented in Standard_Size.hxx) //! @param theValue the unsigned integer which hash code is to be computed //! @return a hash value computed for the given unsigned integer, in range [1, theUpperBound] template typename opencascade::std::enable_if::value && opencascade::std::is_same::value, Standard_Integer>::type HashCode (const TheUnsignedInteger theValue, const Standard_Integer theUpperBound) { return HashCode (static_cast (theValue), theUpperBound); } //! Computes a hash code for the given value of the "long long int" type, in range [1, theUpperBound] //! @param theValue the value of the "long long int" type which hash code is to be computed //! @param theUpperBound the upper bound of the range a computing hash code must be within //! @return a computed hash code, in range [1, theUpperBound] inline Standard_Integer HashCode (const long long int theValue, const Standard_Integer theUpperBound) { return IntegerHashCode(theValue, 0x7fffffffffffffff, theUpperBound); } #if (defined(_LP64) || defined(__LP64__) || defined(_WIN64)) || defined(__APPLE__) //! Computes a hash code for the given value of the Standard_Utf32Char type, in range [1, theUpperBound] //! @param theValue the value of the Standard_Utf32Char type which hash code is to be computed //! @param theUpperBound the upper bound of the range a computing hash code must be within //! @return a computed hash code, in range [1, theUpperBound] inline Standard_Integer HashCode (const Standard_Utf32Char theValue, const Standard_Integer theUpperBound) { return IntegerHashCode(theValue, IntegerLast(), theUpperBound); } // ------------------------------------------------------------------ // IsEqual : Returns Standard_True if two integers are equal // ------------------------------------------------------------------ inline Standard_Boolean IsEqual (const Standard_Utf32Char theOne, const Standard_Utf32Char theTwo) { return theOne == theTwo; } #endif #endif