Debugging/it

Prova preliminare
Prima di provare il debug usare il framework (macro) di test per verificare se i test standard funzionano correttamente. Se non funzionano, è possibile che l'installazione sia danneggiata.

Riga di comando
Il debug di FreeCAD è supportato da alcuni meccanismi interni. La versione a riga di comando di FreeCAD fornisce delle opzioni di supporto del debug:


 * -v: Con la opzione "v" FreeCAD fornisce un output più dettagliato.
 * -l: Con la opzione "l" FreeCAD scrive informazioni aggiuntive in un file di log.

Generare un Backtrace
Se si esegue una versione sperimentale di FreeCAD ancora in fase sviluppo, essa potrebbe "bloccarsi". Si può aiutare a risolvere questi problemi, fornendo agli sviluppatori un "backtrace". Per fare questo, è necessario eseguire un "debug build" del software. "Debug build" è un parametro che viene impostato al momento della compilazione, perciò bisogna autocompilare FreeCAD, oppure ottenere una versione "debug" pre-compilata.

Per Linux
Prerequisiti:


 * pacchetto software gdb installato
 * un debug build di FreeCAD
 * un modello di FreeCAD che causa un crash

Passaggi:

Immettere quanto segue nella finestra del terminale: Ora FreeCAD viene avviato. Effettuare le operazioni che causano il crash di FreeCAD, quindi immettere 'bt' nella finestra del terminale. Questo genera una lunga lista che descrive esattamente ciò che il programma stava facendo quando è andato in crash. Includere questa lista nel vostro rapporto sul problema.

Python debugging
Ecco un esempio di utilizzo di winpdb all'interno di FreeCAD:


 * 1) Eseguire winpdb e impostare la password (ad esempio test)
 * 2) Creare un file Python con questo contenuto
 * 1) Avviare FreeCAD e caricare il file precedente in FreeCAD.
 * 2) Premere F6 per eseguirlo.
 * 3) Ora FreeCAD non risponde perché il debugger Python è in attesa
 * 4) Passare alla GUI di Windpdb e cliccare su "Attach". Dopo pochi secondi appare una voce "" su cui si deve fare doppio clic.
 * 5) Ora in Winpdb viene visualizzato lo script attualmente in esecuzione.
 * 6) Impostare un break nell'ultima riga e premere F5.
 * 7) Ora premere F7 per emtrare nel codice Python di Draft.makeWire