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
1d6842f0
Commit
1d6842f0
authored
May 16, 2017
by
gabime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bugfix in color detection and astyle
parent
eb92cc35
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
46 additions
and
35 deletions
+46
-35
async_log_helper.h
include/spdlog/details/async_log_helper.h
+1
-1
logger_impl.h
include/spdlog/details/logger_impl.h
+0
-0
os.h
include/spdlog/details/os.h
+16
-7
logger.h
include/spdlog/logger.h
+0
-0
android_sink.h
include/spdlog/sinks/android_sink.h
+1
-1
ansicolor_sink.h
include/spdlog/sinks/ansicolor_sink.h
+28
-26
No files found.
include/spdlog/details/async_log_helper.h
View file @
1d6842f0
...
@@ -56,7 +56,7 @@ class async_log_helper
...
@@ -56,7 +56,7 @@ class async_log_helper
~
async_msg
()
=
default
;
~
async_msg
()
=
default
;
async_msg
(
async_msg
&&
other
)
SPDLOG_NOEXCEPT
:
async_msg
(
async_msg
&&
other
)
SPDLOG_NOEXCEPT
:
logger_name
(
std
::
move
(
other
.
logger_name
)),
logger_name
(
std
::
move
(
other
.
logger_name
)),
level
(
std
::
move
(
other
.
level
)),
level
(
std
::
move
(
other
.
level
)),
time
(
std
::
move
(
other
.
time
)),
time
(
std
::
move
(
other
.
time
)),
...
...
include/spdlog/details/logger_impl.h
View file @
1d6842f0
include/spdlog/details/os.h
View file @
1d6842f0
...
@@ -365,14 +365,19 @@ inline std::string filename_to_str(const filename_t& filename)
...
@@ -365,14 +365,19 @@ inline std::string filename_to_str(const filename_t& filename)
}
}
#endif
#endif
inline
std
::
string
errno_to_string
(
char
[
256
],
char
*
res
)
{
inline
std
::
string
errno_to_string
(
char
[
256
],
char
*
res
)
{
return
std
::
string
(
res
);
return
std
::
string
(
res
);
}
}
inline
std
::
string
errno_to_string
(
char
buf
[
256
],
int
res
)
{
inline
std
::
string
errno_to_string
(
char
buf
[
256
],
int
res
)
if
(
res
==
0
)
{
{
if
(
res
==
0
)
{
return
std
::
string
(
buf
);
return
std
::
string
(
buf
);
}
else
{
}
else
{
return
"Unknown error"
;
return
"Unknown error"
;
}
}
}
}
...
@@ -422,20 +427,24 @@ bool is_color_terminal()
...
@@ -422,20 +427,24 @@ bool is_color_terminal()
#ifdef _WIN32
#ifdef _WIN32
return
true
;
return
true
;
#else
#else
static
constexpr
const
char
*
Terms
[]
=
{
static
constexpr
const
char
*
Terms
[]
=
{
"ansi"
,
"color"
,
"console"
,
"cygwin"
,
"gnome"
,
"konsole"
,
"kterm"
,
"ansi"
,
"color"
,
"console"
,
"cygwin"
,
"gnome"
,
"konsole"
,
"kterm"
,
"linux"
,
"msys"
,
"putty"
,
"rxvt"
,
"screen"
,
"vt100"
,
"xterm"
"linux"
,
"msys"
,
"putty"
,
"rxvt"
,
"screen"
,
"vt100"
,
"xterm"
};
};
const
char
*
env_p
=
std
::
getenv
(
"TERM"
);
const
char
*
env_p
=
std
::
getenv
(
"TERM"
);
if
(
env_p
==
nullptr
)
{
if
(
env_p
==
nullptr
)
{
return
false
;
return
false
;
}
}
static
const
bool
result
=
std
::
any_of
(
static
const
bool
result
=
std
::
any_of
(
std
::
begin
(
Terms
),
std
::
end
(
Terms
),
[
&
](
const
char
*
term
)
{
std
::
begin
(
Terms
),
std
::
end
(
Terms
),
[
&
](
const
char
*
term
)
{
return
std
::
strstr
(
env_p
,
term
)
!=
nullptr
;
return
std
::
strstr
(
env_p
,
term
)
!=
nullptr
;
});
});
return
result
;
#endif
#endif
}
}
...
...
include/spdlog/logger.h
View file @
1d6842f0
include/spdlog/sinks/android_sink.h
View file @
1d6842f0
...
@@ -31,7 +31,7 @@ namespace sinks
...
@@ -31,7 +31,7 @@ namespace sinks
class
android_sink
:
public
sink
class
android_sink
:
public
sink
{
{
public
:
public
:
explicit
android_sink
(
const
std
::
string
&
tag
=
"spdlog"
,
bool
use_raw_msg
=
false
)
:
_tag
(
tag
),
_use_raw_msg
(
use_raw_msg
){}
explicit
android_sink
(
const
std
::
string
&
tag
=
"spdlog"
,
bool
use_raw_msg
=
false
)
:
_tag
(
tag
),
_use_raw_msg
(
use_raw_msg
)
{}
void
log
(
const
details
::
log_msg
&
msg
)
override
void
log
(
const
details
::
log_msg
&
msg
)
override
{
{
...
...
include/spdlog/sinks/ansicolor_sink.h
View file @
1d6842f0
...
@@ -14,17 +14,17 @@
...
@@ -14,17 +14,17 @@
namespace
spdlog
namespace
spdlog
{
{
namespace
sinks
namespace
sinks
{
{
/**
/**
* @brief The ansi_color_sink is a decorator around another sink and prefixes
* @brief The ansi_color_sink is a decorator around another sink and prefixes
* the output with an ANSI escape sequence color code depending on the severity
* the output with an ANSI escape sequence color code depending on the severity
* of the message.
* of the message.
*/
*/
class
ansicolor_sink
SPDLOG_FINAL
:
public
sink
class
ansicolor_sink
SPDLOG_FINAL
:
public
sink
{
{
public
:
public
:
ansicolor_sink
(
sink_ptr
wrapped_sink
);
ansicolor_sink
(
sink_ptr
wrapped_sink
);
virtual
~
ansicolor_sink
();
virtual
~
ansicolor_sink
();
...
@@ -66,14 +66,14 @@ namespace spdlog
...
@@ -66,14 +66,14 @@ namespace spdlog
const
std
::
string
on_white
=
"
\033
[47m"
;
const
std
::
string
on_white
=
"
\033
[47m"
;
protected
:
protected
:
bool
is_color_terminal_
;
bool
is_color_terminal_
;
sink_ptr
sink_
;
sink_ptr
sink_
;
std
::
map
<
level
::
level_enum
,
std
::
string
>
colors_
;
std
::
map
<
level
::
level_enum
,
std
::
string
>
colors_
;
};
};
inline
ansicolor_sink
::
ansicolor_sink
(
sink_ptr
wrapped_sink
)
:
sink_
(
wrapped_sink
)
inline
ansicolor_sink
::
ansicolor_sink
(
sink_ptr
wrapped_sink
)
:
sink_
(
wrapped_sink
)
{
{
is_color_terminal_
=
details
::
os
::
is_color_terminal
();
is_color_terminal_
=
details
::
os
::
is_color_terminal
();
colors_
[
level
::
trace
]
=
cyan
;
colors_
[
level
::
trace
]
=
cyan
;
colors_
[
level
::
debug
]
=
cyan
;
colors_
[
level
::
debug
]
=
cyan
;
...
@@ -82,13 +82,14 @@ namespace spdlog
...
@@ -82,13 +82,14 @@ namespace spdlog
colors_
[
level
::
err
]
=
red
+
bold
;
colors_
[
level
::
err
]
=
red
+
bold
;
colors_
[
level
::
critical
]
=
bold
+
on_red
;
colors_
[
level
::
critical
]
=
bold
+
on_red
;
colors_
[
level
::
off
]
=
reset
;
colors_
[
level
::
off
]
=
reset
;
}
}
inline
void
ansicolor_sink
::
log
(
const
details
::
log_msg
&
msg
)
inline
void
ansicolor_sink
::
log
(
const
details
::
log_msg
&
msg
)
{
{
// Wrap the originally formatted message in color codes.
// Wrap the originally formatted message in color codes.
// If color is not supported in the terminal, log as is instead.
// If color is not supported in the terminal, log as is instead.
if
(
is_color_terminal_
)
{
if
(
is_color_terminal_
)
{
const
std
::
string
&
prefix
=
colors_
[
msg
.
level
];
const
std
::
string
&
prefix
=
colors_
[
msg
.
level
];
const
std
::
string
&
s
=
msg
.
formatted
.
str
();
const
std
::
string
&
s
=
msg
.
formatted
.
str
();
const
std
::
string
&
suffix
=
reset
;
const
std
::
string
&
suffix
=
reset
;
...
@@ -100,26 +101,27 @@ namespace spdlog
...
@@ -100,26 +101,27 @@ namespace spdlog
m
.
formatted
<<
prefix
<<
s
<<
suffix
;
m
.
formatted
<<
prefix
<<
s
<<
suffix
;
sink_
->
log
(
m
);
sink_
->
log
(
m
);
}
}
else
{
else
{
sink_
->
log
(
msg
);
sink_
->
log
(
msg
);
}
}
}
}
inline
void
ansicolor_sink
::
flush
()
inline
void
ansicolor_sink
::
flush
()
{
{
sink_
->
flush
();
sink_
->
flush
();
}
}
inline
void
ansicolor_sink
::
set_color
(
level
::
level_enum
color_level
,
const
std
::
string
&
color
)
inline
void
ansicolor_sink
::
set_color
(
level
::
level_enum
color_level
,
const
std
::
string
&
color
)
{
{
colors_
[
color_level
]
=
color
;
colors_
[
color_level
]
=
color
;
}
}
inline
ansicolor_sink
::~
ansicolor_sink
()
inline
ansicolor_sink
::~
ansicolor_sink
()
{
{
flush
();
flush
();
}
}
}
// namespace sinks
}
// namespace sinks
}
// namespace spdlog
}
// namespace spdlog
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