From f44d6e1a111154b70aaeac9ffe38beaee2cc5dd7 Mon Sep 17 00:00:00 2001 From: Mikhail Osipov Date: Tue, 21 Apr 2020 14:54:27 +0300 Subject: rename auto socket to defer --- pkg/server/socket/defer.go | 80 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 pkg/server/socket/defer.go (limited to 'pkg/server/socket/defer.go') diff --git a/pkg/server/socket/defer.go b/pkg/server/socket/defer.go new file mode 100644 index 0000000..bfb2157 --- /dev/null +++ b/pkg/server/socket/defer.go @@ -0,0 +1,80 @@ +package socket + +import ( + "tunnel/pkg/server/env" + "tunnel/pkg/server/queue" +) + +type deferSocket struct { + S +} + +type deferChannel struct { + s *deferSocket + c chan Channel + e env.Env +} + +func newDeferSocket(proto, addr string) (S, error) { + s, err := newDialSocket(proto, addr) + if err != nil { + return s, err + } + + return &deferSocket{s}, nil +} + +func (s *deferSocket) Open(env env.Env) (Channel, error) { + c := &deferChannel{ + s: s, + c: make(chan Channel), + e: env, + } + + return c, nil +} + +func (c *deferChannel) String() string { + return "defer" +} + +func (c *deferChannel) Send(wq queue.Q) error { + if x := <-c.c; x == nil { + return nil + } else { + return x.Send(wq) + } +} + +func (c *deferChannel) Recv(rq queue.Q) error { + b := <-rq + if b == nil { + close(c.c) + return nil + } + + x, err := c.s.S.Open(c.e) + if err != nil { + close(c.c) + return err + } + + c.c <- x + + q := queue.New() + + go func() { + q <- b + queue.Copy(rq, q) + close(q) + }() + + defer q.Dry() + + return x.Recv(q) +} + +/* TODO */ +func (c *deferChannel) Close() error { + return nil +} -- cgit v1.2.3-70-g09d2