libtrbase  1.0.2
Web server and task management solution.
i_logger.c
Go to the documentation of this file.
1 /**
2  * \file
3  *
4  * \author Georg Hopp
5  *
6  * \copyright
7  * Copyright © 2014 Georg Hopp
8  *
9  * This program is free software: you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation, either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program. If not, see <http://www.gnu.org/licenses/>.
21  */
22 
23 #include <stdlib.h>
24 #include <stdio.h>
25 #include <stdarg.h>
26 
27 #include "trbase.h"
28 
29 TR_CREATE_INTERFACE(TR_Logger, 1);
30 
31 void
33  void * _object,
34  TR_logger_level level,
35  const char * const fmt,
36  ...) {
37  TR_Logger object = _object;
38 
39  if (level >= object->min_level) {
40  char * msg = NULL;
41  size_t msg_size = 0;
42  va_list params;
43 
44  va_start(params, fmt);
45  msg_size = vsnprintf(NULL, msg_size, fmt, params);
46  va_end(params);
47 
48  msg = TR_malloc(msg_size + 1);
49 
50  va_start(params, fmt);
51  vsnprintf(msg, msg_size + 1, fmt, params);
52  va_end(params);
53 
54  TR_CALL(_object, TR_Logger, log, level, msg);
55 
56  TR_MEM_FREE(msg);
57  }
58 }
59 
60 // vim: set ts=4 sw=4:
#define TR_CALL(object, _iface, method,...)
Definition: class.h:256
TR_logger_level
Definition: logger.h:30
void TR_loggerLog(void *_object, TR_logger_level level, const char *const fmt,...)
Definition: i_logger.c:32
void * TR_malloc(size_t)
Definition: memory.c:178
#define TR_MEM_FREE(seg)
Definition: memory.h:26
TR_CREATE_INTERFACE(TR_Logger, 1)