Skip to content

Commit

Permalink
Cleanup/expand the code comments
Browse files Browse the repository at this point in the history
- Remove comments now tracked by an issue in the repository
  (#5
  and #16)
- Move comments out of the template literal string with Python code
  and into the JavaScript code around it
- Expand comments to offer more context
  • Loading branch information
waldyrious committed Dec 17, 2022
1 parent 95d414a commit c841192
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 7 deletions.
1 change: 0 additions & 1 deletion index.xhtml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@
to run <a href="https://docutils.sourceforge.io">docutils</a>.
Source code <a href="https://github.com/waldyrious/rst-playground">on GitHub</a>.

<!-- <form oninput="html_output.value=rst_input.value"> -->
<form>
<label for="rst-input">reStructuredText input</label>
<label for="html-output">HTML output</label>
Expand Down
14 changes: 8 additions & 6 deletions script.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ const outputFrame = document.getElementById("html-output");

outputFrame.contentDocument.write("<!DOCTYPE html> Initializing...\n");

// init Pyodide
// Initialize Pyodide
async function main() {
let pyodide = await loadPyodide();
outputFrame.contentDocument.write("Ready.\n");
Expand All @@ -22,16 +22,18 @@ async function rstToHtml() {
// (they automatically trigger syntax highlighting)
await pyodide.loadPackage("pygments");

// We pass the textarea contents as a variable
// instead of interpolating them into the code below.
// For the reasoning, see the description of commit 40037ef37.
pyodide.globals.set('input_text', inputTextarea.value);

// Python code to parse a rST string into HTML using docutils
// as recommended in https://stackoverflow.com/a/6654576/266309.
// Note: the `decode()` is needed to convert `publish_string()`'s output
// from a bytestring to a plain string. See https://stackoverflow.com/a/606199/266309.
let result = await pyodide.runPythonAsync(`
# https://stackoverflow.com/a/6654576/266309
from docutils.core import publish_string
# https://stackoverflow.com/a/606199/266309 → decode bytestring to plain string
publish_string(input_text, writer_name='html5').decode("utf-8")
# TODO: change to publish_doctree() + cleanup + publish_from_doctree()
# (see https://docutils.sourceforge.io/docs/api/publisher.html)
# so that the output can be just the plain inner content and not have to be placed in an iframe
`);

outputFrame.srcdoc = result;
Expand Down

0 comments on commit c841192

Please sign in to comment.