Documentation ¶
Index ¶
- Variables
- func Add(pathBase string) (subsystem string)
- func GetLoc(skip int, subsystem string) (output string)
- func Item(m *metadata) (t types.Type)
- func New(args Desc) *metadata
- func NewBool(m *metadata) (b *_bool)
- func NewDuration(m *metadata) (b *_dur)
- func NewFloat(m *metadata) (b *_flt)
- func NewInt(m *metadata) (b *_int)
- func NewList(m *metadata) (b *_lst)
- func NewString(m *metadata) (b *_str)
- func NewUint(m *metadata) (b *_uin)
- func SetLogLevel(l LogLevel)
- func SetTimeStampFormat(format string)
- func Version() string
- type Chk
- type Configs
- type Desc
- type LevelPrinter
- type LevelSpec
- type LogLevel
- type Logger
- type Printc
- type Printf
- type Println
- type Prints
Constants ¶
This section is empty.
Variables ¶
var ( // App is the name of the application App = " main" // AllSubsystems stores all of the package subsystem names found in the current // application AllSubsystems []string )
var ( // URL is the git URL for the repository URL = "gitlab.com/cybriqsystems/proc" // GitRef is the gitref, as in refs/heads/branchname GitRef = "refs/heads/master" // GitCommit is the commit hash of the current HEAD GitCommit = "3e89ca9e96f6321acaa5dc7d7e931732f39a71a1" // BuildTime stores the time when the current binary was built BuildTime = "2022-07-09T17:33:57+03:00" // SemVer lists the (latest) git tag on the build SemVer = "v0.0.17" // PathBase is the path base returned from runtime caller PathBase = "/home/davidvennik/src/gitlab.com/cybriqsystems/proc/" // Major is the major number from the tag Major = 0 // Minor is the minor number from the tag Minor = 0 // Patch is the patch version number from the tag Patch = 17 )
var LevelSpecs = map[LogLevel]LevelSpec{ Off: gLS(Off, 0, 0, 0), Fatal: gLS(Fatal, 255, 0, 0), Error: gLS(Error, 255, 128, 0), Check: gLS(Check, 255, 255, 0), Warn: gLS(Warn, 255, 255, 0), Info: gLS(Info, 0, 255, 0), Debug: gLS(Debug, 0, 128, 255), Trace: gLS(Trace, 128, 0, 255), }
LevelSpecs specifies the id, string name and color-printing function
var LvlStr = map[LogLevel]string{ Off: "off ", Fatal: "fatal", Error: "error", Warn: "warn ", Info: "info ", Check: "check", Debug: "debug", Trace: "trace", }
var Types = []string{
"bool",
"duration",
"float",
"int",
"list",
"string",
"uint",
}
Functions ¶
func Add ¶ added in v0.0.3
Add adds a subsystem to the list of known subsystems and returns the string so it is nice and neat in the package logg.go file
func GetLoc ¶ added in v0.0.3
GetLoc calls runtime.Caller and formats as expected by source code editors for terminal hyperlinks
Regular expressions and the substitution texts to make these clickable in Tilix and other RE hyperlink configurable terminal emulators:
This matches the shortened paths generated in this command and printed at the very beginning of the line as this logger prints:
^((([\/a-zA-Z@0-9-_.]+/)+([a-zA-Z@0-9-_.]+)):([0-9]+)) /usr/local/bin/goland --line $5 $GOPATH/src/github.com/p9c/matrjoska/$2
I have used a shell variable there but tilix doesn't expand them, so put your GOPATH in manually, and obviously change the repo subpath.
func New ¶ added in v0.0.8
func New(args Desc) *metadata
New allows you to create a metadata with a sparsely filled, named field struct literal.
name, type, group and tags all will be canonicalized to lower case. Type must be valid or function will panic
func NewDuration ¶ added in v0.0.8
func NewDuration(m *metadata) (b *_dur)
func SetLogLevel ¶ added in v0.0.5
func SetLogLevel(l LogLevel)
func SetTimeStampFormat ¶ added in v0.0.5
func SetTimeStampFormat(format string)
Types ¶
type Desc ¶ added in v0.0.8
type Desc struct {
Name, Type, Group, Description, Documentation, Default string
Tags, Aliases []string
}
Desc is the named field form of metadata for generating a metadata
type LevelPrinter ¶
type LevelPrinter struct { Ln Println // F prints like fmt.Println surrounded by log details F Printf // S uses spew.dump to show the content of a variable S Prints // C accepts a function so that the extra computation can be avoided if // it is not being viewed C Printc // Chk is a shortcut for printing if there is an error, or returning // true Chk Chk }
LevelPrinter defines a set of terminal printing primitives that output with extra data, time, level, and code location
type Logger ¶
type Logger struct {
F, E, W, I, D, T LevelPrinter
}
type Printc ¶
type Printc func(closure func() string)
Printc accepts a function so that the extra computation can be avoided if it is not being viewed
type Printf ¶
type Printf func(format string, a ...interface{})
Printf prints like fmt.Println surrounded by log details