KDE Developer Documentation

Carl Schwan carl at carlschwan.eu
Wed Dec 25 01:45:17 GMT 2019


Salut Olivier,

Having the tutorial next to the code and that they break the compilation if they are out of date is an excellent idea. There is already something similar in Rust[1] were the example in the api documentation are compiled and executed as test. This make it quite easy to write examples that work. From my understanding, rustdoc work like this:

1. The library is build
2. The code example are extracted
3. Each code example is built separately, linked to the library and then ran as a unit test

For the case of our libraries:

1. is simple and we are already doing it in the ci :)
2. We would need to either extract the code our self from the code or the generated Doxygen documentation or maybe there is already a way in Doxygen to do it directly
3. I suppose we are already doing it when running autotests

But I'm not sure how difficult such a tool willl be to create. There are probably important details that I missed ;) Maybe it is also worth investigation if another open source project has already created such a tool for C++ and Doxygen documentation, and we can't just use their solution.
Regards,
Carl

[1]: https://doc.rust-lang.org/book/ch14-02-publishing-to-crates-io.html#making-useful-documentation-comments

Le mardi, décembre 24, 2019 1:19 PM, Olivier Churlaud <olivier at churlaud.com> a écrit :

> Hi all (and especially Juan Carlos),
> 

> I just read your report and it's very interesting. I agree with most of what you wrote.
> 

> I have some minor precisions to give about Techbase:
> 

> The goal was to remove (or only archive) the tutorials on techbase and replace them by examples within the framework. If having tutorials on a wiki is nice and findable, it is obsolete very soon after being written and we lack the resources for keeping an eye on every KDE library to curate and update the tutorial.
> 

> The conclusion of that was that tutorials need to live next to the frameworks they belong to AND that they break the compilation if they are out of date. I did some examples [1] and [2].It's a lot of work to do that, though, but at least it stays up to date. It could be loaded in api.kde.org in the future with snippets. That is basically what you propose, issue is that it was never finished. Pruning Techbase would really help as well. Porting the KDE4 Tutorials to KF5 in the wiki doesn't seem to me like the best idea because it's just moving the problem to the future.
>
> Except of this small remark, I really think you did an awesome job of synthesis that will be valuable for priorizing the work ahead.
> 

> Best regards
> Olivier
> 

> [1] https://phabricator.kde.org/D14955
> [2] https://phabricator.kde.org/D14957
> 

> Le lundi 23 décembre 2019, 12:00:43 CET Juan Carlos Torres a écrit :
> 

> > Greetings KDE developers and community members!
> > In March this year, we started on a journey to take stock of our developer
> > documentation and what needs to be done to make them not only more helpful
> > to current contributors but also more inviting to new ones as well as
> > external users of frameworks.
> > The formal work ended in June and I submitted a full report [1] that
> > included an analysis of the current state of developer documentation as
> > well as the proposed actions the community could take together in the
> > months and years ahead. Unfortunately, due to personal and family
> > circumstances, I was unable to follow the matter up and for that, I am
> > truly sorry.
> > Six months have passed since then and while the initial report still holds
> > true, events and situations have opened new opportunities for the community
> > to focus on. An updated report [2] was submitted to the e.V. reflecting
> > these small but important changes. Here is a brief summary of the points in
> > the reports.
> > 

> > 1.  With Qt 6 and KDE Frameworks 6 underway, it is both all the more
> >     important and also a perfect opportunity to update our API documentation
> >     and make sure that they are complete and in good quality.
> >     

> > 2.  There is a growing interest in mobile devices and convergent experiences
> >     which is a good chance to attract more developers into Kirigami and Plasma
> >     Mobile. Updating the developer documentation and documentation systems for
> >     these two projects will be important.
> >     

> > 3.  While still important in order to maintain an orderly environment,
> >     cleaning up and organizing the wikis now takes a lower priority. That said,
> >     certain aspects like guides for new contributors and external developers
> >     are just as or even more important now than ever.
> >     

> > 4.  Since many parts of the developer documentation, particularly those
> >     related to Frameworks, might be in a period of transition or rapid change,
> >     it might be more practical to focus on creating content first in a
> >     temporary staging ground before having writers deal with different systems
> >     and software. The Wikis are perhaps suited for this kind of workflow.
> >     

> > 

> > These are just some of the high-level points from the two reports and those
> > documents contain more precise suggestions for the next actions to take.
> > Again, I apologize to the community for dropping the ball for so long and I
> > am very excited to get it rolling again. Let's make KDE and its developer
> > documentation rock even more!
> > Attached files:
> > 

> > 1.  01 KDE Developer Documentation Update Project Report.pdf
> > 2.  02 KDE Developer Documentation Report Update - 2019-12-09.pdf
-------------- next part --------------
A non-text attachment was scrubbed...
Name: publickey - carl at carlschwan.eu - 0x7F564CB5.asc
Type: application/pgp-keys
Size: 3195 bytes
Desc: not available
URL: <http://mail.kde.org/pipermail/kde-community/attachments/20191225/45268317/attachment.key>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 823 bytes
Desc: OpenPGP digital signature
URL: <http://mail.kde.org/pipermail/kde-community/attachments/20191225/45268317/attachment.sig>


More information about the kde-community mailing list