2010-04-06 18:49:54 -04:00
|
|
|
---
|
2015-04-10 16:17:45 -04:00
|
|
|
layout: doc
|
2015-10-13 23:31:03 -04:00
|
|
|
title: Source Code
|
2015-10-28 18:14:40 -04:00
|
|
|
permalink: /doc/source-code/
|
2015-10-11 03:04:59 -04:00
|
|
|
redirect_from:
|
2015-10-28 18:14:40 -04:00
|
|
|
- /en/doc/source-code/
|
2015-10-11 03:04:59 -04:00
|
|
|
- /doc/SourceCode/
|
|
|
|
- /wiki/SourceCode/
|
2010-04-06 18:49:54 -04:00
|
|
|
---
|
|
|
|
|
|
|
|
Qubes Source Code Repositories
|
|
|
|
==============================
|
2010-04-06 19:35:50 -04:00
|
|
|
|
2016-03-08 16:50:31 -05:00
|
|
|
All the Qubes code is kept in Git repositories. We have divided the project into
|
|
|
|
several components, each of which has its own separate repository, for example:
|
2010-04-06 19:35:50 -04:00
|
|
|
|
2016-03-08 16:50:31 -05:00
|
|
|
* `core-admin.git` -- The core Qubes infrastructure, responsible for VM
|
|
|
|
management, VM templates, fs sharing, etc.
|
|
|
|
* `gui-daemon.git` -- GUI virtualization, Dom0 side.
|
|
|
|
* `gui-agent-linux.git` -- GUI virtualization, Linux VM side.
|
|
|
|
* `linux-template-builder.git` -- Scripts and other files used to create Qubes
|
|
|
|
template images.
|
2010-04-06 19:35:50 -04:00
|
|
|
|
2016-03-08 16:50:31 -05:00
|
|
|
All of our repositories are available under the [QubesOS GitHub account].
|
2010-04-06 19:35:50 -04:00
|
|
|
|
|
|
|
To clone a repository:
|
|
|
|
|
2015-09-26 19:00:33 -04:00
|
|
|
~~~
|
2015-04-21 08:41:23 -04:00
|
|
|
git clone git://github.com/QubesOS/<repo_name>.git <repo_name>
|
2015-09-26 19:00:33 -04:00
|
|
|
~~~
|
2010-04-07 05:51:32 -04:00
|
|
|
|
|
|
|
e.g.:
|
|
|
|
|
2015-09-26 19:00:33 -04:00
|
|
|
~~~
|
2015-05-11 15:48:12 -04:00
|
|
|
git clone git://github.com/QubesOS/qubes-core-admin.git core-admin
|
2015-09-26 19:00:33 -04:00
|
|
|
~~~
|
2010-04-06 19:35:50 -04:00
|
|
|
|
2016-03-08 16:50:31 -05:00
|
|
|
To clone **all** of our repositories in a single command:
|
|
|
|
|
|
|
|
~~~
|
|
|
|
curl "https://api.github.com/orgs/QubesOS/repos?page=1&per_page=100" | grep -e 'git_url*' | cut -d \" -f 4 | xargs -L1 git clone
|
|
|
|
~~~
|
|
|
|
|
|
|
|
To update (git fetch) **all** of these repositories in a single command:
|
|
|
|
|
|
|
|
~~~
|
|
|
|
find . -mindepth 1 -maxdepth 1 -type d -exec git -C {} fetch --tags --recurse-submodules=on-demand --all \;
|
|
|
|
~~~
|
|
|
|
|
|
|
|
(Alternatively, you can pull instead of just fetching.)
|
|
|
|
|
|
|
|
|
|
|
|
How to Send Patches
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
If you want to contribute code to the project, there are two ways. Whichever
|
|
|
|
method you choose, you must [sign your code] before it can be accepted.
|
|
|
|
|
|
|
|
* **Preferred**: Use GitHub's [fork & pull requests].
|
|
|
|
* Send a patch to our developer [mailing list] (`git format-patch`).
|
|
|
|
|
|
|
|
1. Make all the changes in your working directory, i.e. edit files, move them
|
|
|
|
around (you can use 'git mv' for this), etc.
|
|
|
|
2. Add the changes and commit them (`git add`, `git commit`). Never mix
|
|
|
|
different changes into one commit! Write a good description of the commit.
|
|
|
|
The first line should contain a short summary, and then, if you feel like
|
|
|
|
more explanations are needed, enter an empty new line, and then start the
|
|
|
|
long, detailed description (optional).
|
|
|
|
3. Test your changes NOW: check if RPMs build fine, etc.
|
|
|
|
4. Create the patch using `git format-patch`. This has an advantage over
|
|
|
|
`git diff`, because the former will also include your commit message, your
|
|
|
|
name and email, so that *your* name will be used as a commit's author.
|
|
|
|
5. Send your patch to `qubes-devel`. Start the message subject with
|
|
|
|
`[PATCH]`.
|
2015-07-19 12:41:14 -04:00
|
|
|
|
|
|
|
|
2016-03-08 16:50:31 -05:00
|
|
|
[QubesOS GitHub account]: https://github.com/QubesOS/
|
|
|
|
[sign your code]: /doc/code-signing/
|
|
|
|
[fork & pull requests]: https://guides.github.com/activities/forking/
|
|
|
|
[mailing list]: /doc/mailing-lists/
|
2015-07-19 12:41:14 -04:00
|
|
|
|