tl; dr: GitEye = interfaz de usuario más intuitiva, flujo de trabajo más rápido, altamente personalizable
Soy un usuario avanzado de TortoiseHg Workbench y me encanta, por lo que, naturalmente, mis criterios completamente obstinados se basaron principalmente en ello:
* full history visible in main window
* beautiful tree (DAG), branches CLEARLY separated
* current branch clearly visible in history
* superclear list of changed/added files (list + diff detail)
* each changed/added file can be committed separately (or in groups)
* current branch clearly visible while committing
* clear push/pull etc buttons
* shelve = stash {not to be confused with patches}
* revert
* graft = cherry pick
* max git features
* HiDPI support
* all changes become visible on refresh
* refresh shortcut
Probé las siguientes aplicaciones:
- git-cola
- GitEye
- GITK
- git-gui
- QGit
- risilla
- tig
- SmartGit
- gitg
- RabbitVCS
- GitKraken
- GitX
- git-dag
- Bazaar Explorer + bzr-git
- TortoiseHg + hggit (la mejor interfaz de usuario, hggit no funciona)
Resultados
La mayoría de los clientes de git GUI probados son completos ****, a continuación se encuentran 2 de los mejores y 1 que no es tan **** como otros.
Leyenda
- = feature missing or so **** it doesn't count
~ = feature somewhat matches my requirements
+ = feature works like I want :)
1er lugar: GitEye
IU más intuitiva, el flujo de trabajo más rápido, altamente personalizable
~ full history visible in main window [in a separate tab, same UI pattern facilitates looking at the history of separate files]
+ beautiful tree (DAG), branches CLEARLY separated
+ current branch clearly visible in history
+ superclear list of changed/added files (list + diff detail)
+ each changed/added file can be committed separately
+ current branch clearly visible while committing
+ clear push/pull etc buttons
+ shelve = stash [Stashes clearly visible in sidepane]
+ revert
+ graft = cherry pick
+ max git features
~ HiDPI support
+ all changes become visible on refresh
- refresh shortcut [you can set one, but it wont work. bug?]
Nota: si la vista de archivos Git deja de funcionar en usted, use la vista similar de Git Staging
2do lugar: SmartGit
hermoso archivo integrado diff. cometer confusos, historial oculto, requiere una licencia
~ full history visible in main window [separate window, I found myself constantly confusing both windows]
- beautiful tree (DAG), branches CLEARLY separated
- current branch clearly visible in history
+ superclear list of changed/added files (list + diff detail)
~ each changed/added file can be committed separately [UI not clear enough]
- current branch clearly visible while committing
+ clear push/pull etc buttons
+ shelve = stash
+ revert
+ graft = cherry pick
+ max git features
+ HiDPI support
+ all changes become visible on refresh [refreshes automatically]
+ refresh shortcut [refreshes automatically]
3er lugar: QGit
Se puede agregar una hermosa historia clara, confirmar UX, comandos livianos, livianos y personalizados
+ full history visible in main window
+ beautiful tree (DAG), branches CLEARLY separated
+ current branch clearly visible in history
~ superclear list of changed/added files (list + diff detail) [doesn't show new files in main window]
- each changed/added file can be committed separately
- current branch clearly visible while committing
~ clear push/pull etc buttons [could be added via custom commands]
- shelve = stash
- revert
- graft = cherry pick
- max git features
+ HiDPI support
~ all changes become visible on refresh [except for new files]
+ refresh shortcut
Mención de honor: GitKraken
Todavía está en sus fases de desarrollo (1.5.1 aún no cuenta con soporte HiDPI), pero realiza el trabajo básico. Esto podría competir fácilmente con GitEye y SmartGit. Es mejor que QGit seguro.
Todo el resto:
Estoy decepcionado por el tipo de **** hecho para pasar como cliente git. Supongo que sus autores piensan que es más eficiente hacer cosas simples todos los días en la línea de comandos y han basado a sus clientes en ese flujo de trabajo ineficiente.
git mergetool
. Prefiero la GUI de fusión como la herramienta de combinación.