/builders/glib-0/builder-target.sh (cb5a0e9dfb379d31ced5fd7e85059f150a2b98b4) (2272 bytes) (mode 100644) (type blob)
src_name=glib
version=2.56.0
archive_name=$src_name-$version.tar.xz
url0=
src_dir=$src_dir_root/$src_name-$version
cd $src_dir_root
rm -Rf $src_name-$version
tar xf $archive_name
build_dir=$builds_dir_root/$src_name-$version-$target_gnu_triple
rm -Rf $build_dir
mkdir -p $build_dir
cd $build_dir
OLD_PATH=$PATH
export PATH=$cross_toolchain_dir_root/bin:$sdk_gettext_path/bin:$PATH
export "PKG_CONFIG_LIBDIR=\
$target_sysroot/nyan/zlib/0/lib/pkgconfig:\
$target_sysroot/nyan/libffi/0/lib/pkgconfig"
export PKG_CONFIG_SYSROOT_DIR=$target_sysroot
# this one is microsoft/apple grade (aka massive pile of shit)
# some target arch features are not properly detected in cross-compiling mode
# (for linux, for windows its fine), you need to hardcode them
# pcre1 is obsolete
# at link time, the only way to tell gnu ld where to look for shared lib dependencies is to pass the -rpath-link option
export "CC=$target_gnu_triple-gcc -B$target_sysroot/nyan/glibc/current/lib -L$target_sysroot/nyan/glibc/current/lib -Wl,-rpath-link,$target_sysroot/nyan/glibc/current/lib -static-libgcc"
export 'CFLAGS=-O2 -pipe -fPIC'
$src_dir/configure \
--build=$build_gnu_triple \
--host=$target_gnu_triple \
--prefix=/nyan/glib/0 \
--enable-debug=no \
--disable-gtk-doc-html \
--with-threads=posix \
--disable-libmount \
--with-pcre=internal \
--with-python=$sdk_python3_path/bin/python3 \
glib_cv_stack_grows=no \
glib_cv_uscore=no
unset CFLAGS
unset CC
# parallel build breaks code generation with python, ofc
make
make install DESTDIR=$target_sysroot
# cleanup and tidying
find $target_sysroot/nyan/$src_name/0 -type f -name '*.la' | xargs rm -f
find $target_sysroot/nyan/$src_names/0 -type f | while read f; do if file $f | egrep 'ELF.+(shared|executable)' >/dev/null; then $target_gnu_triple-strip -s $f; fi; done
# some target python scripts are installed with the wrong target python path, ofc
sed -i -e '1 c#PYTHON3' \
$target_sysroot/nyan/$src_name/0/bin/gdbus-codegen \
$target_sysroot/nyan/$src_name/0/bin/glib-genmarshal \
$target_sysroot/nyan/$src_name/0/bin/glib-mkenums \
$target_sysroot/nyan/$src_name/0/bin/gdbus-codegen \
$target_sysroot/nyan/$src_name/0/bin/gtester-report
rm -Rf $build_dir $src_dir
export PATH=$OLD_PATH
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
5 |
8eba6c8dd4dcaf6166bd22285ed34625f38a84ff |
.gitignore |
100755 |
blob |
1587 |
57fa4264b9ee0ae0a6f678f2527a05d3b22dda78 |
00-bootstrap-build.sh |
100755 |
blob |
848 |
a30f443bf405d56682efe3b4c5d3a19d5f7eb45d |
01-re-bootstrap-build.sh |
100644 |
blob |
2142 |
f19c2d6b293244bb11a3f74ee77c10675cadc7d6 |
INSTALL |
100644 |
blob |
30 |
c9b735fa1332286f4b3f5f81fa10527fd7506b6e |
LICENSE |
040000 |
tree |
- |
dafcdc47689e7f55dddc3ef81ae62ee65b1cc89d |
builders |
100644 |
blob |
1773 |
ef1551089a803bde37e36edc8d61bb819d06f793 |
conf.bootstrap.sh |
100644 |
blob |
479 |
8cc15efe46965ac7750fe304460f5a2b0aa4201c |
conf.sh |
040000 |
tree |
- |
7b9a10f45c2ce0f3169feab699ade1467b9e9033 |
files |
100755 |
blob |
356 |
8fb8be28ac72f7214b59934b9f74a682665f2d32 |
pkg-build |
100644 |
blob |
22800641 |
e9e6291054c857401f6835c728f31541dae4311e |
steam.tar.bz2 |
100644 |
blob |
173 |
2047af328b22f9d146585cd9e759edbc18122250 |
utils.sh |
040000 |
tree |
- |
8e23f551092a35f82b37129dd08c35c4d313c17b |
x64 |
040000 |
tree |
- |
b7a22de7f5cbd97650dd45412ef7d4246e395eb8 |
x86 |
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/sylware/nyanlinux
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/sylware/nyanlinux
Clone this repository using git:
git clone git://git.rocketgit.com/user/sylware/nyanlinux
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main