Commit ad391c90 authored by Martin Möhrmann's avatar Martin Möhrmann Committed by Rob Pike

fmt: split doPrint into two specialized functions

Remove format flag reset from doPrint. Flags will not be set in
doPrint and printArg will not return with flags modified.

Remove the extra arguments addspace and addnewline and split up
doPrint into two simpler and specialized functions.

Change-Id: Ib884d027abfbb31c6f01b008f51d6d76fc0c1a17
Reviewed-on: https://go-review.googlesource.com/21181
Run-TryBot: Rob Pike <r@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarRob Pike <r@golang.org>
parent b9daf0a4
...@@ -210,7 +210,7 @@ func Errorf(format string, a ...interface{}) error { ...@@ -210,7 +210,7 @@ func Errorf(format string, a ...interface{}) error {
// It returns the number of bytes written and any write error encountered. // It returns the number of bytes written and any write error encountered.
func Fprint(w io.Writer, a ...interface{}) (n int, err error) { func Fprint(w io.Writer, a ...interface{}) (n int, err error) {
p := newPrinter() p := newPrinter()
p.doPrint(a, false, false) p.doPrint(a)
n, err = w.Write(p.buf) n, err = w.Write(p.buf)
p.free() p.free()
return return
...@@ -227,7 +227,7 @@ func Print(a ...interface{}) (n int, err error) { ...@@ -227,7 +227,7 @@ func Print(a ...interface{}) (n int, err error) {
// Spaces are added between operands when neither is a string. // Spaces are added between operands when neither is a string.
func Sprint(a ...interface{}) string { func Sprint(a ...interface{}) string {
p := newPrinter() p := newPrinter()
p.doPrint(a, false, false) p.doPrint(a)
s := string(p.buf) s := string(p.buf)
p.free() p.free()
return s return s
...@@ -242,7 +242,7 @@ func Sprint(a ...interface{}) string { ...@@ -242,7 +242,7 @@ func Sprint(a ...interface{}) string {
// It returns the number of bytes written and any write error encountered. // It returns the number of bytes written and any write error encountered.
func Fprintln(w io.Writer, a ...interface{}) (n int, err error) { func Fprintln(w io.Writer, a ...interface{}) (n int, err error) {
p := newPrinter() p := newPrinter()
p.doPrint(a, true, true) p.doPrintln(a)
n, err = w.Write(p.buf) n, err = w.Write(p.buf)
p.free() p.free()
return return
...@@ -259,7 +259,7 @@ func Println(a ...interface{}) (n int, err error) { ...@@ -259,7 +259,7 @@ func Println(a ...interface{}) (n int, err error) {
// Spaces are always added between operands and a newline is appended. // Spaces are always added between operands and a newline is appended.
func Sprintln(a ...interface{}) string { func Sprintln(a ...interface{}) string {
p := newPrinter() p := newPrinter()
p.doPrint(a, true, true) p.doPrintln(a)
s := string(p.buf) s := string(p.buf)
p.free() p.free()
return s return s
...@@ -1127,20 +1127,27 @@ formatLoop: ...@@ -1127,20 +1127,27 @@ formatLoop:
} }
} }
func (p *pp) doPrint(a []interface{}, addspace, addnewline bool) { func (p *pp) doPrint(a []interface{}) {
prevString := false prevString := false
for argNum, arg := range a { for argNum, arg := range a {
p.fmt.clearflags()
isString := arg != nil && reflect.TypeOf(arg).Kind() == reflect.String isString := arg != nil && reflect.TypeOf(arg).Kind() == reflect.String
// Add a space between two non-string arguments or if // Add a space between two non-string arguments.
// explicitly asked for by addspace. if argNum > 0 && !isString && !prevString {
if argNum > 0 && (addspace || (!isString && !prevString)) {
p.buf.WriteByte(' ') p.buf.WriteByte(' ')
} }
p.printArg(arg, 'v') p.printArg(arg, 'v')
prevString = isString prevString = isString
} }
if addnewline { }
p.buf.WriteByte('\n')
// doPrintln is like doPrint but always adds a space between arguments
// and a newline after the last argument.
func (p *pp) doPrintln(a []interface{}) {
for argNum, arg := range a {
if argNum > 0 {
p.buf.WriteByte(' ')
}
p.printArg(arg, 'v')
} }
p.buf.WriteByte('\n')
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment