Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
S
spdlog
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
spdlog
Commits
8dbf88f9
Commit
8dbf88f9
authored
Mar 30, 2016
by
gabime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor example.cpp
parent
ff2398b6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
60 additions
and
57 deletions
+60
-57
example.cpp
example/example.cpp
+60
-57
No files found.
example/example.cpp
View file @
8dbf88f9
...
@@ -6,15 +6,18 @@
...
@@ -6,15 +6,18 @@
// spdlog usage example
// spdlog usage example
//
//
#include "spdlog/spdlog.h"
#include "spdlog/spdlog.h"
#include "spdlog/sinks/ansicolor_sink.h"
#include <cstdlib> // EXIT_FAILURE
#include <cstdlib> // EXIT_FAILURE
#include <iostream>
#include <iostream>
#include <memory>
#include <memory>
void
async_example
();
void
syslog_example
();
void
color_example
();
namespace
spd
=
spdlog
;
int
main
(
int
,
char
*
[])
int
main
(
int
,
char
*
[])
{
{
namespace
spd
=
spdlog
;
try
try
{
{
//Create console, multithreaded logger
//Create console, multithreaded logger
...
@@ -33,85 +36,43 @@ int main(int, char*[])
...
@@ -33,85 +36,43 @@ int main(int, char*[])
console
->
info
(
"{:>30}"
,
"right aligned"
);
console
->
info
(
"{:>30}"
,
"right aligned"
);
console
->
info
(
"{:^30}"
,
"centered"
);
console
->
info
(
"{:^30}"
,
"centered"
);
//
spd
::
get
(
"console"
)
->
info
(
"loggers can be retrieved from a global registry using the spdlog::get(logger_name) function"
);
// Runtime log levels
// Runtime log levels
//
spd
::
set_level
(
spd
::
level
::
info
);
//Set global log level to info
spd
::
set_level
(
spd
::
level
::
info
);
//Set global log level to info
console
->
debug
(
"This message shold not be displayed!"
);
console
->
debug
(
"This message shold not be displayed!"
);
console
->
set_level
(
spd
::
level
::
debug
);
// Set specific logger's log level
console
->
set_level
(
spd
::
level
::
debug
);
// Set specific logger's log level
console
->
debug
(
"
Now it shoul
d.."
);
console
->
debug
(
"
This message shold be displaye
d.."
);
//
// Create a file rotating logger with 5mb size max and 3 rotated files
// Create a file rotating logger with 5mb size max and 3 rotated files
//
auto
file_logger
=
spd
::
rotating_logger_mt
(
"file_logger"
,
"logs/mylogfile"
,
1048576
*
5
,
3
);
auto
file_logger
=
spd
::
rotating_logger_mt
(
"file_logger"
,
"logs/mylogfile"
,
1048576
*
5
,
3
);
for
(
int
i
=
0
;
i
<
10
;
++
i
)
for
(
int
i
=
0
;
i
<
10
;
++
i
)
file_logger
->
info
(
"{} * {} equals {:>10}"
,
i
,
i
,
i
*
i
);
file_logger
->
info
(
"{} * {} equals {:>10}"
,
i
,
i
,
i
*
i
);
//
// Create a daily logger - a new file is created every day on 2:30am
// Create a daily logger - a new file is created every day on 2:30am
//
auto
daily_logger
=
spd
::
daily_logger_mt
(
"daily_logger"
,
"logs/daily"
,
2
,
30
);
auto
daily_logger
=
spd
::
daily_logger_mt
(
"daily_logger"
,
"logs/daily"
,
2
,
30
);
//
// Customize msg format for all messages
// Customize msg format for all messages
//
spd
::
set_pattern
(
"*** [%H:%M:%S %z] [thread %t] %v ***"
);
spd
::
set_pattern
(
"*** [%H:%M:%S %z] [thread %t] %v ***"
);
file_logger
->
info
(
"This is another message with custom format"
);
file_logger
->
info
(
"This is another message with custom format"
);
spd
::
get
(
"console"
)
->
info
(
"loggers can be retrieved from a global registry using the spdlog::get(logger_name) function"
);
//
// Compile time debug or trace macros.
// Compile time debug or trace macros.
// Enabled #ifdef SPDLOG_DEBUG_ON or #ifdef SPDLOG_TRACE_ON
// Enabled #ifdef SPDLOG_DEBUG_ON or #ifdef SPDLOG_TRACE_ON
//
SPDLOG_TRACE
(
console
,
"Enabled only #ifdef SPDLOG_TRACE_ON..{} ,{}"
,
1
,
3.23
);
SPDLOG_TRACE
(
console
,
"Enabled only #ifdef SPDLOG_TRACE_ON..{} ,{}"
,
1
,
3.23
);
SPDLOG_DEBUG
(
console
,
"Enabled only #ifdef SPDLOG_DEBUG_ON.. {} ,{}"
,
1
,
3.23
);
SPDLOG_DEBUG
(
console
,
"Enabled only #ifdef SPDLOG_DEBUG_ON.. {} ,{}"
,
1
,
3.23
);
//
// Asynchronous logging is very fast..
// Asynchronous logging is very fast..
// Just call spdlog::set_async_mode(q_size) and all created loggers from now on will be asynchronous..
// Just call spdlog::set_async_mode(q_size) and all created loggers from now on will be asynchronous..
//
async_example
();
size_t
q_size
=
1048576
;
//queue size must be power of 2
spdlog
::
set_async_mode
(
q_size
);
// syslog example. linux/osx only..
auto
async_file
=
spd
::
daily_logger_st
(
"async_file_logger"
,
"logs/async_log.txt"
);
syslog_example
();
for
(
int
i
=
0
;
i
<
100
;
++
i
)
async_file
->
info
(
"Async message #{}"
,
i
);
//
// syslog example. linux only..
//
#ifdef __linux__
std
::
string
ident
=
"spdlog-example"
;
auto
syslog_logger
=
spd
::
syslog_logger
(
"syslog"
,
ident
,
LOG_PID
);
syslog_logger
->
warn
(
"This is warning that will end up in syslog. This is Linux only!"
);
#endif
//
// terminal color example (works under linux/osx. windows: only if ansi.sys is loaded)
// ANSI color logging (OS X and Linux. Windows only if ansi.sys is loaded.)
color_example
();
//
// Release and close all loggers
// Create a sink to add colors to.
auto
console_out
=
spdlog
::
sinks
::
stderr_sink_st
::
instance
();
auto
color_sink
=
std
::
make_shared
<
spd
::
sinks
::
ansicolor_sink
>
(
console_out
);
// wraps around another sink
auto
color_logger
=
spd
::
details
::
registry
::
instance
().
create
(
"Color"
,
color_sink
);
color_logger
->
set_level
(
spd
::
level
::
trace
);
color_sink
->
setColor
(
spd
::
level
::
info
,
color_sink
->
bold
+
color_sink
->
green
);
color_logger
->
info
(
"Testing color logger..."
);
color_logger
->
trace
(
"Trace"
);
color_logger
->
debug
(
"Debug"
);
color_logger
->
info
(
"Info"
);
color_logger
->
notice
(
"Notice"
);
color_logger
->
warn
(
"Warning"
);
color_logger
->
error
(
"Error"
);
color_logger
->
critical
(
"Critical"
);
color_logger
->
alert
(
"Alert"
);
color_logger
->
emerg
(
"Emergency"
);
//
//Release and close all loggers
//
spdlog
::
drop_all
();
spdlog
::
drop_all
();
}
}
...
@@ -124,6 +85,48 @@ int main(int, char*[])
...
@@ -124,6 +85,48 @@ int main(int, char*[])
}
}
void
async_example
()
{
size_t
q_size
=
4096
;
//queue size must be power of 2
spdlog
::
set_async_mode
(
q_size
);
auto
async_file
=
spd
::
daily_logger_st
(
"async_file_logger"
,
"logs/async_log.txt"
);
for
(
int
i
=
0
;
i
<
100
;
++
i
)
async_file
->
info
(
"Async message #{}"
,
i
);
}
//syslog example (linux/osx only)
void
syslog_example
()
{
#if defined (__linux__) || defined(__APPLE__)
std
::
string
ident
=
"spdlog-example"
;
auto
syslog_logger
=
spd
::
syslog_logger
(
"syslog"
,
ident
,
LOG_PID
);
syslog_logger
->
warn
(
"This is warning that will end up in syslog. This is Linux only!"
);
#endif
}
// terminal color example (works under linux/osx. windows: only if ansi.sys is loaded)
#include "spdlog/sinks/ansicolor_sink.h"
void
color_example
()
{
// Create a sink to add colors to.
auto
console_out
=
spdlog
::
sinks
::
stderr_sink_st
::
instance
();
auto
color_sink
=
std
::
make_shared
<
spd
::
sinks
::
ansicolor_sink
>
(
console_out
);
// wraps around another sink
auto
color_logger
=
spd
::
details
::
registry
::
instance
().
create
(
"Color"
,
color_sink
);
color_logger
->
set_level
(
spd
::
level
::
trace
);
color_sink
->
setColor
(
spd
::
level
::
info
,
color_sink
->
bold
+
color_sink
->
green
);
color_logger
->
info
(
"Testing color logger..."
);
color_logger
->
trace
(
"Trace"
);
color_logger
->
debug
(
"Debug"
);
color_logger
->
info
(
"Info"
);
color_logger
->
notice
(
"Notice"
);
color_logger
->
warn
(
"Warning"
);
color_logger
->
error
(
"Error"
);
color_logger
->
critical
(
"Critical"
);
color_logger
->
alert
(
"Alert"
);
color_logger
->
emerg
(
"Emergency"
);
}
// Example of user defined class with operator<<
// Example of user defined class with operator<<
class
some_class
{};
class
some_class
{};
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
some_class
&
)
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
some_class
&
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment