Google
Web alhem.net
Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Class Members | File Members

MySocketsLog.cpp

Go to the documentation of this file.
00001 00005 /* 00006 Copyright (C) 2004 Anders Hedström (grymse@alhem.net) 00007 00008 This program is free software; you can redistribute it and/or 00009 modify it under the terms of the GNU General Public License 00010 as published by the Free Software Foundation; either version 2 00011 of the License, or (at your option) any later version. 00012 00013 This program is distributed in the hope that it will be useful, 00014 but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 GNU General Public License for more details. 00017 00018 You should have received a copy of the GNU General Public License 00019 along with this program; if not, write to the Free Software 00020 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 00021 */ 00022 #include <stdio.h> 00023 #ifdef _WIN32 00024 #pragma warning(disable:4786) 00025 #endif 00026 #include <time.h> 00027 #include "SocketHandler.h" 00028 #include "Socket.h" 00029 #include "MySocketsLog.h" 00030 00031 00032 #define D2(x) { \ 00033 FILE *fil = fopen("c:\\deb.log","at"); \ 00034 x; \ 00035 fclose(fil); \ 00036 } 00037 00038 00039 void MySocketsLog::error(SocketHandler *,Socket *,const std::string& call,int err,const std::string& sys_err,loglevel_t lvl) 00040 { 00041 time_t t = time(NULL); 00042 struct tm *tp = localtime(&t); 00043 std::string level; 00044 00045 switch (lvl) 00046 { 00047 case LOG_LEVEL_WARNING: 00048 level = "Warning"; 00049 break; 00050 case LOG_LEVEL_ERROR: 00051 level = "Error"; 00052 break; 00053 case LOG_LEVEL_FATAL: 00054 level = "Fatal"; 00055 break; 00056 } 00057 00058 D2( 00059 fprintf(fil,"%d-%02d-%02d %02d:%02d:%02d :: %s: %s (%s)\n", 00060 tp -> tm_year + 1900, 00061 tp -> tm_mon + 1, 00062 tp -> tm_mday, 00063 tp -> tm_hour,tp -> tm_min,tp -> tm_sec, 00064 call.c_str(),sys_err.c_str(),level.c_str()); 00065 ) 00066 } 00067 00068 00069

Generated on Thu Feb 10 22:42:34 2005 for Distributed URL Classification Tool by doxygen 1.3.7