Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
张磊
/
FileStorageBeego
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Builds
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
9c6775c2
authored
2015-06-13 00:25:21 +0800
by
astaxie
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
log default use synchro, and support async
1 parent
4d70b22f
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
2 deletions
logs/log.go
logs/log.go
View file @
9c6775c
...
...
@@ -92,6 +92,7 @@ type BeeLogger struct {
level
int
enableFuncCallDepth
bool
loggerFuncCallDepth
int
asynchronous
bool
msg
chan
*
logMsg
outputs
map
[
string
]
LoggerInterface
}
...
...
@@ -110,7 +111,11 @@ func NewLogger(channellen int64) *BeeLogger {
bl
.
loggerFuncCallDepth
=
2
bl
.
msg
=
make
(
chan
*
logMsg
,
channellen
)
bl
.
outputs
=
make
(
map
[
string
]
LoggerInterface
)
//bl.SetLogger("console", "") // default output to console
return
bl
}
func
(
bl
*
BeeLogger
)
Async
()
*
BeeLogger
{
bl
.
asynchronous
=
true
go
bl
.
startLogger
()
return
bl
}
...
...
@@ -164,7 +169,17 @@ func (bl *BeeLogger) writerMsg(loglevel int, msg string) error {
}
else
{
lm
.
msg
=
msg
}
bl
.
msg
<-
lm
if
bl
.
asynchronous
{
bl
.
msg
<-
lm
}
else
{
for
name
,
l
:=
range
bl
.
outputs
{
err
:=
l
.
WriteMsg
(
lm
.
msg
,
lm
.
level
)
if
err
!=
nil
{
fmt
.
Println
(
"unable to WriteMsg to adapter:"
,
name
,
err
)
return
err
}
}
}
return
nil
}
...
...
Write
Preview
Styling with
Markdown
is supported
Attach a file
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 post a comment