CLI interface for managing a folder based zettelkasten using emacs org-mode file zettels and a bibtex reference system
Project description
zettelkasten
Very first steps
Initial
- Initialize
gitinside your repo:
git init
- If you don't have
Poetryinstalled run:
make download-poetry
- Initialize poetry and install
pre-commithooks:
make install
- Upload initial code to GitHub (ensure you've run
make installto usepre-commit):
git add .
git commit -m ":tada: Initial commit"
git branch -M main
git remote add origin https://github.com/tZ3ma/zettelkasten.git
git push -u origin main
Initial setting up
- Set up Dependabot to ensure you have the latest dependencies.
- Set up Stale bot for automatic issue closing.
Poetry
All manipulations with dependencies are executed through Poetry. If you're new to it, look through the documentation.
Notes about Poetry
Poetry's commands are very intuitive and easy to learn, like:
poetry add numpypoetry run pytestpoetry build- etc
Building your package
Building a new version of the application contains steps:
- Bump the version of your package
poetry version <version>. You can pass the new version explicitly, or a rule such asmajor,minor, orpatch. For more details, refer to the Semantic Versions standard. - Make a commit to
GitHub. - Create a
GitHub release. - And... publish 🙂
poetry publish --build
What's next
Well, that's up to you. I can only recommend the packages and articles that helped me.
Packages:
Typeris great for creating CLI applications.Richmakes it easy to add beautiful formatting in the terminal.FastAPIis a type-driven asynchronous web framework.IceCreamis a little library for sweet and creamy debugging
Articles:
- Open Source Guides
- GitHub Actions Documentation
- Maybe you would like to add gitmoji to commit names. This is really funny. 😄
🚀 Features
For your development we've prepared:
- Supports for
Python 3.7and higher. Poetryas the dependencies manager. See configuration inpyproject.tomlandsetup.cfg.- Power of
black,isortandpyupgradeformatters. - Ready-to-use
pre-commithooks with formatters above. - Type checks with the configured
mypy. - Testing with
pytest. - Docstring checks with
darglint. - Security checks with
safetyandbandit. - Well-made
.editorconfig,.dockerignore, and.gitignore. You don't have to worry about those things.
For building and deployment:
GitHubintegration.Makefilefor building routines. Everything is already set up for security checks, codestyle checks, code formatting, testing, linting, docker builds, etc. More details at Makefile summary).- Dockerfile for your package.
Github Actionswith predefined build workflow as the default CI/CD.- Always up-to-date dependencies with
@dependabot(You will only enable it). - Automatic drafts of new releases with
Release Drafter. It creates a list of changes based on labels in mergedPull Requests. You can see labels (akacategories) inrelease-drafter.yml. Works perfectly with Semantic Versions specification.
For creating your open source community:
- Ready-to-use Pull Requests templates and several Issue templates.
- Files such as:
LICENSE,CONTRIBUTING.md,CODE_OF_CONDUCT.md, andSECURITY.mdare generated automatically. Stale botthat closes abandoned issues after a period of inactivity. (You will only need to setup free plan). Configuration is here.- Semantic Versions specification with
Release Drafter.
Installation
pip install -U zettelkasten
or install with Poetry
poetry add zettelkasten
Then you can run
zettelkasten --help
zettelkasten --name Roman
or if installed with Poetry:
poetry run zettelkasten --help
poetry run zettelkasten --name Roman
Makefile usage
Makefile contains many functions for fast assembling and convenient work.
1. Download Poetry
make download-poetry
2. Install all dependencies and pre-commit hooks
make install
If you do not want to install pre-commit hooks, run the command with the NO_PRE_COMMIT flag:
make install NO_PRE_COMMIT=1
3. Check the security of your code
make check-safety
This command launches a Poetry and Pip integrity check as well as identifies security issues with Safety and Bandit. By default, the build will not crash if any of the items fail. But you can set STRICT=1 for the entire build, or you can configure strictness for each item separately.
make check-safety STRICT=1
or only for safety:
make check-safety SAFETY_STRICT=1
multiple
make check-safety PIP_STRICT=1 SAFETY_STRICT=1
List of flags for
check-safety(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT.
4. Check the codestyle
The command is similar to check-safety but to check the code style, obviously. It uses Black, Darglint, Isort, and Mypy inside.
make check-style
It may also contain the STRICT flag.
make check-style STRICT=1
List of flags for
check-style(can be set to1or0):STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.
5. Run all the codestyle formaters
Codestyle uses pre-commit hooks, so ensure you've run make install before.
make codestyle
6. Run tests
make test
7. Run all the linters
make lint
the same as:
make test && make check-safety && make check-style
List of flags for
lint(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.
8. Build docker
make docker
which is equivalent to:
make docker VERSION=latest
More information here.
📈 Releases
You can see the list of available releases on the GitHub Releases page.
We follow Semantic Versions specification.
We use Release Drafter. As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you’re ready. With the categories option, you can categorize pull requests in release notes using labels.
For Pull Request this labels are configured, by default:
| Label | Title in Releases |
|---|---|
enhancement, feature |
🚀 Features |
bug, refactoring, bugfix, fix |
🔧 Fixes & Refactoring |
build, ci, testing |
📦 Build System & CI/CD |
breaking |
💥 Breaking Changes |
documentation |
📝 Documentation |
dependencies |
⬆️ Dependencies updates |
You can update it in release-drafter.yml.
GitHub creates the bug, enhancement, and documentation labels for you. Dependabot creates the dependencies label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.
🛡 License
This project is licensed under the terms of the MIT license. See LICENSE for more details.
📃 Citation
@misc{zettelkasten,
author = {tZ3ma},
title = {Folder based zettelkasten with a bibtex reference system and emacs org-mode file zettels},
year = {2021},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/tZ3ma/zettelkasten}}
}
Credits
This project was generated with python-package-template.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zettelkasten-0.2.3.tar.gz.
File metadata
- Download URL: zettelkasten-0.2.3.tar.gz
- Upload date:
- Size: 29.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.5 Linux/4.15.0-132-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d82580a17494b80915d0217b7ec7b55050c5d1bfffa8e85099660643d7ed947c
|
|
| MD5 |
16376fa3081e518762439297a4dac836
|
|
| BLAKE2b-256 |
3fea876a5980f7bf0f9b8ac73975a0f5575d90cc1cf40fa016e527654ca3b71f
|
File details
Details for the file zettelkasten-0.2.3-py3-none-any.whl.
File metadata
- Download URL: zettelkasten-0.2.3-py3-none-any.whl
- Upload date:
- Size: 28.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.5 Linux/4.15.0-132-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2389b5143aa822943136e7fe11f756129e04b48cfceea2d2b360fe48c71e1fc4
|
|
| MD5 |
304593cda7a635f03b8b4d00d8f9b859
|
|
| BLAKE2b-256 |
73c2d5f2d264090b6dc6b1052f72f2354554daeb067eaf2aa80b7f3f73f50abb
|