source: at-w96k/content/digarden/20210410205030-emacs_vc.org@ 962709f

Last change on this file since 962709f was 962709f, checked in by w96k <w96k@…>, on Apr 2, 2023 at 10:58:22 PM

Add logsec

  • Property mode set to 100644
File size: 3.7 KB
Line 
1:PROPERTIES:
2:ID: b0c8ec58-f9a1-4ea0-827f-70f447840fc0
3:END:
4#+title: emacs-vc
5* Emacs VC
6Встроенный модуль для работы с системами контроля версий в Emacs.
7
8Встроенная поддержка есть для следующих модулей
9#+begin_src emacs-lisp :results list
10 vc-handled-backends
11#+end_src
12
13#+RESULTS:
14- RCS
15- CVS
16- SVN
17- SCCS
18- SRC
19- Bzr
20- Git
21- Hg
22- Mtn
23
24Доступны интерфейсы к известным системам контроля версий:
25- Git
26- Mercurial
27- Subversion
28- Darcs
29
30И менее известным:
31- rcs
32- CVS
33- MetaCVS
34- GNU Arch
35- sccs
36- SourceSafe
37- ClearCase
38
39Часть из интерфейсов доступна при помощи установки стороннего расширения.
40
41[[https://www.gnu.org/software/emacs/manual/html_node/emacs/Version-Control.html][Документация]]
42или
43#+begin_src bash :results none
44 info emacs vc
45#+end_src
46
47* История модуля VC
48** Основан на [[https://www.gnu.org/software/rcs/][GNU Rcs]]
49Rcs -- древняя централизированная система контроля версий от проекта
50GNU. Проект живой, но неизвестно кем используется.
51** Подробнее об истории
52[[https://alexott.net/en/writings/emacs-vcs/EmacsVC.html][История модуля VC (AlexOtt)]]
53
54
55* Как работать с ним
56** Начало
57Инициализация проекта предполагается через cli утилиту вашей системы контроля
58версий. Вроде:
59#+begin_src bash
60 mkdir ~/projects/emacs-vc
61 cd ~/projects/emacs-vc
62 git init .
63#+end_src
64
65Общий вид доступен по команде vc-dir
66
67#+begin_src emacs-lisp :results none
68 (vc-dir "~/projects/emacs-vc")
69#+end_src
70
71** Альтернативы командам git
72*** git add
73В VC так называется "регистрация" файла. Можно выполнить напрямую через
74команду ~M-x vc-register~, но в VC воркфлоу несколько иной.
75
76Создадим файл и добавим
77#+begin_src emacs-lisp :results none
78 (find-file "~/projects/emacs-vc/file1.el")
79 (insert "(+ 2 (* 2 2))")
80 (save-some-buffers)
81#+end_src
82
83*** git reset
84Откат изменений происходит при помощи ~M-x vc-revert~ или сочетания клавиш ~C-x
85v u~.
86
87Для разрешения конфликтов ~M-x vc-resolve-conflicts~.
88
89*** git branch
90Для создания ветки ~M-x vc-create-tag~ или бинд ~C-x v s
91Для смены ветки ~M-x vc-retrieve-tag~ или бинд ~C-x v r~
92
93*** git merge
94Слияние веток происходит при помощи ~vc-merge~
95
96** Воркфлоу в VC
97В любой непонятной ситуации используешь ~M-x vc-next-action~ или бинд ~C-x v v~
98
99- Если файл не зарегистрирован, то он регистрируется, но изменения не подтверждаются;
100- Если файл уже был добавлен, но не подтвержден, то это изменение подтверждается;
101- Если файл был изменен, а "главный" файл нет, то ваши изменения подтверждаются после ввода описания изменений;
102- Если файл в репозитории был изменен, то пользователю выдадут запрос на слияние изменений в ваш рабочий файл.
103
104** Ссылки
105- [[https://snarfed.org/emacs-vc-git-tweaks][Emacs VC Tricks]]
Note: See TracBrowser for help on using the repository browser.