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
2a6ff3b6
Commit
2a6ff3b6
authored
Oct 09, 2014
by
gabi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added ostream_sink
parent
6c7793d4
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
78 additions
and
29 deletions
+78
-29
c11logtest.vcxproj
c11logtest/c11logtest/c11logtest.vcxproj
+4
-1
c11logtest.vcxproj.filters
c11logtest/c11logtest/c11logtest.vcxproj.filters
+16
-7
example.cpp
example/example.cpp
+13
-10
log_msg.h
include/c11log/details/log_msg.h
+2
-0
logger.h
include/c11log/logger.h
+7
-11
ostream_sink.h
include/c11log/sinks/ostream_sink.h
+36
-0
No files found.
c11logtest/c11logtest/c11logtest.vcxproj
View file @
2a6ff3b6
...
@@ -91,15 +91,18 @@
...
@@ -91,15 +91,18 @@
<ClInclude
Include=
"..\..\include\c11log\details\flush_helper.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\flush_helper.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\line_logger.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\line_logger.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\log_msg.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\log_msg.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\null_mutex.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\os.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\os.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\stack_buf.h"
/>
<ClInclude
Include=
"..\..\include\c11log\details\stack_buf.h"
/>
<ClInclude
Include=
"..\..\include\c11log\formatter.h"
/>
<ClInclude
Include=
"..\..\include\c11log\formatter.h"
/>
<ClInclude
Include=
"..\..\include\c11log\logger.h"
/>
<ClInclude
Include=
"..\..\include\c11log\logger.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\async_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\async_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\base_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\base_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\
console_sinks
.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\
ostream_sink
.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\file_sinks.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\file_sinks.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\isink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\null_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\null_sink.h"
/>
<ClInclude
Include=
"..\..\include\c11log\sinks\stdout_sinks.h"
/>
<ClInclude
Include=
"stdafx.h"
/>
<ClInclude
Include=
"stdafx.h"
/>
<ClInclude
Include=
"targetver.h"
/>
<ClInclude
Include=
"targetver.h"
/>
</ItemGroup>
</ItemGroup>
...
...
c11logtest/c11logtest/c11logtest.vcxproj.filters
View file @
2a6ff3b6
...
@@ -45,9 +45,6 @@
...
@@ -45,9 +45,6 @@
<ClInclude
Include=
"..\..\include\c11log\details\blocking_queue.h"
>
<ClInclude
Include=
"..\..\include\c11log\details\blocking_queue.h"
>
<Filter>
Header Files\c11log\details
</Filter>
<Filter>
Header Files\c11log\details
</Filter>
</ClInclude>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\details\factory.h"
>
<Filter>
Header Files\c11log\details
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\details\fast_oss.h"
>
<ClInclude
Include=
"..\..\include\c11log\details\fast_oss.h"
>
<Filter>
Header Files\c11log\details
</Filter>
<Filter>
Header Files\c11log\details
</Filter>
</ClInclude>
</ClInclude>
...
@@ -72,15 +69,27 @@
...
@@ -72,15 +69,27 @@
<ClInclude
Include=
"..\..\include\c11log\sinks\base_sink.h"
>
<ClInclude
Include=
"..\..\include\c11log\sinks\base_sink.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\console_sinks.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\file_sinks.h"
>
<ClInclude
Include=
"..\..\include\c11log\sinks\file_sinks.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\null_sink.h"
>
<ClInclude
Include=
"..\..\include\c11log\details\factory.h"
>
<Filter>
Header Files\c11log\details
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\isink.h"
>
<Filter>
Header Files
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\details\null_mutex.h"
>
<Filter>
Header Files\c11log\details
</Filter>
<Filter>
Header Files\c11log\details
</Filter>
</ClInclude>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\null_sink.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\ostream_sink.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
<ClInclude
Include=
"..\..\include\c11log\sinks\stdout_sinks.h"
>
<Filter>
Header Files\c11log\sinks
</Filter>
</ClInclude>
</ItemGroup>
</ItemGroup>
<ItemGroup>
<ItemGroup>
<ClCompile
Include=
"stdafx.cpp"
>
<ClCompile
Include=
"stdafx.cpp"
>
...
...
example/example.cpp
View file @
2a6ff3b6
// example.cpp : Simple logger example
// example.cpp : Simple logger example
//
//
#include <mutex>
#include "c11log/logger.h"
#include "c11log/logger.h"
#include "c11log/sinks/async_sink.h"
#include "c11log/sinks/async_sink.h"
#include "c11log/sinks/file_sinks.h"
#include "c11log/sinks/file_sinks.h"
#include "c11log/sinks/
console
_sinks.h"
#include "c11log/sinks/
stdout
_sinks.h"
#include "c11log/sinks/null_sink.h"
#include "c11log/sinks/null_sink.h"
#include "utils.h"
#include "utils.h"
...
@@ -14,33 +14,36 @@ using namespace std::chrono;
...
@@ -14,33 +14,36 @@ using namespace std::chrono;
using
namespace
c11log
;
using
namespace
c11log
;
using
namespace
utils
;
using
namespace
utils
;
int
main
(
int
argc
,
char
*
argv
[])
int
main
(
int
argc
,
char
*
argv
[])
{
{
const
unsigned
int
howmany
=
argc
<=
1
?
10000
:
atoi
(
argv
[
1
]);
logger
cout_logger
(
"example"
,
sinks
::
stdout_sink
());
const
unsigned
int
howmany
=
argc
<=
1
?
10000
:
atoi
(
argv
[
1
]);
logger
cout_logger
(
"example"
,
std
::
make_shared
<
sinks
::
stderr_sink_st
>
());
cout_logger
.
info
()
<<
"Hello logger"
;
cout_logger
.
info
()
<<
"Hello logger"
;
auto
nullsink
=
std
::
make_shared
<
sinks
::
null_sink
>
();
//auto nullsink = std::make_shared<sinks::null_sink<std::mutex>>();
//auto fsink = std::make_shared<sinks::rotating_file_sink>("log", "txt", 1024*1024*50 , 5, 0);
//auto nullsink = std::make_shared<sinks::null_sink<details::null_mutex>>();
auto
fsink
=
std
::
make_shared
<
sinks
::
rotating_file_sink_mt
>
(
"log"
,
"txt"
,
1024
*
1024
*
50
,
5
,
1
);
//auto as = std::make_shared<sinks::async_sink>(1000);
//auto as = std::make_shared<sinks::async_sink>(1000);
//as->add_sink(fsink);
//as->add_sink(fsink);
logger
my_logger
(
"my_logger"
,
null
sink
);
logger
my_logger
(
"my_logger"
,
f
sink
);
auto
start
=
system_clock
::
now
();
auto
start
=
system_clock
::
now
();
for
(
unsigned
int
i
=
1
;
i
<=
howmany
;
++
i
)
for
(
unsigned
int
i
=
1
;
i
<=
howmany
;
++
i
)
my_logger
.
info
()
<<
"Hello logger: msg #"
<<
i
;
my_logger
.
info
()
<<
"Hello logger: msg #"
<<
i
;
my_logger
.
info
(
"FFF"
);
//as->shutdown(std::chrono::milliseconds(15000));
//as->shutdown(std::chrono::milliseconds(15000));
auto
delta
=
system_clock
::
now
()
-
start
;
auto
delta
=
system_clock
::
now
()
-
start
;
auto
delta_d
=
duration_cast
<
duration
<
double
>>
(
delta
).
count
();
auto
delta_d
=
duration_cast
<
duration
<
double
>>
(
delta
).
count
();
cout
<<
"Total:"
<<
format
(
howmany
)
<<
endl
;
cout
<<
"Total:"
<<
format
(
howmany
)
<<
endl
;
cout
<<
"Delta:"
<<
format
(
delta_d
)
<<
endl
;
cout
<<
"Delta:"
<<
format
(
delta_d
)
<<
endl
;
cout
<<
"Rate:"
<<
format
(
howmany
/
delta_d
)
<<
"/sec"
<<
endl
;
cout
<<
"Rate:"
<<
format
(
howmany
/
delta_d
)
<<
"/sec"
<<
endl
;
return
0
;
return
0
;
}
}
include/c11log/details/log_msg.h
View file @
2a6ff3b6
#pragma once
#pragma once
#include "../common_types.h"
namespace
c11log
namespace
c11log
{
{
namespace
details
namespace
details
...
...
include/c11log/logger.h
View file @
2a6ff3b6
...
@@ -4,7 +4,6 @@
...
@@ -4,7 +4,6 @@
// Has log level and vector sinks which do the actual logging
// Has log level and vector sinks which do the actual logging
#include<vector>
#include<vector>
#include<memory>
#include<memory>
#include<mutex>
#include<atomic>
#include<atomic>
#include <sstream>
#include <sstream>
...
@@ -25,14 +24,11 @@ class line_logger;
...
@@ -25,14 +24,11 @@ class line_logger;
template
<
std
::
size_t
>
class
fast_buf
;
template
<
std
::
size_t
>
class
fast_buf
;
}
}
class
logger
class
logger
{
{
public
:
public
:
using
sink_ptr
=
std
::
shared_ptr
<
sinks
::
base_
sink
>
;
using
sink_ptr
=
std
::
shared_ptr
<
sinks
::
i
sink
>
;
using
sinks_vector_t
=
std
::
vector
<
sink_ptr
>
;
using
sinks_vector_t
=
std
::
vector
<
sink_ptr
>
;
using
sinks_init_list
=
std
::
initializer_list
<
sink_ptr
>
;
using
sinks_init_list
=
std
::
initializer_list
<
sink_ptr
>
;
...
@@ -84,20 +80,20 @@ private:
...
@@ -84,20 +80,20 @@ private:
};
};
std
::
shared_ptr
<
c11log
::
logger
>
create_logger
(
const
std
::
string
&
name
,
logger
::
sinks_init_list
sinks
,
logger
::
formatter_ptr
formatter
=
nullptr
);
//
std::shared_ptr<c11log::logger> create_logger(const std::string& name, logger::sinks_init_list sinks, logger::formatter_ptr formatter = nullptr);
std
::
shared_ptr
<
logger
>
get_logger
(
const
std
::
string
&
name
);
//
std::shared_ptr<logger> get_logger(const std::string& name);
}
}
//
//
// Logger i
nline i
mplementation
// Logger implementation
//
//
#include "details/line_logger.h"
#include "details/line_logger.h"
#include "details/factory.h"
#include "details/factory.h"
/*
inline std::shared_ptr<c11log::logger> c11log::create_logger(const std::string& name, logger::sinks_init_list sinks, logger::formatter_ptr formatter)
inline std::shared_ptr<c11log::logger> c11log::create_logger(const std::string& name, logger::sinks_init_list sinks, logger::formatter_ptr formatter)
{
{
return details::factory::instance().create_logger(name, sinks, std::move(formatter));
return details::factory::instance().create_logger(name, sinks, std::move(formatter));
...
@@ -105,7 +101,7 @@ inline std::shared_ptr<c11log::logger> c11log::create_logger(const std::string&
...
@@ -105,7 +101,7 @@ inline std::shared_ptr<c11log::logger> c11log::create_logger(const std::string&
inline std::shared_ptr<c11log::logger> c11log::get_logger(const std::string& name)
inline std::shared_ptr<c11log::logger> c11log::get_logger(const std::string& name)
{
{
return details::factory::instance().get_logger(name);
return details::factory::instance().get_logger(name);
}
}
*/
inline
c11log
::
logger
::
logger
(
const
std
::
string
&
name
,
sinks_init_list
sinks_list
,
formatter_ptr
f
)
:
inline
c11log
::
logger
::
logger
(
const
std
::
string
&
name
,
sinks_init_list
sinks_list
,
formatter_ptr
f
)
:
...
@@ -113,7 +109,7 @@ inline c11log::logger::logger(const std::string& name, sinks_init_list sinks_lis
...
@@ -113,7 +109,7 @@ inline c11log::logger::logger(const std::string& name, sinks_init_list sinks_lis
_formatter
(
std
::
move
(
f
)),
_formatter
(
std
::
move
(
f
)),
_sinks
(
sinks_list
)
_sinks
(
sinks_list
)
{
{
//Seems that vs2013 doesn
t support std::atomic member initialization, so its done here
//Seems that vs2013 doesn
't support std::atomic member initialization yet
_min_level
=
level
::
INFO
;
_min_level
=
level
::
INFO
;
if
(
!
_formatter
)
if
(
!
_formatter
)
_formatter
=
std
::
make_unique
<
formatters
::
default_formatter
>
();
_formatter
=
std
::
make_unique
<
formatters
::
default_formatter
>
();
...
...
include/c11log/sinks/ostream_sink.h
0 → 100644
View file @
2a6ff3b6
#pragma once
#include <iostream>
#include <mutex>
#include <memory>
#include "../details/null_mutex.h"
#include "base_sink.h"
namespace
c11log
{
namespace
sinks
{
template
<
class
Mutex
>
class
ostream_sink
:
public
base_sink
<
Mutex
>
{
public
:
explicit
ostream_sink
(
std
::
ostream
&
os
)
:
_ostream
(
os
)
{}
ostream_sink
(
const
ostream_sink
&
)
=
delete
;
ostream_sink
&
operator
=
(
const
ostream_sink
&
)
=
delete
;
virtual
~
ostream_sink
()
=
default
;
protected
:
virtual
void
_sink_it
(
const
details
::
log_msg
&
msg
)
override
{
_ostream
<<
msg
.
formatted
;
}
std
::
ostream
&
_ostream
;
};
typedef
ostream_sink
<
std
::
mutex
>
ostream_sink_mt
;
typedef
ostream_sink
<
details
::
null_mutex
>
ostream_sink_st
;
}
}
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