00001 //=========================================================================== 00002 //Copyright (C) 2003, 2004 Zentaro Kavanagh 00003 // 00004 //Redistribution and use in source and binary forms, with or without 00005 //modification, are permitted provided that the following conditions 00006 //are met: 00007 // 00008 //- Redistributions of source code must retain the above copyright 00009 // notice, this list of conditions and the following disclaimer. 00010 // 00011 //- Redistributions in binary form must reproduce the above copyright 00012 // notice, this list of conditions and the following disclaimer in the 00013 // documentation and/or other materials provided with the distribution. 00014 // 00015 //- Neither the name of Zentaro Kavanagh nor the names of contributors 00016 // may be used to endorse or promote products derived from this software 00017 // without specific prior written permission. 00018 // 00019 //THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00020 //``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00021 //LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00022 //PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ORGANISATION OR 00023 //CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00024 //EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00025 //PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00026 //PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00027 //LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00028 //NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00029 //SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00030 //=========================================================================== 00031 00032 #include "stdafx.h" 00033 #include <libilliCore/iBE_Math.h> 00034 00035 iBE_Math::iBE_Math(void) 00036 { 00037 } 00038 00039 iBE_Math::~iBE_Math(void) 00040 { 00041 } 00042 00043 unsigned long iBE_Math::charArrToULong(unsigned char* inCharArray) 00044 { 00045 //Turns the next four bytes from the pointer in a long MSB (most sig. byte first/leftmost) 00046 unsigned long locVal = 0; 00047 for (int i = 0; i < 4; i++) { 00048 locVal <<= 8; 00049 locVal += inCharArray[i]; 00050 } 00051 return locVal; 00052 } 00053 void iBE_Math::ULongToCharArr(unsigned long inLong, unsigned char* outCharArray) 00054 { 00055 //Writes a long MSB (Most sig. byte first/leftmost) out to the char arr 00056 outCharArray[0] = (unsigned char) (inLong >> 24); 00057 outCharArray[1] = (unsigned char) ((inLong << 8) >> 24); 00058 outCharArray[2] = (unsigned char) ((inLong << 16) >> 24); 00059 outCharArray[3] = (unsigned char) ((inLong << 24) >> 24); 00060 00061 } 00062 00063 unsigned short iBE_Math::charArrToUShort(unsigned char* inCharArray) { 00064 unsigned short retShort = inCharArray[0]; 00065 retShort = (retShort << 8) + inCharArray[1]; 00066 return retShort; 00067 00068 }