summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@lukeshu.com>2018-06-03 21:00:55 -0400
committerLuke Shumaker <lukeshu@lukeshu.com>2018-06-03 21:00:55 -0400
commit8caefed85ae0253a1ea5b95a5a0ad25146b5d6d7 (patch)
tree96f9859d91469e6ab2781ea0314d4d048f96b1cc
parent4b93b2a2355d1d74254b8910b7b1b19d5840012a (diff)
cow-dedupe: Use sd_notify as appropriate
-rw-r--r--.gitmodules6
-rw-r--r--go/src/cow-dedupe/dedupe.go15
m---------go/src/git.lukeshu.com/go/libsystemd0
m---------go/src/golang.org/x/sys0
-rw-r--r--go/src/lib/statusline/daemonstatus.go30
-rw-r--r--go/src/lib/statusline/tee.go21
6 files changed, 71 insertions, 1 deletions
diff --git a/.gitmodules b/.gitmodules
new file mode 100644
index 0000000..f0ba993
--- /dev/null
+++ b/.gitmodules
@@ -0,0 +1,6 @@
+[submodule "go/src/git.lukeshu.com/go/libsystemd"]
+ path = go/src/git.lukeshu.com/go/libsystemd
+ url = https://git.lukeshu.com/go/libsystemd
+[submodule "go/src/golang.org/x/sys"]
+ path = go/src/golang.org/x/sys
+ url = https://go.googlesource.com/sys
diff --git a/go/src/cow-dedupe/dedupe.go b/go/src/cow-dedupe/dedupe.go
index 84f03f8..4913f3d 100644
--- a/go/src/cow-dedupe/dedupe.go
+++ b/go/src/cow-dedupe/dedupe.go
@@ -28,7 +28,20 @@ func errhandle(err error) {
}
func myStatusLine() statusline.StatusLine {
- return statusline.StopWatch(statusline.RateLimit(statusline.New(os.Stderr), time.Second/2), time.Second)
+ var outs []statusline.StatusLine
+ if C.isatty(2) != 0 {
+ outs = append(outs, statusline.StopWatch(statusline.RateLimit(statusline.New(os.Stderr), time.Second/2), time.Second))
+ }
+ if os.Getenv("NOTIFY_SOCKET") != "" {
+ outs = append(outs, statusline.RateLimit(statusline.DaemonStatus(0), time.Second/2))
+ }
+ if len(outs) == 0 {
+ outs = append(outs, statusline.New(os.Stderr))
+ }
+ if len(outs) == 1 {
+ return outs[0]
+ }
+ return statusline.Tee(outs...)
}
func getFiemaps(paths []string) map[string][]string {
diff --git a/go/src/git.lukeshu.com/go/libsystemd b/go/src/git.lukeshu.com/go/libsystemd
new file mode 160000
+Subproject 0a43955333992153412a6b8a99b2825c3d0a74c
diff --git a/go/src/golang.org/x/sys b/go/src/golang.org/x/sys
new file mode 160000
+Subproject c11f84a56e43e20a78cee75a7c034031ecf57d1
diff --git a/go/src/lib/statusline/daemonstatus.go b/go/src/lib/statusline/daemonstatus.go
new file mode 100644
index 0000000..49599a7
--- /dev/null
+++ b/go/src/lib/statusline/daemonstatus.go
@@ -0,0 +1,30 @@
+package statusline
+
+import (
+ "git.lukeshu.com/go/libsystemd/sd_daemon"
+)
+
+type daemonStatus struct {
+ pid int
+}
+
+func DaemonStatus(pid int) StatusLine {
+ return &daemonStatus{pid: pid}
+}
+
+func (sl *daemonStatus) Put(line string) {
+ sd_daemon.Notification{
+ PID: sl.pid,
+ State: "STATUS=" + line,
+ }.Send(false)
+}
+
+func (sl *daemonStatus) End(keep bool) {
+ if keep {
+ return
+ }
+ sd_daemon.Notification{
+ PID: sl.pid,
+ State: "STATUS=",
+ }.Send(false)
+}
diff --git a/go/src/lib/statusline/tee.go b/go/src/lib/statusline/tee.go
new file mode 100644
index 0000000..a762a01
--- /dev/null
+++ b/go/src/lib/statusline/tee.go
@@ -0,0 +1,21 @@
+package statusline
+
+type tee struct {
+ outs []StatusLine
+}
+
+func Tee(outs ...StatusLine) StatusLine {
+ return &tee{outs: outs}
+}
+
+func (sl *tee) Put(line string) {
+ for _, out := range sl.outs {
+ out.Put(line)
+ }
+}
+
+func (sl *tee) End(keep bool) {
+ for _, out := range sl.outs {
+ out.End(keep)
+ }
+}