aboutsummaryrefslogtreecommitdiff
path: root/src/encoding/xml/xml.go
diff options
context:
space:
mode:
authorFilippo Valsorda <filippo@golang.org>2021-03-10 22:33:48 +0100
committerFilippo Valsorda <filippo@golang.org>2021-03-10 22:33:48 +0100
commit055f1da6e6b96d4de842fd80773dea6d977fc025 (patch)
tree577cd1fed4dbd7b4dce4aea9e0585462b63e37cd /src/encoding/xml/xml.go
parent2a0dd053ecfa528adc0f763a546519a7257ed8cd (diff)
parent13722418773b6a081816e8cc48131306565db1bd (diff)
downloadgo-055f1da6e6b96d4de842fd80773dea6d977fc025.tar.gz
go-055f1da6e6b96d4de842fd80773dea6d977fc025.zip
[dev.boringcrypto.go1.15] all: merge go1.15.9 into dev.boringcrypto.go1.15
Change-Id: I618981e3ae425ce492aa9affb2703f074d778198
Diffstat (limited to 'src/encoding/xml/xml.go')
-rw-r--r--src/encoding/xml/xml.go19
1 files changed, 10 insertions, 9 deletions
diff --git a/src/encoding/xml/xml.go b/src/encoding/xml/xml.go
index adaf4daf19..6f9594d7ba 100644
--- a/src/encoding/xml/xml.go
+++ b/src/encoding/xml/xml.go
@@ -271,7 +271,7 @@ func NewTokenDecoder(t TokenReader) *Decoder {
// it will return an error.
//
// Token implements XML name spaces as described by
-// https://www.w3.org/TR/REC-xml-names/. Each of the
+// https://www.w3.org/TR/REC-xml-names/. Each of the
// Name structures contained in the Token has the Space
// set to the URL identifying its name space when known.
// If Token encounters an unrecognized name space prefix,
@@ -285,16 +285,17 @@ func (d *Decoder) Token() (Token, error) {
if d.nextToken != nil {
t = d.nextToken
d.nextToken = nil
- } else if t, err = d.rawToken(); err != nil {
- switch {
- case err == io.EOF && d.t != nil:
- err = nil
- case err == io.EOF && d.stk != nil && d.stk.kind != stkEOF:
- err = d.syntaxError("unexpected EOF")
+ } else {
+ if t, err = d.rawToken(); t == nil && err != nil {
+ if err == io.EOF && d.stk != nil && d.stk.kind != stkEOF {
+ err = d.syntaxError("unexpected EOF")
+ }
+ return nil, err
}
- return t, err
+ // We still have a token to process, so clear any
+ // errors (e.g. EOF) and proceed.
+ err = nil
}
-
if !d.Strict {
if t1, ok := d.autoClose(t); ok {
d.nextToken = t