Update hcsshim tag to v0.10.0-rc.9
Signed-off-by: Kirtana Ashok <kiashok@microsoft.com>
This commit is contained in:
		
							
								
								
									
										8
									
								
								vendor/github.com/sirupsen/logrus/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								vendor/github.com/sirupsen/logrus/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -9,7 +9,7 @@ the last thing you want from your Logging library (again...).
 | 
			
		||||
 | 
			
		||||
This does not mean Logrus is dead. Logrus will continue to be maintained for
 | 
			
		||||
security, (backwards compatible) bug fixes, and performance (where we are
 | 
			
		||||
limited by the interface). 
 | 
			
		||||
limited by the interface).
 | 
			
		||||
 | 
			
		||||
I believe Logrus' biggest contribution is to have played a part in today's
 | 
			
		||||
widespread use of structured logging in Golang. There doesn't seem to be a
 | 
			
		||||
@@ -43,7 +43,7 @@ plain text):
 | 
			
		||||
With `log.SetFormatter(&log.JSONFormatter{})`, for easy parsing by logstash
 | 
			
		||||
or Splunk:
 | 
			
		||||
 | 
			
		||||
```json
 | 
			
		||||
```text
 | 
			
		||||
{"animal":"walrus","level":"info","msg":"A group of walrus emerges from the
 | 
			
		||||
ocean","size":10,"time":"2014-03-10 19:57:38.562264131 -0400 EDT"}
 | 
			
		||||
 | 
			
		||||
@@ -99,7 +99,7 @@ time="2015-03-26T01:27:38-04:00" level=fatal method=github.com/sirupsen/arcticcr
 | 
			
		||||
```
 | 
			
		||||
Note that this does add measurable overhead - the cost will depend on the version of Go, but is
 | 
			
		||||
between 20 and 40% in recent tests with 1.6 and 1.7.  You can validate this in your
 | 
			
		||||
environment via benchmarks: 
 | 
			
		||||
environment via benchmarks:
 | 
			
		||||
```
 | 
			
		||||
go test -bench=.*CallerTracing
 | 
			
		||||
```
 | 
			
		||||
@@ -317,6 +317,8 @@ log.SetLevel(log.InfoLevel)
 | 
			
		||||
It may be useful to set `log.Level = logrus.DebugLevel` in a debug or verbose
 | 
			
		||||
environment if your application has that.
 | 
			
		||||
 | 
			
		||||
Note: If you want different log levels for global (`log.SetLevel(...)`) and syslog logging, please check the [syslog hook README](hooks/syslog/README.md#different-log-levels-for-local-and-remote-logging).
 | 
			
		||||
 | 
			
		||||
#### Entries
 | 
			
		||||
 | 
			
		||||
Besides the fields added with `WithField` or `WithFields` some fields are
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										36
									
								
								vendor/github.com/sirupsen/logrus/writer.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										36
									
								
								vendor/github.com/sirupsen/logrus/writer.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -4,6 +4,7 @@ import (
 | 
			
		||||
	"bufio"
 | 
			
		||||
	"io"
 | 
			
		||||
	"runtime"
 | 
			
		||||
	"strings"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Writer at INFO level. See WriterLevel for details.
 | 
			
		||||
@@ -20,15 +21,18 @@ func (logger *Logger) WriterLevel(level Level) *io.PipeWriter {
 | 
			
		||||
	return NewEntry(logger).WriterLevel(level)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Writer returns an io.Writer that writes to the logger at the info log level
 | 
			
		||||
func (entry *Entry) Writer() *io.PipeWriter {
 | 
			
		||||
	return entry.WriterLevel(InfoLevel)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// WriterLevel returns an io.Writer that writes to the logger at the given log level
 | 
			
		||||
func (entry *Entry) WriterLevel(level Level) *io.PipeWriter {
 | 
			
		||||
	reader, writer := io.Pipe()
 | 
			
		||||
 | 
			
		||||
	var printFunc func(args ...interface{})
 | 
			
		||||
 | 
			
		||||
	// Determine which log function to use based on the specified log level
 | 
			
		||||
	switch level {
 | 
			
		||||
	case TraceLevel:
 | 
			
		||||
		printFunc = entry.Trace
 | 
			
		||||
@@ -48,23 +52,51 @@ func (entry *Entry) WriterLevel(level Level) *io.PipeWriter {
 | 
			
		||||
		printFunc = entry.Print
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Start a new goroutine to scan the input and write it to the logger using the specified print function.
 | 
			
		||||
	// It splits the input into chunks of up to 64KB to avoid buffer overflows.
 | 
			
		||||
	go entry.writerScanner(reader, printFunc)
 | 
			
		||||
 | 
			
		||||
	// Set a finalizer function to close the writer when it is garbage collected
 | 
			
		||||
	runtime.SetFinalizer(writer, writerFinalizer)
 | 
			
		||||
 | 
			
		||||
	return writer
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// writerScanner scans the input from the reader and writes it to the logger
 | 
			
		||||
func (entry *Entry) writerScanner(reader *io.PipeReader, printFunc func(args ...interface{})) {
 | 
			
		||||
	scanner := bufio.NewScanner(reader)
 | 
			
		||||
	for scanner.Scan() {
 | 
			
		||||
		printFunc(scanner.Text())
 | 
			
		||||
 | 
			
		||||
	// Set the buffer size to the maximum token size to avoid buffer overflows
 | 
			
		||||
	scanner.Buffer(make([]byte, bufio.MaxScanTokenSize), bufio.MaxScanTokenSize)
 | 
			
		||||
 | 
			
		||||
	// Define a split function to split the input into chunks of up to 64KB
 | 
			
		||||
	chunkSize := bufio.MaxScanTokenSize // 64KB
 | 
			
		||||
	splitFunc := func(data []byte, atEOF bool) (int, []byte, error) {
 | 
			
		||||
		if len(data) >= chunkSize {
 | 
			
		||||
			return chunkSize, data[:chunkSize], nil
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		return bufio.ScanLines(data, atEOF)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Use the custom split function to split the input
 | 
			
		||||
	scanner.Split(splitFunc)
 | 
			
		||||
 | 
			
		||||
	// Scan the input and write it to the logger using the specified print function
 | 
			
		||||
	for scanner.Scan() {
 | 
			
		||||
		printFunc(strings.TrimRight(scanner.Text(), "\r\n"))
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// If there was an error while scanning the input, log an error
 | 
			
		||||
	if err := scanner.Err(); err != nil {
 | 
			
		||||
		entry.Errorf("Error while reading from Writer: %s", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Close the reader when we are done
 | 
			
		||||
	reader.Close()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// WriterFinalizer is a finalizer function that closes then given writer when it is garbage collected
 | 
			
		||||
func writerFinalizer(writer *io.PipeWriter) {
 | 
			
		||||
	writer.Close()
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user