/** \page About About \section about_history History The implementation of this documentation set is based on the fantastic work of the Eigen project. Please refer to their GitLab repository and the online version of their Doxygen-based documentation. Not only does Eigen set a standard as a piece of software, but also as an example of documentation done right. \section about_documentation Documentation about Documentation In this section, we describe common documentation maintenance tasks. \subsection plain_html Including Plain HTML Pages The most common use case for this is the inclusion of older documentation. New documentation should, whenever possible, be created using Doxygen markdown! Use Doxygen's htmlinclude special command to include existing plain HTML pages. An example from this documentation set can be seen here. \subsection new_rm_entry Creating a New Reference Manual Entry Please refer to the \ref RMT for guidance on how to create a new reference manual entry. \subsubsection new_example Adding and Referencing API Examples For each HDF5 module, such as \Code{H5F}, there is an examples source file called \Code{H5*_examples.c}. For example, the \Code{H5F} API examples are located in H5F_examples.c. Examples are code blocks marked as Doxygen snippets. For example, the source code for the H5Fcreate() API sample is located between the \verbatim //! ... //! \endverbatim comments in H5F_examples.c. Add a new API example by adding a new code block enclosed between matching snippet tags. The name of the tag is usually the function name stripped of the module prefix. The inclusion of such a block of code can then be triggered via Doxygen's snippet special command. For example, the following markup \verbatim * \snippet H5F_examples.c create \endverbatim yields \snippet H5F_examples.c create \subsubsection api_macro Adding an API Macro API macros are handled by the api_vers_2, api_vers_3, api_vers_4 custom commands. The numbers indicate the number of potential API function mappings. For example, H5Acreate() has two potential mappings, H5Acreate1() and H5Acreate2(). To trigger the creation of a reference manual entry for H5Acreate() use the following markup: \verbatim \api_vers_2{H5Acreate,H5Acreate1,H5Acreate2} \endverbatim This yields: \api_vers_2{H5Acreate,H5Acreate1,H5Acreate2} \subsection custom_commands Creating Custom Commands See Doxygen's Custom Commands documentation as a general reference. All custom commands for this project are located in the aliases file in the doxygen subdirectory of the main HDF5 repo. The custom commands are grouped in sections. Find a suitable section for your command or ask for help if unsure! \subsection new_rfc Adding a New RFC or Referencing an Existing RFC For ease of reference, we define custom commands for each RFC in the RFCs section of the aliases file. For example the custom command \Code{ref_rfc20141210} can be used to insert a reference to "RFC: Virtual Object Layer". In other words, the markup \verbatim \ref_rfc20141210 \endverbatim yields a clickable link: \ref_rfc20141210 To add a new RFC, add a custom command for the RFC to the aliases file. The naming convention for the custom command is \Code{ref_rfcYYYYMMDD}, where \Code{YYYYMMDD} is the ID of the RFC. The URL is composed of the prefix \verbatim https://\RFCURL/ \endverbatim and the name of your RFC file, typically, a PDF file, i.e., the full URL would be \verbatim https://\RFCURL/my_great_rfc_name.pdf \endverbatim \subsection hosting How Do Updates and Changes Get Published? Currently, the files underlying this documentation website are stored in an bucket on AWS S3. The top-level bucket is
s3://docs.hdfgroup.org/hdf5/
There are folders for the development branch and all supported release version. Talk to your friendly IT-team if you need write access, or you need someone to push an updated version for you! */