mirror of
https://github.com/restic/restic.git
synced 2025-01-01 04:36:52 +00:00
Install log buffer for global logs
This hides logged message from the net/http library and only shows them in case an error occurs.
This commit is contained in:
parent
c5ae5524ff
commit
0096eca7fe
1 changed files with 19 additions and 0 deletions
|
@ -1,7 +1,10 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"restic"
|
"restic"
|
||||||
"restic/debug"
|
"restic/debug"
|
||||||
|
@ -44,6 +47,14 @@ directories in an encrypted repository stored on different backends.
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var logBuffer = bytes.NewBuffer(nil)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
// install custom global logger into a buffer, if an error occurs
|
||||||
|
// we can show the logs
|
||||||
|
log.SetOutput(logBuffer)
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
debug.Log("main %#v", os.Args)
|
debug.Log("main %#v", os.Args)
|
||||||
err := cmdRoot.Execute()
|
err := cmdRoot.Execute()
|
||||||
|
@ -55,6 +66,14 @@ func main() {
|
||||||
fmt.Fprintf(os.Stderr, "%v\n", err)
|
fmt.Fprintf(os.Stderr, "%v\n", err)
|
||||||
case err != nil:
|
case err != nil:
|
||||||
fmt.Fprintf(os.Stderr, "%+v\n", err)
|
fmt.Fprintf(os.Stderr, "%+v\n", err)
|
||||||
|
|
||||||
|
if logBuffer.Len() > 0 {
|
||||||
|
fmt.Fprintf(os.Stderr, "also, the following messages were logged by a library:\n")
|
||||||
|
sc := bufio.NewScanner(logBuffer)
|
||||||
|
for sc.Scan() {
|
||||||
|
fmt.Fprintln(os.Stderr, sc.Text())
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var exitCode int
|
var exitCode int
|
||||||
|
|
Loading…
Reference in a new issue