-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathdebug.go
More file actions
116 lines (91 loc) · 2.28 KB
/
debug.go
File metadata and controls
116 lines (91 loc) · 2.28 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// Copyright 2017-2019 Dale Farnsworth. All rights reserved.
// Dale Farnsworth
// 1007 W Mendoza Ave
// Mesa, AZ 85210
// USA
//
// dale@farnsworth.org
// This file is part of Editcp.
//
// Editcp is free software: you can redistribute it and/or modify
// it under the terms of version 3 of the GNU General Public License
// as published by the Free Software Foundation.
//
// Editcp is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Editcp. If not, see <http://www.gnu.org/licenses/>.
package l
import (
"fmt"
"log"
"os"
"path/filepath"
"regexp"
"runtime/debug"
"strings"
)
var StderrFilename = filepath.Join(os.TempDir(), "editcp_stderr.txt")
var PreviousPanicFilename = filepath.Join(os.TempDir(), "editcp_crash.txt")
var logBuffer strings.Builder
func init() {
log.SetOutput(&logBuffer)
log.SetFlags(log.Lshortfile)
}
func DisplayLog() {
if logBuffer.Len() > 0 {
display("Debugging Information", logBuffer.String())
}
logBuffer.Reset()
}
func P(v ...interface{}) {
str := " "
for _, arg := range v {
str += fmt.Sprintf("%#v ", arg)
}
log.Output(2, str)
DisplayLog()
}
func PrintStack() {
log.Println(string(debug.Stack()))
DisplayLog()
}
func Warningf(s string, v ...interface{}) {
log.Output(2, fmt.Sprintf(s, v...))
log.Println(string(debug.Stack()))
log.Output(2, fmt.Sprintf(s, v...))
DisplayLog()
}
func Warning(v ...interface{}) {
log.Output(2, fmt.Sprintln(v...))
log.Println(string(debug.Stack()))
log.Output(2, fmt.Sprintln(v...))
DisplayLog()
}
func Fatalf(s string, v ...interface{}) {
Warningf(s, v...)
os.Exit(1)
}
func Fatal(v ...interface{}) {
Warning(v...)
os.Exit(1)
}
func Print(v ...interface{}) {
display("Debugging Information", fmt.Sprint(v...))
}
func Println(v ...interface{}) {
display("Debugging Information", fmt.Sprintln(v...))
}
func Printf(s string, v ...interface{}) {
display("Debugging Information", fmt.Sprintf(s, v...))
}
func Match(re string, s string) bool {
match, err := regexp.MatchString(re, s)
if err != nil {
Fatal("Match", err)
}
return match
}