Only allow this language: ((n|s)!(w|e)!(u|d)!;)+ for directions.
[UnsignedByte.git] / src / Sockets / StdoutLog.cpp
blob9e95b5fa4752081829a12262d0f5bf6e5b919cf2
1 /** \file StdoutLog.cpp
2 ** \date 2004-06-01
3 ** \author grymse@alhem.net
4 **/
5 /*
6 Copyright (C) 2004-2007 Anders Hedstrom
8 This library is made available under the terms of the GNU GPL.
10 If you would like to use this library in a closed-source application,
11 a separate license agreement is available. For information about
12 the closed-source license agreement for the C++ sockets library,
13 please visit http://www.alhem.net/Sockets/license.html and/or
14 email license@alhem.net.
16 This program is free software; you can redistribute it and/or
17 modify it under the terms of the GNU General Public License
18 as published by the Free Software Foundation; either version 2
19 of the License, or (at your option) any later version.
21 This program is distributed in the hope that it will be useful,
22 but WITHOUT ANY WARRANTY; without even the implied warranty of
23 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24 GNU General Public License for more details.
26 You should have received a copy of the GNU General Public License
27 along with this program; if not, write to the Free Software
28 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
30 #ifdef _WIN32
31 #ifndef __MINGW32__
32 #pragma warning(disable:4786)
33 #endif
34 #endif
35 #include "ISocketHandler.h"
36 #include "Socket.h"
37 #include "StdoutLog.h"
39 #ifdef SOCKETS_NAMESPACE
40 namespace SOCKETS_NAMESPACE {
41 #endif
46 void StdoutLog::error(ISocketHandler *,Socket *sock,const std::string& call,int err,const std::string& sys_err,loglevel_t lvl)
48 time_t t = time(NULL);
49 struct tm tp;
50 #ifdef _WIN32
51 memcpy(&tp, localtime(&t), sizeof(tp));
52 #else
53 localtime_r(&t, &tp);
54 #endif
55 std::string level;
57 switch (lvl)
59 case LOG_LEVEL_WARNING:
60 level = "Warning";
61 break;
62 case LOG_LEVEL_ERROR:
63 level = "Error";
64 break;
65 case LOG_LEVEL_FATAL:
66 level = "Fatal";
67 break;
68 case LOG_LEVEL_INFO:
69 level = "Info";
70 break;
72 if (sock)
74 printf("%d-%02d-%02d %02d:%02d:%02d :: fd %d :: %s: %d %s (%s)\n",
75 tp.tm_year + 1900,
76 tp.tm_mon + 1,
77 tp.tm_mday,
78 tp.tm_hour,tp.tm_min,tp.tm_sec,
79 sock -> GetSocket(),
80 call.c_str(),err,sys_err.c_str(),level.c_str());
82 else
84 printf("%d-%02d-%02d %02d:%02d:%02d :: %s: %d %s (%s)\n",
85 tp.tm_year + 1900,
86 tp.tm_mon + 1,
87 tp.tm_mday,
88 tp.tm_hour,tp.tm_min,tp.tm_sec,
89 call.c_str(),err,sys_err.c_str(),level.c_str());
94 #ifdef SOCKETS_NAMESPACE
96 #endif