[Qt-creator] Recommendations for 3rd-party QCH file installation folder for easy discovery?
Friedrich W. H. Kossebau
kossebau at kde.org
Mon Nov 21 21:40:31 CET 2016
Hi,
two questions to anyone working on/with QCH files:
Q1: what would be a good system path pattern (on *nixoid systems) for Qt-based
libraries to install their QCH files to?
Q2: And would/could there be some way to have 3rd-party QCH files
automatically added to Qt Assistant, Creator & Co. on installation, to spare
the user the additional manual step?
For Q1, I see all the Qt ones are on my system at
/usr/share/doc/packages/qt5/*.qch
So far I would have guessed
/usr/share/doc/$lib/$lib.qch
might be a good location. So what patterns do people use for their QCH files
when delivering to others as part of an install?
For Q2, having to manually add all QCH files one-by-one to Qt Assistant & Co.
does not nicely scale if there are a dozen and more 3rd-party QCH files (think
e.g. all the non-KF5 and KF5 libs created in the KDE community).
Would it perhaps make sense to have some registration system, so QCH files can
register themselves somewhere, so Qt Assistant/Creator & other documentation
viewers know what is present on the system?
Would some simple sym-linking into some generic dir make sense for a start?
The /usr/share/doc/packages/qt5 perhaps should be reserved to original Qt
ones, but perhaps some separate generic dir like
/usr/share/doc/qch
would work? Or something based on ENV vars, which would avoid hardcoding such
dirs into Qt Assistant & Co.?
Actually it would be nice if an installed QCH file would be automatically
added to Qt Assistant & Co., after all one installed it for a purpose. Are
there any plans with regard to that?
Background:
I am currently working on adding QCH support to the buildsystem for all the
libraries of the KDE Frameworks (and other (KDE) library products), for the
generation of QCH files during builds (https://phabricator.kde.org/D2854).
This is done with the goals that the API documentation of KDE Frameworks
libraries can be viewed/used offline with e.g. Qt Assistant, Qt Creator or
KDevelop, and that packagers/distributors of those libraries automatically
from the build also have a QCH file matching the very API version of the
library for packaging (& inclusion into in any package update mechanism).
The implementation of this support is done by new CMake macros which for now
make use of the QCH generation feature of doxygen. The macros even support the
automatic qthelp:// linking to documentation of base libraries, like the Qt
ones.
So once that support works, there will be dozens of QCH files which currently
would each need manual work by the user to have them added to Qt Assistant &
Co. Not perfect!
Cheers
Friedrich
More information about the Qt-creator
mailing list