Skip to content
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

HTML Blocks #231

Open
cppgent0 opened this issue Nov 12, 2024 · 1 comment
Open

HTML Blocks #231

cppgent0 opened this issue Nov 12, 2024 · 1 comment
Labels

Comments

@cppgent0
Copy link

I have a markdown file with html in it e.g.

<table class="info_table">
<tr class="ja_info_tr">
<td class="ja_info_td"><strong>PyPi module</strong></td>
<td class="ja_info_td">N/A</td>
</tr>
<tr class="ja_info_tr">
<td class="ja_info_td"><strong>Version Info</strong></td>
<td class="ja_info_td"><ul><li>macOS 14.5, Python 3.10</li><li>Ubuntu 20.04 focal, Python 3.10</li>
</ul></td>
</tr>
</table>

This, according to commonmark is allowed see https://spec.commonmark.org/0.31.2/#html-blocks
and I've checked it out https://spec.commonmark.org/dingus/ and it works fine there.

Also see https://spec.commonmark.org/0.31.2/spec.json which has their test spec (in JSON) for this scenario:

  {
    "markdown": "<table>\n  <tr>\n    <td>\n           hi\n    </td>\n  </tr>\n</table>\n\nokay.\n",
    "html": "<table>\n  <tr>\n    <td>\n           hi\n    </td>\n  </tr>\n</table>\n<p>okay.</p>\n",
    "example": 149,
    "start_line": 2457,
    "end_line": 2476,
    "section": "HTML blocks"
  },

I've taken a copy of html_renderer.py and modifying it for my markdown files. So far so good, except for this html block.
It translates into

<p>&lt;table class="ja_info_table"&gt;
&lt;tr class="ja_info_tr"&gt;
etc.

I've dumped the AST and there are no HTML block elements, they are all RawText.

In html_rendered.py script there is a function:

    @staticmethod
    def render_html_block(token: block_token.HtmlBlock) -> str:

But it's never called (checked it with a print()). I checked out base_renderer and it doesn't seem to be called there either.

I can't tell if the problem is with my code or if the renderer is just not calling the render_html_block or the AST parser is failing to detect the raw HTML in the markdown file at all.

@pbodnar
Copy link
Collaborator

pbodnar commented Dec 15, 2024

Hi @cppgent0, I guess you've run into the "infamous usage bug" #56 here. That is, are you sure you call Document(input) after initializing your instance of HtmlRenderer (ideally within the with construct)?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants