mirror of
https://github.com/fosslinux/live-bootstrap.git
synced 2026-03-04 10:25:25 +01:00
Remove the notion of "sys*"
- 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.
This commit is contained in:
parent
0907cfd073
commit
6ed2e09f3a
546 changed files with 700 additions and 1299 deletions
107
steps/python-2.0.1/files/disable-unicode.patch
Normal file
107
steps/python-2.0.1/files/disable-unicode.patch
Normal file
|
|
@ -0,0 +1,107 @@
|
|||
SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
|
||||
SPDX-License-Identifier: Python-2.0.1
|
||||
|
||||
unicodetype_db.h is a file that needs to be regened, but it not
|
||||
particularly trivial to regen. For the first build of Python,
|
||||
strip out any kind of unicode support that requires
|
||||
unicodetype_db.h indiscriminately.
|
||||
|
||||
We are effectively restricted to ASCII characters with this change,
|
||||
but it works.
|
||||
|
||||
--- Objects/unicodectype.c 2000-09-26 08:48:13.000000000 +1100
|
||||
+++ Objects/unicodectype.c 2022-10-03 21:09:02.108869321 +1100
|
||||
@@ -29,30 +29,12 @@
|
||||
const unsigned char digit;
|
||||
} _PyUnicode_TypeRecord;
|
||||
|
||||
-#include "unicodetype_db.h"
|
||||
-
|
||||
-static const _PyUnicode_TypeRecord *
|
||||
-gettyperecord(int code)
|
||||
-{
|
||||
- int index;
|
||||
-
|
||||
- if (code < 0 || code >= 65536)
|
||||
- index = 0;
|
||||
- else {
|
||||
- index = index1[(code>>SHIFT)];
|
||||
- index = index2[(index<<SHIFT)+(code&((1<<SHIFT)-1))];
|
||||
- }
|
||||
- return &_PyUnicode_TypeRecords[index];
|
||||
-}
|
||||
-
|
||||
/* Returns 1 for Unicode characters having the category 'Zl' or type
|
||||
'B', 0 otherwise. */
|
||||
|
||||
int _PyUnicode_IsLinebreak(register const Py_UNICODE ch)
|
||||
{
|
||||
- const _PyUnicode_TypeRecord *ctype = gettyperecord(ch);
|
||||
-
|
||||
- return (ctype->flags & LINEBREAK_MASK) != 0;
|
||||
+ return 0;
|
||||
}
|
||||
|
||||
/* Returns the titlecase Unicode characters corresponding to ch or just
|
||||
@@ -60,12 +44,7 @@
|
||||
|
||||
Py_UNICODE _PyUnicode_ToTitlecase(register const Py_UNICODE ch)
|
||||
{
|
||||
- const _PyUnicode_TypeRecord *ctype = gettyperecord(ch);
|
||||
-
|
||||
- if (ctype->title)
|
||||
- return ch + ctype->title;
|
||||
-
|
||||
- return ch + ctype->upper;
|
||||
+ return ch;
|
||||
}
|
||||
|
||||
/* Returns 1 for Unicode characters having the category 'Lt', 0
|
||||
@@ -73,9 +52,7 @@
|
||||
|
||||
int _PyUnicode_IsTitlecase(register const Py_UNICODE ch)
|
||||
{
|
||||
- const _PyUnicode_TypeRecord *ctype = gettyperecord(ch);
|
||||
-
|
||||
- return (ctype->flags & TITLE_MASK) != 0;
|
||||
+ return 0;
|
||||
}
|
||||
|
||||
/* Returns the integer decimal (0-9) for Unicode characters having
|
||||
@@ -83,15 +60,13 @@
|
||||
|
||||
int _PyUnicode_ToDecimalDigit(register const Py_UNICODE ch)
|
||||
{
|
||||
- const _PyUnicode_TypeRecord *ctype = gettyperecord(ch);
|
||||
-
|
||||
- return (ctype->flags & DECIMAL_MASK) ? ctype->decimal : -1;
|
||||
+ return -1;
|
||||
}
|
||||
|
||||
int _PyUnicode_IsDecimalDigit(register const Py_UNICODE ch)
|
||||
{
|
||||
if (_PyUnicode_ToDecimalDigit(ch) < 0)
|
||||
- return 0;
|
||||
+ return 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
@@ -100,15 +75,13 @@
|
||||
|
||||
int _PyUnicode_ToDigit(register const Py_UNICODE ch)
|
||||
{
|
||||
- const _PyUnicode_TypeRecord *ctype = gettyperecord(ch);
|
||||
-
|
||||
- return (ctype->flags & DIGIT_MASK) ? ctype->digit : -1;
|
||||
+ return -1;
|
||||
}
|
||||
|
||||
int _PyUnicode_IsDigit(register const Py_UNICODE ch)
|
||||
{
|
||||
if (_PyUnicode_ToDigit(ch) < 0)
|
||||
- return 0;
|
||||
+ return 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
45
steps/python-2.0.1/files/keyword.c
Normal file
45
steps/python-2.0.1/files/keyword.c
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
/*
|
||||
* SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
*
|
||||
* SPDX-License-Identifier: Python-2.0.1
|
||||
*
|
||||
* Reimplmentation of keyword.py main() in C, to break bootstrapping loop
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#define MAX_LINE 128
|
||||
|
||||
int main() {
|
||||
char filename[] = "Lib/keyword.py";
|
||||
FILE *orig = fopen(filename, "r");
|
||||
/* Read-write until starter line */
|
||||
char *line = malloc(MAX_LINE);
|
||||
do {
|
||||
fgets(line, MAX_LINE, orig);
|
||||
puts(line);
|
||||
} while (strcmp(line, "#--start keywords--\n") != 0);
|
||||
/* Perform the actual transformation */
|
||||
while (fgets(line, MAX_LINE, stdin) != NULL) {
|
||||
char *token = line;
|
||||
while (*token != '"') token++;
|
||||
token++;
|
||||
/* Now at beginning of keyword */
|
||||
char *end = token;
|
||||
while (*end != '"') end++;
|
||||
*end = '\0';
|
||||
/* Write output line to stdout */
|
||||
printf("'%s',\n", token);
|
||||
/* For each line also advance orig pointer */
|
||||
fgets(line, MAX_LINE, orig);
|
||||
/* Cleanup */
|
||||
free(line);
|
||||
line = malloc(MAX_LINE);
|
||||
}
|
||||
/* Read-write until end */
|
||||
while (fgets(line, MAX_LINE, orig) != NULL) {
|
||||
puts(line);
|
||||
}
|
||||
}
|
||||
46
steps/python-2.0.1/files/token.c
Normal file
46
steps/python-2.0.1/files/token.c
Normal file
|
|
@ -0,0 +1,46 @@
|
|||
/*
|
||||
* SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
*
|
||||
* SPDX-License-Identifier: Python-2.0.1
|
||||
*
|
||||
* Reimplmentation of token.py main() in C, to break bootstrapping loop
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#define MAX_LINE 128
|
||||
|
||||
int main(int argc, char** argv) {
|
||||
char *filename = argv[1];
|
||||
FILE *orig = fopen(filename, "r");
|
||||
/* Read-write until starter line */
|
||||
char *line = malloc(MAX_LINE);
|
||||
do {
|
||||
fgets(line, MAX_LINE, orig);
|
||||
puts(line);
|
||||
} while (strcmp(line, "#--start constants--\n") != 0);
|
||||
/* Perform the actual transformation */
|
||||
while (fgets(line, MAX_LINE, stdin) != NULL) {
|
||||
/* Transform input into output */
|
||||
char *tokena = line + 8;
|
||||
char *tokenb = strstr(tokena, "\t");
|
||||
if (tokenb == 0) tokenb = strstr(tokena, " ");
|
||||
*tokenb = '\0';
|
||||
tokenb++;
|
||||
while (*tokenb == '\t' || *tokenb == ' ') tokenb++;
|
||||
/* Write output line to stdout */
|
||||
printf("%s = %s", tokena, tokenb);
|
||||
/* For each line also advance orig pointer */
|
||||
fgets(line, MAX_LINE, orig);
|
||||
/* Cleanup */
|
||||
free(line);
|
||||
line = malloc(MAX_LINE);
|
||||
}
|
||||
/* Read-write until end */
|
||||
while (fgets(line, MAX_LINE, orig) != NULL) {
|
||||
puts(line);
|
||||
fflush(stdout);
|
||||
}
|
||||
}
|
||||
69
steps/python-2.0.1/pass1.sh
Executable file
69
steps/python-2.0.1/pass1.sh
Executable file
|
|
@ -0,0 +1,69 @@
|
|||
# SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
src_prepare() {
|
||||
default
|
||||
|
||||
# Delete generated files
|
||||
rm Modules/glmodule.c
|
||||
rm Modules/unicodedata_db.h Objects/unicodetype_db.h
|
||||
rm Modules/sre_constants.h
|
||||
mv Lib/plat-generic .
|
||||
rm -r Lib/plat-*
|
||||
mv plat-generic Lib/
|
||||
grep generated -r . -l | grep encodings | xargs rm
|
||||
|
||||
# Disable sre and unicodedata modules
|
||||
sed -i "/^_sre/d" Modules/Setup.in
|
||||
sed -i "/^unicodedata/d" Modules/Setup.in
|
||||
|
||||
# Patch
|
||||
patch -Np0 -i disable-unicode.patch
|
||||
|
||||
# Regenerate autoconf
|
||||
autoreconf-2.71 -fi
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
MACHDEP=linux ac_sys_system=Linux \
|
||||
./configure \
|
||||
--prefix="${PREFIX}" \
|
||||
--libdir="${LIBDIR}" \
|
||||
--with-wctype-functions
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
# Build pgen
|
||||
pushd Parser
|
||||
make -j1 pgen
|
||||
popd
|
||||
# Regen graminit.c and graminit.h
|
||||
pushd Grammar
|
||||
make -j1 graminit.c
|
||||
popd
|
||||
|
||||
# Regenerate some Python scripts using the other regenerated files
|
||||
gcc -o keyword keyword.c
|
||||
gcc -o token token.c
|
||||
# This gets all of the grammar tokens
|
||||
grep -E '\{1, "[^"]+"' Python/graminit.c | ./keyword > Lib/keyword.py.new
|
||||
mv Lib/keyword.py.new Lib/keyword.py
|
||||
./token Lib/symbol.py < Include/graminit.h > Lib/symbol.py.new
|
||||
mv Lib/symbol.py.new Lib/symbol.py
|
||||
# These get all of the #defines that have to be translated
|
||||
grep '#define[[:space:]][A-Z]*[[:space:]][[:space:]]*[0-9][0-9]*' Include/token.h | ./token Lib/token.py > Lib/token.py.new
|
||||
mv Lib/token.py.new Lib/token.py
|
||||
|
||||
# Now build the main program
|
||||
make -j1
|
||||
}
|
||||
|
||||
src_install() {
|
||||
mkdir -p "${DESTDIR}/usr"
|
||||
default
|
||||
|
||||
# Remove non-reproducible .pyc/o files
|
||||
find "${DESTDIR}" -name "*.pyc" -delete
|
||||
find "${DESTDIR}" -name "*.pyo" -delete
|
||||
}
|
||||
68
steps/python-2.0.1/pass2.sh
Executable file
68
steps/python-2.0.1/pass2.sh
Executable file
|
|
@ -0,0 +1,68 @@
|
|||
# SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
src_prepare() {
|
||||
default
|
||||
|
||||
# Delete generated files
|
||||
rm Modules/glmodule.c
|
||||
mv Lib/plat-generic .
|
||||
rm -r Lib/plat-*
|
||||
mv plat-generic Lib/
|
||||
grep generated -r . -l | grep encodings | xargs rm
|
||||
|
||||
# Regenerate unicode
|
||||
rm Modules/unicodedata_db.h Objects/unicodetype_db.h
|
||||
mv ../UnicodeData-3.0.0.txt UnicodeData-Latest.txt
|
||||
python Tools/unicode/makeunicodedata.py
|
||||
|
||||
# Regenerate sre_constants.h
|
||||
rm Modules/sre_constants.h
|
||||
python Lib/sre_constants.py
|
||||
|
||||
# Regenerate autoconf
|
||||
autoreconf-2.71 -fi
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
MACHDEP=linux ac_sys_system=Linux \
|
||||
./configure \
|
||||
--prefix="${PREFIX}" \
|
||||
--libdir="${LIBDIR}"
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
# Build pgen
|
||||
pushd Parser
|
||||
make -j1 pgen
|
||||
popd
|
||||
# Regen graminit.c and graminit.h
|
||||
pushd Grammar
|
||||
make -j1 graminit.c
|
||||
popd
|
||||
|
||||
# Regenerate some Python scripts using the other regenerated files
|
||||
gcc -o keyword keyword.c
|
||||
gcc -o token token.c
|
||||
# This gets all of the grammar tokens
|
||||
grep -E '\{1, "[^"]+"' Python/graminit.c | ./keyword > Lib/keyword.py.new
|
||||
mv Lib/keyword.py.new Lib/keyword.py
|
||||
./token Lib/symbol.py < Include/graminit.h > Lib/symbol.py.new
|
||||
mv Lib/symbol.py.new Lib/symbol.py
|
||||
# These get all of the #defines that have to be translated
|
||||
grep '#define[[:space:]][A-Z]*[[:space:]][[:space:]]*[0-9][0-9]*' Include/token.h | ./token Lib/token.py > Lib/token.py.new
|
||||
mv Lib/token.py.new Lib/token.py
|
||||
|
||||
# Now build the main program
|
||||
make -j1
|
||||
}
|
||||
|
||||
src_install() {
|
||||
mkdir -p "${DESTDIR}/usr"
|
||||
default
|
||||
|
||||
# Remove non-reproducible .pyc/o files
|
||||
find "${DESTDIR}" -name "*.pyc" -delete
|
||||
find "${DESTDIR}" -name "*.pyo" -delete
|
||||
}
|
||||
206
steps/python-2.0.1/patches/destdir.patch
Normal file
206
steps/python-2.0.1/patches/destdir.patch
Normal file
|
|
@ -0,0 +1,206 @@
|
|||
SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
|
||||
SPDX-License-Identifier: Python-2.0.1
|
||||
|
||||
Python 2.0 does not support DESTDIR, so add it in.
|
||||
|
||||
--- Makefile.in 2022-10-21 17:56:48.034287578 +1100
|
||||
+++ Makefile.in 2022-10-21 18:07:54.267542882 +1100
|
||||
@@ -224,16 +224,16 @@
|
||||
|
||||
# Install the interpreter (by creating a hard link to python$(VERSION))
|
||||
bininstall: altbininstall
|
||||
- -if test -f $(BINDIR)/python$(EXE); \
|
||||
- then rm -f $(BINDIR)/python$(EXE); \
|
||||
+ -if test -f $(DESTDIR)$(BINDIR)/python$(EXE); \
|
||||
+ then rm -f $(DESTDIR)$(BINDIR)/python$(EXE); \
|
||||
else true; \
|
||||
fi
|
||||
- (cd $(BINDIR); $(LN) python$(VERSION)$(EXE) python$(EXE))
|
||||
+ (cd $(DESTDIR)$(BINDIR); $(LN) python$(VERSION)$(EXE) python$(EXE))
|
||||
|
||||
# Install the interpreter with $(VERSION) affixed
|
||||
# This goes into $(exec_prefix)
|
||||
altbininstall: python$(EXE)
|
||||
- @for i in $(BINDIR); \
|
||||
+ @for i in $(DESTDIR)$(BINDIR); \
|
||||
do \
|
||||
if test ! -d $$i; then \
|
||||
echo "Creating directory $$i"; \
|
||||
@@ -242,15 +242,15 @@
|
||||
else true; \
|
||||
fi; \
|
||||
done
|
||||
- $(INSTALL_PROGRAM) python$(EXE) $(BINDIR)/python$(VERSION)$(EXE)
|
||||
+ $(INSTALL_PROGRAM) python$(EXE) $(DESTDIR)$(BINDIR)/python$(VERSION)$(EXE)
|
||||
if test -f libpython$(VERSION).so; then \
|
||||
- $(INSTALL_DATA) libpython$(VERSION).so $(LIBDIR); \
|
||||
+ $(INSTALL_DATA) libpython$(VERSION).so $(DESTDIR)$(LIBDIR); \
|
||||
else true; \
|
||||
fi
|
||||
|
||||
# Install the manual page
|
||||
maninstall:
|
||||
- @for i in $(MANDIR) $(MANDIR)/man1; \
|
||||
+ @for i in $(DESTDIR)$(MANDIR) $(DESTDIR)$(MANDIR)/man1; \
|
||||
do \
|
||||
if test ! -d $$i; then \
|
||||
echo "Creating directory $$i"; \
|
||||
@@ -260,7 +260,7 @@
|
||||
fi; \
|
||||
done
|
||||
$(INSTALL_DATA) $(srcdir)/Misc/python.man \
|
||||
- $(MANDIR)/man1/python.1
|
||||
+ $(DESTDIR)$(MANDIR)/man1/python.1
|
||||
|
||||
# Install the library
|
||||
PLATDIR= plat-$(MACHDEP)
|
||||
@@ -269,7 +269,7 @@
|
||||
LIBSUBDIRS= lib-old lib-tk site-packages test test/output encodings \
|
||||
distutils distutils/command $(XMLLIBSUBDIRS) curses $(MACHDEPS)
|
||||
libinstall: python $(srcdir)/Lib/$(PLATDIR)
|
||||
- @for i in $(SCRIPTDIR) $(LIBDEST); \
|
||||
+ @for i in $(DESTDIR)$(SCRIPTDIR) $(DESTDIR)$(LIBDEST); \
|
||||
do \
|
||||
if test ! -d $$i; then \
|
||||
echo "Creating directory $$i"; \
|
||||
@@ -278,11 +278,11 @@
|
||||
else true; \
|
||||
fi; \
|
||||
done
|
||||
- @for d in $(LIBSUBDIRS); \
|
||||
+ @for d in $(DESTDIR)$(LIBSUBDIRS); \
|
||||
do \
|
||||
a=$(srcdir)/Lib/$$d; \
|
||||
if test ! -d $$a; then continue; else true; fi; \
|
||||
- b=$(LIBDEST)/$$d; \
|
||||
+ b=$(DESTDIR)$(LIBDEST)/$$d; \
|
||||
if test ! -d $$b; then \
|
||||
echo "Creating directory $$b"; \
|
||||
mkdir $$b; \
|
||||
@@ -293,18 +293,18 @@
|
||||
@for i in $(srcdir)/Lib/*.py $(srcdir)/Lib/*.doc; \
|
||||
do \
|
||||
if test -x $$i; then \
|
||||
- $(INSTALL_PROGRAM) $$i $(LIBDEST); \
|
||||
- echo $(INSTALL_PROGRAM) $$i $(LIBDEST); \
|
||||
+ $(INSTALL_PROGRAM) $$i $(DESTDIR)$(LIBDEST); \
|
||||
+ echo $(INSTALL_PROGRAM) $$i $(DESTDIR)$(LIBDEST); \
|
||||
else \
|
||||
- $(INSTALL_DATA) $$i $(LIBDEST); \
|
||||
- echo $(INSTALL_DATA) $$i $(LIBDEST); \
|
||||
+ $(INSTALL_DATA) $$i $(DESTDIR)$(LIBDEST); \
|
||||
+ echo $(INSTALL_DATA) $$i $(DESTDIR)$(LIBDEST); \
|
||||
fi; \
|
||||
done
|
||||
@for d in $(LIBSUBDIRS); \
|
||||
do \
|
||||
a=$(srcdir)/Lib/$$d; \
|
||||
if test ! -d $$a; then continue; else true; fi; \
|
||||
- b=$(LIBDEST)/$$d; \
|
||||
+ b=$(DESTDIR)$(LIBDEST)/$$d; \
|
||||
for i in $$a/*; \
|
||||
do \
|
||||
case $$i in \
|
||||
@@ -324,11 +324,11 @@
|
||||
esac; \
|
||||
done; \
|
||||
done
|
||||
- $(INSTALL_DATA) $(srcdir)/LICENSE $(LIBDEST)/LICENSE.txt
|
||||
- PYTHONPATH=$(LIBDEST) \
|
||||
- ./python$(EXE) -tt $(LIBDEST)/compileall.py $(LIBDEST)
|
||||
- PYTHONPATH=$(LIBDEST) \
|
||||
- ./python$(EXE) -O $(LIBDEST)/compileall.py $(LIBDEST)
|
||||
+ $(INSTALL_DATA) $(srcdir)/LICENSE $(DESTDIR)$(LIBDEST)/LICENSE.txt
|
||||
+ PYTHONPATH=$(DESTDIR)$(LIBDEST) \
|
||||
+ ./python$(EXE) -tt $(DESTDIR)$(LIBDEST)/compileall.py $(DESTDIR)$(LIBDEST)
|
||||
+ PYTHONPATH=$(DESTDIR)$(LIBDEST) \
|
||||
+ ./python$(EXE) -O $(DESTDIR)$(LIBDEST)/compileall.py $(DESTDIR)$(LIBDEST)
|
||||
|
||||
# Create the PLATDIR source directory, if one wasn't distributed..
|
||||
$(srcdir)/Lib/$(PLATDIR):
|
||||
@@ -344,25 +344,25 @@
|
||||
inclinstall:
|
||||
@for i in $(INCLDIRSTOMAKE); \
|
||||
do \
|
||||
- if test ! -d $$i; then \
|
||||
- echo "Creating directory $$i"; \
|
||||
- mkdir $$i; \
|
||||
- chmod $(DIRMODE) $$i; \
|
||||
+ if test ! -d $(DESTDIR)$$i; then \
|
||||
+ echo "Creating directory $(DESTDIR)$$i"; \
|
||||
+ mkdir $(DESTDIR)$$i; \
|
||||
+ chmod $(DIRMODE) $(DESTDIR)$$i; \
|
||||
else true; \
|
||||
fi; \
|
||||
done
|
||||
@for i in $(srcdir)/Include/*.h; \
|
||||
do \
|
||||
- echo $(INSTALL_DATA) $$i $(INCLUDEPY); \
|
||||
- $(INSTALL_DATA) $$i $(INCLUDEPY); \
|
||||
+ echo $(INSTALL_DATA) $$i $(DESTDIR)$(INCLUDEPY); \
|
||||
+ $(INSTALL_DATA) $$i $(DESTDIR)$(INCLUDEPY); \
|
||||
done
|
||||
- $(INSTALL_DATA) config.h $(CONFINCLUDEPY)/config.h
|
||||
+ $(INSTALL_DATA) config.h $(DESTDIR)$(CONFINCLUDEPY)/config.h
|
||||
|
||||
# Install the library and miscellaneous stuff needed for extending/embedding
|
||||
# This goes into $(exec_prefix)
|
||||
LIBPL= $(LIBP)/config
|
||||
libainstall: all
|
||||
- @for i in $(LIBDIR) $(LIBP) $(LIBPL); \
|
||||
+ @for i in $(DESTDIR)$(LIBDIR) $(DESTDIR)$(LIBP) $(DESTDIR)$(LIBPL); \
|
||||
do \
|
||||
if test ! -d $$i; then \
|
||||
echo "Creating directory $$i"; \
|
||||
@@ -372,19 +372,19 @@
|
||||
fi; \
|
||||
done
|
||||
@if test -d $(LIBRARY); then :; else \
|
||||
- $(INSTALL_DATA) $(LIBRARY) $(LIBPL)/$(LIBRARY) ; \
|
||||
- $(RANLIB) $(LIBPL)/$(LIBRARY) ; \
|
||||
+ $(INSTALL_DATA) $(LIBRARY) $(DESTDIR)$(LIBPL)/$(LIBRARY) ; \
|
||||
+ $(RANLIB) $(DESTDIR)$(LIBPL)/$(LIBRARY) ; \
|
||||
fi
|
||||
- $(INSTALL_DATA) Modules/config.c $(LIBPL)/config.c
|
||||
- $(INSTALL_DATA) Modules/python.o $(LIBPL)/python.o
|
||||
- $(INSTALL_DATA) $(srcdir)/Modules/config.c.in $(LIBPL)/config.c.in
|
||||
- $(INSTALL_DATA) Modules/Makefile $(LIBPL)/Makefile
|
||||
- $(INSTALL_DATA) Modules/Setup $(LIBPL)/Setup
|
||||
- $(INSTALL_DATA) Modules/Setup.local $(LIBPL)/Setup.local
|
||||
- $(INSTALL_DATA) Modules/Setup.config $(LIBPL)/Setup.config
|
||||
- $(INSTALL_PROGRAM) $(srcdir)/Modules/makesetup $(LIBPL)/makesetup
|
||||
- $(INSTALL_PROGRAM) $(srcdir)/install-sh $(LIBPL)/install-sh
|
||||
- $(INSTALL_DATA) $(srcdir)/Misc/Makefile.pre.in $(LIBPL)/Makefile.pre.in
|
||||
+ $(INSTALL_DATA) Modules/config.c $(DESTDIR)$(LIBPL)/config.c
|
||||
+ $(INSTALL_DATA) Modules/python.o $(DESTDIR)$(LIBPL)/python.o
|
||||
+ $(INSTALL_DATA) $(srcdir)/Modules/config.c.in $(DESTDIR)$(LIBPL)/config.c.in
|
||||
+ $(INSTALL_DATA) Modules/Makefile $(DESTDIR)$(LIBPL)/Makefile
|
||||
+ $(INSTALL_DATA) Modules/Setup $(DESTDIR)$(LIBPL)/Setup
|
||||
+ $(INSTALL_DATA) Modules/Setup.local $(DESTDIR)$(LIBPL)/Setup.local
|
||||
+ $(INSTALL_DATA) Modules/Setup.config $(DESTDIR)$(LIBPL)/Setup.config
|
||||
+ $(INSTALL_PROGRAM) $(srcdir)/Modules/makesetup $(DESTDIR)$(LIBPL)/makesetup
|
||||
+ $(INSTALL_PROGRAM) $(srcdir)/install-sh $(DESTDIR)$(LIBPL)/install-sh
|
||||
+ $(INSTALL_DATA) $(srcdir)/Misc/Makefile.pre.in $(DESTDIR)$(LIBPL)/Makefile.pre.in
|
||||
@if [ -s Modules/python.exp -a \
|
||||
"`echo $(MACHDEP) | sed 's/^\(...\).*/\1/'`" = "aix" ]; then \
|
||||
echo; echo "Installing support files for building shared extension modules on AIX:"; \
|
||||
@@ -425,6 +425,7 @@
|
||||
CCSHARED="$(CCSHARED)" \
|
||||
LINKFORSHARED="$(LINKFORSHARED)" \
|
||||
DESTSHARED="$(DESTSHARED)" \
|
||||
+ DESTDIR="$(DESTDIR)" \
|
||||
prefix="$(prefix)" \
|
||||
exec_prefix="$(exec_prefix)" \
|
||||
sharedinstall
|
||||
--- Modules/Makefile.pre.in 2022-10-21 17:56:44.635251486 +1100
|
||||
+++ Modules/Makefile.pre.in 2022-10-21 17:57:00.124415957 +1100
|
||||
@@ -240,7 +240,7 @@
|
||||
sharedinstall: $(DESTSHARED) $(SHAREDMODS)
|
||||
-for i in X $(SHAREDMODS); do \
|
||||
if test $$i != X; \
|
||||
- then $(INSTALL_SHARED) $$i $(DESTSHARED)/$$i; \
|
||||
+ then $(INSTALL_SHARED) $$i $(DESTDIR)$(DESTSHARED)/$$i; \
|
||||
fi; \
|
||||
done
|
||||
|
||||
33
steps/python-2.0.1/patches/posixmodule.patch
Normal file
33
steps/python-2.0.1/patches/posixmodule.patch
Normal file
|
|
@ -0,0 +1,33 @@
|
|||
SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
|
||||
SPDX-License-Identifier: Python-2.0.1
|
||||
|
||||
musl (correctly) implements the POSIX posix_close function, however
|
||||
this was added well after Python 2.0.1 was released.
|
||||
|
||||
--- Modules/posixmodule.c 2022-09-16 16:46:09.809812072 +1000
|
||||
+++ Modules/posixmodule.c 2022-09-16 16:47:23.254166370 +1000
|
||||
@@ -3267,12 +3267,12 @@
|
||||
}
|
||||
|
||||
|
||||
-static char posix_close__doc__[] =
|
||||
+static char py_posix_close__doc__[] =
|
||||
"close(fd) -> None\n\
|
||||
Close a file descriptor (for low level IO).";
|
||||
|
||||
static PyObject *
|
||||
-posix_close(PyObject *self, PyObject *args)
|
||||
+py_posix_close(PyObject *self, PyObject *args)
|
||||
{
|
||||
int fd, res;
|
||||
if (!PyArg_ParseTuple(args, "i:close", &fd))
|
||||
@@ -5300,7 +5300,7 @@
|
||||
{"tcsetpgrp", posix_tcsetpgrp, METH_VARARGS, posix_tcsetpgrp__doc__},
|
||||
#endif /* HAVE_TCSETPGRP */
|
||||
{"open", posix_open, METH_VARARGS, posix_open__doc__},
|
||||
- {"close", posix_close, METH_VARARGS, posix_close__doc__},
|
||||
+ {"close", py_posix_close, METH_VARARGS, py_posix_close__doc__},
|
||||
{"dup", posix_dup, METH_VARARGS, posix_dup__doc__},
|
||||
{"dup2", posix_dup2, METH_VARARGS, posix_dup2__doc__},
|
||||
{"lseek", posix_lseek, METH_VARARGS, posix_lseek__doc__},
|
||||
18
steps/python-2.0.1/patches/undefs.patch
Normal file
18
steps/python-2.0.1/patches/undefs.patch
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
SPDX-FileCopyrightText: 2022 fosslinux <fosslinux@aussies.space>
|
||||
|
||||
SPDX-License-Identifier: Python-2.0.1
|
||||
|
||||
Python 2.0.1's Makefile does not support custom CFLAGS for some
|
||||
reason, so we have to patch our __DATE__ __TIME__ undefs in.
|
||||
|
||||
--- Makefile.in 2022-12-23 18:33:56.486325025 +1100
|
||||
+++ Makefile.in 2022-12-23 18:46:05.910387214 +1100
|
||||
@@ -127,7 +127,7 @@
|
||||
DIST= $(DISTFILES) $(DISTDIRS)
|
||||
|
||||
# Compilation flags for getbuildinfo.c only
|
||||
-CFLAGS= $(OPT) -I. $(DEFS)
|
||||
+CFLAGS= $(OPT) -I. $(DEFS) -U__DATE__ -U__TIME__
|
||||
|
||||
LIBRARY= libpython$(VERSION).a
|
||||
LDLIBRARY= @LDLIBRARY@
|
||||
2
steps/python-2.0.1/sources
Normal file
2
steps/python-2.0.1/sources
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
https://www.python.org/ftp/python/2.0.1/Python-2.0.1.tgz 98557b819a42d2093b41d8637302d1311b81f627af9ad20036357d7eb2813872
|
||||
http://ftp.unicode.org/Public/3.0-Update/UnicodeData-3.0.0.txt f41d967bc458ee106f0c3948bfad71cd0860d96c49304e3fd02eaf2bbae4b6d9
|
||||
Loading…
Add table
Add a link
Reference in a new issue