full diff: f3200d17e0...ab34263943
Worth mentioning that there's a comment updated in golang.org/x/net/websocket:
    This package currently lacks some features found in alternative
    and more actively maintained WebSocket packages:
        https://godoc.org/github.com/gorilla/websocket
        https://godoc.org/nhooyr.io/websocket
It's used in k8s.io/apiserver/pkg/util/wsstream/stream.go, so perhaps that should
be reviewed if the alternatives are better for how it's used.
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
		
	
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2014 The Go Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a BSD-style
 | 
						|
// license that can be found in the LICENSE file.
 | 
						|
 | 
						|
// Flow control
 | 
						|
 | 
						|
package http2
 | 
						|
 | 
						|
// flow is the flow control window's size.
 | 
						|
type flow struct {
 | 
						|
	_ incomparable
 | 
						|
 | 
						|
	// n is the number of DATA bytes we're allowed to send.
 | 
						|
	// A flow is kept both on a conn and a per-stream.
 | 
						|
	n int32
 | 
						|
 | 
						|
	// conn points to the shared connection-level flow that is
 | 
						|
	// shared by all streams on that conn. It is nil for the flow
 | 
						|
	// that's on the conn directly.
 | 
						|
	conn *flow
 | 
						|
}
 | 
						|
 | 
						|
func (f *flow) setConnFlow(cf *flow) { f.conn = cf }
 | 
						|
 | 
						|
func (f *flow) available() int32 {
 | 
						|
	n := f.n
 | 
						|
	if f.conn != nil && f.conn.n < n {
 | 
						|
		n = f.conn.n
 | 
						|
	}
 | 
						|
	return n
 | 
						|
}
 | 
						|
 | 
						|
func (f *flow) take(n int32) {
 | 
						|
	if n > f.available() {
 | 
						|
		panic("internal error: took too much")
 | 
						|
	}
 | 
						|
	f.n -= n
 | 
						|
	if f.conn != nil {
 | 
						|
		f.conn.n -= n
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// add adds n bytes (positive or negative) to the flow control window.
 | 
						|
// It returns false if the sum would exceed 2^31-1.
 | 
						|
func (f *flow) add(n int32) bool {
 | 
						|
	sum := f.n + n
 | 
						|
	if (sum > n) == (f.n > 0) {
 | 
						|
		f.n = sum
 | 
						|
		return true
 | 
						|
	}
 | 
						|
	return false
 | 
						|
}
 |