0ad/source/lib/byte_order.cpp
janwas 0bb0df5b2c # new year's cleanup (reduce dependencies, clean up headers)
- remove headers always included from PCH
- nommgr.h is only included ifdef REDEFINED_NEW (allows leaving out the
mmgr stuff)
- in lib/*.cpp, moved the corresponding include file to right behind the
PCH (catches headers that aren't compilable by themselves)
- byte_order no longer depends on SDL
- add debug_level (another means of filtering debug output; needed for
thesis)
- split posix stuff up into subdirs (lib/posix and sysdep/win/wposix).
makes including only some of the modules (e.g. sockets, time) much
easier.

This was SVN commit r4728.
2007-01-01 21:25:47 +00:00

176 lines
2.6 KiB
C++

/**
* =========================================================================
* File : byte_order.cpp
* Project : 0 A.D.
* Description : byte order (endianness) support routines.
*
* @author Jan.Wassenberg@stud.uni-karlsruhe.de
* =========================================================================
*/
/*
* Copyright (c) 2003 Jan Wassenberg
*
* Redistribution and/or modification are also permitted under the
* terms of the GNU General Public License as published by the
* Free Software Foundation (version 2 or later, at your option).
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*/
#include "precompiled.h"
#include "byte_order.h"
#ifndef swap16
u16 swap16(const u16 x)
{
return (u16)(((x & 0xff) << 8) | (x >> 8));
}
u32 swap32(const u32 x)
{
return (x << 24) |
(x >> 24) |
((x << 8) & 0x00ff0000) |
((x >> 8) & 0x0000ff00);
}
u64 swap64(const u64 x)
{
const u32 lo = (u32)(x & 0xFFFFFFFF);
const u32 hi = (u32)(x >> 32);
u64 ret = swap32(lo);
ret <<= 32;
// careful: must shift var of type u64, not u32
ret |= swap32(hi);
return ret;
}
#endif // #ifndef swap16
//-----------------------------------------------------------------------------
u16 to_le16(u16 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return swap16(x);
#else
return x;
#endif
}
u32 to_le32(u32 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return swap32(x);
#else
return x;
#endif
}
u64 to_le64(u64 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return swap64(x);
#else
return x;
#endif
}
u16 to_be16(u16 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return x;
#else
return swap16(x);
#endif
}
u32 to_be32(u32 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return x;
#else
return swap32(x);
#endif
}
u64 to_be64(u64 x)
{
#if BYTE_ORDER == BIG_ENDIAN
return x;
#else
return swap64(x);
#endif
}
u16 read_le16(const void* p)
{
return to_le16(*(u16*)p);
}
u32 read_le32(const void* p)
{
return to_le32(*(u32*)p);
}
u64 read_le64(const void* p)
{
return to_le64(*(u64*)p);
}
u16 read_be16(const void* p)
{
return to_be16(*(u16*)p);
}
u32 read_be32(const void* p)
{
return to_be32(*(u32*)p);
}
u64 read_be64(const void* p)
{
return to_be64(*(u64*)p);
}
void write_le16(void* p, u16 x)
{
*(u16*)p = to_le16(x);
}
void write_le32(void* p, u32 x)
{
*(u32*)p = to_le32(x);
}
void write_le64(void* p, u64 x)
{
*(u64*)p = to_le64(x);
}
void write_be16(void* p, u16 x)
{
*(u16*)p = to_be16(x);
}
void write_be32(void* p, u32 x)
{
*(u32*)p = to_be32(x);
}
void write_be64(void* p, u64 x)
{
*(u64*)p = to_be64(x);
}