Shadowrun: Awakened 29 September 2011 - Build 871
EndianNeutral.hpp
Go to the documentation of this file.
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.

GNU Lesser General Public License 3 Sourceforge.net