mirror of
https://github.com/fosslinux/live-bootstrap.git
synced 2026-03-04 10:25:25 +01:00
- This idea originates from very early in the project and was, at the
time, a very easy way to categorise things.
- Now, it doesn't really make much sense - it is fairly arbitary, often
occuring when there is a change in kernel, but not from builder-hex0
to fiwix, and sysb is in reality completely unnecessary.
- In short, the sys* stuff is a bit of a mess that makes the project
more difficult to understand.
- This puts everything down into one folder and has a manifest file that
is used to generate the build scripts on the fly rather than using
coded scripts.
- This is created in the "seed" stage.
stage0-posix -- (calls) --> seed -- (generates) --> main steps
Alongside this change there are a variety of other smaller fixups to the
general structure of the live-bootstrap rootfs.
- Creating a rootfs has become much simpler and is defined as code in
go.sh. The new structure, for an about-to-be booted system, is
/
-- /steps (direct copy of steps/)
-- /distfiles (direct copy of distfiles/)
-- all files from seed/*
-- all files from seed/stage0-posix/*
- There is no longer such a thing as /usr/include/musl, this didn't
really make any sense, as musl is the final libc used. Rather, to
separate musl and mes, we have /usr/include/mes, which is much easier
to work with.
- This also makes mes easier to blow away later.
- A few things that weren't properly in packages have been changed;
checksum-transcriber, simple-patch, kexec-fiwix have all been given
fully qualified package names.
- Highly breaking change, scripts now exist in their package directory
but NOT WITH THE packagename.sh. Rather, they use pass1.sh, pass2.sh,
etc. This avoids manual definition of passes.
- Ditto with patches; default directory is patches, but then any patch
series specific to a pass are named patches-passX.
29 lines
1 KiB
Diff
29 lines
1 KiB
Diff
SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
|
|
|
SPDX-License-Identifier: PSF-2.0
|
|
|
|
sorted() was only added in Python 2.5. But we are building Python 2.5.
|
|
|
|
We cannot use .sort(), as it doesn't support the key= parameter.
|
|
Instead we just use a basic custom selection sort to sort it ourselves
|
|
using a custom key.
|
|
|
|
--- Tools/compiler/astgen.py.bak 2022-07-11 09:24:59.600238862 +1000
|
|
+++ Tools/compiler/astgen.py 2022-07-11 09:32:25.814974174 +1000
|
|
@@ -215,7 +215,15 @@
|
|
# some extra code for a Node's __init__ method
|
|
name = mo.group(1)
|
|
cur = classes[name]
|
|
- return sorted(classes.values(), key=lambda n: n.name)
|
|
+ ret = classes.values()
|
|
+ # basic custom selection sort
|
|
+ for i in range(len(ret)):
|
|
+ min_i = i
|
|
+ for j in range(i + 1, len(ret)):
|
|
+ if ret[min_i].name > ret[j].name:
|
|
+ min_i = j
|
|
+ ret[i], ret[min_i] = ret[min_i], ret[i]
|
|
+ return ret
|
|
|
|
def main():
|
|
prologue, epilogue = load_boilerplate(sys.argv[-1])
|