-
-
Notifications
You must be signed in to change notification settings - Fork 558
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Source position seems off #296
Comments
Thank you. I added a passing test case in #297, hopefully that makes it easier to get started (or if this is expected behavior, we can merge it as-is). |
For more information, I found that for md like
For the 1st pass when generating the blocks. The container block's string content already skips the spaces. So the container block node has text |
Related issue: #204 |
This issue becomes more pronouncedly odd when you try the inverse: A
B produces <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE document SYSTEM "CommonMark.dtd">
<document sourcepos="1:1-2:1" xmlns="http://commonmark.org/xml/1.0">
<paragraph sourcepos="1:3-2:1">
<text sourcepos="1:3-1:3" xml:space="preserve">A</text>
<softbreak />
<text sourcepos="2:3-2:3" xml:space="preserve">B</text>
</paragraph>
</document> The lazy continuation means we end up treating everything as though it started at column 3. |
@kivikakk I think that's because the first line has two leading spaces. If you try to change it to 3 or 1, you will see the start column of following lines changed. I briefly went through the parsing logic: https://github.com/commonmark/cmark/blob/master/src/blocks.c#L186-L187 this line only adds the skipped text to the container node. For example: A
B The text of the paragraph node is changed from |
Seems to me that the inline parser should receive a list of starting columns for each input line, which it can use to adjust source positions. This would avoid the need to strip whitespace (as in #298) which imposes a performance penalty. This adds a bit of complexity, which is why I didn't implement inline source positions originally. |
I would also like to see this feature, as it would allow me to easily extract sections from a bigger markdown file. E.g. API descriptions, where I wanna parse the general format of the documentation (API call definitions, parameter tables), but leave the description in markdown to be processed later on (if even necessary). |
Give the following input:
The cmark library reports (through
cmark_node_get_start_column
) that the strong node starts at line 2, column 1, and ends at column 5. I would have expected it to start at column 5. Is this a bug, or is my interpretation of start column wrong?The text was updated successfully, but these errors were encountered: