Skip to main content

a base Pelican Plugin template.

Project description

travis-link codecov-link pypi-link

These are the bare minimum yet possibly over-explained steps for creating a Pelican plugin.

Steps

Please let us know in an issue if we forgot anything!

Copy Plugin Base

  1. Fork thedropin.

  2. Change all dir names and references to this project’s name[1]_.

Dependencies

See instructions for installing Pipenv. Then run pipenv install --dev.

Developing Your Plugin

This is now where you get to get 🎨 creative! Good luck, have fun.

ETC

This is wading into dangerous territory to start recommending text-editor practices, but if you open your editor from inside the Pipenv shell, that may help your editor loading the proper environment-specific dependencies.

Tests

  1. pipenv run tests

Linting

  1. pipenv run lints

Sharing

Two great ways to share your code with the community.

Pelican Plugins Community Repo

See Contributing a plugin and Using Git and Github about adding a plugin to the pelican-plugins repo.

Publishing to PyPI

This is probably the hardest part, and is why I’d wager there are so few Pelican projects registered on PyPI[2]_. Begin with the manual steps. Afterwards, add support for the automated steps as soon as possible while everything is fresh in your head.

First Time

Your first time uploading a project to PyPI requires using Twine. All of the below commands can be found in the Pipfile [scripts] section for your convenience.

  1. pipenv shell Enter your dev environment where twine will be accessible.

  2. python setup.py sdist bdist_wheel Create a normal distribution.

  3. Register on PyPI.

  4. Think hard on your project name once more before uploading. Short lowercase 1 word names are best.

Optionally, you can do some checks on your distribution before attempting an official upload.

  1. Also register on TestPyPI if you intend to test your distribution before making it official.

  2. twine check dist/* Check the distribution you made in the second step.

  3. twine upload --repository testpypi dist/* Run a test of the upload. Preview at https://test.pypi.org/project/thedropin.

Back to the official upload steps..

  1. twine upload dist/* Upload your project to PyPI.

Continue below before you’re tired!

Automated Release to PyPI
  1. Visit https://pypi.org/manage/account/token/ to get your API token.

  2. Create a project-scoped token.

  3. gem install travis Install the Travis CLI.

  4. travis login Log into the CLI app. Use --com if you’ve opted into the https://travis-ci.com/ beta.

  5. travis encrypt "your-api-token" --com Override the token in this repo. Travis is migrating to Travis travis-ci.com.

  6. python ./release.py Save your changes and bump the version.

Try bumping the version and tags again using the release script. After you’ve found your groove with this, give yourself a pat on the back. Job well done!

Installation

The installation instructions for your new plugin will now be the following.

  1. pipenv install --dev thedropin

  2. update your pelicanconf.py’s plugins settings to include the following.

    import thedropin
    PLUGINS = [thedropin]

You can now include {{ article.emoji }} or {{ page.emoji }} in your templates. This can be overridden in the article, or page’s, metadata. For example, :emoji: 🧙.

References

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

thedropin-1.0.1.tar.gz (5.0 kB view details)

Uploaded Source

File details

Details for the file thedropin-1.0.1.tar.gz.

File metadata

  • Download URL: thedropin-1.0.1.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.7

File hashes

Hashes for thedropin-1.0.1.tar.gz
Algorithm Hash digest
SHA256 ca8efd552025156c59307bbe2e975d0a0aa6c3c08e7c14e2c9274c381d03e96c
MD5 e7c3fc4236b976381ecb3663dd86043c
BLAKE2b-256 851c97626384d56650d27da71dccd2a126c4a753b578021cc685c6edd9f81f16

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page