Commit 47459937 authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab
Browse files

sphinx: parser_yaml.py: fix line numbers information



As reported by Donald, this code:

	rst_parser = RSTParser()
	rst_parser.parse('\n'.join(result), document)

breaks line parsing. As an alternative, I tested a variant of it:

	rst_parser.parse(result, document)

but still line number was not preserved. As Donald noted,
standard Parser classes don't have a direct mechanism to preserve
line numbers from ViewList().

So, instead, let's use a mechanism similar to what we do already at
kerneldoc.py: call the statemachine mechanism directly there.

I double-checked when states and statemachine were introduced:
both were back in 2002. I also tested doc build with docutils 0.16
and 0.21.2. It worked with both, so it seems to be stable enough
for our needs.

Reported-by: default avatarDonald Hunter <donald.hunter@gmail.com>
Closes: https://lore.kernel.org/linux-doc/m24ivk78ng.fsf@gmail.com/T/#u


Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent d90555ef
Loading
Loading
Loading
Loading
+14 −7
Original line number Diff line number Diff line
@@ -11,7 +11,9 @@ import sys

from pprint import pformat

from docutils import statemachine
from docutils.parsers.rst import Parser as RSTParser
from docutils.parsers.rst import states
from docutils.statemachine import ViewList

from sphinx.util import logging
@@ -56,6 +58,8 @@ class YamlParser(Parser):

    re_lineno = re.compile(r"\.\. LINENO ([0-9]+)$")

    tab_width = 8

    def rst_parse(self, inputstring, document, msg):
        """
        Receives a ReST content that was previously converted by the
@@ -66,10 +70,18 @@ class YamlParser(Parser):

        result = ViewList()

        self.statemachine = states.RSTStateMachine(state_classes=states.state_classes,
                                                   initial_state='Body',
                                                   debug=document.reporter.debug_flag)

        try:
            # Parse message with RSTParser
            lineoffset = 0;
            for line in msg.split('\n'):

            lines = statemachine.string2lines(msg, self.tab_width,
                                              convert_whitespace=True)

            for line in lines:
                match = self.re_lineno.match(line)
                if match:
                    lineoffset = int(match.group(1))
@@ -77,12 +89,7 @@ class YamlParser(Parser):

                result.append(line, document.current_source, lineoffset)

            # Fix backward compatibility with docutils < 0.17.1
            if "tab_width" not in vars(document.settings):
                document.settings.tab_width = 8

            rst_parser = RSTParser()
            rst_parser.parse('\n'.join(result), document)
            self.statemachine.run(result, document)

        except Exception as e:
            document.reporter.error("YAML parsing error: %s" % pformat(e))