summaryrefslogtreecommitdiff
path: root/src/mongo/gotools/vendor/src/github.com/spacemonkeygo/spacelog/logger.go
blob: ae1734b278099e1dea293b08a0123f1d9cfe5020 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
// Copyright (C) 2014 Space Monkey, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//   http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package spacelog

import (
	"sync"
	"sync/atomic"
)

// Logger is the basic type that allows for logging. A logger has an associated
// name, given to it during construction, either through a logger collection,
// GetLogger, GetLoggerNamed, or another Logger's Scope method. A logger also
// has an associated level and handler, typically configured through the logger
// collection to which it belongs.
type Logger struct {
	level      LogLevel
	name       string
	collection *LoggerCollection

	handler_mtx sync.RWMutex
	handler     Handler
}

// Scope returns a new Logger with the same level and handler, using the
// receiver Logger's name as a prefix.
func (l *Logger) Scope(name string) *Logger {
	return l.collection.getLogger(l.name+"."+name, l.getLevel(),
		l.getHandler())
}

func (l *Logger) setLevel(level LogLevel) {
	atomic.StoreInt32((*int32)(&l.level), int32(level))
}

func (l *Logger) getLevel() LogLevel {
	return LogLevel(atomic.LoadInt32((*int32)(&l.level)))
}

func (l *Logger) setHandler(handler Handler) {
	l.handler_mtx.Lock()
	defer l.handler_mtx.Unlock()
	l.handler = handler
}

func (l *Logger) getHandler() Handler {
	l.handler_mtx.RLock()
	defer l.handler_mtx.RUnlock()
	return l.handler
}