diff options
| author | 2023-05-09 19:19:48 +0200 | |
|---|---|---|
| committer | 2023-05-09 18:19:48 +0100 | |
| commit | 6392e00653d3b81062ef60d8ae2fa2621873533f (patch) | |
| tree | 761d0ff445c2c6a85020cecdc58f92ae1cf78513 /vendor/google.golang.org/grpc/internal/grpclog | |
| parent | [bugfix] Don't try to get user when serializing local instance account (#1757) (diff) | |
| download | gotosocial-6392e00653d3b81062ef60d8ae2fa2621873533f.tar.xz | |
feat: initial tracing support (#1623)
Diffstat (limited to 'vendor/google.golang.org/grpc/internal/grpclog')
| -rw-r--r-- | vendor/google.golang.org/grpc/internal/grpclog/grpclog.go | 126 | ||||
| -rw-r--r-- | vendor/google.golang.org/grpc/internal/grpclog/prefixLogger.go | 81 | 
2 files changed, 207 insertions, 0 deletions
| diff --git a/vendor/google.golang.org/grpc/internal/grpclog/grpclog.go b/vendor/google.golang.org/grpc/internal/grpclog/grpclog.go new file mode 100644 index 000000000..b68e26a36 --- /dev/null +++ b/vendor/google.golang.org/grpc/internal/grpclog/grpclog.go @@ -0,0 +1,126 @@ +/* + * + * Copyright 2020 gRPC authors. + * + * 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 grpclog (internal) defines depth logging for grpc. +package grpclog + +import ( +	"os" +) + +// Logger is the logger used for the non-depth log functions. +var Logger LoggerV2 + +// DepthLogger is the logger used for the depth log functions. +var DepthLogger DepthLoggerV2 + +// InfoDepth logs to the INFO log at the specified depth. +func InfoDepth(depth int, args ...interface{}) { +	if DepthLogger != nil { +		DepthLogger.InfoDepth(depth, args...) +	} else { +		Logger.Infoln(args...) +	} +} + +// WarningDepth logs to the WARNING log at the specified depth. +func WarningDepth(depth int, args ...interface{}) { +	if DepthLogger != nil { +		DepthLogger.WarningDepth(depth, args...) +	} else { +		Logger.Warningln(args...) +	} +} + +// ErrorDepth logs to the ERROR log at the specified depth. +func ErrorDepth(depth int, args ...interface{}) { +	if DepthLogger != nil { +		DepthLogger.ErrorDepth(depth, args...) +	} else { +		Logger.Errorln(args...) +	} +} + +// FatalDepth logs to the FATAL log at the specified depth. +func FatalDepth(depth int, args ...interface{}) { +	if DepthLogger != nil { +		DepthLogger.FatalDepth(depth, args...) +	} else { +		Logger.Fatalln(args...) +	} +	os.Exit(1) +} + +// LoggerV2 does underlying logging work for grpclog. +// This is a copy of the LoggerV2 defined in the external grpclog package. It +// is defined here to avoid a circular dependency. +type LoggerV2 interface { +	// Info logs to INFO log. Arguments are handled in the manner of fmt.Print. +	Info(args ...interface{}) +	// Infoln logs to INFO log. Arguments are handled in the manner of fmt.Println. +	Infoln(args ...interface{}) +	// Infof logs to INFO log. Arguments are handled in the manner of fmt.Printf. +	Infof(format string, args ...interface{}) +	// Warning logs to WARNING log. Arguments are handled in the manner of fmt.Print. +	Warning(args ...interface{}) +	// Warningln logs to WARNING log. Arguments are handled in the manner of fmt.Println. +	Warningln(args ...interface{}) +	// Warningf logs to WARNING log. Arguments are handled in the manner of fmt.Printf. +	Warningf(format string, args ...interface{}) +	// Error logs to ERROR log. Arguments are handled in the manner of fmt.Print. +	Error(args ...interface{}) +	// Errorln logs to ERROR log. Arguments are handled in the manner of fmt.Println. +	Errorln(args ...interface{}) +	// Errorf logs to ERROR log. Arguments are handled in the manner of fmt.Printf. +	Errorf(format string, args ...interface{}) +	// Fatal logs to ERROR log. Arguments are handled in the manner of fmt.Print. +	// gRPC ensures that all Fatal logs will exit with os.Exit(1). +	// Implementations may also call os.Exit() with a non-zero exit code. +	Fatal(args ...interface{}) +	// Fatalln logs to ERROR log. Arguments are handled in the manner of fmt.Println. +	// gRPC ensures that all Fatal logs will exit with os.Exit(1). +	// Implementations may also call os.Exit() with a non-zero exit code. +	Fatalln(args ...interface{}) +	// Fatalf logs to ERROR log. Arguments are handled in the manner of fmt.Printf. +	// gRPC ensures that all Fatal logs will exit with os.Exit(1). +	// Implementations may also call os.Exit() with a non-zero exit code. +	Fatalf(format string, args ...interface{}) +	// V reports whether verbosity level l is at least the requested verbose level. +	V(l int) bool +} + +// DepthLoggerV2 logs at a specified call frame. If a LoggerV2 also implements +// DepthLoggerV2, the below functions will be called with the appropriate stack +// depth set for trivial functions the logger may ignore. +// This is a copy of the DepthLoggerV2 defined in the external grpclog package. +// It is defined here to avoid a circular dependency. +// +// # Experimental +// +// Notice: This type is EXPERIMENTAL and may be changed or removed in a +// later release. +type DepthLoggerV2 interface { +	// InfoDepth logs to INFO log at the specified depth. Arguments are handled in the manner of fmt.Println. +	InfoDepth(depth int, args ...interface{}) +	// WarningDepth logs to WARNING log at the specified depth. Arguments are handled in the manner of fmt.Println. +	WarningDepth(depth int, args ...interface{}) +	// ErrorDepth logs to ERROR log at the specified depth. Arguments are handled in the manner of fmt.Println. +	ErrorDepth(depth int, args ...interface{}) +	// FatalDepth logs to FATAL log at the specified depth. Arguments are handled in the manner of fmt.Println. +	FatalDepth(depth int, args ...interface{}) +} diff --git a/vendor/google.golang.org/grpc/internal/grpclog/prefixLogger.go b/vendor/google.golang.org/grpc/internal/grpclog/prefixLogger.go new file mode 100644 index 000000000..82af70e96 --- /dev/null +++ b/vendor/google.golang.org/grpc/internal/grpclog/prefixLogger.go @@ -0,0 +1,81 @@ +/* + * + * Copyright 2020 gRPC authors. + * + * 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 grpclog + +import ( +	"fmt" +) + +// PrefixLogger does logging with a prefix. +// +// Logging method on a nil logs without any prefix. +type PrefixLogger struct { +	logger DepthLoggerV2 +	prefix string +} + +// Infof does info logging. +func (pl *PrefixLogger) Infof(format string, args ...interface{}) { +	if pl != nil { +		// Handle nil, so the tests can pass in a nil logger. +		format = pl.prefix + format +		pl.logger.InfoDepth(1, fmt.Sprintf(format, args...)) +		return +	} +	InfoDepth(1, fmt.Sprintf(format, args...)) +} + +// Warningf does warning logging. +func (pl *PrefixLogger) Warningf(format string, args ...interface{}) { +	if pl != nil { +		format = pl.prefix + format +		pl.logger.WarningDepth(1, fmt.Sprintf(format, args...)) +		return +	} +	WarningDepth(1, fmt.Sprintf(format, args...)) +} + +// Errorf does error logging. +func (pl *PrefixLogger) Errorf(format string, args ...interface{}) { +	if pl != nil { +		format = pl.prefix + format +		pl.logger.ErrorDepth(1, fmt.Sprintf(format, args...)) +		return +	} +	ErrorDepth(1, fmt.Sprintf(format, args...)) +} + +// Debugf does info logging at verbose level 2. +func (pl *PrefixLogger) Debugf(format string, args ...interface{}) { +	if !Logger.V(2) { +		return +	} +	if pl != nil { +		// Handle nil, so the tests can pass in a nil logger. +		format = pl.prefix + format +		pl.logger.InfoDepth(1, fmt.Sprintf(format, args...)) +		return +	} +	InfoDepth(1, fmt.Sprintf(format, args...)) +} + +// NewPrefixLogger creates a prefix logger with the given prefix. +func NewPrefixLogger(logger DepthLoggerV2, prefix string) *PrefixLogger { +	return &PrefixLogger{logger: logger, prefix: prefix} +} | 
