source: vscpl/src/hu/varadiistvan/scpl/Log.cc

Last change on this file was 35:091570efd33f, checked in by István Váradi <ivaradi@…>, 23 months ago

Simple logging interface.

File size: 3.0 KB
Line 
1// Copyright (c) 2022 by István Váradi
2
3// This file is part of VSCPL, a simple cross-platform utility library
4
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are met:
7
8// 1. Redistributions of source code must retain the above copyright notice, this
9// list of conditions and the following disclaimer.
10// 2. Redistributions in binary form must reproduce the above copyright notice,
11// this list of conditions and the following disclaimer in the documentation
12// and/or other materials provided with the distribution.
13
14// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
15// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
16// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
17// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
18// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
19// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
20// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
21// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
23// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24
25// The views and conclusions contained in the software and documentation are those
26// of the authors and should not be interpreted as representing official policies,
27// either expressed or implied, of the FreeBSD Project.
28
29//------------------------------------------------------------------------------
30
31#include "Log.h"
32
33#include <cstdio>
34#include <cstdarg>
35
36//------------------------------------------------------------------------------
37
38using hu::varadiistvan::scpl::Log;
39
40//------------------------------------------------------------------------------
41
42namespace {
43
44//------------------------------------------------------------------------------
45
46std::function<void(const char*)> logFunction;
47
48//------------------------------------------------------------------------------
49
50} /* anonymous namespace */
51
52//------------------------------------------------------------------------------
53
54void Log::registerFunction(std::function<void(const char*)> fn)
55{
56 logFunction = fn;
57}
58
59//------------------------------------------------------------------------------
60
61void Log::log(const char* format, ...)
62{
63 if (logFunction) {
64 va_list ap;
65 va_start(ap, format);
66
67 char buf[256];
68 vsnprintf(buf, sizeof(buf), format, ap);
69
70 va_end(ap);
71
72 logFunction(buf);
73 } else {
74 va_list ap;
75 va_start(ap, format);
76
77 vprintf(format, ap);
78
79 va_end(ap);
80 }
81}
82
83//------------------------------------------------------------------------------
84//------------------------------------------------------------------------------
85
86// Local Variables:
87// mode: C++
88// c-basic-offset: 4
89// indent-tabs-mode: nil
90// End:
Note: See TracBrowser for help on using the repository browser.