/*** * * Copyright (c) 1999, Valve LLC. All rights reserved. * * This product contains software technology licensed from Id * Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc. * All Rights Reserved. * * Use, distribution, and modification of this source code and/or resulting * object code is restricted to non-commercial enhancements to products from * Valve LLC. All other use, distribution, or modification is prohibited * without written permission from Valve LLC. * ****/ // // parsemsg.cpp // //-------------------------------------------------------------------------------------------------------------- #if defined(_MSC_VER) && _MSC_VER >= 1400 #ifndef _CRT_SECURE_NO_DEPRECATE #define _CRT_SECURE_NO_DEPRECATE #endif #ifndef _CRT_SECURE_NO_WARNINGS #define _CRT_SECURE_NO_WARNINGS #endif #pragma warning(disable: 4996) // deprecated functions #endif #include "parsemsg.h" #include typedef unsigned char byte; #define true 1 static byte *gpBuf; static int giSize; static int giRead; static int giBadRead; int READ_OK( void ) { return !giBadRead; } void BEGIN_READ( void *buf, int size ) { giRead = 0; giBadRead = 0; giSize = size; gpBuf = (byte*)buf; } int READ_CHAR( void ) { int c; if (giRead + 1 > giSize) { giBadRead = true; return -1; } c = (signed char)gpBuf[giRead]; giRead++; return c; } int READ_BYTE( void ) { int c; if (giRead+1 > giSize) { giBadRead = true; return -1; } c = (unsigned char)gpBuf[giRead]; giRead++; return c; } int READ_SHORT( void ) { int c; if (giRead+2 > giSize) { giBadRead = true; return -1; } c = (short)( gpBuf[giRead] + ( gpBuf[giRead+1] << 8 ) ); giRead += 2; return c; } int READ_WORD( void ) { return READ_SHORT(); } int READ_LONG( void ) { int c; if (giRead+4 > giSize) { giBadRead = true; return -1; } c = gpBuf[giRead] + (gpBuf[giRead + 1] << 8) + (gpBuf[giRead + 2] << 16) + (gpBuf[giRead + 3] << 24); giRead += 4; return c; } float READ_FLOAT( void ) { union { byte b[4]; float f; int l; } dat; dat.b[0] = gpBuf[giRead]; dat.b[1] = gpBuf[giRead+1]; dat.b[2] = gpBuf[giRead+2]; dat.b[3] = gpBuf[giRead+3]; giRead += 4; // dat.l = LittleLong (dat.l); return dat.f; } char* READ_STRING( void ) { static char string[2048]; size_t l; int c; string[0] = 0; l = 0; do { if ( giRead+1 > giSize ) break; // no more characters c = READ_CHAR(); if (c == -1 || c == 0) break; string[l] = c; l++; } while (l < sizeof(string)-1); string[l] = 0; return string; } float READ_COORD( void ) { return (float)(READ_SHORT() * (1.0/8)); } float READ_ANGLE( void ) { return (float)(READ_CHAR() * (360.0/256)); } float READ_HIRESANGLE( void ) { return (float)(READ_SHORT() * (360.0/65536)); } //-------------------------------------------------------------------------------------------------------------- BufferWriter::BufferWriter() { Init( NULL, 0 ); } //-------------------------------------------------------------------------------------------------------------- BufferWriter::BufferWriter( unsigned char *buffer, int bufferLen ) { Init( buffer, bufferLen ); } //-------------------------------------------------------------------------------------------------------------- void BufferWriter::Init( unsigned char *buffer, int bufferLen ) { m_overflow = false; m_buffer = buffer; m_remaining = bufferLen; m_overallLength = bufferLen; } //-------------------------------------------------------------------------------------------------------------- void BufferWriter::WriteByte( unsigned char data ) { if (!m_buffer || !m_remaining) { m_overflow = true; return; } *m_buffer = data; ++m_buffer; --m_remaining; } //-------------------------------------------------------------------------------------------------------------- void BufferWriter::WriteLong( int data ) { if (!m_buffer || m_remaining < 4) { m_overflow = true; return; } m_buffer[0] = data&0xff; m_buffer[1] = (data>>8)&0xff; m_buffer[2] = (data>>16)&0xff; m_buffer[3] = data>>24; m_buffer += 4; m_remaining -= 4; } //-------------------------------------------------------------------------------------------------------------- void BufferWriter::WriteString( const char *str ) { if (!m_buffer || !m_remaining) { m_overflow = true; return; } if (!str) str = ""; int len = strlen(str)+1; if ( len > m_remaining ) { m_overflow = true; str = ""; len = 1; } strcpy((char *)m_buffer, str); m_remaining -= len; m_buffer += len; } //-------------------------------------------------------------------------------------------------------------- int BufferWriter::GetSpaceUsed() { return m_overallLength - m_remaining; } //--------------------------------------------------------------------------------------------------------------