| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- // Copyright 2013, Cong Ding. All rights reserved.
- //
- // 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.
- //
- // author: Cong Ding <dinggnu@gmail.com>
- package logging
- import (
- "errors"
- "fmt"
- "strings"
- )
- // pre-defined formats
- const (
- BasicFormat = "%s [%6s] %30s - %s\n name,levelname,time,message"
- RichFormat = "%s [%6s] %d %30s - %d - %s:%s:%d - %s\n name, levelname, seqid, time, thread, filename, funcname, lineno, message"
- )
- // genLog generates log string from the format setting.
- func (logger *Logger) genLog(level Level, message string) string {
- fs := make([]interface{}, len(logger.recordArgs))
- r := new(record)
- r.message = message
- r.level = level
- for k, v := range logger.recordArgs {
- fs[k] = fields[v](logger, r)
- }
- return fmt.Sprintf(logger.recordFormat, fs...)
- }
- // parseFormat checks the legality of format and parses it to recordFormat and recordArgs
- func (logger *Logger) parseFormat(format string) error {
- logger.runtime = false
- fts := strings.Split(format, "\n")
- if len(fts) != 2 {
- return errors.New("logging format error")
- }
- logger.recordFormat = fts[0]
- logger.recordArgs = strings.Split(fts[1], ",")
- for k, v := range logger.recordArgs {
- tv := strings.TrimSpace(v)
- _, ok := fields[tv]
- if ok == false {
- return errors.New("logging format error")
- }
- logger.recordArgs[k] = tv
- logger.runtime = logger.runtime || runtimeFields[tv]
- }
- return nil
- }
|