1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5 <link rel=
"stylesheet" media=
"screen" type=
"text/css" href=
"./style.css" />
6 <link rel=
"stylesheet" media=
"screen" type=
"text/css" href=
"./design.css" />
7 <link rel=
"stylesheet" media=
"print" type=
"text/css" href=
"./print.css" />
9 <meta http-equiv=
"Content-Type" content=
"text/html; charset=utf-8" />
14 <em>Translations of this page are also available in the following languages:
</em> <a href=
"geda-scm.ru.html" class=
"wikilink1" title=
"geda-scm.ru.html">Русский
</a>.
17 <h1 class=
"sectionedit1" id=
"geda_uses_git">gEDA uses git
</h1>
21 gEDA uses
<strong>git
</strong> for source code management. git is a distributed version control system, where every user has his or her own full copy of the revision history.
24 <li class=
"level1"><div class=
"li"> <a href=
"http://git.or.cz/" class=
"urlextern" title=
"http://git.or.cz/" rel=
"nofollow">official git website
</a></div>
26 <li class=
"level1"><div class=
"li"> <a href=
"http://www.kernel.org/pub/software/scm/git/docs/" class=
"urlextern" title=
"http://www.kernel.org/pub/software/scm/git/docs/" rel=
"nofollow">git documentation online
</a></div>
34 <li class=
"level1"><div class=
"li"> <a href=
"https://www.atlassian.com/git/tutorials/" class=
"urlextern" title=
"https://www.atlassian.com/git/tutorials/" rel=
"nofollow">comprehensive set of tutorials
</a> at atlassian.com
</div>
36 <li class=
"level1"><div class=
"li"> <a href=
"https://git.wiki.kernel.org/index.php/GitSvnCrashCourse" class=
"urlextern" title=
"https://git.wiki.kernel.org/index.php/GitSvnCrashCourse" rel=
"nofollow">GitSvnCrashCourse
</a> – git courses for SVN users
</div>
38 <li class=
"level1"><div class=
"li"> <a href=
"http://git.huit.harvard.edu/guide/" class=
"urlextern" title=
"http://git.huit.harvard.edu/guide/" rel=
"nofollow"> Git - The Simple Guide
</a> – very concise and condensed cheat sheet style tutorial
</div>
43 <!-- EDIT1 SECTION "gEDA uses git" [106-780] -->
44 <h2 class=
"sectionedit2" id=
"read-only_access_the_geda_repositories">Read-only access the geda repositories
</h2>
48 To clone the geda-gaf.git repository (or any repository hosted at
<a href=
"http://git.geda-project.org" class=
"urlextern" title=
"http://git.geda-project.org" rel=
"nofollow">git.geda-project.org
</a>) using anonymous git access:
50 <pre class=
"code">git clone git://git.geda-project.org/geda-gaf.git
</pre>
55 <pre class=
"code">git clone git://git.geda-project.org/pcb.git
</pre>
58 For different repositories hosted at git.geda-project.org, just substitute the last part of the above
<abbr title=
"Uniform Resource Locator">URL
</abbr>.
62 There is a
<a href=
"http://hjemli.net/git/cgit/about/" class=
"urlextern" title=
"http://hjemli.net/git/cgit/about/" rel=
"nofollow">cgit
</a> interface to the repositories of the various projects. Just point a www browser to
<a href=
"http://git.geda-project.org/" class=
"urlextern" title=
"http://git.geda-project.org/" rel=
"nofollow">http://git.geda-project.org/
</a> .
66 <!-- EDIT2 SECTION "Read-only access the geda repositories" [781-1366] -->
67 <h2 class=
"sectionedit3" id=
"feature_branches">Feature branches
</h2>
71 <a href=
"http://git-scm.com/book/en/v2/Git-Branching-Branches-in-a-Nutshell" class=
"urlextern" title=
"http://git-scm.com/book/en/v2/Git-Branching-Branches-in-a-Nutshell" rel=
"nofollow">Branches
</a> are a major feature of git. The geda project uses feature branches to test non-trivial changes. Once they are assessed as useful, the changes a branch represents gets merged into the main head. You can try and test a feature branch even if you don
't have write access to the git repository of geda-project, yet.
75 <!-- EDIT3 SECTION "Feature branches" [1367-1788] -->
76 <h3 class=
"sectionedit4" id=
"list_all_branches_of_a_project">List all branches of a project
</h3>
80 To list all branches of a project available on the geda-project server cd to your local copy of the project and emit this git command:
82 <pre class=
"code">$ git branch -r
</pre>
85 <!-- EDIT4 SECTION "List all branches of a project" [1789-1993] -->
86 <h3 class=
"sectionedit5" id=
"track_a_feature_branch">Track a feature branch
</h3>
90 This will create a branch with the name
<code><local name
></code> in your local repository, which tracks the
<code><remote name
></code>'d branch.
92 <pre class=
"code">$ git checkout --track -b
<local name
> origin/
<remote name
></pre>
95 Go ahead and build the application from the branch as described by the
<a href=
"geda-gaf_building_git_version.html" class=
"wikilink1" title=
"geda-gaf_building_git_version.html">build instructions
</a>. By default the command
<code>make install
</code> will copy the binaries to
<code>/usr/local/*
</code>. That way, it will not interfere with an install done by your linux distribution. You may use full paths, symbolic links or aliases to pick which version to use.
99 <!-- EDIT5 SECTION "Track a feature branch" [1994-2598] -->
100 <h3 class=
"sectionedit6" id=
"communicate_your_experience">Communicate your experience
</h3>
104 Generally, there will be a launchpad bug associated with the feature of the branch. Please report your experience with the branch there. Your input will influence whether or not the feature will make into mainstream. There is a group of users and developers who keep an eye on changes to bug reports. They will get noticed by email.
108 For additional visibility you may report your experience on the mailing list
<a href=
"geda-mailinglists.html" class=
"wikilink1" title=
"geda-mailinglists.html">geda-user
</a>. It may even spark a discussion. As with all forms of general online discussion, the note may get archived and gradually be forgotten without any action taken.
112 <!-- EDIT6 SECTION "Communicate your experience" [2599-3240] -->
113 <h2 class=
"sectionedit7" id=
"format_a_patch_to_send_to_the_developers">Format a patch to send to the developers
</h2>
117 The simplest possible way includes all changes since the local repository was syncronized with the repository at geda-project.org:
119 <pre class=
"code">$ git diff
> name_of_patchfile
</pre>
122 A more complicated way with more control on what the patch contains:
124 <pre class=
"code">$ git add -i # select files to be committed
125 $ git status # check you
're committing what you think you
're committing
126 $ git commit # create a commit
127 $ git format-patch -
1 # create a patch file based on that commit
</pre>
130 This will output a filename which contains the patch. Be sure to look at the documentation for format-patch for more information. This file can be e-mailed to developers who have write access and can be applied using git apply.
134 <!-- EDIT7 SECTION "Format a patch to send to the developers" [3241-4009] -->
135 <h2 class=
"sectionedit8" id=
"access_the_repository_with_write_permission">Access the repository with write permission
</h2>
139 For developer git access, you should write DJ Delorie or Traumflug an email with your SSH public key and your preferred user name. They
'll install this key on the server, then. Having done so, the git
<abbr title=
"Uniform Resource Locator">URL
</abbr> to push to is (note the
<em>:
65</em>):
141 <pre class=
"code">ssh://git@git.geda-project.org:
65/
<repository
>.git
</pre>
144 Note: If you
're having trouble pushing commits upstream, make sure you
're using git
1.5 or newer.
148 Accordingly, to grab a repository copy with write privileges you
'd do this:
150 <pre class=
"code">git clone ssh://git@git.geda-project.org:
65/
<repository
>.git
</pre>
153 If you have a read-only clone already you can change it to one with write access:
155 <pre class=
"code">git remote remove origin
156 git remote add origin ssh://git@git.geda-project.org:
65/
<repository
>.git
</pre>
159 Having this done, your local clone works just as before, just a
<code>git push origin
<branch
></code> succeeds.
163 <!-- EDIT8 SECTION "Access the repository with write permission" [4010-4889] -->
164 <h3 class=
"sectionedit9" id=
"use_a_unique_ssh_key_for_geda">Use a unique SSH key for gEDA
</h3>
168 You can use a separate key for accessing the gEDA git access. This has no further advantage other than having a unique key. In this case you may also need to add a line to your ~/.ssh/config file to specify this alternate key:
170 <pre class=
"code">Host git.geda-project.org
172 IdentityFile ~/.ssh/gedaproject_dsa
</pre>
175 Note, the file you refer to here is the private key. By contrast, the file you send for the server side is the corresponding public key.
179 <!-- EDIT9 SECTION "Use a unique SSH key for gEDA" [4890-5380] -->
180 <h2 class=
"sectionedit10" id=
"commit_changes">Commit changes
</h2>
184 <!-- EDIT10 SECTION "Commit changes" [5381-5408] -->
185 <h3 class=
"sectionedit11" id=
"set_up_user_information">Set up user information
</h3>
189 You should make sure that your username
& e-mail address are set in your git configuration file.
191 <pre class=
"code">$ git config --global user.name
"Your Name Comes Here
"
192 $ git config --global user.email you@yourdomain.example.com
</pre>
195 <!-- EDIT11 SECTION "Set up user information" [5409-5661] -->
196 <h3 class=
"sectionedit12" id=
"commit_patches_from_other_contributors">Commit patches from other contributors
</h3>
200 If you apply a patch from someone else (e.g. from a launchpad patch record) there are a few things to consider.
201 Git stores two different names and e-mail addresses for a given commit: the “author” of the patch, and the “committer” of the patch, so these details must be set correctly when making the commit.
205 First of all, check a few things:
208 <li class=
"level1"><div class=
"li"> You have the latest version of the patch.
</div>
210 <li class=
"level1"><div class=
"li"> The author of the patch is happy for it to be committed (and wasn
't still working on it)
</div>
212 <li class=
"level1"><div class=
"li"> That the you
're happy with the patch, and taking responsibility for committing those changes.
</div>
217 For simplicity, start from an unmodified up-to date tree (git status shows no changes).
221 Apply the patch as usual (as an example):
223 <pre class=
"code">$ patch -p1
< example_changes.patch
</pre>
226 You can also use the git apply command:
228 <pre class=
"code">$ git apply example_changes.patch
</pre>
231 If the patch needs any minor editing before it is committed (eg. white-space changes), please inform the author this was done.
232 They may have other work based on their patch and will want to know if there were changes to the applied version.
234 <div class=
"noteclassic">This is easy to miss accidentally if your editor introduces tabs. Please avoid letting it do so!
237 For every file changed, added or removed, you need to inform git before it will commit the changes. To see the modified files, run:
239 <pre class=
"code">$ git status
</pre>
242 For speed, the command:
244 <pre class=
"code">$ git add -u
</pre>
247 will update all files which git tracks, including any files which were deleted.
251 For adding any new files the patch introduced, use the command
253 <pre class=
"code">$ git add new_file.c
</pre>
256 Note: git add also takes wild-cards.
260 Commit the patch, making sure that the Author
's name and e-mail address are specified:
262 <pre class=
"code">$ git commit --author
"Author
's Name Comes Here
<author@example.com
>"</pre>
265 As an alternative, you can set the GIT_AUTHOR_NAME and GIT_AUTHOR_EMAIL environment variables before issuing the normal commit command
269 <!-- EDIT12 SECTION "Commit patches from other contributors" [5662-7588] -->
270 <h3 class=
"sectionedit13" id=
"write_good_commit_messages">Write good commit messages
</h3>
274 The commit message format is as follows: a *strictly* one-line summary of the patch, followed by a blank line, followed by a long description. If you can fit the whole description of the patch on one line, that
's fine; don
't bother with the long description.
278 The one-line summary is used for generating e-mail subject lines, and for the gitk
& gitweb log displays. Having a good one-line summary is really useful, because it means those tools can be used to quickly find a commit of interest.
282 <strong>Do not
</strong> put a list of files changed into commit messages. This information can be trivially obtained using the git tools.
288 <pre class=
"code">Added new GedaList class derived from GObject
290 This abstracts a GList with API for write access. Its main use is in list
291 change notification, as it emits a
"changed
" g_signal when modified.
292 Read only access to the underlying GList is provided by an accessor,
293 currenly implemented as a macro.
</pre>
296 <!-- EDIT13 SECTION "Write good commit messages" [7589-8568] -->
297 <h2 class=
"sectionedit14" id=
"keep_the_local_copy_current">Keep the local copy current
</h2>
301 For those who are are not merging changes back into the central git repository you can run:
303 <pre class=
"code">$ git pull
</pre>
306 However, for those of you who are going to be pushing your changes back into the central git repository, using git pull will clutter up the history with merge messages (“Merge branch
'master
'”). To avoid this you should run:
308 <pre class=
"code">$ git fetch
309 $ git rebase origin
</pre>
312 <!-- EDIT14 SECTION "Keep the local copy current" [8569-8979] -->
313 <h2 class=
"sectionedit15" id=
"commit_changes_to_the_local_git_repository">Commit changes to the local git repository
</h2>
315 <pre class=
"code">$ git commit -a
</pre>
318 This command will find all changed files that git knows about (added with git-add) and prompt you for a commit message. Be sure to follow the above commit message convention if you plan on pushing your changes to the central repository.
322 If you want to commit files in the current directory or want to explicitly commit only certain files, do not specify the -a flag and/or specify the individual filenames on the command line like:
324 <pre class=
"code">$ git commit filename1 filename2
</pre>
327 <!-- EDIT15 SECTION "Commit changes to the local git repository" [8980-9525] -->
328 <h2 class=
"sectionedit16" id=
"undo_any_uncommitted_local_changes">Undo any uncommitted local changes
</h2>
330 <pre class=
"code">$ git checkout -f
</pre>
333 Note this will discard any changes to any files that are being tracked by git.
337 If you want to just discard edits in a single file, just run:
339 <pre class=
"code">$ git checkout path/to/file/to/discard
</pre>
342 If you want to discard all edits from the current directory and downward recursively, just run:
344 <pre class=
"code">$ git checkout .
</pre>
347 <!-- EDIT16 SECTION "Undo any uncommitted local changes" [9526-9896] -->
348 <h2 class=
"sectionedit17" id=
"fix_a_less_than_perfect_last_commit">Fix a less than perfect last commit
</h2>
350 <pre class=
"code">$ Edit whatever files
351 $ git commit --amend filename1..filenameN
</pre>
354 This will pickup any changes you made and recommit them again with the previous commit message.
358 <!-- EDIT17 SECTION "Fix a less than perfect last commit" [9897-10111] -->
359 <h2 class=
"sectionedit18" id=
"create_a_personalized_branch">Create a personalized branch
</h2>
363 If you have write permission to the git repository of the gEDA project, you can create personalized branches for your patches. This is recommend to facilitate tests, review and finally application of the patches to the master branch of the application. For this purpose a personalized name space is available in the git repositories. The prefix of this name space is
<code>home/
<user_name
>/
</code>, where
<code><user_name
></code> is your user name.
367 First create the branch locally and simultaneously switch to it as the current branch:
369 <pre class=
"code"> $ git checkout -b home/
<user_name
>/
<name_of_the_branch
></pre>
372 Make some changes. Stage the changes and issue a commit:
374 <pre class=
"code"> $ git stage
<files to commit
>
375 $ git commit -F
<commit_message
></pre>
378 Where
<code><commit_message
></code> points to a file which contains the commit message.
382 To publish the changed branch to the remote repository do:
384 <pre class=
"code"> $ git push origin home/
<user_name
>/
<name_of_the_branch
></pre>
387 The first push to a branch creates it on the remote server.
388 For a little more convenience, you can advise git to always push to the current branch:
390 <pre class=
"code"> $ git config --global push.default current
</pre>
393 Skip the option
<code>--global
</code> if you want this to be active only in this particular git project. With this directive the command above reduces to a mere
395 <pre class=
"code"> $ git push
399 <!-- EDIT18 SECTION "Create a personalized branch" [10112-11438] -->
400 <h2 class=
"sectionedit19" id=
"delete_a_personalized_branch">Delete a personalized branch
</h2>
404 In case you
'd rather not have your branch sitting indefinitely in the remote repository, you can issue a delete directive. To delete the branch on the server do:
406 <pre class=
"code"> $ git push origin --delete home/
<user_name
>/
<name_of_the_branch
></pre>
409 To delete the branch on the local repository, too:
411 <pre class=
"code"> $ git branch --delete home/
<user_name
>/
<name_of_the_branch
>
415 <!-- EDIT19 SECTION "Delete a personalized branch" [11439-11827] -->
416 <h2 class=
"sectionedit20" id=
"fetch_a_development_branch_from_other_people">Fetch a development branch from other people
</h2>
420 Beside the
<a href=
"http://git.geda-project.org/" class=
"urlextern" title=
"http://git.geda-project.org/" rel=
"nofollow">http://git.geda-project.org/
</a> repository we have a mirror of that repository at
<a href=
"http://repo.or.cz/w/geda-gaf.git" class=
"urlextern" title=
"http://repo.or.cz/w/geda-gaf.git" rel=
"nofollow">http://repo.or.cz/w/geda-gaf.git
</a>. Some of the developers have forks of that repository with new feature branches.
424 If you like to test one of the feature branches you have to fetch it from their repository.
425 The easiest way to get a branch is to use the fetch command.
427 <pre class=
"code"> $ git fetch repository_url remote_branchname:local_branchname
</pre>
430 <strong>Examples:
</strong>
431 Getting the
<em>cairo_experiment
</em> branch from Peter C. would look like this:
433 <pre class=
"code"> $ git fetch git://repo.or.cz/geda-gaf/pcjc2.git cairo_experiment:peters_cairo_experiment
</pre>
436 Now you can switch to the local copy of the branch
<em>peters_cairo_experiment
</em> and play with it.
440 It is also possible to add multiple remote forks into the local repository:
442 <pre class=
"code"> $ git remote add
<name
> <url
>
443 $ git fetch
<name
></pre>
446 As long as
<name
> is unique you will be able to follow their work without the
447 need to create local branches. With a tool like gitk it is now possible to keep
448 an eye on development in various feature branches on various forks:
450 <pre class=
"code"> $ gitk --all
</pre>
453 <strong>Examples:
</strong>
455 <pre class=
"code"> $ git remote add peter-b https://github.com/peter-b/geda-gaf.git
457 $ git remote add gareth8118 https://github.com/gareth8118/geda-gaf.git
458 $ git fetch gareth8118
459 $ git remote add bert https://github.com/bert/geda-gaf.git
464 Now gitk can become quite filled up, but
<strong>File
</strong>→
<strong>List references
</strong> (
<kbd>F2
</kbd>) will open
465 a dialog for easier navigation.
469 Updating favourite remotes will then boil down to:
471 <pre class=
"code"> $ git fetch --all
</pre>
474 <!-- EDIT20 SECTION "Fetch a development branch from other people" [11828-13493] -->
475 <h2 class=
"sectionedit21" id=
"recover_from_a_really_messed_up_local_repository">Recover from a really messed up local repository
</h2>
479 First off, do not push any repository that you think is somehow messed up. Ask one of the experienced git people first.
483 Second, the command that will really save your bacon is git-reflog. Using it works something like this:
485 <pre class=
"code"> $ git reflog
486 086908e... HEAD@{
0}: cherry-pick: Last minute updates to the READMEs for all pro
487 2a79a23... HEAD@{
1}: checkout: moving to master
488 2a79a23... HEAD@{
2}: checkout: moving to master
490 $ git reset --hard HEAD@{
1}
</pre>
493 The last command (git reset --hard ...) will rollback all your changes to the “checkout: moving to master”. Remember: don
't panic! Most things are fixable when using git.
497 <!-- EDIT21 SECTION "Recover from a really messed up local repository" [13494-] --></body>