This extension serves as a support for the users interested in developing their own extension for PyScaffold. It configures your project so that you can start writing your extension logic and tests right away, taking care of all the wiring required to conform to PyScaffold’s needs.

Let’s say you want to create an extension named notebooks that creates a notebooks folder with some template Jupyter notebook. After having installed this extension with:

pip install pyscaffoldext-custom-extension

you will be able to just use it with:

putup --custom-extension notebooks

This will create a typical PyScaffold project template with some modifications:

  • the topmost namespace will be pyscaffoldext to have a unified namespace for PyScaffold extensions,
  • assures that the project is named pyscaffoldext-notebooks in setup.cfg,
  • sets the correct setup_requires and install_requires as well as the options.entry_points parameters in setup.cfg,
  • automatically activates the extensions --no-skeleton, --pre-commit, --travis and --tox since we want clean-coded, high-quality extensions,
  • creates a module holding a class Notebooks which serves you as a template for your extension,
  • adds basic unit tests checking that the invocation of your extension works and that it complies with our flake8 code guidelines,
  • provides a modified README.rst indicating that this is a PyScaffold extensions and how to install it.


For more information about PyScaffold and its extension mechanism, check out

Indices and tables