So you've written a blocklet for i3blocks and would like to share it with the community, great! Let's just set a few ground rules in order to get your blocklet included.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119.
- A blocklet MUST be confined to a single directory and the name of the directory MUST be relevant to the blocklet's purpose or core feature.
- A blocklet MUST be human readable.
- A blocklet MUST contain a
README.md
explaining what the blocklet does, what its dependencies are, and any special instruction or setup required to use it. - A suggested i3blocks configuration MUST be included in an
i3blocks.conf
file or within theREADME.md
. - Any non-obvious assumptions required to make the configuration work SHOULD
be included either in the
README.md
or as comments in the configuration. - A blocklet's suggested command SHOULD be of the form
command=$SCRIPT_DIR/myscript [args...]
even if the script is a single line. - The command file (
myscript
above) SHOULD be the entirety of the executable part of your blocklet, i.e. your code is a single script. - The command file's name, SHOULD match the name of the
containing directory. E.g.
myscript/myscript
is a good name, butmyscript/yourscript
is not. - A blocklet SHOULD NOT have a separate non
i3blocks.conf
configuration file. Any extra configuration (e.g. default colors, paths, etc.) SHOULD be contained in the command file near the top. - A blocklet MUST include at least one screenshot of what it looks like in action.
- A blocklet MAY require building, but if it does the build process SHOULD be
as simple as possible (preferably nothing more than running
make
) - A blocklet SHOULD include a
LICENSE
file. - A blocklet MAY include a
.gitignore
file.
- Listing standard utilities as dependencies is OPTIONAL.
- If a blocklet requires a specific minimum version of a program, that program SHOULD be listed as a dependency, and the minimum version SHOULD be listed as well.
- Every commit being merged in a pull request MUST begin with the name of the
blocklet it concerns, .e.g.
myscript: update colors
- A contributor with write access MUST NOT merge any pull request that he or she created, unless there are no other contributors with write access currently active.
- Commit messages SHOULD be written in imperative form. E.g.
myscript: add option to configure colors
, instead ofmyscript: added option to configure colors
. - Commit message first lines SHOULD be 72 characters or less but descriptive, and details MAY be added to subsequent lines.
- Commit details SHOULD write
Fixes: [issue]
orCloses: [issue]
if the commit is meant to fix/close an issue on the issues page. - A pull request SHOULD contribute significant change to exactly one blocklet. A bug fix or new command line option will usually be considered a significant change.
In case you have never made a pull request before, here is an example workflow.
- You write and test your blocklet called
myscript
. - You write a
README.md
andi3blocks.conf
to go with your script, make ascreenshot.png
and putmyscript
,README.md
,i3blocks.conf
,screenshot.png
, and your favoriteLICENSE
into a directory calledmyscript
. - You fork the i3blocks-contrib repository on github, and clone your fork of
i3blocks-contrib onto your computer with
git clone [your fork here]
. - You copy your
myscript
directory to the top level of the cloned i3blocks-contrib directory and change to the top level directory. - You
git add myscript
to tell git to track your blocklet's directory, you will need to do this before every commit. - You
git commit
and leave a commit message of the formmyscript: add myscript, a short description of myscript
- Perhaps you make a few last minute changes, and add another commit.
- You squash your commits into one with
git rebase -i
and follow the instruction, leaving only your first commit and commits that were already there unsquashed. - You push your changes to your fork on github with
git push
. - You navigate to vivien's i3blocks-contrib, click "pull requests" and "New pull request". You click "compare across forks", then select the base as vivien's i3blocks-contrib and the head fork as yours. You click "Create pull request".
- The community makes some comments and suggests some things to improve before your blocklet is accepted.
- You add and commit changes to your local copy, and then squash them as before, so that there are only two commits besides those that were there when you first forked, your initial commit and one representing all the changes made to address community concerns.
- You push to your remote fork of i3blocks-contrib, and the changes automatically get incorporated into the pull request process.
- A maintainer with write access to vivien's i3blocks-contrib decides your script is ready to be merged and merges it in, possibly making minor changes of their own in the process.
Whenever you make a significant change to your blocklet or fix a bug, squash your local commits since your last pull request and replace the commit message with something of the form
myscript: what has changed since last pull request
More detailed description of changes, perhaps including:
Change 1
Change 2
Change 3
Then push to your remote fork, navigate to vivien's, and make a new pull request.