aboutsummaryrefslogtreecommitdiffstats
path: root/common/format.go
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2016-10-18 16:18:07 +0800
committerPéter Szilágyi <peterke@gmail.com>2016-10-18 18:16:36 +0800
commit64500ab0fa68bd2c45e2f5459462faaaa675cb28 (patch)
tree930e67ae48d72a30032b7c9be179c5cc153b566f /common/format.go
parent6952fe3a5caf22ae76b7efb332b0d98ad02398de (diff)
downloaddexon-64500ab0fa68bd2c45e2f5459462faaaa675cb28.tar.gz
dexon-64500ab0fa68bd2c45e2f5459462faaaa675cb28.tar.zst
dexon-64500ab0fa68bd2c45e2f5459462faaaa675cb28.zip
common, core, eth/downloader: adjust import log formatting
Diffstat (limited to 'common/format.go')
-rw-r--r--common/format.go40
1 files changed, 40 insertions, 0 deletions
diff --git a/common/format.go b/common/format.go
new file mode 100644
index 000000000..119637d2e
--- /dev/null
+++ b/common/format.go
@@ -0,0 +1,40 @@
+// Copyright 2016 The go-ethereum Authors
+// This file is part of the go-ethereum library.
+//
+// The go-ethereum library is free software: you can redistribute it and/or modify
+// it under the terms of the GNU Lesser General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// The go-ethereum library 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 Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
+
+package common
+
+import (
+ "fmt"
+ "regexp"
+ "strings"
+ "time"
+)
+
+// PrettyDuration is a pretty printed version of a time.Duration value that cuts
+// the unnecessary precision off from the formatted textual representation.
+type PrettyDuration time.Duration
+
+var prettyDurationRe = regexp.MustCompile("\\.[0-9]+")
+
+// String implements the Stringer interface, allowing pretty printing of duration
+// values rounded to three decimals.
+func (d PrettyDuration) String() string {
+ label := fmt.Sprintf("%v", time.Duration(d))
+ if match := prettyDurationRe.FindString(label); len(match) > 4 {
+ label = strings.Replace(label, match, match[:4], 1)
+ }
+ return label
+}