Skip to content

A novel approach to documenting command line tools written in shell-script.

License

Notifications You must be signed in to change notification settings

madworx/docshell

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Build Status

docshell

A novel approach to documenting command line tools written in shell-script.

Rationale

Typically in Software development, documentation has a tendency to be perceived as being boring to do all fall behind the regular development process.

By keeping documentation tightly knit to the source code, we increase the likelihood of the documentation being up-to-date; For more advanced programming languages, there's already lots of good frameworks for this.

Shell-scripts prove to be an interesting domain in that aspect -- shell-scripts are typically expected to be portable across operating systems, shell language variants; There also, de facto, doesn't exist a single authoritative specification on how the "language"(s) actually works, and different vendors have over time implemented different functionality.

Goals

Three important factors are:

  • portability (being able to run on a diverse set of operating systems and shell dialects)

  • low dependency on external utilities (not assuming that specific tools are installed in the environment the script is being run in),

  • as well as having a small footprint. (low SLOC for the framework itself)

By placing the documentation at the top of the file, it is the first thing a developer sees when opening up the script in the editor -- this will hopefully provide a "hint" as to update the documentation if details in the script change.

Also, by attempting to produce good-looking --help output, combined with dynamic features (such as default value variable expansion) we further hope that the developer in question will see the point in keeping the documentation always-up-to-date.

Compatability

Compatability with various shells and operating systems are automatically tested and reports are published on the following Wiki page:

Further reading

Author

Martin Kjellstrand martin.kjellstrand@madworx.se

About

A novel approach to documenting command line tools written in shell-script.

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published