| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | // 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. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-18 14:09:16 -07:00
										 |  |  | import "fmt" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | // Send the sequence 2, 3, 4, ... to returned channel  | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | func generate() chan int { | 
					
						
							| 
									
										
										
										
											2009-01-06 15:49:27 -08:00
										 |  |  | 	ch := make(chan int); | 
					
						
							|  |  |  | 	go func(ch chan int){ | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 		for i := 2; ; i++ { | 
					
						
							| 
									
										
										
										
											2008-09-16 19:40:38 -07:00
										 |  |  | 			ch <- i | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	}(ch); | 
					
						
							|  |  |  | 	return ch; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Filter out input values divisible by 'prime', send rest to returned channel | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | func filter(in chan int, prime int) chan int { | 
					
						
							| 
									
										
										
										
											2009-01-06 15:49:27 -08:00
										 |  |  | 	out := make(chan int); | 
					
						
							|  |  |  | 	go func(in chan int, out chan int, prime int) { | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 		for { | 
					
						
							|  |  |  | 			if i := <-in; i % prime != 0 { | 
					
						
							| 
									
										
										
										
											2008-09-16 19:40:38 -07:00
										 |  |  | 				out <- i | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}(in, out, prime); | 
					
						
							|  |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | func sieve() chan int { | 
					
						
							| 
									
										
										
										
											2009-01-06 15:49:27 -08:00
										 |  |  | 	out := make(chan int); | 
					
						
							|  |  |  | 	go func(out chan int) { | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | 		ch := generate(); | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 		for { | 
					
						
							|  |  |  | 			prime := <-ch; | 
					
						
							| 
									
										
										
										
											2008-09-16 19:40:38 -07:00
										 |  |  | 			out <- prime; | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | 			ch = filter(ch, prime); | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	}(out); | 
					
						
							|  |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							| 
									
										
										
										
											2009-01-15 17:54:07 -08:00
										 |  |  | 	primes := sieve(); | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 	for { | 
					
						
							| 
									
										
										
										
											2009-03-18 14:09:16 -07:00
										 |  |  | 		fmt.Println(<-primes); | 
					
						
							| 
									
										
										
										
											2008-09-16 11:00:11 -07:00
										 |  |  | 	} | 
					
						
							|  |  |  | } |