Documentation du code source

From FreeCAD Documentation
Revision as of 13:29, 19 November 2019 by Mario52 (talk | contribs)

Le code source de FreeCAD est commenté pour permettre la génération automatique de documentation HTML à l'aide de Doxygen, un système de documentation de code source populaire. Doxygen peut documenter les parties C++ et Python de FreeCAD, générant ainsi des pages HTML avec des hyperliens vers chaque fonction et classe documentées.

La documentation source hébergée en ligne sur web. Veuillez noter que cette documentation n'est pas toujours maintenue à jour. Si vous avez besoin de plus de détails, téléchargez le dernier code source de FreeCAD et compilez vous-même la documentation. Si vous avez des questions urgentes sur le code, veuillez les poser dans la section développeurs du FreeCAD forum.

La compilation de la documentation de l'API suit les mêmes étapes générales que la compilation de l'exécutable FreeCAD, comme indiqué dans la page de compilation sous Unix.

Flux de travail général pour compiler la documentation de programmation de FreeCAD. Les packages Doxygen et Graphviz doivent être dans le système, ainsi que le code source FreeCAD lui-même. CMake configure le système de telle sorte qu'avec une seule instruction make, la documentation de l'ensemble du projet soit compilée dans de nombreux fichiers HTML avec des diagrammes.

Compilation de la documentation

Si vous avez installé Doxygen, il est très facile de construire la documentation. Installez également Graphviz pour pouvoir produire des diagrammes montrant les relations entre différentes classes et bibliothèques dans le code FreeCAD. Graphviz est également utilisé par graphe de dépendance de FreeCAD pour montrer les relations entre différents objets.

sudo apt install doxygen graphviz

Suivez ensuite les mêmes étapes que pour compiler FreeCAD, comme décrit à la page Compiler sous Unix, et résumées ici pour plus de commodité.

  • Obtenez le code source de FreeCAD et placez-le dans son propre répertoire freecad-source.
  • Créez un autre répertoire freecad-build dans lequel vous compilerez FreeCAD et sa documentation.
  • Configurez les sources avec cmake, en vous assurant d'indiquer le répertoire source et de spécifier les options requises pour votre construction.
  • Déclenchez la création de la documentation avec make.
git clone https://github.com/FreeCAD/FreeCAD.git freecad-source
mkdir freecad-build
cd freecad-build
cmake -DBUILD_QT5=ON -DPYTHON_EXECUTABLE=/usr/bin/python3 ../freecad-source

Pendant que vous êtes dans le répertoire de compilation, émettez les instructions suivantes pour ne créer que la documentation.

make -j$(nproc --ignore=2) DevDoc

Comme mentionné dans Compilation (Accélération), l'option -j définit le nombre de cœurs de processeur utilisés pour la compilation. Les fichiers de documentation résultants apparaîtront dans le répertoire

freecad-build/doc/SourceDocu/html/

Le point d’entrée de la documentation est le fichier index.html, que vous pouvez ouvrir avec un navigateur Web:

xdg-open freecad-build/doc/SourceDocu/html/index.html

La cible DevDoc générera une quantité importante de données, environ 5 Go de nouveaux fichiers, en raison notamment des diagrammes créés par Graphviz.

Une autre version plus petite de la documentation, qui ne nécessite qu'environ 600 Mo, peut être générée avec une cible différente. Ceci est la version affichée sur le site Web de l'API FreeCAD.

make -j$(nproc --ignore=2) WebDoc

Autres versions

Comme alternative, la doc est générée de temps en temps, et est accessible sur sourceforge ici.

FreeCAD 0.16 development documentation construite par qingfeng.xia.

FreeCAD 0.19 development documentation construite par qingfeng.xia.

Intégrer la documentation Coin3D

Sur les systèmes Unix, il est possible de lier la documentation source Coin3D avec FreeCAD. Cela facilite la navigation et complète les diagrammes d'héritage pour les classes dérivées de Coin.

  • Installez le libcoin-doc, libcoin80-doc, ou un paquetage similaire.
  • Décompressez l'archive coin.tar.gz située dans /usr/share/doc/libcoin-doc/html; les fichiers sont peut-être déjà décompressés dans votre système.
  • Générez à nouveau la documentation source.

Si vous n'installez pas le package de documentation pour Coin, les liens seront générés pour accéder à la documentation en ligne à l'adresse BitBucket. Cela se produira si un fichier de balise Doxygen peut être téléchargé au moment de la configuration avec wget.

Utiliser Doxygen

Voir la page Doxygen pour une explication détaillée sur la façon de commenter le code source C++ et Python afin qu'il puisse être traité par Doxygen pour créer automatiquement la documentation.

Essentiellement, un bloc de commentaires commençant par /** ou /// pour C++, ou ## pour Python, doit apparaître avant chaque définition de classe ou de fonction, afin qu’elle soit sélectionnée par Doxygen. De nombreuses commandes spéciales, commençant par \ ou @, peuvent être utilisées pour définir des parties du code et formater la sortie. La syntaxe Markdown est également comprise dans le bloc de commentaires, ce qui facilite la mise en évidence de certaines parties de la documentation.

/**
 * Returns the name of the workbench object.
 */
std::string name() const;

/**
 * Set the name to the workbench object.
 */
void setName(const std::string&);

/// remove the added TaskWatcher
void removeTaskWatcher(void);