Magit (/ˈmædʒɪt/ MA-jit or /ˈmʌɡɪt/ MUH-git[3]) is an interface to the Git version control system, available as a GNU Emacs package[4][5] written in Emacs Lisp. It is available through the MELPA package repository,[6] on which it is the most-downloaded non-library package, with over 4.3 million downloads as of September 2024.[7]

Magit
Original author(s)Marius Vollmer
Developer(s)Jonas Bernoulli, Kyle Meyer, and Noam Postavsky
Stable release
4.0.0.[1] / August 8, 2024; 3 months ago (2024-08-08)[2]
Repositorygithub.com/magit/magit
Written inEmacs Lisp
Type
  • Git client
  • Text editor plugin
LicenseGPL-3.0-or-later
Websitemagit.vc

Like many graphical user interfaces, Magit provides a visual interface to represent version control actions; however, it uses a keyboard-centric model, and also functions as a text-based user interface.[a] The issue of key-memorization is mitigated through use of a popup menu which displays the actions available to the user[8] — serving as a mnemonic aid.[9]

History

edit

Magit was created by Marius Vollmer in 2008,[10] with Jonas Bernoulli assuming the role of maintainer in 2013.[11] Since its release, Magit has seen a high degree of community involvement, with 350 individuals[12] having contributed code to this free software project as of September 2020.

In 2018 Magit underwent a Kickstarter funding campaign[13] which aimed to fund the maintainer for a year of work. The fundraising was successful and resulted in the project being the 27th most funded software project on Kickstarter.[14] Since the Kickstarter funded period expired donations are encouraged to support the authors development via direct payments, GitHub's sponsorship program and various other crowdfunding services.[15]

Functionality

edit
 
A Magit buffer displaying the Emacs git repository's log

Magit aims to encapsulate the entire functionality of Git,[16] and has interfaces for workflows such as:[17]

  • Cloning a repository, and fetching/pulling from it
  • Staging, unstaging, and discarding changes in the worktree
  • Creating commits and pushing them to a remote
  • Creating branches, and either merging or rebasing onto them
    • Magit makes use of Emacs' Ediff to provide 3-way-merge functionality
  • Browsing and bisecting the commit history
  • Creating and applying patches
  • Adding notes and tags to commits

Forges

edit

Magit's Forge provides integration with a number of forges,[18] namely GitHub and GitLab.[19]

Partial support is also listed for: Gitea, Gogs, Bitbucket, Gitweb, Cgit, StGit and SourceHut.

Forge currently allows for[20]

  • Fetching topics and notifications
  • Listing topics, issues, pull-requests, notifications, and repositories
  • Creating issues, pull-requests (PRs), PR from an issue, PR reviews, and forks

Reception

edit

Magit is favourably covered in a number of blog posts and tutorials and a talk delivered by former Emacs' maintainer John Wiegley.[21][22][23]

Magit is included by default in the Emacs configuration frameworks Spacemacs and Doom Emacs.[24][25]

There has been interest in including Magit as a built-in feature package in Emacs, but there are issues with obtaining FSF copyright assignment from all contributors to the project.[26]

As of February 2023, Magit is the most starred Emacs package on GitHub.[27]

See also

edit

Notes

edit
  1. ^ In part this is a consequence of being designed for GNU Emacs, which itself can operate as a TUI.

References

edit
  1. ^ Bernoulli, Jonas (2024-08-09). "Emacsair! Magit 4.0 released". emacsair.me. Retrieved 2024-09-15.
  2. ^ "magit/docs/RelNotes/4.0.0.org at main · magit/magit". GitHub. Retrieved 2024-09-15.
  3. ^ "How to pronounce Magit? (Magit User Manual)". magit.vc. Retrieved 2024-09-15.
  4. ^ Corbet, Jonathan (July 12, 2017). "Emacs and Magit". LWN.net.
  5. ^ "EmacsWiki: Magit". Retrieved 2020-09-17.
  6. ^ "magit". Milkypostman's Emacs Lisp Package Archive. Retrieved 2020-09-20.
  7. ^ "Current List of Packages". Milkypostman's Emacs Lisp Package Archive. Retrieved 2024-09-15.
  8. ^ "Transient commands". GitHub. Retrieved 2020-09-17.
  9. ^ Bernoulli, Jonas (2017-09-01). "Magit, the magical Git interface". EmacsAir.
  10. ^ "magit/magit.el". GitHub. Retrieved 2020-09-17.
  11. ^ "Magit 1.4.0 Release Notes". GitHub. 2015-07-01. Retrieved 2020-09-20.
  12. ^ "GitStats - magit". magit.vc. Retrieved 2022-03-08.
  13. ^ "It's Magit! The magical Git client". Kickstarter.
  14. ^ "Discover » Technology / Software » Most Funded — Kickstarter". Retrieved 2020-09-17.
  15. ^ "Please help making it better".
  16. ^ Bernoulli, Jonas. "It's Magit! A Git Porcelain inside Emacs". magit.vc. Retrieved 2022-01-02.
  17. ^ "Top (Magit User Manual)". magit.vc.
  18. ^ Heartman, Thomas (16 March 2020). "Improve your workflow with Forge".
  19. ^ "Forge User and Developer Manual". magit.vc.
  20. ^ "Usage (Forge User and Developer Manual)". magit.vc.
  21. ^ Patil, Sachin. "How to use Magit to manage Git projects". opensource.com.
  22. ^ Bachmann, Gunther. "Magit – A textual git interface". itemis.
  23. ^ Wiegley, John. "It's Magit!". YouTube.
  24. ^ "Spacemacs - source control layer". GitHub. Retrieved 2020-09-19.
  25. ^ "Doom Emacs - default modules file". GitHub. Retrieved 2020-09-19.
  26. ^ Stallman, Richard (5 July 2017). "Re: In support of Jonas Bernoulli's Magit". emacs-devel (Mailing list). Retrieved 2020-09-19.
  27. ^ "GitHub Search for "stars:>1000", Emacs lisp, sorted by most stars". GitHub. Retrieved 2020-09-19.
edit