2023-07-10 15:43:08 +00:00
|
|
|
---
|
|
|
|
title: Code review
|
|
|
|
x-toc-enable: true
|
|
|
|
...
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
NOTE FOR CONTRIBUTORS:
|
|
|
|
======================
|
2023-07-17 15:45:56 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The preferred development style is: work on Libreboot, and port changes from
|
|
|
|
each Libreboot release into Canoeboot, but do it all at once. Whenever a new
|
|
|
|
Libreboot release comes out, a Canoeboot release will happen either
|
|
|
|
simultaneously or a few days later, porting all suitable changes over
|
|
|
|
from the Libreboot release. More information about this is available
|
|
|
|
in the [about page](about.md).
|
2023-07-17 15:45:56 +00:00
|
|
|
|
extreme cleanup / grandiose gesture
make canoeboot a truly GNU FSDG compliant coreboot distro,
by removing all overly positive reference to Libreboot;
what remains is technical in nature, so as to provide
historical context since Canoeboot is a fork of Libreboot.
I've stated before that I wish to take a more neutral tone
toward the FSF, in contrast to the *coldboot war* of 2023
when GNU Boot started.
Canoeboot was heavily linking to Libreboot, even going so far
as to call itself "inferior" and tell the reader to use
Libreboot.
From now on, Canoeboot will be maintained as though I actually
believed in FSF propoganda. I don't, but its users do. Treat
them with respect. My reason for providing Canoeboot is
precisely that I wish for such people to have a high quality
coreboot distro, much unlike the inferior *GNU Boot* project;
inferior because to this day, it's still based on very old
Libreboot, with not much changed (of any real substance)
relative to the Libreboot 20220710 release on which it forked.
In general, I've also found a lot of stragglers from when
Canoeboot started, where paragraphs referred to Libreboot that
should have actually referred to Canoeboot, or paragraphs
with Libreboot-specific information that does not make sense
in the Canoeboot project e.g. references to vendor scripts.
The resulting canoeboot.org will now look no different to any
typical reader than a typical FSF-aligned project.
There is a next stage to this, which will become apparent to
everyone if I have my way.
Signed-off-by: Leah Rowe <info@minifree.org>
2024-05-10 02:12:44 +00:00
|
|
|
Exceptions are often made. Since only a subset of Libreboot changes are suitable
|
|
|
|
for Canoeboot at any given time, the result is that a given Libreboot release
|
|
|
|
may be *skipped* if the remaining Canoeboot-friendly changes are of low quantity.
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
In other words: please only send patches directly to Canoeboot, if they are
|
|
|
|
patches that only Canoeboot can benefit from; use your best judgement. The
|
|
|
|
same rule applies for bug reports and testing; do Libreboot first.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Leah Rowe is the founder and lead developer of both Canoeboot *and* Libreboot.
|
|
|
|
Please see: [Libreboot git page](https://libreboot.org/git.html)
|
|
|
|
and [Libreboot testers page](https://libreboot.org/docs/maintain/testing.html).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2024-05-10 02:37:02 +00:00
|
|
|
While not everyone(especially the more hardened FSF fanatics) may approve of it,
|
|
|
|
this is how Canoeboot is officially developed. It is essentially no different
|
extreme cleanup / grandiose gesture
make canoeboot a truly GNU FSDG compliant coreboot distro,
by removing all overly positive reference to Libreboot;
what remains is technical in nature, so as to provide
historical context since Canoeboot is a fork of Libreboot.
I've stated before that I wish to take a more neutral tone
toward the FSF, in contrast to the *coldboot war* of 2023
when GNU Boot started.
Canoeboot was heavily linking to Libreboot, even going so far
as to call itself "inferior" and tell the reader to use
Libreboot.
From now on, Canoeboot will be maintained as though I actually
believed in FSF propoganda. I don't, but its users do. Treat
them with respect. My reason for providing Canoeboot is
precisely that I wish for such people to have a high quality
coreboot distro, much unlike the inferior *GNU Boot* project;
inferior because to this day, it's still based on very old
Libreboot, with not much changed (of any real substance)
relative to the Libreboot 20220710 release on which it forked.
In general, I've also found a lot of stragglers from when
Canoeboot started, where paragraphs referred to Libreboot that
should have actually referred to Canoeboot, or paragraphs
with Libreboot-specific information that does not make sense
in the Canoeboot project e.g. references to vendor scripts.
The resulting canoeboot.org will now look no different to any
typical reader than a typical FSF-aligned project.
There is a next stage to this, which will become apparent to
everyone if I have my way.
Signed-off-by: Leah Rowe <info@minifree.org>
2024-05-10 02:12:44 +00:00
|
|
|
to how *Trisquel* is maintained, re-basing upon each new Ubuntu release! It is
|
|
|
|
simply more efficient, enabling a general reduction in the duplication of labour.
|
|
|
|
|
|
|
|
Leah Rowe is the BDFL for both Libreboot and Canoeboot, so this arrangement
|
|
|
|
enables a tight grip on both projects, ensuring that they are always in
|
|
|
|
absolutely perfect sync with each other (with the exception that Canoeboot
|
|
|
|
will only include those changes which comply with GNU FSDG criteria).
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Canoeboot repositories
|
|
|
|
===================
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Information about who works on canoeboot and who runs the project can be
|
|
|
|
found on [who.md](who.md)
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The `canoeboot` project has 3 main Git repositories:
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
* Build system: <https://codeberg.org/canoeboot/cbmk>
|
|
|
|
* Website (+docs): <https://codeberg.org/canoeboot/cbwww>
|
|
|
|
* Images (for website): <https://codeberg.org/canoeboot/cbwww-img>
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Development of canoeboot is done using the Git version control system.
|
2023-07-10 15:43:08 +00:00
|
|
|
Refer to the [official Git documentation](https://git-scm.com/doc) if you don't
|
|
|
|
know how to use Git.
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
cbmk (canoeboot-make)
|
2023-07-10 15:43:08 +00:00
|
|
|
---------------------
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
This is the core build system in canoeboot. You could say that `cbmk` *is*
|
|
|
|
canoeboot! Download the Git repository:
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
git clone https://codeberg.org/canoeboot/cbmk
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The `git` command, seen above, will download the canoeboot build system `cbmk`.
|
2023-07-10 15:43:08 +00:00
|
|
|
You can then go into it like so:
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
cd cbmk
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Make whatever changes you like, or simply build it. For instructions on how to
|
2023-10-26 00:10:41 +00:00
|
|
|
build `cbmk`, refer to the [build instructions](docs/build/).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Information about the build system itself, and how it works, is available in
|
2023-10-26 00:10:41 +00:00
|
|
|
the [cbmk maintenance guide](docs/maintain/).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
cbwww and cbwww-img
|
2023-07-10 15:43:08 +00:00
|
|
|
-------------------
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The *entire* canoeboot website and documentation is hosted in a Git repository.
|
2023-07-10 15:43:08 +00:00
|
|
|
Download it like so:
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
git clone https://codeberg.org/canoeboot/cbwww
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Images are hosted on <https://av.canoeboot.org/> and available in a separate
|
2023-07-10 15:43:08 +00:00
|
|
|
repository:
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
git clone https://codeberg.org/canoeboot/cbwww-img
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Make whatever changes you like. See notes below about how to send patches.
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The entire website is written in Markdown, specifically the Pandoc version of
|
|
|
|
it. The static HTML pages are generated with [Untitled](https://untitled.vimuser.org/).
|
|
|
|
Leah Rowe, the founder of canoeboot, is also the founder of the Untitled static
|
|
|
|
site generator project.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
If you like, you can set up a local HTTP server and build your own local
|
|
|
|
version of the website. Please note that images will still link to the ones
|
2023-10-26 00:10:41 +00:00
|
|
|
hosted on <https://av.canoeboot.org/>, so any images that you add to `cbwww-img`
|
|
|
|
will not show up on your local `cbwww` site if you make the image links (for
|
|
|
|
images that you add) link to `av.canoeboot.org`. However, it is required that such
|
|
|
|
images be hosted on av.canoeboot.org.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Therefore, if you wish to add images to the website, please also submit to the
|
2023-10-26 00:10:41 +00:00
|
|
|
`cbwww-img` repository, with the links to them being
|
|
|
|
<https://av.canoeboot.org/path/to/your/new/image/in/cbwww-img> for each one.
|
|
|
|
When it is merged on the canoeboot website, your images will appear live.
|
|
|
|
|
|
|
|
If adding a photo, compress it for web distribution. Images should be about
|
|
|
|
800px wide, and usually under 100KiB in size:
|
|
|
|
|
|
|
|
First, scale your image down to approximately 800px width, using your favourite
|
|
|
|
image manipulation program. For example, with `imagemagick` you can do the
|
|
|
|
following (make sure the image isn't already smaller or equal than preferred).
|
|
|
|
|
|
|
|
convert original.jpg -resize 600000@ -quality 70% web.jpg
|
|
|
|
|
|
|
|
You should always run `jpegoptim` on jpg images before submitting them.
|
|
|
|
It strips useless metadata and *losslessly* optimises them further by cleverly
|
|
|
|
rearranging the huffman tables used in them.
|
|
|
|
|
|
|
|
jpegoptim -s --all-progressive web.jpg
|
|
|
|
|
|
|
|
If the image is a (line) drawing, vector graphics are preferable to bitmaps.
|
|
|
|
Therefore, if possible, save them as SVGs. Those are easy to modify,
|
|
|
|
and will surely make translators' work easier as well.
|
|
|
|
|
|
|
|
PNG images should be optimised with `zopfli` (this is lossless as well).
|
|
|
|
For example, this reduced the Canoeboot boot logo from around 11k to 3k:
|
|
|
|
|
|
|
|
zopflipng -ym image.png image.png
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
For development purposes, you might make your images local links first, and
|
|
|
|
then adjust the URLs when you submit your documentation/website patches.
|
|
|
|
|
|
|
|
Instructions are on the Untitled website, for how to set up your local version
|
|
|
|
of the website. Download untitled, and inside your `untitled` directory, create
|
2023-10-26 00:10:41 +00:00
|
|
|
a directory named `www/` then go inside the www directory, and clone the `cbwww`
|
2023-07-10 15:43:08 +00:00
|
|
|
repository there. Configure your local HTTP server accordingly.
|
|
|
|
|
|
|
|
Again, instructions are available on the Untitled website for this purpose.
|
|
|
|
|
|
|
|
Name not required
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Contributions that you make are publicly recorded, in a Git repository which
|
|
|
|
everyone can access. This includes the name and email address of the
|
|
|
|
contributor.
|
|
|
|
|
|
|
|
In Git, for author name and email address, you do not have to use identifying
|
2023-10-26 00:10:41 +00:00
|
|
|
data. You can use `canoeboot Contributor` and your email address could be
|
|
|
|
specified as contributor@canoeboot.org. You are permitted to do this, if
|
2023-07-10 15:43:08 +00:00
|
|
|
you wish to maintain privacy. We believe in privacy. If you choose to remain
|
|
|
|
anonymous, we will honour this.
|
|
|
|
|
|
|
|
Of course, you can use whichever name and/or email address you like.
|
|
|
|
|
|
|
|
Legally speaking, all copyright is automatic under the Berne Convention of
|
|
|
|
international copyright law. It does not matter which name, or indeed whether
|
|
|
|
you even declare a copyright (but we do require that certain copyright
|
|
|
|
licenses are used - read more about that on this same page).
|
|
|
|
|
|
|
|
If you use a different name and email address on your commits/patches, then you
|
|
|
|
should be fairly anonymous. Use
|
|
|
|
[git log](https://git-scm.com/book/en/v2/Git-Basics-Viewing-the-Commit-History)
|
|
|
|
and [git show](https://git-scm.com/docs/git-show) to confirm that before you
|
|
|
|
push changes to a public Git repository.
|
|
|
|
|
|
|
|
Licenses (for contributors)
|
|
|
|
--------
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Make sure to freely license your work, under a libre license. Canoeboot no
|
|
|
|
longer sets arbitrary restrictions on what licenses are accepted, and many
|
|
|
|
licenses out there already exist. We will audit your contribution and tell
|
|
|
|
you if there are problems with it (e.g. no license).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
*Always* declare a license on your work! Not declaring a license means that
|
|
|
|
the default, restrictive copyright laws apply, which would make your work
|
|
|
|
proprietary, subject to all of the same restrictions.
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The MIT license is a good one to start with, and it is the preferred license
|
|
|
|
for all new works in Canoeboot, but we're not picky. Canoeboot has historically
|
|
|
|
used GNU licensing such as GPL; much of that remains, and is likely to remain.
|
|
|
|
It's your work; obviously, if you're deriving from an existing work,
|
|
|
|
it may make sense to use the same license on your contribution, for license
|
|
|
|
compatibility.
|
|
|
|
|
|
|
|
You can find common examples of licenses
|
|
|
|
[here](https://opensource.org/licenses).
|
|
|
|
|
|
|
|
If you *are* deriving from an existing work, it's important that your license
|
|
|
|
(for your contribution) be compatible with the licensing of the work from which
|
|
|
|
yours was derived. The MIT license is good because it's widely compatible
|
|
|
|
with many other licenses, and permits many freedoms (such as the freedom to
|
|
|
|
sublicense) that other licenses do not:
|
|
|
|
|
|
|
|
<https://opensource.org/licenses/MIT>
|
|
|
|
|
|
|
|
Send patches
|
|
|
|
------------
|
|
|
|
|
|
|
|
Make an account on <https://codeberg.org/> and navigate (while logged in) to the
|
|
|
|
repository that you wish to work on. Click *Fork* and in your account,
|
|
|
|
you will have your own repository of canoeboot. Clone your repository, make
|
|
|
|
whatever changes you like to it and then push to your repository, in your
|
|
|
|
account on Codeberg. You can also do this on a new branch, if you wish.
|
|
|
|
|
|
|
|
In your Codeberg account, you can then navigate to the official canoeboot
|
|
|
|
repository and submit a Pull Request. The way it works is similar to other
|
|
|
|
popular web-based Git platforms that people use these days.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
You can submit your patches there. Alternative, you can log onto the canoeboot
|
|
|
|
IRC channel and notify the channel of which patches you want reviewed, if you
|
|
|
|
have your own Git repository with the patches.
|
|
|
|
|
|
|
|
Once you have issued a Pull Request, the canoeboot maintainers will be notified
|
|
|
|
via email. If you do not receive a fast enough response from the project, then
|
|
|
|
you could also notify the project via the `#canoeboot` channel on Libera Chat.
|
|
|
|
|
|
|
|
Another way to submit patches is to email Leah Rowe directly:
|
|
|
|
[info@minifree.org](mailto:info@minifree.org) is Leah's project email address.
|
|
|
|
|
|
|
|
However, for transparency of the code review process, it's recommended that you
|
|
|
|
use Codeberg, for the time being.
|
|
|
|
|
|
|
|
Git mirrors
|
|
|
|
===========
|
|
|
|
|
|
|
|
Mirrors of cbmk.git
|
|
|
|
-------------------
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
The `cbmk` repository contains Canoeboot's automated build system, which
|
|
|
|
produces Canoeboot releases (including compiled ROM images).
|
|
|
|
|
|
|
|
You can run `git clone` on any of these links (the links are also clickable,
|
|
|
|
to view changes in your Web browser):
|
|
|
|
|
|
|
|
* <https://git.sr.ht/~canoeboot/cbmk>
|
|
|
|
* <https://git.disroot.org/canoeboot/cbmk>
|
|
|
|
* <https://gitea.treehouse.systems/canoeboot/cbmk>
|
|
|
|
* <https://0xacab.org/canoeboot/cbmk/>
|
|
|
|
* <https://framagit.org/canoeboot/canoeboot>
|
|
|
|
* <https://gitlab.com/canoeboot/cbmk>
|
|
|
|
* <https://notabug.org/canoeboot/cbmk>
|
|
|
|
|
|
|
|
cbwww.git mirror
|
|
|
|
----------------
|
|
|
|
|
|
|
|
The `cbwww` repository contains Markdown files (pandoc variant), for use
|
|
|
|
with the [Untitled Static Site Generator](https://untitled.vimuser.org/); this
|
|
|
|
is what Canoeboot uses to provide HTML web pages, *including* the page that
|
|
|
|
you are reading right now!
|
|
|
|
|
|
|
|
You can run `git clone` on these links, and/or click to view changes in your
|
|
|
|
Web browser. See:
|
|
|
|
|
|
|
|
* <https://git.sr.ht/~canoeboot/cbwww>
|
|
|
|
* <https://git.disroot.org/canoeboot/cbwww>
|
|
|
|
* <https://gitea.treehouse.systems/canoeboot/cbwww>
|
|
|
|
* <https://0xacab.org/canoeboot/cbwww>
|
|
|
|
* <https://framagit.org/canoeboot/cbwww/>
|
|
|
|
* <https://gitlab.com/canoeboot/cbwww>
|
|
|
|
* <https://notabug.org/canoeboot/cbwww>
|
|
|
|
|
|
|
|
cbwww-img.git mirror
|
|
|
|
----------------
|
|
|
|
|
|
|
|
You can run `git clone` on these links, and/or click to view changes in your
|
|
|
|
Web browser. See:
|
|
|
|
|
|
|
|
* <https://git.sr.ht/~canoeboot/cbwww-img>
|
|
|
|
* <https://git.disroot.org/canoeboot/cbwww-img>
|
|
|
|
* <https://gitea.treehouse.systems/canoeboot/cbwww-img>
|
|
|
|
* <https://0xacab.org/canoeboot/cbwww-img>
|
|
|
|
* <https://framagit.org/canoeboot/cbwww-img/>
|
|
|
|
* <https://gitlab.com/canoeboot/cbwww-img>
|
|
|
|
* <https://notabug.org/canoeboot/cbwww-img>
|