![]() |
Shadowrun: Awakened 29 September 2011 - Build 871
|
00001 /* 00002 Copyright (c) 2009-2010 Christopher A. Taylor. All rights reserved. 00003 00004 Redistribution and use in source and binary forms, with or without 00005 modification, are permitted provided that the following conditions are met: 00006 00007 * Redistributions of source code must retain the above copyright notice, 00008 this list of conditions and the following disclaimer. 00009 * Redistributions in binary form must reproduce the above copyright notice, 00010 this list of conditions and the following disclaimer in the documentation 00011 and/or other materials provided with the distribution. 00012 * Neither the name of LibCat nor the names of its contributors may be used 00013 to endorse or promote products derived from this software without 00014 specific prior written permission. 00015 00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00017 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00018 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00019 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00020 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00021 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00022 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00023 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00024 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00025 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00026 POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00029 #ifndef CAT_ENDIAN_NEUTRAL_HPP 00030 #define CAT_ENDIAN_NEUTRAL_HPP 00031 00032 #include <cat/Platform.hpp> 00033 00034 namespace cat { 00035 00036 00037 // getLE() converts from little-endian word to native byte-order word 00038 // getBE() converts from big-endian word to native byte-order word 00039 00040 template<typename T> 00041 CAT_INLINE T NoChangeNeeded(const T t) 00042 { 00043 return t; 00044 } 00045 00046 #if defined(CAT_ENDIAN_LITTLE) 00047 00048 # define swapLE(n) NoChangeNeeded(n) 00049 # define getLE(n) NoChangeNeeded(n) 00050 # define getLE16(n) NoChangeNeeded(n) 00051 # define getLE32(n) NoChangeNeeded(n) 00052 # define getLE64(n) NoChangeNeeded(n) 00053 00054 CAT_INLINE u16 swapBE(u16 &n) { return n = CAT_BOSWAP16(n); } 00055 CAT_INLINE u32 swapBE(u32 &n) { return n = CAT_BOSWAP32(n); } 00056 CAT_INLINE u64 swapBE(u64 &n) { return n = CAT_BOSWAP64(n); } 00057 CAT_INLINE u16 getBE(u16 n) { return CAT_BOSWAP16(n); } 00058 CAT_INLINE u32 getBE(u32 n) { return CAT_BOSWAP32(n); } 00059 CAT_INLINE u64 getBE(u64 n) { return CAT_BOSWAP64(n); } 00060 CAT_INLINE u16 getBE16(u16 n) { return CAT_BOSWAP16(n); } 00061 CAT_INLINE u32 getBE32(u32 n) { return CAT_BOSWAP32(n); } 00062 CAT_INLINE u64 getBE64(u64 n) { return CAT_BOSWAP64(n); } 00063 CAT_INLINE s16 swapBE(s16 &n) { return n = CAT_BOSWAP16((u16)n); } 00064 CAT_INLINE s32 swapBE(s32 &n) { return n = CAT_BOSWAP32((u32)n); } 00065 CAT_INLINE s64 swapBE(s64 &n) { return n = CAT_BOSWAP64((u64)n); } 00066 CAT_INLINE s16 getBE(s16 n) { return CAT_BOSWAP16((u16)n); } 00067 CAT_INLINE s32 getBE(s32 n) { return CAT_BOSWAP32((u32)n); } 00068 CAT_INLINE s64 getBE(s64 n) { return CAT_BOSWAP64((u64)n); } 00069 00070 CAT_INLINE float getBE(float n) { 00071 Float32 c = n; 00072 c.i = CAT_BOSWAP32(c.i); 00073 return c.f; 00074 } 00075 00076 #elif defined(CAT_ENDIAN_BIG) 00077 00078 # define swapBE(n) NoChangeNeeded(n) 00079 # define getBE(n) NoChangeNeeded(n) 00080 # define getBE16(n) NoChangeNeeded(n) 00081 # define getBE32(n) NoChangeNeeded(n) 00082 # define getBE64(n) NoChangeNeeded(n) 00083 00084 CAT_INLINE u16 swapLE(u16 &n) { return n = CAT_BOSWAP16(n); } 00085 CAT_INLINE u32 swapLE(u32 &n) { return n = CAT_BOSWAP32(n); } 00086 CAT_INLINE u64 swapLE(u64 &n) { return n = CAT_BOSWAP64(n); } 00087 CAT_INLINE u16 getLE(u16 n) { return CAT_BOSWAP16(n); } 00088 CAT_INLINE u32 getLE(u32 n) { return CAT_BOSWAP32(n); } 00089 CAT_INLINE u64 getLE(u64 n) { return CAT_BOSWAP64(n); } 00090 CAT_INLINE u16 getLE16(u16 n) { return CAT_BOSWAP16(n); } 00091 CAT_INLINE u32 getLE32(u32 n) { return CAT_BOSWAP32(n); } 00092 CAT_INLINE u64 getLE64(u64 n) { return CAT_BOSWAP64(n); } 00093 CAT_INLINE s16 swapLE(s16 &n) { return n = CAT_BOSWAP16((u16)n); } 00094 CAT_INLINE s32 swapLE(s32 &n) { return n = CAT_BOSWAP32((u32)n); } 00095 CAT_INLINE s64 swapLE(s64 &n) { return n = CAT_BOSWAP64((u64)n); } 00096 CAT_INLINE s16 getLE(s16 n) { return CAT_BOSWAP16((u16)n); } 00097 CAT_INLINE s32 getLE(s32 n) { return CAT_BOSWAP32((u32)n); } 00098 CAT_INLINE s64 getLE(s64 n) { return CAT_BOSWAP64((u64)n); } 00099 00100 CAT_INLINE float getLE(float n) { 00101 Float32 c = n; 00102 c.i = CAT_BOSWAP32(c.i); 00103 return c.f; 00104 } 00105 00106 #elif defined(CAT_ENDIAN_UNKNOWN) 00107 00108 class RuntimeEndianDetector 00109 { 00110 public: 00111 bool _big_endian, _little_endian; 00112 00113 RuntimeEndianDetector(); 00114 }; 00115 00116 class Endianness 00117 { 00118 public: 00119 static RuntimeEndianDetector detector; 00120 static CAT_INLINE bool IsBigEndian() { return detector._big_endian; } 00121 static CAT_INLINE bool IsLittleEndian() { return detector._little_endian; } 00122 }; 00123 00124 CAT_INLINE u16 swapBE(u16 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP16(n); } 00125 CAT_INLINE u32 swapBE(u32 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP32(n); } 00126 CAT_INLINE u64 swapBE(u64 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP64(n); } 00127 CAT_INLINE u16 getBE(u16 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP16(n); } 00128 CAT_INLINE u32 getBE(u32 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP32(n); } 00129 CAT_INLINE u64 getBE(u64 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP64(n); } 00130 CAT_INLINE u16 getBE16(u16 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP16(n); } 00131 CAT_INLINE u32 getBE32(u32 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP32(n); } 00132 CAT_INLINE u64 getBE64(u64 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP64(n); } 00133 CAT_INLINE s16 swapBE(s16 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP16((u16)n); } 00134 CAT_INLINE s32 swapBE(s32 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP32((u32)n); } 00135 CAT_INLINE s64 swapBE(s64 &n) { return Endianness::IsBigEndian() ? n : n = CAT_BOSWAP64((u64)n); } 00136 CAT_INLINE s16 getBE(s16 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP16((u16)n); } 00137 CAT_INLINE s32 getBE(s32 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP32((u32)n); } 00138 CAT_INLINE s64 getBE(s64 n) { return Endianness::IsBigEndian() ? n : CAT_BOSWAP64((u64)n); } 00139 00140 CAT_INLINE float getBE(float n) 00141 { 00142 if (Endianness::IsBigEndian()) 00143 return n; 00144 else 00145 { 00146 Float32 c = n; 00147 c.i = CAT_BOSWAP32(c.i); 00148 return c.f; 00149 } 00150 } 00151 00152 CAT_INLINE u16 swapLE(u16 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP16(n); } 00153 CAT_INLINE u32 swapLE(u32 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP32(n); } 00154 CAT_INLINE u64 swapLE(u64 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP64(n); } 00155 CAT_INLINE u16 getLE(u16 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP16(n); } 00156 CAT_INLINE u32 getLE(u32 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP32(n); } 00157 CAT_INLINE u64 getLE(u64 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP64(n); } 00158 CAT_INLINE u16 getLE16(u16 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP16(n); } 00159 CAT_INLINE u32 getLE32(u32 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP32(n); } 00160 CAT_INLINE u64 getLE64(u64 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP64(n); } 00161 CAT_INLINE s16 swapLE(s16 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP16((u16)n); } 00162 CAT_INLINE s32 swapLE(s32 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP32((u32)n); } 00163 CAT_INLINE s64 swapLE(s64 &n) { return Endianness::IsLittleEndian() ? n : n = CAT_BOSWAP64((u64)n); } 00164 CAT_INLINE s16 getLE(s16 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP16((u16)n); } 00165 CAT_INLINE s32 getLE(s32 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP32((u32)n); } 00166 CAT_INLINE s64 getLE(s64 n) { return Endianness::IsLittleEndian() ? n : CAT_BOSWAP64((u64)n); } 00167 00168 CAT_INLINE float getLE(float n) 00169 { 00170 if (Endianness::IsLittleEndian()) 00171 return n; 00172 else 00173 { 00174 Float32 c = n; 00175 c.i = CAT_BOSWAP32(c.i); 00176 return c.f; 00177 } 00178 } 00179 00180 #endif 00181 00182 00183 } // namespace cat 00184 00185 #endif // CAT_ENDIAN_NEUTRAL_HPP
Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.