From 27046feabeb0f3682c0fc734c9d4e49e7d082a0f Mon Sep 17 00:00:00 2001 From: i10416 Date: Wed, 24 Jan 2024 12:58:26 +0900 Subject: [PATCH] improve: just use content_LT to fix 16458 Just replacing element with content_LT, it works. See https://github.com/lampepfl/dotty/pull/19522#issuecomment-1907084802 --- .../dotc/parsing/xml/MarkupParserCommon.scala | 8 -------- .../tools/dotc/parsing/xml/MarkupParsers.scala | 15 ++++----------- 2 files changed, 4 insertions(+), 19 deletions(-) diff --git a/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParserCommon.scala b/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParserCommon.scala index 906d104041b2..803470fe85a5 100644 --- a/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParserCommon.scala +++ b/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParserCommon.scala @@ -202,14 +202,6 @@ private[dotty] trait MarkupParserCommon { /** skip optional space S? */ def xSpaceOpt(): Unit = while (isSpace(ch) && !eof) nextch() - /** skip optional space S? and return the number of consumed characters */ - def xSpaceOptN(): Int = - var i = 0 - while (isSpace(ch) && !eof) do - nextch() - i += 1 - i - /** scan [3] S ::= (#x20 | #x9 | #xD | #xA)+ */ def xSpace(): Unit = if (isSpace(ch)) { nextch(); xSpaceOpt() } diff --git a/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParsers.scala b/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParsers.scala index 2a8ae5c64a5b..06e8645b82c0 100644 --- a/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParsers.scala +++ b/compiler/src/dotty/tools/dotc/parsing/xml/MarkupParsers.scala @@ -371,17 +371,10 @@ object MarkupParsers { // parse more XML? if (charComingAfter(xSpaceOpt()) == '<') { while { - if xSpaceOptN() == 0 then - nextch() - if content_LT(ts) then // Is `` valid xml? - xToken("/>") - charComingAfter(xSpaceOpt()) == '<' - else - // this is surely not a special node as any special node - // should start with `<{special symbol}` without space. - nextch() - ts.append(element) - charComingAfter(xSpaceOpt()) == '<' + xSpaceOpt() + nextch() + content_LT(ts) + charComingAfter(xSpaceOpt()) == '<' } do () handle.makeXMLseq(Span(start, curOffset, start), ts) }