Tutorial on how to create a plugin component for both PsychoPy and PsychoJS
Project description
The purpose of this repo is to give prospective plugin creators a starting point in the form of a minimal, working plugin to copy and edit rather than having to start from scratch.
Setting up a dev environment
Writing your plugin code
In general, how you write the Python code for your plugin is completely up to you! A plugin is ultimately just a normal Python package with some extra stuff (entry points) telling it how to interact with PsychoPy. The code in the folder psychopy_plugin_template (which you'll need to rename to the name you want your plugin to be imported as) gives an example structure and examples of a new Component, a new Standalone Routine and some new hardware and visual classes. Feel free however to start fully from scratch in whatever format you like!
Setting up your pyproject.toml
The file pyproject.toml tells Python's packaging system what to do with your plugin - what to call it, what version it's on, who to list as author, what to put where in PsychoPy, etc.
The pyproject.toml
for this repo is set up with details for the psychopy-plugin-template
package, so you'll need to change the following values:
- name: Replace with the name you want your plugin to be installed by (should begin with
psychopy-
still) - version: What version your plugin is on - if you're just starting it, this will be
0.0.0
. See here for more information about version number guidelines. - description: Replace this with a description of your plugin telling users what it does.
- authors: Give yourself credit for your work! List your name and email here (you can remove OST Science Team)
- dependencies: If you need any Python packages which don't already come with PsychoPy, list them here and they'll be installed when users install your plugin
- project.urls: Once you've set up documentation (we'll get to that later), you'll need to replace the links here with links to your docs
- project.entry-points."...": Entry points tell Python to pretend that parts of your plugin are in PsychoPy. We'll set these up later, but just be aware that all these values are going to change.
Installing your plugin to test
Once you have some code you'd like to test out, and once your pyproject.toml
is set up, you can do what's called an "editable install". Essentially, install your plugin from the folder it's in rather than from the usual installation process.
Publishing your plugin to PyPi
Once you're happy that your plugin works, it's time to publish! As your project is already on GitHub, users could install it using pip install git+https://github.com/<your username>/<plugin repo name>@<branch>
, but if you want it to appear in the packages search panel then it needs to be uploaded to PyPi - the go-to repository for Python packages. This repository is already set up with automatic publishing, so you just need to set up a few things to give permission.
Create a pypi
account
If you don't already have one, go to PyPi.org and create an account. They need to know who's publishing before letting you publish!
Add a "trusted publisher" on PyPi
PyPi needs to know that your plugin repo is associated with your PyPi account, and the easiest way to do this is to add it as a "trusted publisher":
- Go to your account settings and select the "Publishing" tab
- Scroll down to the "Add a new pending publisher" and make sure the "GitHub" tab is selected
- Fill in the fields as instructed, the "Workflow name" needs to be
pypi.yaml
and the "Environment name" needs to bepypi
If you're setting up auto publishing for a project you've already created, you can find the same interface in the settings for that project rather than your user account and fill it out in the same way.
Create an environment on GitHub
The "trusted publisher" form asked for the name of a GitHub environment, didn't it? Well, in order for it to work, there needs to be an environment by that name!
- Go to the settings for your plugin repo on GitHub
- Go to "Environments" from the tabs on the left side
- Click "New environment"
- Enter the name as
pypi
- Click "Configure environment" The default settings should do just fine, so you once you've created the environment there's no more you need to do (unless you want to of course)
Create a "Release" on GitHub
Once you've done the previous steps, your repo is configured to automatically publish to PyPi whenever you make a new release on GitHub. So to publish, just go to "Releases" and click "New Release". Make sure you've updated the version number in your pyproject.toml
file (as PyPi only lets you upload each numbered version once), and set the "tag" for this release to be that version number. Write some text to describe your plugin (see the releases of this repo for guidance) and then just click publish, the rest should work by magic!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file psychopy_plugin_template-0.0.5.tar.gz
.
File metadata
- Download URL: psychopy_plugin_template-0.0.5.tar.gz
- Upload date:
- Size: 40.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5a5668b5bb99167ad5d81471d90299d0566ef7f9ec35607534cda7986d103b55 |
|
MD5 | 65134afa131ee8df72a83f12e745b127 |
|
BLAKE2b-256 | 4f967670d7c7e2ba6afc06c3160a49ffb00c74d706d37fc5fe0a57203471ed1b |
File details
Details for the file psychopy_plugin_template-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: psychopy_plugin_template-0.0.5-py3-none-any.whl
- Upload date:
- Size: 49.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9cc19e9a57d7cd62f6add2b819244b3abd6adce1c23bf654e76c43028da8e2d0 |
|
MD5 | 1f837fe48929b7e9be0fa249cc6d8897 |
|
BLAKE2b-256 | 359f2dcc1444e20e9fac164725718ab15e8a90467067f1f816b4a145d19b4a7d |