From b6b9bb3d35c71501a4a543fba1215736f2ddb6e1 Mon Sep 17 00:00:00 2001 From: electricbubble Date: Sun, 25 Apr 2021 01:24:32 +0800 Subject: [PATCH] fix: [SyslogRelay] adjust the logic of stop --- lockdown_test.go | 1 + syslogrelay.go | 20 ++++++++++++++------ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/lockdown_test.go b/lockdown_test.go index f5a899b..a267839 100644 --- a/lockdown_test.go +++ b/lockdown_test.go @@ -53,6 +53,7 @@ func Test_lockdown_SyslogRelayService(t *testing.T) { if err != nil { t.Fatal(err) } + syslogRelaySrv.Stop() lines := syslogRelaySrv.Lines() diff --git a/syslogrelay.go b/syslogrelay.go index 03680bc..414c8db 100644 --- a/syslogrelay.go +++ b/syslogrelay.go @@ -12,8 +12,9 @@ var _ SyslogRelay = (*syslogRelay)(nil) func newSyslogRelay(client *libimobiledevice.SyslogRelayClient) *syslogRelay { r := &syslogRelay{ - client: client, - stop: make(chan bool), + client: client, + stop: make(chan bool), + isReading: false, } r.reader = bufio.NewReader(r.client.InnerConn().RawConn()) return r @@ -22,18 +23,23 @@ func newSyslogRelay(client *libimobiledevice.SyslogRelayClient) *syslogRelay { type syslogRelay struct { client *libimobiledevice.SyslogRelayClient - reader *bufio.Reader - stop chan bool + reader *bufio.Reader + stop chan bool + isReading bool } func (r *syslogRelay) Lines() <-chan string { out := make(chan string) + r.isReading = true go func() { + defer func() { + close(out) + r.isReading = false + }() for { select { case <-r.stop: - close(out) return default: bs, err := r.readLine() @@ -54,7 +60,9 @@ func (r *syslogRelay) Lines() <-chan string { } func (r *syslogRelay) Stop() { - r.stop <- true + if r.isReading { + r.stop <- true + } } func (r *syslogRelay) readLine() ([]byte, error) {