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
6991857a
Commit
6991857a
authored
May 09, 2015
by
gabime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added SPDLOG_NO_REGISTRY_MUTEX option to tweakme.h
parent
9cad840a
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
29 additions
and
17 deletions
+29
-17
registry.h
include/spdlog/details/registry.h
+23
-17
tweakme.h
include/spdlog/tweakme.h
+6
-0
No files found.
include/spdlog/details/registry.h
View file @
6991857a
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
#include <unordered_map>
#include <unordered_map>
#include <functional>
#include <functional>
#include "./null_mutex.h"
#include "../logger.h"
#include "../logger.h"
#include "../async_logger.h"
#include "../async_logger.h"
#include "../common.h"
#include "../common.h"
...
@@ -41,20 +42,20 @@ namespace spdlog
...
@@ -41,20 +42,20 @@ namespace spdlog
{
{
namespace
details
namespace
details
{
{
class
registry
template
<
class
Mutex
>
class
registry_t
{
{
public
:
public
:
void
register_logger
(
std
::
shared_ptr
<
logger
>
logger
)
void
register_logger
(
std
::
shared_ptr
<
logger
>
logger
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
register_logger_impl
(
logger
);
register_logger_impl
(
logger
);
}
}
std
::
shared_ptr
<
logger
>
get
(
const
std
::
string
&
logger_name
)
std
::
shared_ptr
<
logger
>
get
(
const
std
::
string
&
logger_name
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
auto
found
=
_loggers
.
find
(
logger_name
);
auto
found
=
_loggers
.
find
(
logger_name
);
return
found
==
_loggers
.
end
()
?
nullptr
:
found
->
second
;
return
found
==
_loggers
.
end
()
?
nullptr
:
found
->
second
;
}
}
...
@@ -65,7 +66,7 @@ public:
...
@@ -65,7 +66,7 @@ public:
std
::
shared_ptr
<
logger
>
new_logger
;
std
::
shared_ptr
<
logger
>
new_logger
;
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
if
(
_async_mode
)
if
(
_async_mode
)
...
@@ -83,13 +84,13 @@ public:
...
@@ -83,13 +84,13 @@ public:
void
drop
(
const
std
::
string
&
logger_name
)
void
drop
(
const
std
::
string
&
logger_name
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_loggers
.
erase
(
logger_name
);
_loggers
.
erase
(
logger_name
);
}
}
void
drop_all
()
void
drop_all
()
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_loggers
.
clear
();
_loggers
.
clear
();
}
}
std
::
shared_ptr
<
logger
>
create
(
const
std
::
string
&
logger_name
,
sinks_init_list
sinks
)
std
::
shared_ptr
<
logger
>
create
(
const
std
::
string
&
logger_name
,
sinks_init_list
sinks
)
...
@@ -105,7 +106,7 @@ public:
...
@@ -105,7 +106,7 @@ public:
void
formatter
(
formatter_ptr
f
)
void
formatter
(
formatter_ptr
f
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_formatter
=
f
;
_formatter
=
f
;
for
(
auto
&
l
:
_loggers
)
for
(
auto
&
l
:
_loggers
)
l
.
second
->
set_formatter
(
_formatter
);
l
.
second
->
set_formatter
(
_formatter
);
...
@@ -113,7 +114,7 @@ public:
...
@@ -113,7 +114,7 @@ public:
void
set_pattern
(
const
std
::
string
&
pattern
)
void
set_pattern
(
const
std
::
string
&
pattern
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_formatter
=
std
::
make_shared
<
pattern_formatter
>
(
pattern
);
_formatter
=
std
::
make_shared
<
pattern_formatter
>
(
pattern
);
for
(
auto
&
l
:
_loggers
)
for
(
auto
&
l
:
_loggers
)
l
.
second
->
set_formatter
(
_formatter
);
l
.
second
->
set_formatter
(
_formatter
);
...
@@ -121,7 +122,7 @@ public:
...
@@ -121,7 +122,7 @@ public:
void
set_level
(
level
::
level_enum
log_level
)
void
set_level
(
level
::
level_enum
log_level
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
for
(
auto
&
l
:
_loggers
)
for
(
auto
&
l
:
_loggers
)
l
.
second
->
set_level
(
log_level
);
l
.
second
->
set_level
(
log_level
);
_level
=
log_level
;
_level
=
log_level
;
...
@@ -129,7 +130,7 @@ public:
...
@@ -129,7 +130,7 @@ public:
void
set_async_mode
(
size_t
q_size
,
const
async_overflow_policy
overflow_policy
,
const
std
::
function
<
void
()
>&
worker_warmup_cb
)
void
set_async_mode
(
size_t
q_size
,
const
async_overflow_policy
overflow_policy
,
const
std
::
function
<
void
()
>&
worker_warmup_cb
)
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_async_mode
=
true
;
_async_mode
=
true
;
_async_q_size
=
q_size
;
_async_q_size
=
q_size
;
_overflow_policy
=
overflow_policy
;
_overflow_policy
=
overflow_policy
;
...
@@ -138,13 +139,13 @@ public:
...
@@ -138,13 +139,13 @@ public:
void
set_sync_mode
()
void
set_sync_mode
()
{
{
std
::
lock_guard
<
std
::
m
utex
>
lock
(
_mutex
);
std
::
lock_guard
<
M
utex
>
lock
(
_mutex
);
_async_mode
=
false
;
_async_mode
=
false
;
}
}
static
registry
&
instance
()
static
registry
_t
<
Mutex
>
&
instance
()
{
{
static
registry
s_instance
;
static
registry
_t
<
Mutex
>
s_instance
;
return
s_instance
;
return
s_instance
;
}
}
...
@@ -156,10 +157,10 @@ private:
...
@@ -156,10 +157,10 @@ private:
throw
spdlog_ex
(
"logger with name "
+
logger_name
+
" already exists"
);
throw
spdlog_ex
(
"logger with name "
+
logger_name
+
" already exists"
);
_loggers
[
logger
->
name
()]
=
logger
;
_loggers
[
logger
->
name
()]
=
logger
;
}
}
registry
()
=
default
;
registry
_t
<
Mutex
>
()
=
default
;
registry
(
const
registry
&
)
=
delete
;
registry
_t
<
Mutex
>
(
const
registry_t
<
Mutex
>
&
)
=
delete
;
registry
&
operator
=
(
const
registry
&
)
=
delete
;
registry
_t
<
Mutex
>&
operator
=
(
const
registry_t
<
Mutex
>
&
)
=
delete
;
std
::
m
utex
_mutex
;
M
utex
_mutex
;
std
::
unordered_map
<
std
::
string
,
std
::
shared_ptr
<
logger
>>
_loggers
;
std
::
unordered_map
<
std
::
string
,
std
::
shared_ptr
<
logger
>>
_loggers
;
formatter_ptr
_formatter
;
formatter_ptr
_formatter
;
level
::
level_enum
_level
=
level
::
info
;
level
::
level_enum
_level
=
level
::
info
;
...
@@ -168,5 +169,10 @@ private:
...
@@ -168,5 +169,10 @@ private:
async_overflow_policy
_overflow_policy
=
async_overflow_policy
::
block_retry
;
async_overflow_policy
_overflow_policy
=
async_overflow_policy
::
block_retry
;
std
::
function
<
void
()
>
_worker_warmup_cb
=
nullptr
;
std
::
function
<
void
()
>
_worker_warmup_cb
=
nullptr
;
};
};
#ifndef SPDLOG_NO_REGISTRY_MUTEX
typedef
registry_t
<
std
::
mutex
>
registry
;
#else
typedef
registry_t
<
spdlog
::
details
::
null_mutex
>
registry
;
#endif
}
}
}
}
include/spdlog/tweakme.h
View file @
6991857a
...
@@ -65,3 +65,8 @@
...
@@ -65,3 +65,8 @@
// #define SPDLOG_TRACE_ON
// #define SPDLOG_TRACE_ON
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
// Uncomment to avoid locking in the registry operations (spdlog::get(), spdlog::drop() spdlog::register())
// Use only if your code never modifes concurrently the registry
// Note that upon creating a logger the registry is modified by spdlog..
// #define SPDLOG_NO_REGISTRY_MUTEX
\ No newline at end of file
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