From 4ff46ad447c22346a4b636a51caff305fec7001b Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Mon, 18 Jul 2016 16:28:26 -0600 Subject: [PATCH] Refactor Server into TCPServer and UDPServer --- caddy.go | 37 +++++++++++++++++++++---------------- 1 file changed, 21 insertions(+), 16 deletions(-) diff --git a/caddy.go b/caddy.go index 49d29cec9..6517ab8ff 100644 --- a/caddy.go +++ b/caddy.go @@ -235,20 +235,9 @@ func listenerAddrEqual(ln net.Listener, addr string) bool { return false } -// Server is a type that can listen and serve. -// -// These methods must be implemented in pairs. If the server uses -// TCP, it should implement Listen() and Serve(). If it uses UDP -// or some other protocol, it should implement ListenPacket() and -// ServePacket(). If it uses both, all four methods should be -// implemented. Any unimplemented methods should be made as no-ops -// that simply return nil values. -// -// A Server must associate with exactly or one listeners and -// zero or one packetconns. -type Server interface { - // TCP methods - +// TCPServer is a type that can listen and serve connections. +// A TCPServer must associate with exactly or one net.Listeners. +type TCPServer interface { // Listen starts listening by creating a new listener // and returning it. It does not start accepting // connections. For UDP-only servers, this method @@ -262,9 +251,11 @@ type Server interface { // words, until the server is stopped. For UDP-only // servers, this method can be a no-op that returns nil. Serve(net.Listener) error +} - // UDP methods - +// UDPServer is a type that can listen and serve packets. +// A UDPServer must associate with exactly or one net.PacketConns. +type UDPServer interface { // ListenPacket starts listening by creating a new packetconn // and returning it. It does not start accepting connections. // TCP-only servers may leave this method blank and return @@ -280,6 +271,20 @@ type Server interface { ServePacket(net.PacketConn) error } +// Server is a type that can listen and serve. It supports both +// TCP and UDP, although the UDPServer interface can be used +// for more than just UDP. +// +// If the server uses TCP, it should implement TCPServer completely. +// If it uses UDP or some other protocol, it should implement +// UDPServer completely. If it uses both, both interfaces should be +// fully implemented. Any unimplemented methods should be made as +// no-ops that simply return nil values. +type Server interface { + TCPServer + UDPServer +} + // Stopper is a type that can stop serving. The stop // does not necessarily have to be graceful. type Stopper interface {