-
Notifications
You must be signed in to change notification settings - Fork 21
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
Refactor source code and split it up into multiple files? #162
Comments
Thanks @agriyakhetarpal, but I don't really have an opinion on this one way or the other, beyond that I agree it would be good to add a |
Hey! No strong feeling about whether or not to split the package in multiple files. Though could be good indeed if we continue adding features to it. |
Sure! My suggestion here is quite trivial, really, so I'll be happy to start my work on this once some of the recent PRs can get merged – and maybe after we come out with a release with those, to not cause any trouble(s) before a release. |
Sounds great! |
Problem
An issue I found while contributing to the Sphinx extension, coupled with the lack of a
CONTRIBUTING.md
document (which is another, unrelated issue) is that it was a bit difficult to navigate what was going on for someone whose Sphinx skills have been a bit rusty since quite some time. I would like to put in a request to refactor the codebase and move things around, and here are my suggestions:Proposed Solution
IFrame
classes to a non-namespace sub-modulejupyterlite_sphinx/iframes/
and then similarly moving the directives tojupyterlite_sphinx/directives/
can workDirective
classes, where all of them are subclasses that derive from_LiteDirective
, which itself derives from the standardSphinxDirective
. These would be likely candidates to split up into multiple files, and it should be easy to fix up their imports back intojupyterlite_sphinx.py
(it might make sense to rename the file because of the folder structure, i.e.,jupyterlite_sphinx.main
sounds a bit better thanjupyterlite_sphinx.jupyterlite_sphinx
)jupyterlite_sphinx.js
andjupyterlite_sphinx.css
files are standalone in their usage and exist only for copying into the_static
folder for a documentation website.Additional context
Though it is a bit outdated and unmaintained at the time of writing, another project: https://github.com/sphinx-contrib/cookiecutter has a nice structure to offer. However, it may or may not be needed here for now because the packaging is modern with
hatch
anyway and a test suite does not exist (and that may not be required anytime soon?).cc: @steppi
The text was updated successfully, but these errors were encountered: