mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-24 23:39:19 -04:00 
			
		
		
		
	Simplify websocket ticker shutdown code
"A receive from a closed channel returns the zero value immediately" Close the tickerChan in the calling function, this causes "case <-c" to unblock immediately, ending the goroutine and stopping the ticker.
This commit is contained in:
		
							parent
							
								
									b713a7796e
								
							
						
					
					
						commit
						d4a14af14d
					
				| @ -172,7 +172,7 @@ func reader(conn *websocket.Conn, stdout io.ReadCloser, stdin io.WriteCloser) { | ||||
| 	conn.SetReadDeadline(time.Now().Add(pongWait)) | ||||
| 	conn.SetPongHandler(func(string) error { conn.SetReadDeadline(time.Now().Add(pongWait)); return nil }) | ||||
| 	tickerChan := make(chan bool) | ||||
| 	defer func() { tickerChan <- true }() // make sure to close the ticker when we are done. | ||||
| 	defer close(tickerChan) // make sure to close the ticker when we are done. | ||||
| 	go ticker(conn, tickerChan) | ||||
| 
 | ||||
| 	for { | ||||
| @ -213,10 +213,7 @@ func reader(conn *websocket.Conn, stdout io.ReadCloser, stdin io.WriteCloser) { | ||||
| // between the server and client to keep it alive with ping messages. | ||||
| func ticker(conn *websocket.Conn, c chan bool) { | ||||
| 	ticker := time.NewTicker(pingPeriod) | ||||
| 	defer func() { | ||||
| 		ticker.Stop() | ||||
| 		close(c) | ||||
| 	}() | ||||
| 	defer ticker.Stop() | ||||
| 
 | ||||
| 	for { // blocking loop with select to wait for stimulation. | ||||
| 		select { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user