summaryrefslogtreecommitdiff
path: root/auto
diff options
context:
space:
mode:
authordavidovski <david@davidovski.xyz>2022-06-03 13:05:13 +0100
committerdavidovski <david@davidovski.xyz>2022-06-03 13:05:13 +0100
commit66c326b6d65388e9f1003715ad9675505f01f9d2 (patch)
tree40d7355cccfa3464902cf339a563e744c28a7101 /auto
parentfccdaa986f67f820df2914bef851d5fed77abac8 (diff)
added porting from alpine linux
Diffstat (limited to 'auto')
-rwxr-xr-xauto/create_meta.sh2
-rwxr-xr-xauto/port-alpine.sh88
2 files changed, 88 insertions, 2 deletions
diff --git a/auto/create_meta.sh b/auto/create_meta.sh
index 04c7e84..da610bf 100755
--- a/auto/create_meta.sh
+++ b/auto/create_meta.sh
@@ -22,8 +22,6 @@ create() {
mkdir -p repo/meta/all/
ls repo | create 'AlL tHe pacKageS!!' > repo/meta/all/all.xibuild
-skip="skip meta"
-
for repo in $(ls repo); do
pkg_name=repo-$repo
if echo $skip | grep -q $repo; then
diff --git a/auto/port-alpine.sh b/auto/port-alpine.sh
new file mode 100755
index 0000000..9a6a623
--- /dev/null
+++ b/auto/port-alpine.sh
@@ -0,0 +1,88 @@
+#!/bin/sh
+#
+# port a package from alpine linux
+#
+
+package=$1
+aports_dir="/home/david/docs/proj/alpine/aports"
+
+pkgbuild=$(find $aports_dir -name "$package" -type d | head -1)
+
+[ ! -d "$pkgbuild" ] && printf "${RED}package not found" && exit 1
+
+apkbuild="$pkgbuild/APKBUILD"
+additional=$(ls $pkgbuild | grep -v ^APKBUILD$)
+
+. $apkbuild
+
+
+name=$pkgname
+
+version=$pkgver
+
+# some use a _ pkg ver
+[ ! -z "$_pkgver"] && version=$_pkgver
+
+url=$(echo "$source" | head -1)
+makedeps=""
+for dep in $makedepends; do
+ makedeps="$makedeps $(echo $dep | sed -E 's/(-dev|-lib|-doc)$//g')"
+done
+
+builddir="repo/$package"
+buildfile="$builddir/$package.xibuild"
+mkdir -p $builddir
+touch $buildfile
+
+cat > $buildfile << EOF
+#!/bin/sh
+
+NAME="$pkgname"
+DESC="$pkgdesc"
+
+MAKEDEPS="$makedeps"
+
+PKG_VER=$version
+EOF
+
+grep "source=" $apkbuild | sed 's/source=/SOURCE=/g' | sed 's/pkgver/PKG_VER/g' | sed -r 's/([^"])$/\1"/' >> $buildfile
+echo >> $buildfile
+
+[ "${#additional}" != "0" ] && {
+ echo "ADDITIONAL=\"" >> $buildfile
+ for file in $additional; do
+ echo $file >> $buildfile
+ [ -f $pkgbuild/$file ] && cp $pkgbuild/$file $builddir/
+ done
+ echo '"' >> $buildfile
+ echo >> $buildfile
+}
+
+# TODO make this better
+counting=false
+while IFS= read -r line; do
+ case "$line" in
+ *"()"*"{") counting=true;;
+ sha512sums=*) counting=false;;
+ esac
+
+ $counting && printf "%s\n" "$line" >> $buildfile
+done < $apkbuild
+
+sed -i "s/\$pkgname/$name/g" $buildfile
+sed -i "s/\$pkgver/\$PKG_VER/g" $buildfile
+sed -i "s/\$pkgdir/\$PKG_DEST/g" $buildfile
+sed -i "s/\$subpkgdir/\$PKG_DEST/g" $buildfile
+sed -i "s/\$srcdir/\$BUILD_ROOT/g" $buildfile
+sed -i "s/\$builddir/\$BUILD_ROOT/g" $buildfile
+sed -i "s/^sha512sums=.*$//g" $buildfile
+# ignore build and host options for configure; we arent cross compiling
+sed -i "s/^\w*--build=//g" $buildfile
+sed -i "s/^\w*--host=//g" $buildfile
+
+sed -i 's/abuild-meson/meson --prefix=\/usr \\\n/' $buildfile
+
+echo "press enter to edit"
+read edit
+
+vim -O $buildfile $apkbuild