| // Copyright 2013 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 bufio_test | 
 |  | 
 | import ( | 
 | 	"bufio" | 
 | 	"fmt" | 
 | 	"os" | 
 | 	"strconv" | 
 | 	"strings" | 
 | ) | 
 |  | 
 | func ExampleWriter() { | 
 | 	w := bufio.NewWriter(os.Stdout) | 
 | 	fmt.Fprint(w, "Hello, ") | 
 | 	fmt.Fprint(w, "world!") | 
 | 	w.Flush() // Don't forget to flush! | 
 | 	// Output: Hello, world! | 
 | } | 
 |  | 
 | // The simplest use of a Scanner, to read standard input as a set of lines. | 
 | func ExampleScanner_lines() { | 
 | 	scanner := bufio.NewScanner(os.Stdin) | 
 | 	for scanner.Scan() { | 
 | 		fmt.Println(scanner.Text()) // Println will add back the final '\n' | 
 | 	} | 
 | 	if err := scanner.Err(); err != nil { | 
 | 		fmt.Fprintln(os.Stderr, "reading standard input:", err) | 
 | 	} | 
 | } | 
 |  | 
 | // Use a Scanner to implement a simple word-count utility by scanning the | 
 | // input as a sequence of space-delimited tokens. | 
 | func ExampleScanner_words() { | 
 | 	// An artificial input source. | 
 | 	const input = "Now is the winter of our discontent,\nMade glorious summer by this sun of York.\n" | 
 | 	scanner := bufio.NewScanner(strings.NewReader(input)) | 
 | 	// Set the split function for the scanning operation. | 
 | 	scanner.Split(bufio.ScanWords) | 
 | 	// Count the words. | 
 | 	count := 0 | 
 | 	for scanner.Scan() { | 
 | 		count++ | 
 | 	} | 
 | 	if err := scanner.Err(); err != nil { | 
 | 		fmt.Fprintln(os.Stderr, "reading input:", err) | 
 | 	} | 
 | 	fmt.Printf("%d\n", count) | 
 | 	// Output: 15 | 
 | } | 
 |  | 
 | // Use a Scanner with a custom split function (built by wrapping ScanWords) to validate | 
 | // 32-bit decimal input. | 
 | func ExampleScanner_custom() { | 
 | 	// An artificial input source. | 
 | 	const input = "1234 5678 1234567901234567890" | 
 | 	scanner := bufio.NewScanner(strings.NewReader(input)) | 
 | 	// Create a custom split function by wrapping the existing ScanWords function. | 
 | 	split := func(data []byte, atEOF bool) (advance int, token []byte, err error) { | 
 | 		advance, token, err = bufio.ScanWords(data, atEOF) | 
 | 		if err == nil && token != nil { | 
 | 			_, err = strconv.ParseInt(string(token), 10, 32) | 
 | 		} | 
 | 		return | 
 | 	} | 
 | 	// Set the split function for the scanning operation. | 
 | 	scanner.Split(split) | 
 | 	// Validate the input | 
 | 	for scanner.Scan() { | 
 | 		fmt.Printf("%s\n", scanner.Text()) | 
 | 	} | 
 |  | 
 | 	if err := scanner.Err(); err != nil { | 
 | 		fmt.Printf("Invalid input: %s", err) | 
 | 	} | 
 | 	// Output: | 
 | 	// 1234 | 
 | 	// 5678 | 
 | 	// Invalid input: strconv.ParseInt: parsing "1234567901234567890": value out of range | 
 | } | 
 |  | 
 | // Use a Scanner with a custom split function to parse a comma-separated | 
 | // list with an empty final value. | 
 | func ExampleScanner_emptyFinalToken() { | 
 | 	// Comma-separated list; last entry is empty. | 
 | 	const input = "1,2,3,4," | 
 | 	scanner := bufio.NewScanner(strings.NewReader(input)) | 
 | 	// Define a split function that separates on commas. | 
 | 	onComma := func(data []byte, atEOF bool) (advance int, token []byte, err error) { | 
 | 		for i := 0; i < len(data); i++ { | 
 | 			if data[i] == ',' { | 
 | 				return i + 1, data[:i], nil | 
 | 			} | 
 | 		} | 
 | 		// There is one final token to be delivered, which may be the empty string. | 
 | 		// Returning bufio.ErrFinalToken here tells Scan there are no more tokens after this | 
 | 		// but does not trigger an error to be returned from Scan itself. | 
 | 		return 0, data, bufio.ErrFinalToken | 
 | 	} | 
 | 	scanner.Split(onComma) | 
 | 	// Scan. | 
 | 	for scanner.Scan() { | 
 | 		fmt.Printf("%q ", scanner.Text()) | 
 | 	} | 
 | 	if err := scanner.Err(); err != nil { | 
 | 		fmt.Fprintln(os.Stderr, "reading input:", err) | 
 | 	} | 
 | 	// Output: "1" "2" "3" "4" "" | 
 | } |