If you like this project and want to make it better, help out. It could be as simple as sending @donkirkby@hachyderm.io a nice note on Mastodon, you could report a bug, or pitch in with some development work. There are usually some small issues labeled as good first issues or some larger ones with help wanted.
Please create issue descriptions on GitHub. Be as specific as possible. Which version are you using? What did you do? What did you expect to happen? Are you planning to submit your own fix in a pull request? Please include a small code sample and what you would like the live code display to show for that code.
Depending on what you want to work on, there are several possible develpment
environments to choose from. How to set up and use each environment is described
in its own contributing-*.md
file.
- Browser tutorials - this is the easiest environment to set up, and a great
place to start, because it all runs in your browser without installing
anything. You can edit a tutorial in a markdown file, including the code
blocks that become live coding samples. You can also edit the Javascript code
that displays the live coding samples. See
contributing-browser-tutorial.md
for details. - Browser full - you can still run this in your browser without installing
anything, but it takes a few minutes to start, and takes more storage space on
GitHub's codespaces. You can make changes to the live coding Python library,
as well as editing all the features you can edit in the browser tutorials
environment. See
contributing-browser-full.md
for details. - PyCharm - this takes a while to install, but you can make changes to the live
coding Python library or the PyCharm plugin, as well as stepping through the
code in debug mode. See
contributing-pycharm.md
for details. - Emacs - lets you edit the Emacs minor mode. See
contributing-emacs.md
for details. - SublimeText - lets you edit the SublimeText plugin. See
contributing-sublime.md
for details. - Space Tracer - the command-line version that you can edit in any Python
environment. See
contributing-space-tracer.md
for details of how to publish a new release on PyPI.
The Python code should follow PEP8 guidelines, and the Java code should be compatible with Java 11. The plugin verifier will check for Java compatibility with the different versions of the IntelliJ platform.
If you're adding features, please make sure to add tests as well. PyCharm tests
are at test/PySrc/tests
, Javascript tests are at html/src
, and Java tests
are at pycharm/src/test
. See the .github/workflows
folder for details on how
each set of tests gets run.
See test/PySrc/tests/live_coding_fuzzer.py
for details on how to run the
fuzzing test. It generates random Python source code, runs it through space
tracer, then strips off the live coding display and compares the stripped report
with the source code. Any differences trigger a failure.
If you want to use live coding with a new editor, you can add basic support with two features:
First, launch a process like this:
PYTHONPATH=plugin/PySrc/ python -m space_tracer -
Then pass the source code from the editor as the standard input for that process, and capture the standard output.
Second, display that standard output beside the source code, and keep the two windows synchronized as they scroll up and down.
If you use your editor's plug-in system to package that up with the
plugin/PySrc/space_tracer
folder, then you're ready to publish your first
release.
To add more features, look at the options by running:
python plugin/PySrc/code_tracer.py -h
The canvas commands are for turtle graphics and matplotlib: bgcolor
,
create_line
, create_polygon
, create_text
, and create_image
. Look at
SplitFileEditor.TurtleCanvas
in the pycharm
project for an example.
The driver command and arguments let you use another script or unit tests to call the live coding file.