From 9b1c0e006f20091f28f3f468cfcab1feb51286bd Mon Sep 17 00:00:00 2001 From: Neo2003 Date: Thu, 2 Oct 2008 16:23:55 -0500 Subject: [svn] * Proper SVN structure --HG-- branch : trunk --- src/shared/vmap/DebugCmdLogger.cpp | 125 +++++++++++++++++++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 src/shared/vmap/DebugCmdLogger.cpp (limited to 'src/shared/vmap/DebugCmdLogger.cpp') diff --git a/src/shared/vmap/DebugCmdLogger.cpp b/src/shared/vmap/DebugCmdLogger.cpp new file mode 100644 index 00000000000..56a5d3ffd2a --- /dev/null +++ b/src/shared/vmap/DebugCmdLogger.cpp @@ -0,0 +1,125 @@ +/* + * Copyright (C) 2005-2008 MaNGOS + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#include "DebugCmdLogger.h" + +using namespace G3D; + +namespace VMAP +{ + + bool CommandFileRW::appendCmd(const Command& +#ifdef _DEBUG + pCommand +#endif + ) + { + #ifdef _DEBUG + bool result = false; + if(iWritingEnabled || pCommand.isCoreCmd()) + { + FILE* f = fopen(iFileName.c_str(), "ab"); + if(f) + { + result = true; + if(fwrite(&pCommand, sizeof(Command), 1, f) != 1) { result = false; } + fclose(f); + } + } + else + { + result = true; + } + return result; + #else + return true; + #endif + } + + //========================================================= + + bool CommandFileRW::appendCmds(const Array& +#ifdef _DEBUG + pCmdArray +#endif + ) + { + #ifdef _DEBUG + bool result = false; + if(iWritingEnabled) + { + FILE* f; + if(resetfile) + f = fopen(iFileName.c_str(), "wb"); + else + f = fopen(iFileName.c_str(), "ab"); + resetfile = false; + + if(f) + { + result = true; + for(int i=0; i& pCmdArray) + { + bool result = false; + FILE* f = fopen(iFileName.c_str(), "rb"); + if(f) + { + Command cmd; + if(fseek(f, iLastPos, SEEK_SET) == 0) { result = true; } + while(result) + { + if(fread(&cmd, sizeof(Command), 1, f) != 1) + { + result = false; + } + iLastPos = ftell(f); + if(cmd.getType() == STOP) + { + break; + } + pCmdArray.append(cmd); + } + fclose(f); + } + if(result) + { + iCommandArray.append(pCmdArray); + } + return(result); + } + //======================================================== +} -- cgit v1.2.3