README.md 2.77 KB
Newer Older
Lars-Magnus Skog committed
1 2
## Introduction

3
This set of scripts are helpers that modify and create the source packages coming
Ruben Rodriguez committed
4 5 6 7
from the Ubuntu upstream which need it. It might be because they contain
non-free stuff, references to Ubuntu that need to be changed, or because we
want the package to work our way.

mtsio committed
8
This helpers are similar to some of those in the [gNewSense](http://www.gnewsense.org/Builder/HowToCreateYourOwnGNULinuxDistribution) builder, we took
Ruben Rodriguez committed
9 10 11
some ideas and even some lines from them. If you plan to build an Ubuntu
derivative of your own, we suggest you to use Builder instead of this helpers.

12 13 14
Once a new package is added, it takes priority over the original one from Ubuntu,
so they never enter into the repo from upstream and need to be
compiled with this helpers and pushed into reprepro. 
Ruben Rodriguez committed
15

16 17 18 19 20 21 22 23 24 25 26 27
To add a package to the list, follow the [CONTRIBUTING](https://devel.trisquel.info/trisquel/package-helpers/blob/belenos/CONTRIBUTING.md) guidelines.

## Steps

Those are the steps done by the helpers:

1. Create local apt configuration, so you don't need to be root to run the helpers
2. Get the ubuntu and trisquel gpg keys
3. Get the source packages from their original repo
4. Uncompress them
5. Apply the changes described in the helper
6. Re-package it, adding "triquel$VERSION" version string
Ruben Rodriguez committed
28

Lars-Magnus Skog committed
29
## Recommendations
Ruben Rodriguez committed
30

31 32 33 34
* You don't need to use sudo in order to run those scripts, but some extra packages are needed:

     `sudo apt-get install dpkg-dev sed git rpl devscripts quilt patch`

Lars-Magnus Skog committed
35 36 37
* Take care to use the right sourcePackageName, many source packages produce
several binary packages. `apt-cache showsrc binary-package` can help you.
* If possible, use sed to replace chains in the upstream source without the
Ruben Rodriguez committed
38
need of external files or patches. If you really need to include a file, place
Lars-Magnus Skog committed
39 40
it at the `DATA/sourcePackageName` directory
* Do not replace *all* references to Ubuntu in the package, just those that
Ruben Rodriguez committed
41
would actually be shown to the user. Avoid replacing copyright statements!
Lars-Magnus Skog committed
42
* Try to write your replacements in a way they might work in future versions
Ruben Rodriguez committed
43
of the upstream package. Well written regexps and sed will help with that.
44 45
* You can test your changes by doing them inside the _PACKAGES/sourcePackageName/source/_ directory, 
and running `dpkg-source -b .`, before being added to the helper script
Ruben Rodriguez committed
46

Lars-Magnus Skog committed
47
## Netinstall
Ruben Rodriguez committed
48 49 50 51 52 53 54

Included are the set of scipts used to generate the network installer images
found in Trisquel GNU/Linux LTS (version 2.0, 4.0, 6.0... and up). The scripts
may not be available for all versions.

To generate the images, we run the following scripts:

Lars-Magnus Skog committed
55 56 57 58 59 60 61
* `make-apt-setup`
* `make-base-installer`
* `make-choose-mirror`
* `make-main-menu`
* `make-netcfg`
* `make-net-retriever`
* `make-pkgsel`
Ruben Rodriguez committed
62 63

Then we push the results into the Trisquel repository and run the script
Lars-Magnus Skog committed
64
`make-debian-installer` to build the final images.
65