diff options
author | Filippo Valsorda <filippo@golang.org> | 2021-03-10 22:33:48 +0100 |
---|---|---|
committer | Filippo Valsorda <filippo@golang.org> | 2021-03-10 22:33:48 +0100 |
commit | 055f1da6e6b96d4de842fd80773dea6d977fc025 (patch) | |
tree | 577cd1fed4dbd7b4dce4aea9e0585462b63e37cd /src/encoding/xml/xml.go | |
parent | 2a0dd053ecfa528adc0f763a546519a7257ed8cd (diff) | |
parent | 13722418773b6a081816e8cc48131306565db1bd (diff) | |
download | go-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.go | 19 |
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 |