Skip to content

Instantly share code, notes, and snippets.

@snaury
Created May 17, 2012 22:08
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save snaury/2721869 to your computer and use it in GitHub Desktop.
Save snaury/2721869 to your computer and use it in GitHub Desktop.
Channel with an unrestricted buffer in the middle
type Message struct {
Value string
}
func MakeElastic() (<-chan Message, chan<- Message) {
input := make(chan Message, 64)
output := make(chan Message, 64)
middle := make(chan []Message, 1)
go func(middle chan []Message, input <-chan Message) {
defer close(middle)
for message := range(input) {
var buffer []Message
select {
case buffer = <-middle:
buffer = append(buffer, message)
default:
buffer = []Message{message}
}
middle <- buffer
}
}(middle, input)
go func(output chan<- Message, middle <-chan []Message) {
defer close(output)
for messages := range(middle) {
for _, message := range(messages) {
output <- message
}
}
}(output, middle)
return output, input
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment