Bayonne2 / Common C++ 2 Framework
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
slog.h
Go to the documentation of this file.
1 // Copyright (C) 1999-2005 Open Source Telecom Corporation.
2 // Copyright (C) 2006-2010 David Sugar, Tycho Softworks.
3 //
4 // This program is free software; you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation; either version 2 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 //
18 // As a special exception, you may use this file as part of a free software
19 // library without restriction. Specifically, if other files instantiate
20 // templates or use macros or inline functions from this file, or you compile
21 // this file and link it with other files to produce an executable, this
22 // file does not by itself cause the resulting executable to be covered by
23 // the GNU General Public License. This exception does not however
24 // invalidate any other reasons why the executable file might be covered by
25 // the GNU General Public License.
26 //
27 // This exception applies only to the code released under the name GNU
28 // Common C++. If you copy code from other releases into a copy of GNU
29 // Common C++, as the General Public License permits, the exception does
30 // not apply to the code that you add in this way. To avoid misleading
31 // anyone as to the status of such modified files, you must delete
32 // this exception notice from them.
33 //
34 // If you write modifications of your own for GNU Common C++, it is your choice
35 // whether to permit this exception to apply to your modifications.
36 // If you do not wish that, delete this exception notice.
37 //
38 
44 #ifndef CCXX_SLOG_H_
45 #define CCXX_SLOG_H_
46 
47 #ifndef CCXX_MISSING_H_
48 #include <cc++/missing.h>
49 #endif
50 
51 #ifndef CCXX_THREAD_H_
52 #include <cc++/thread.h>
53 #endif
54 
55 #ifndef HAVE_SYSLOG_H
56 #include <cstdio>
57 #endif
58 
59 #ifdef CCXX_NAMESPACES
60 namespace ost {
61 #endif
62 
104 class __EXPORT Slog : protected std::streambuf, public std::ostream
105 {
106 public:
107  typedef enum Class {
120  classLocal7
121  } Class;
122 
123  typedef enum Level {
124  levelEmergency = 1,
131  levelDebug
132  } Level;
133 
134 private:
135 #ifndef HAVE_SYSLOG_H
137  FILE *syslog;
138 #endif
139  int priority;
141  bool _enable;
143 
144  ThreadImpl *getPriv(void);
145 
146 protected:
152  int overflow(int c);
153 
154 public:
162  Slog(void);
163 
164  virtual ~Slog(void);
165 
166  void close(void);
167 
173  void open(const char *ident, Class grp = classUser);
174 
181  Slog &operator()(const char *ident, Class grp = classUser,
182  Level level = levelError);
183 
189  Slog &operator()(Level level, Class grp = classDefault);
190 
194  Slog &operator()(void);
195 
196 #ifdef HAVE_SNPRINTF
197 
202  void error(const char *format, ...);
203 
209  void warn(const char *format, ...);
210 
216  void debug(const char *format, ...);
217 
223  void emerg(const char *format, ...);
224 
230  void alert(const char *format, ...);
231 
237  void critical(const char *format, ...);
238 
244  void notice(const char *format, ...);
245 
251  void info(const char *format, ...);
252 #endif
253 
258  inline void level(Level enable)
259  {_level = enable;};
260 
266  inline void clogEnable(bool f=true)
267  {_clogEnable = f;};
268 
269  inline Slog &warn(void)
270  {return operator()(Slog::levelWarning);};
271 
272  inline Slog &error(void)
273  {return operator()(Slog::levelError);};
274 
275  inline Slog &debug(void)
276  {return operator()(Slog::levelDebug);};
277 
278  inline Slog &emerg(void)
279  {return operator()(Slog::levelEmergency);};
280 
281  inline Slog &alert(void)
282  {return operator()(Slog::levelAlert);};
283 
284  inline Slog &critical(void)
285  {return operator()(Slog::levelCritical);};
286 
287  inline Slog &notice(void)
288  {return operator()(Slog::levelNotice);};
289 
290  inline Slog &info(void)
291  {return operator()(Slog::levelInfo);};
292 
293 };
294 
295 //#ifdef CYGWIN_IMPORTS
296 //extern __declspec(dllimport) Slog slog;
297 //#else
298 extern __EXPORT Slog slog;
299 //#endif
300 
301 #ifdef CCXX_NAMESPACES
302 }
303 #endif
304 
305 #endif
306 
Class
Definition: slog.h:107
__EXPORT AppLog & debug(AppLog &sl)
Manipulator for debug level.
Definition: applog.h:525
__EXPORT AppLog & error(AppLog &sl)
Manipulator for error level.
Definition: applog.h:541
FILE * syslog
Definition: slog.h:137
void clogEnable(bool f=true)
Enables or disables the echoing of the messages to clog in addition to the syslog daemon...
Definition: slog.h:266
__EXPORT AppLog & info(AppLog &sl)
Manipulator for info level.
Definition: applog.h:581
substitute functions which may be missing in target platform libc.
The Mutex class is used to protect a section of code so that at any given time only a single thread c...
Definition: thread.h:186
Slog & info(void)
Definition: slog.h:290
Slog & emerg(void)
Definition: slog.h:278
Synchronization and threading services.
Level
Definition: slog.h:123
__EXPORT AppLog & emerg(AppLog &sl)
Manipulator for emerg level.
Definition: applog.h:549
Slog & notice(void)
Definition: slog.h:287
int priority
Definition: slog.h:139
Level _level
Definition: slog.h:140
__EXPORT AppLog & notice(AppLog &sl)
Manipulator for notice level.
Definition: applog.h:573
__EXPORT Slog slog
Mutex lock
Definition: slog.h:136
#define __EXPORT
Definition: audio2.h:51
__EXPORT AppLog & alert(AppLog &sl)
Manipulator for alert level.
Definition: applog.h:557
void level(Level enable)
Sets the logging level.
Definition: slog.h:258
The slog class is used to stream messages to the system's logging facility (syslogd).
Definition: slog.h:104
bool _enable
Definition: slog.h:141
bool _clogEnable
Definition: slog.h:142
Slog & error(void)
Definition: slog.h:272
Slog & alert(void)
Definition: slog.h:281
__EXPORT AppLog & warn(AppLog &sl)
Manipulator for warn level.
Definition: applog.h:533
Slog & critical(void)
Definition: slog.h:284
Slog & warn(void)
Definition: slog.h:269
__EXPORT AppLog & critical(AppLog &sl)
Manipulator for critical level.
Definition: applog.h:565
Slog & debug(void)
Definition: slog.h:275