Personally I wish it remained so. From an end-user perspective the structural regularity of generated docs is more important. Leaving these things to the producer’s tastes is not such a good idea.
I don’t especially agree,
I’m thinking of the library: data-encoding. The main module data_encoding.mli provides multiple utilities, but they kind all depend on a sub-module Encoding .
The whole library works only because of that sub module and its documentation is as much important as the library entry point documentation.
Here, I defined one module per protocol message. Each 9P message typically has 0-3 fields that are unique to that message, so initially I wanted to expand the sub-module documentation into this parent page, and only document the unique fields. The common fields could have been documented elsewhere. I thought it would be nicer if readers could see the signatures and docs on the same page.
Looking at the generate docs for this module (https://docs.ocaml.pro/html/LIBRARY.data_encoding@data-encoding.0.2/Data_encoding/index.html), it looks pretty good to me; the Encoding module signature is quite large and warrants its own page, in my opinion. Ocamldoc comments for the module itself could be added to summarize it and describe its importance, and those would appear in the parent module’s page.
@vch9 I’m not saying you won’t be able to find examples where the feature makes sense.
The problem is that everyone will have a different definition of what is small, or some will have the impression that it’s always better to inline everything regardless of the size of the module. So in aggregate docsets like those generated by odig for your opam switches, you get an unpredictable structure for end users (starting with the hackability of URLs).
Now someone of course will say oh but you should be able to override it on the cli of odoc but that’s not good either because the way you write your docs does depend on the structure of the output, so you don’t want to be betrayed by it later.