1
/***************************************************************************
2
* Copyright (c) 2005 Imetric 3D GmbH *
4
* This file is part of the FreeCAD CAx development system. *
6
* This library is free software; you can redistribute it and/or *
7
* modify it under the terms of the GNU Library General Public *
8
* License as published by the Free Software Foundation; either *
9
* version 2 of the License, or (at your option) any later version. *
11
* This library is distributed in the hope that it will be useful, *
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14
* GNU Library General Public License for more details. *
16
* You should have received a copy of the GNU Library General Public *
17
* License along with this library; see the file COPYING.LIB. If not, *
18
* write to the Free Software Foundation, Inc., 59 Temple Place, *
19
* Suite 330, Boston, MA 02111-1307, USA *
21
***************************************************************************/
24
#include "PreCompiled.h"
28
unsigned short Base::SwapOrder()
30
unsigned short usDummy = 1;
31
return *((char*)&usDummy) == 1 ? LOW_ENDIAN : HIGH_ENDIAN;
34
void Base::SwapVar(char& /*unused*/)
37
void Base::SwapVar(unsigned char& /*unused*/)
40
void Base::SwapVar(short& s)
45
for (i = 0; i < (int)sizeof(short); i++) {
46
*(((char*)&sTmp) + i) = *(((char*)&s) + sizeof(short) - i - 1);
51
void Base::SwapVar(unsigned short& s)
56
for (i = 0; i < (int)sizeof(short); i++) {
57
*(((char*)&sTmp) + i) = *(((char*)&s) + sizeof(short) - i - 1);
62
void Base::SwapVar(long& l)
67
for (i = 0; i < (int)sizeof(long); i++) {
68
*(((char*)&lTmp) + i) = *(((char*)&l) + sizeof(long) - i - 1);
73
void Base::SwapVar(unsigned long& l)
78
for (i = 0; i < (int)sizeof(long); i++) {
79
*(((char*)&lTmp) + i) = *(((char*)&l) + sizeof(long) - i - 1);
84
void Base::SwapVar(float& f)
89
for (i = 0; i < (int)sizeof(float); i++) {
90
*(((char*)&fTmp) + i) = *(((char*)&f) + sizeof(float) - i - 1);
95
void Base::SwapVar(double& d)
100
for (i = 0; i < (int)sizeof(double); i++) {
101
*(((char*)&dTmp) + i) = *(((char*)&d) + sizeof(double) - i - 1);