| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | // $G $F.go && $L $F.$A  # don't run it - goes forever | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Copyright 2009 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. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 13:56:33 -07:00
										 |  |  | package main | 
					
						
							| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Send the sequence 2, 3, 4, ... to channel 'ch'. | 
					
						
							| 
									
										
										
										
											2008-09-16 19:33:40 -07:00
										 |  |  | func Generate(ch *chan<- int) { | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 	for i := 2; ; i++ { | 
					
						
							| 
									
										
										
										
											2008-09-16 19:33:40 -07:00
										 |  |  | 		ch <- i  // Send 'i' to channel 'ch'. | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Copy the values from channel 'in' to channel 'out', | 
					
						
							|  |  |  | // removing those divisible by 'prime'. | 
					
						
							| 
									
										
										
										
											2008-09-16 19:33:40 -07:00
										 |  |  | func Filter(in *<-chan int, out *chan<- int, prime int) { | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 	for { | 
					
						
							|  |  |  | 		i := <-in  // Receive value of new variable 'i' from 'in'. | 
					
						
							|  |  |  | 		if i % prime != 0 { | 
					
						
							| 
									
										
										
										
											2008-09-16 19:33:40 -07:00
										 |  |  | 			out <- i  // Send 'i' to channel 'out'. | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // The prime sieve: Daisy-chain Filter processes together. | 
					
						
							|  |  |  | func Sieve() { | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 	ch := new(chan int);  // Create a new channel. | 
					
						
							|  |  |  | 	go Generate(ch);  // Start Generate() as a subprocess. | 
					
						
							|  |  |  | 	for { | 
					
						
							|  |  |  | 		prime := <-ch; | 
					
						
							| 
									
										
										
										
											2008-08-11 22:07:49 -07:00
										 |  |  | 		print(prime, "\n"); | 
					
						
							| 
									
										
										
										
											2008-07-15 20:52:07 -07:00
										 |  |  | 		ch1 := new(chan int); | 
					
						
							|  |  |  | 		go Filter(ch, ch1, prime); | 
					
						
							|  |  |  | 		ch = ch1 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 13:56:33 -07:00
										 |  |  | func main() { | 
					
						
							| 
									
										
										
										
											2008-06-27 11:36:40 -07:00
										 |  |  |   Sieve() | 
					
						
							| 
									
										
										
										
											2008-03-11 18:07:22 -07:00
										 |  |  | } |