import suggestion from ward
This commit is contained in:
parent
853f862880
commit
6b2aa07fa5
@ -8,43 +8,43 @@
|
||||
// pattern to write your own Go line filters.
|
||||
package main
|
||||
|
||||
// Package `bufio` will help us read line-by-line.
|
||||
import "bufio"
|
||||
import "strings"
|
||||
import "os"
|
||||
import "io"
|
||||
import (
|
||||
"bufio"
|
||||
"io"
|
||||
"log"
|
||||
"os"
|
||||
"strings"
|
||||
)
|
||||
|
||||
func main() {
|
||||
|
||||
// Wrapping the unbuffered `os.Stdin` with a buffered
|
||||
// reader gives us a convenient `ReadString` method
|
||||
// that we'll use to read input line-by-line.
|
||||
in := bufio.NewReader(os.Stdin)
|
||||
rdr := bufio.NewReader(os.Stdin)
|
||||
out := os.Stdout
|
||||
|
||||
// `ReadString` returns the next string from the
|
||||
// input up to the given separator byte. We give the
|
||||
// newline byte `'\n'` as our separator so we'll get
|
||||
// successive input lines.
|
||||
for {
|
||||
inLine, err := in.ReadString('\n')
|
||||
|
||||
// The `EOF` error is expected when we reach the
|
||||
// end of input, so exit gracefully in that case.
|
||||
// Otherwise there's a problem.
|
||||
if err == io.EOF {
|
||||
return
|
||||
}
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
// Write out the uppercased line, checking for an
|
||||
// error on the write as we did on the read.
|
||||
outLine := strings.ToUpper(inLine)
|
||||
_, err = out.WriteString(outLine)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
// `ReadString` returns the next string from the
|
||||
// input up to the given separator byte. We give the
|
||||
// newline byte `'\n'` as our separator so we'll get
|
||||
// successive input lines.
|
||||
switch line, err := rdr.ReadString('\n'); err {
|
||||
case nil:
|
||||
// Write out the uppercased line, checking for an
|
||||
// error on the write as we did on the read.
|
||||
ucl := strings.ToUpper(line)
|
||||
if _, err = out.WriteString(ucl); err != nil {
|
||||
log.Println(err)
|
||||
os.Exit(-1)
|
||||
}
|
||||
case io.EOF:
|
||||
// The `EOF` error is expected when we reach the
|
||||
// end of input, so exit gracefully in that case.
|
||||
os.Exit(0)
|
||||
default:
|
||||
// Otherwise there's a problem
|
||||
log.Println(err)
|
||||
os.Exit(-1)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user