2023-07-10 15:43:08 +00:00
|
|
|
---
|
|
|
|
title: Code review
|
|
|
|
x-toc-enable: true
|
|
|
|
...
|
|
|
|
|
2024-05-12 00:27:09 +00:00
|
|
|
If you wish to submit patches, you can. Submit them, using the instructions
|
|
|
|
provided in the following sections:
|
2023-07-10 15:43:08 +00:00
|
|
|
|
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
|
|
|
Informationen darüber wer an Canoeboot arbeitet und wer das Projekt betreibt
|
|
|
|
sind unter [who.de.md](who.de.md) zu finden.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Das `canoeboot` Projekt hat hauptsächlich 3 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>
|
|
|
|
* Webseite (+Anleitungen): <https://codeberg.org/canoeboot/cbwww>
|
|
|
|
* Bilder (für die Webseite): <https://codeberg.org/canoeboot/cbwww-img>
|
2023-07-10 15:43:08 +00:00
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Die Entwicklung von Canoeboot findet mithilfe der Versionskontrolle von
|
2023-07-10 15:43:08 +00:00
|
|
|
Git statt. Sieh in der [offiziellen Git Dokumentation](https://git-scm.com/doc)
|
|
|
|
nach, sofern Du nicht weisst wie man Git verwendet.
|
|
|
|
|
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
|
|
|
Dies ist das zentrale build system in Canoeboot. Man könnte auch sagen `cbmk` *ist*
|
|
|
|
Canoeboot! Das Git repository herunterladen:
|
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
|
|
|
Der oben dargestellte `git` Befehl, wird das Canoeboot build system `cbmk`
|
2023-07-10 15:43:08 +00:00
|
|
|
herunterladen.
|
|
|
|
Du kannst dann folgendermassen in das Verzeichnis wechseln:
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
cd cbmk
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Ändere dies nach deinen Vorstellungen oder erstelle einfach einen build.
|
2023-10-26 00:10:41 +00:00
|
|
|
Für Anleitungen bzgl. `cbmk` build, siehe [build Anleitungen](docs/build/).
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Informationen über das build system selbst und wie es funktioniert, sind
|
2023-10-26 00:10:41 +00:00
|
|
|
verfügbar unter dem [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
|
|
|
Die *gesamte* Canoeboot Website sowie Dokumentation befindet sich in einem
|
2023-07-10 15:43:08 +00:00
|
|
|
Git Repository.
|
|
|
|
Du kannst es folgendermassen herunterladen:
|
|
|
|
|
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
|
|
|
Bilder befinden sich unter <https://av.canoeboot.org/> und sind verfügbar
|
2023-07-10 15:43:08 +00:00
|
|
|
in einem separaten Git 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
|
|
|
|
|
|
|
Du kannst alles nach deinen Vorstellungen ändern. Beachte die nachfolgenden
|
|
|
|
Informationen wie Du deine Änderungen zur Verfügung stellen kannst.
|
|
|
|
|
|
|
|
Die gesamte Website ist in Markdown geschrieben, insbesondere die Pandoc Version.
|
|
|
|
Die statischen HTML Seiten werden mit [Untitled](https://untitled.vimuser.org/)
|
2023-10-26 00:10:41 +00:00
|
|
|
generiert. Leah Rowe, die Gründerin von Canoeboot, ist auch die Gründerin des Untitled static
|
2023-07-10 15:43:08 +00:00
|
|
|
site generator Projekts.
|
|
|
|
|
|
|
|
Wenn Du möchtest, kannst Du einen lokalen HTTP Server einrichten und eine
|
|
|
|
lokale Version der Website herstellen. Bitte bedenke, dass alle Bilder nach
|
2023-10-26 00:10:41 +00:00
|
|
|
wie vor mit den Bildern auf <https://av.canoeboot.org/> verknüpft werden,
|
|
|
|
daher werden jegliche Bilder die Du `cbwww-img` hinzugefügt hast nicht auf
|
|
|
|
deiner lokalen `cbwww` Seite dargestellt, sofern Du die Bilder (die Du
|
|
|
|
hinzugefügt hast) mit `av.canoeboot.org` verknüpfst. Es ist jedoch erforderlich,
|
|
|
|
dass sich diese Bilder auf av.canoeboot.org befinden.
|
2023-07-10 15:43:08 +00:00
|
|
|
|
|
|
|
Sofern Du der Webseite Bilder hinzufügen möchtest, füge diese ebenso
|
2023-10-26 00:10:41 +00:00
|
|
|
dem `cbwww-img` Repository hinzu, indem Du diese dann jeweils mit diesem Link verknüpfst
|
|
|
|
<https://av.canoeboot.org/path/to/your/new/image/in/cbwww-img>.
|
|
|
|
Wenn dein Patch der Canoeboot Webseite hinzugefügt wird, werden erscheinen deine Bilder 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
|
|
|
|
|
|
|
Zu Entwicklungszwecken, könntest Du deine Bilder auch lokal verknüpfen, und
|
|
|
|
anschliesend die URLs anpassen sobald Du deine Patches für die Dokumentation/Webseite schickst.
|
|
|
|
|
|
|
|
Eine Anleitung wie Du eine lokale Version der Webseite herstellen kannst,
|
|
|
|
befinden sich auf der Untitled Webseite. Lade untitled
|
|
|
|
herunter, und erstelle in dem `untitled` Verzeichnis ein Verzeichnis mit
|
2023-10-26 00:10:41 +00:00
|
|
|
dem Namen `www/` dann wechsle in dieses Verzeichnis und klone das `cbwww`
|
2023-07-10 15:43:08 +00:00
|
|
|
Repository dorthin. Konfiguriere deinen lokalen HTTP Server entsprechend.
|
|
|
|
|
|
|
|
Nochmal, Anleitungen hierfür findest Du auf der Untitled Webseite.
|
|
|
|
|
|
|
|
Name nicht erforderlich
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Beiträge die Du hinzufügst, werden in einem für jeden zugänglichen Git
|
|
|
|
Repository öffentlich aufgezeichnet. Dies betrifft ebenso den Namen sowie
|
|
|
|
die email Adresse des Mitwirkenden.
|
|
|
|
|
|
|
|
Du musst bei Git keinen Autoren Namen bzw. keine email Addresse verwenden,
|
2023-10-26 00:10:41 +00:00
|
|
|
mithilfe derer Du identifizierbar bist. Du kannst `canoeboot Contributor`
|
|
|
|
verwenden und deine email Addresse könnte als contributor@canoeboot.org
|
2023-07-10 15:43:08 +00:00
|
|
|
spezifiert werden. Es ist Dir gestattet dies zu tun, sofern Du deine Privatsphäre
|
|
|
|
wahren möchtest. Wir glauben an Privatsphäre. Sofern Du anonym bleiben möchtest
|
|
|
|
werden wir dies respektieren.
|
|
|
|
|
|
|
|
Natürlich kannst Du jeglichen Namen und/oder jegliche email Adresse verwenden
|
|
|
|
die Du möchtest.
|
|
|
|
|
|
|
|
Rechtlich gesprochen, jegliches Urheberrecht fällt automatisch unter die
|
|
|
|
Berner Übereinkunft zum Schutz von Werken der Literatur und Kunst. Es spielt
|
|
|
|
keine Rolle welchen Namen, oder ob Du tatsächlich überhaupt ein Urheberrecht
|
|
|
|
deklariert hast (aber wir setzen voraus das bestimmte Lizenzen für das
|
|
|
|
Urheberrecht verwndet werden - lies mehr darüber auf dieser Seite).
|
|
|
|
|
|
|
|
Sofern Du einen anderen Namen sowie eine andere email Adresse für deine
|
|
|
|
Commits/Patches verwendest dann solltest Du anonym sein. Verwende
|
|
|
|
[git log](https://git-scm.com/book/en/v2/Git-Basics-Viewing-the-Commit-History)
|
|
|
|
und [git show](https://git-scm.com/docs/git-show) um dies zu überprüfen
|
|
|
|
bevor Du einem öffentlichen Git Repository Änderungen hinzufügst.
|
|
|
|
|
2023-10-26 00:10:41 +00:00
|
|
|
Patches senden
|
|
|
|
------------
|
|
|
|
|
|
|
|
Erstelle einen Account unter <https://codeberg.org/> und navigiere (während
|
|
|
|
Du eingeloggt bist) zu dem Repository das Du bearbeiten möchtest. Klicke
|
|
|
|
auf *Fork* und Du wirst ein eigenes Canoeboot Repository in deinem Account
|
|
|
|
erhalten. Erstelle einen Clone dieses Repository, füge alle gewünschten Änderungen hinzu
|
|
|
|
und führe anschliessend einen Push in dein Repository in deinem Account
|
|
|
|
auf Codeberg durch. Du kannst dies auch in einem neuen Branch erledigen,
|
|
|
|
sofern Du magst.
|
|
|
|
|
|
|
|
In deinem Codeberg Account kannst Du nun zum offiziellen Canoeboot
|
|
|
|
Repository navigieren und dort einen Pull Request erstellen. Die Art und
|
|
|
|
Weise wie dies funktioniert ist vergleichbar mit anderen populären Web basierten
|
|
|
|
Git Plattformen die heutzutage verwendet werden.
|
|
|
|
|
|
|
|
Du kannst dort deine Patches bereitstellen. Alternativ kannst Du dich in
|
|
|
|
den Canoeboot IRC Kanal einloggen und dort bekannt geben welche deiner Patches
|
|
|
|
geprüft werden sollen, sofern Du ein eigenes Git repository mit den Patches
|
|
|
|
hast.
|
|
|
|
|
|
|
|
Sobald Du einen Pull Request erstellt hast, werden die Canoeboot Maintainer
|
|
|
|
per email informiert. Sofern Du nicht schnell genug eine Antwort erhälst,
|
|
|
|
kannst Du das Projekt ebenso mithilfe des `#canoeboot` Kanals auf Libera
|
|
|
|
Chat kontaktieren.
|
|
|
|
|
|
|
|
Ein weiterer Weg Patches zu senden ist Leah Rowe direkt eine email zu senden:
|
|
|
|
[info@minifree.org](mailto:info@minifree.org) ist Leah's Projekt email Addresse.
|
|
|
|
|
|
|
|
Um den Prozess der Quelltext Überprüfung transparent zu gestalten,
|
|
|
|
wird jedoch empfohlen künftig Codeberg zu verwenden.
|
|
|
|
|
|
|
|
Git mirrors
|
|
|
|
===========
|
|
|
|
|
|
|
|
Mirrors für cbmk.git
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
Das `cbmk` Repository enthält Canoeboot's automatischess build system, welches
|
|
|
|
Canoeboot Veröffentlichungen herstellt (inklusive kompilierter ROM Images).
|
|
|
|
|
|
|
|
Du kannst `git clone` für alle diese Links ausführen (die Links können auch
|
|
|
|
angeklickt werden, um Änderungen in deinem Web Browser anzusehen):
|
|
|
|
|
|
|
|
* <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
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Das `cbwww` Repository enthält Markdown Dateien (Pandoc Variant), für die
|
|
|
|
Verwendung mit dem [Untitled Static Site Generator](https://untitled.vimuser.org/);
|
|
|
|
dies wird von Canoeboot verwendet um HTML Web Seiten bereitzustellen, *inklusive*
|
|
|
|
der Seite die Du gerade liest!
|
|
|
|
|
|
|
|
Du kannst `git clone` für diese Links ausführen und/oder die Links
|
|
|
|
anklicken um Änderungen in deinem Web Browser anzusehen). Siehe:
|
|
|
|
|
|
|
|
* <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
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Du kannst `git clone` für diese Links ausführen und/oder die Links
|
|
|
|
anklicken um Änderungen in deinem Web Browser anzusehen). Siehe:
|
|
|
|
|
|
|
|
* <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>
|