Contributing to TLDR (collaborative cheatsheets for console commands)
Assumed audience: developers interested in Command-Line Interface tools and in contributing to Open Source Projects.
My first contributions to the tldr
open-source project
Since a few months, I occasionally contribute to tldr
(also known as tldr-pages
) which describes as:
Collaborative cheat-sheets for console commands
See my contributions).
This blog post lists the good and bad parts of these contributions.
The good parts ๐
Share my "local knowledge" ๐
Many commands that were only in my Unix shell history or in my head are now shared to all tldr
usersโฆ and to my-self!
I can now retrieve my favorite commands typing tldr <command_name>
, i.e. tldr espanso
since my contribution #5662 :
$ tldr espanso
espanso
Cross-platform Text Expander written in Rust.
More information: <https://espanso.org>.
- Check status:
espanso status
- Edit the configuration:
espanso edit config
- Install a package from the hub store (<https://hub.espanso.org/>):
espanso install package_name
- Restart (required after installing a package, useful in case of failure):
espanso restart
And it's easier that searching my shell history:
$ history | grep espanso
4998 brew tap federico-terzi/espanso
4999 brew install espanso
5000 espanso register
5001 mkdir espanso
5002 cd espanso
5013 espanso stop
5014 espanso start
5015 espanso path
A welcoming community ๐ค
Contributors were welcoming and encouraged me without putting any pressure. My feelings are mainly related to the comments on pull requests / issues, for example this kind comment:
Welcome to tldr-pages, @nicokosi! โก ๐
However, I hardly used the Gitter discussion board. I think I'm not active enough (I contribute a few minutes / hours per week) to be able to keep up with the flow of trade!
Learn new commands ๐จโ๐
While reviewing the contributions (pull requests), I sometimes discovered new commands/discovered new options.
For example, I learned that it was possible to format the return of the GitHub CLI command gh
as JSON via [this pull request gh-formatting: add page # 6290
] (https://github.com / tldr-pages / tldr / pull / 6290 / files? short_path = 193df31 # diff-193df31fff2a4e88a95b3bd8732bead1fbbe8343eb8617ed1b727e4d1ba4d751):
Formatting options for JSON data exported from gh GitHub CLI command. More information: https://cli.github.com/manual/gh_help_formatting. Display help about formatting JSON output from gh using jq: gh formatting
Learn to compromise โ๏ธ
I have learned to accept feedback from others and sometimes to accept a majority opinion that is not mine.
Example: using the term slug
in an authentication context for this post.
The bad parts ๐
Time-consuming โณ
Contributors on OSS project do this on their free time. Moreover, when collaborating on pull requests, everything is done writing in English, but we are not all bilingual. So collaboration/contribution is not always easy and can take time.
Example of misunderstanding (link):
Yes, it does seem that only common is shown, anyway that can be fixed since a user might think we have a lack of pages if we only show them.
Sorry, I don't understand after "anyway".
Example of slowness: it took a little less to integrate this contribution, Prevent search misses via input's placeholder / tooltip
.
No user feedback ๐งโ๐ฆฏ
Only contributors give feedback via pull requests or issues GitHub. There are no metrics such as "number of views", "rating" etc. therefore we do not really know the use of examples (which is a good thing for confidentiality)..
What's next? ๐
Contribute on code rather than documentation? ๐งโ๐ป
On this project or on another? To be continued! ๐ฎ