Explanation
History and Motivation
During the first phase of Sienna's (previously SIIP's) development, Sienna used a 3-part documentation organization, based on the expected needs of different user personas:
- Modeler: Users that want to use existing functionality
- Model Developer: Users that want to develop custom structs, components, models, and/or workflows
- Code Base Developers: Users that want to add new core functionalities or fix bugs in the core capabilities
However, as Sienna's user base has expanded, it has become apparent that this previous organization is no longer serving. As of 2024, a new effort is underway to clean up and re-organize the Sienna documentation according to the 4-part Diataxis framework, a well-established, systematic approach to technical documentation split up into:
In addition, the current documentation has multiple quality issues, including misformatted text, broken reference links, and documentation that has been written but is not visible to users in the API ("missing docstrings"). While the style guide has been available, the guide focuses primarily on the style of code itself, without providing clear guidelines and best practices for other parts of the documentation besides docstrings. In addition, the first stage of Sienna's development coincided with the initial development of the Documenter.jl package. Early versions of Sienna's packages were documented requiring Documenter.jl v0.27, and in the meantime, Documenter.jl has released its v1.0 and onwards, which contain much more rigorous checks for documentation quality. Sienna's packages have not kept up with these improvements.
Purpose of the Documentation Best Practices
We aim to remedy the historical issues above through a concerted clean up and re-organization effort and compliance with Documenter.jl >v1.0's quality control checks, following these best practice guidelines. These guidelines are not intended to reiterate Diataxis, beyond regularly reminding contributers to refer to them – and contributers should read the Diataxis website in its entirety before getting started. Instead, the best practices are intended to bridge the gap where there are Julia- or Sienna-specific recommendations, either to consistently implement the Diataxis framework or to highlight common documentation issues throughout the Sienna packages that need to be addressed as part of our concerted clean-up effort.