mirror of
https://github.com/soheilhy/cmux.git
synced 2025-01-19 03:06:07 +08:00
remove named returns and useless closures
This commit is contained in:
parent
a18f806553
commit
903d5c95f0
16
cmux.go
16
cmux.go
@ -7,11 +7,11 @@ import (
|
||||
)
|
||||
|
||||
// Matcher matches a connection based on its content.
|
||||
type Matcher func(r io.Reader) (ok bool)
|
||||
type Matcher func(io.Reader) bool
|
||||
|
||||
// ErrorHandler handles an error and returns whether
|
||||
// the mux should continue serving the listener.
|
||||
type ErrorHandler func(err error) (ok bool)
|
||||
type ErrorHandler func(error) bool
|
||||
|
||||
var _ net.Error = ErrNotMatched{}
|
||||
|
||||
@ -49,7 +49,7 @@ func New(l net.Listener) CMux {
|
||||
return &cMux{
|
||||
root: l,
|
||||
bufLen: 1024,
|
||||
errh: func(err error) bool { return true },
|
||||
errh: func(_ error) bool { return true },
|
||||
}
|
||||
}
|
||||
|
||||
@ -59,12 +59,12 @@ type CMux interface {
|
||||
// the connections matched by at least one of the matcher.
|
||||
//
|
||||
// The order used to call Match determines the priority of matchers.
|
||||
Match(matchers ...Matcher) net.Listener
|
||||
Match(...Matcher) net.Listener
|
||||
// Serve starts multiplexing the listener. Serve blocks and perhaps
|
||||
// should be invoked concurrently within a go routine.
|
||||
Serve() error
|
||||
// HandleError registers an error handler that handles listener errors.
|
||||
HandleError(h ErrorHandler)
|
||||
HandleError(ErrorHandler)
|
||||
}
|
||||
|
||||
type matchersListener struct {
|
||||
@ -79,7 +79,7 @@ type cMux struct {
|
||||
sls []matchersListener
|
||||
}
|
||||
|
||||
func (m *cMux) Match(matchers ...Matcher) (l net.Listener) {
|
||||
func (m *cMux) Match(matchers ...Matcher) net.Listener {
|
||||
ml := muxListener{
|
||||
Listener: m.root,
|
||||
connc: make(chan net.Conn, m.bufLen),
|
||||
@ -155,9 +155,9 @@ type muxListener struct {
|
||||
donec chan struct{}
|
||||
}
|
||||
|
||||
func (l muxListener) Accept() (c net.Conn, err error) {
|
||||
func (l muxListener) Accept() (net.Conn, error) {
|
||||
select {
|
||||
case c = <-l.connc:
|
||||
case c := <-l.connc:
|
||||
return c, nil
|
||||
case <-l.donec:
|
||||
return nil, ErrListenerClosed
|
||||
|
10
matchers.go
10
matchers.go
@ -21,9 +21,7 @@ func Any() Matcher {
|
||||
// starts with any of the strings in strs.
|
||||
func PrefixMatcher(strs ...string) Matcher {
|
||||
pt := newPatriciaTreeString(strs...)
|
||||
return func(r io.Reader) bool {
|
||||
return pt.matchPrefix(r)
|
||||
}
|
||||
return pt.matchPrefix
|
||||
}
|
||||
|
||||
var defaultHTTPMethods = []string{
|
||||
@ -88,9 +86,7 @@ var (
|
||||
// HTTP2 parses the frame header of the first frame to detect whether the
|
||||
// connection is an HTTP2 connection.
|
||||
func HTTP2() Matcher {
|
||||
return func(r io.Reader) bool {
|
||||
return hasHTTP2Preface(r)
|
||||
}
|
||||
return hasHTTP2Preface
|
||||
}
|
||||
|
||||
// HTTP1HeaderField returns a matcher matching the header fields of the first
|
||||
@ -109,7 +105,7 @@ func HTTP2HeaderField(name, value string) Matcher {
|
||||
}
|
||||
}
|
||||
|
||||
func hasHTTP2Preface(r io.Reader) (ok bool) {
|
||||
func hasHTTP2Preface(r io.Reader) bool {
|
||||
b := make([]byte, len(http2Preface))
|
||||
n, err := r.Read(b)
|
||||
if err != nil {
|
||||
|
Loading…
Reference in New Issue
Block a user