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

Infra: Add make htmllive to rebuild and reload HTML files in your browser #3521

Merged
merged 1 commit into from
Nov 12, 2023

Conversation

hugovk
Copy link
Member

@hugovk hugovk commented Nov 4, 2023

Add a make htmllive target to use https://github.com/executablebooks/sphinx-autobuild.

When you run it, it builds the docs and serves them at something like http://127.0.0.1:8000/

You can visit any page, for example http://127.0.0.1:8000/pep-0101.html, and when you edit/save your source .rst file, it will automatically rebuild and update the page in the browser.

This drastically improves the edit/inspect loop. A very nice touch is it will also keep you at the same position in the page.

Compare before:

  1. switch to IDE: edit, save
  2. switch to prompt: make html
  3. switch to browser: reload, inspect
  4. repeat

To this PR:

  1. switch to IDE: edit, save
  2. switch to prompt: make html
  3. switch to browser: reload, inspect
  4. repeat

(There's still some slowness due to #3477, but this automation reduces the manual labour.)

We've already added this to the devguide (python/devguide#1208, python/devguide#1212) and can add thing to CPython Docs later.

cc @pradyunsg


📚 Documentation preview 📚: https://pep-previews--3521.org.readthedocs.build/

@hugovk hugovk added the infra Core infrastructure for building and rendering PEPs label Nov 4, 2023
@hugovk hugovk requested a review from AA-Turner as a code owner November 4, 2023 19:38
@Rosuav
Copy link
Contributor

Rosuav commented Nov 4, 2023

Nice. How representative is it? Obviously the autoreload is going to require some JS, but as long as it isn't messing with the structure of the document, this is going to be very handy.

@hugovk
Copy link
Member Author

hugovk commented Nov 5, 2023

Yes, it's using https://github.com/lepture/python-livereload which uses livereload.js, but I think that's all server-side stuff, and the output files in the build directory are just the same as a regular make html build.

@Rosuav
Copy link
Contributor

Rosuav commented Nov 5, 2023

By definition it's going to need something clientside that triggers the refresh, but it looks like that isn't going to mess with the structure. (I've seen some of those sorts of things that add a banner or something, which is annoying.)

@hugovk
Copy link
Member Author

hugovk commented Nov 5, 2023

We can ask @pradyunsg to explain it to us, he's maintaining both https://github.com/executablebooks/sphinx-autobuild and https://github.com/lepture/python-livereload :)

@pradyunsg
Copy link
Member

pradyunsg commented Nov 5, 2023

By definition it's going to need something clientside that triggers the refresh, but it looks like that isn't going to mess with the structure.

The HTTP server used in sphinx-autobuild looks for </head> on HTML responses and injects a blurb of JS to load a script. That script then makes a websocket connection on the same server and listens for reload events. Once a reload event is received, it calls window.reload basically (i.e. roughly the same as doing a manual refresh of the page).

There's no DOM manipulation on the client side in the logic AFAIK.

@Rosuav
Copy link
Contributor

Rosuav commented Nov 5, 2023

"Websocket"! You said the magic word...

(I love websockets, have used 'em in so many ridiculous and not-so-ridiculous ways)

@hugovk hugovk merged commit f7ccb48 into python:main Nov 12, 2023
5 checks passed
@hugovk hugovk deleted the make-htmllive branch November 12, 2023 11:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
infra Core infrastructure for building and rendering PEPs
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants