8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-26 07:23:08 +01:00
firebird-mirror/src/include/memory_routines.h

287 lines
5.0 KiB
C++

/*
* PROGRAM: Client/Server Common Code
* MODULE: memory_routines.h
* DESCRIPTION: Misc memory content routines
*
* The contents of this file are subject to the Interbase Public
* License Version 1.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy
* of the License at http://www.firebirdsql.org/index.php?op=doc&id=ipl
*
* Software distributed under the License is distributed on an
* "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
* or implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code was created by Inprise Corporation
* and its predecessors. Portions created by Inprise Corporation are
* Copyright (C) Inprise Corporation.
*
* Created by: Dimitry Sibiryakov <aafemt@users.sourceforge.net>
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*/
#ifndef MEMORY_ROUTINES_H
#define MEMORY_ROUTINES_H
template <typename T>
inline void copy_toptr(void* to, const T from)
{
#ifndef I386
memcpy(to, &from, sizeof(T));
#else
*((T*) to) = from;
#endif
}
template <typename T>
inline void copy_fromptr(T& to, const void* from)
{
#ifndef I386
memcpy(&to, from, sizeof(T));
#else
to = *(T*) from;
#endif
}
inline USHORT get_short(const UCHAR* p)
{
/**************************************
*
* g e t _ s h o r t
*
**************************************
*
* Functional description
* Gather one unsigned short int
* from two chars
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
USHORT temp;
memcpy(&temp, p, sizeof(USHORT));
return temp;
#else
// big-endian
union
{
USHORT n;
UCHAR c[2];
} temp;
temp.c[0] = p[0];
temp.c[1] = p[1];
return temp.n;
#endif
}
inline SLONG get_long(const UCHAR* p)
{
/**************************************
*
* g e t _ l o n g
*
**************************************
*
* Functional description
* Gather one signed long int
* from four chars
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
SLONG temp;
memcpy(&temp, p, sizeof(SLONG));
return temp;
#else
// big-endian
union
{
SLONG n;
UCHAR c[4];
} temp;
temp.c[0] = p[0];
temp.c[1] = p[1];
temp.c[2] = p[2];
temp.c[3] = p[3];
return temp.n;
#endif
}
inline void put_short(UCHAR* p, USHORT value)
{
/**************************************
*
* p u t _ s h o r t
*
**************************************
*
* Functional description
* Store one unsigned short int as
* two chars
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
memcpy(p, &value, sizeof(USHORT));
#else
// big-endian
union
{
USHORT n;
UCHAR c[2];
} temp;
temp.n = value;
p[0] = temp.c[0];
p[1] = temp.c[1];
#endif
}
inline void put_long(UCHAR* p, SLONG value)
{
/**************************************
*
* p u t _ l o n g
*
**************************************
*
* Functional description
* Store one signed long int as
* four chars
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
memcpy(p, &value, sizeof(SLONG));
#else
// big-endian
union
{
SLONG n;
UCHAR c[4];
} temp;
temp.n = value;
p[0] = temp.c[0];
p[1] = temp.c[1];
p[2] = temp.c[2];
p[3] = temp.c[3];
#endif
}
inline void put_vax_short(UCHAR* p, SSHORT value)
{
/**************************************
*
* p u t _ v a x _ s h o r t
*
**************************************
*
* Functional description
* Store one signed short int as
* two chars in VAX format
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
memcpy(p, &value, sizeof(value));
#else
// big-endian
union
{
SSHORT n;
UCHAR c[2];
} temp;
temp.n = value;
p[0] = temp.c[1];
p[1] = temp.c[0];
#endif
}
inline void put_vax_long(UCHAR* p, SLONG value)
{
/**************************************
*
* p u t _ v a x _ l o n g
*
**************************************
*
* Functional description
* Store one signed long int as
* four chars in VAX format
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
memcpy(p, &value, sizeof(SLONG));
#else
// big-endian
union
{
SLONG n;
UCHAR c[4];
} temp;
temp.n = value;
p[0] = temp.c[3];
p[1] = temp.c[2];
p[2] = temp.c[1];
p[3] = temp.c[0];
#endif
}
inline void put_vax_int64(UCHAR* p, SINT64 value)
{
/**************************************
*
* p u t _ v a x _ i n t 6 4
*
**************************************
*
* Functional description
* Store one signed long long int as
* eight chars in VAX format
*
**************************************/
#ifndef WORDS_BIGENDIAN
// little-endian
memcpy(p, &value, sizeof(SINT64));
#else
// big-endian
union
{
SINT64 n;
UCHAR c[8];
} temp;
temp.n = value;
p[0] = temp.c[7];
p[1] = temp.c[6];
p[2] = temp.c[5];
p[3] = temp.c[4];
p[4] = temp.c[3];
p[5] = temp.c[2];
p[6] = temp.c[1];
p[7] = temp.c[0];
#endif
}
#endif // MEMORY_ROUTINES_H