WebTools Git/it

Descrizione
Questo comando consente di eseguire il commit del documento attivo a un repository GIT. Il documento attivo deve già essere stato salvato in precedenza, e fare già parte di un repository GIT, configurato al di fuori di FreeCAD.

Git is a complex tool, consider learning the basics of it before using this tool, to avoid wrong operations that can cause data loss. An abundant literature about GIT is available and easy to find on the internet.

Current limitations:


 * The tool cannot create new repositories yet. You must have an existing local repository already created (FreeCAD will check if the current document file is inside a Git repository)
 * The tool cannot change or create branches. You must do that manually with standard Git tools.

Note: Per essere in grado di utilizzare questo comando, sul sistema deve essere installato il pacchetto gitpython. Sulla maggior parte delle distribuzioni Linux, gitpython è disponibile nei repository software standard come gitpython o python-git.

Utilizzo

 * 1) Salvare il documento attivo corrente
 * 2) Assicurarsi che il file salvato è già parte di un repository git
 * 3) Selezionare il menu Arch -> Utilità ->

Opzioni



 * Si può fare il commit del solo file FreeCAD, o di tutti i file modificati presenti nel repository GIT.
 * Opzionalmente, Si può anche conferire nel ramo di default remoto del GIT corrente.

Enabling human-readable diff for FCStd files
FreeCAD's Fcstd file format is a zip-based binary format, for which Git cannot produce proper diffs. This means that you cannot see what has changed between one version and another, and also that each new version stored in the Git repository is a full copy of the file.

Although the second problem currently has no solution, the first one can be solved with a little tool available from the FreeCAD source code, called fcinfo. Git can be told to use the fcinfo utility to print a human-friendly report of a FCStd file, and, when asked to produce a diff between two FCStd files, will produce a diff between the two fcinfo reports instead. Please note that this is only visual feedback, a full copy of the file will still be stored internally.

Example of a diff produced with fcinfo:

Each FreeCAD file contains a SHA1 checksum number, which will change each time the file is saved, even if no contents was changed. So fcinfo will always print something, no matter of the contents changes.

To enable the use of fcinfo (Linux and Mac only - TODO: add Windows instructions)

*.FCStd diff=fcinfo
 * 1) Save the fcinfo file somewhere in your system path
 * 2) Make it executalbe
 * 3) Create a .gitattributes file in your Git repository
 * 4) Add the following line in it: