pacman: WIP, it now builds

This commit is contained in:
Francisco Demartino 2015-12-23 23:44:52 -03:00
parent 3888e4cd39
commit f6f8b3d361
2 changed files with 32 additions and 15 deletions

View File

@ -6,20 +6,23 @@ TERMUX_PKG_HOMEPAGE=https://www.archlinux.org/pacman/
TERMUX_PKG_DESCRIPTION="A library-based package manager with dependency support" TERMUX_PKG_DESCRIPTION="A library-based package manager with dependency support"
TERMUX_PKG_VERSION=$pkgver TERMUX_PKG_VERSION=$pkgver
TERMUX_PKG_DEPENDS="bash glibc libarchive curl gpgme asciidoc python2 fakechroot" TERMUX_PKG_DEPENDS="bash glibc libarchive curl gpgme asciidoc python2 fakechroot libandroid-glob libandroid-support"
TERMUX_PKG_SRCURL="https://sources.archlinux.org/other/pacman/$pkgname-$pkgver.tar.gz" TERMUX_PKG_SRCURL="https://sources.archlinux.org/other/pacman/$pkgname-$pkgver.tar.gz"
TERMUX_PKG_BUILD_IN_SRC=yes TERMUX_PKG_BUILD_IN_SRC=yes
TERMUX_PKG_MAINTAINER="Francisco Demartino <demartino.francisco@gmail.com>" TERMUX_PKG_MAINTAINER="Francisco Demartino <demartino.francisco@gmail.com>"
TERMUX_PKG_EXTRA_CONFIGURE_ARGS="--prefix=$TERMUX_PREFIX/usr --sysconfdir=$TERMUX_PREFIX/usr/etc" TERMUX_PKG_EXTRA_CONFIGURE_ARGS="--prefix=$TERMUX_PREFIX --sysconfdir=$TERMUX_PREFIX/etc"
TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --localstatedir=$TERMUX_PREFIX/usr/var --enable-doc " TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --localstatedir=$TERMUX_PREFIX/var --enable-doc "
TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-scriptlet-shell=/usr/bin/bash" TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-scriptlet-shell=/usr/bin/bash"
export LDFLAGS="$LDFLAGS -llog -landroid-glob"
termux_step_make () { termux_step_make () {
make make
make -C contrib make -C contrib
make -C "$pkgname-$pkgver" check # make -C "$pkgname-$pkgver" check
} }
#package() { #package() {
@ -29,8 +32,8 @@ termux_step_make_install () {
make DESTDIR="$TERMUX_PREFIX" -C contrib install make DESTDIR="$TERMUX_PREFIX" -C contrib install
# install Arch specific stuff # install Arch specific stuff
install -dm755 "$TERMUX_PREFIX/usr/etc" install -dm755 "$TERMUX_PREFIX/etc"
install -m644 "pacman.conf" "$TERMUX_PREFIX/usr/etc/pacman.conf" install -m644 "$TERMUX_PKG_BUILDER_DIR/pacman.conf" "$TERMUX_PREFIX/etc/pacman.conf"
case $TERMUX_ARCH in case $TERMUX_ARCH in
i686) i686)
@ -46,20 +49,22 @@ termux_step_make_install () {
esac esac
# set things correctly in the default conf file # set things correctly in the default conf file
install -m644 "makepkg.conf" "$TERMUX_PREFIX/usr/etc" install -m644 "$TERMUX_PKG_BUILDER_DIR/makepkg.conf" "$TERMUX_PREFIX/etc"
sed -i "$TERMUX_PREFIX/usr/etc/makepkg.conf" \ sed -i "$TERMUX_PREFIX/etc/makepkg.conf" \
-e "s|@CARCH[@]|$mycarch|g" \ -e "s|@CARCH[@]|$mycarch|g" \
-e "s|@CHOST[@]|$mychost|g" \ -e "s|@CHOST[@]|$mychost|g" \
-e "s|@CARCHFLAGS[@]|$myflags|g" -e "s|@CARCHFLAGS[@]|$myflags|g"
# FIXME bash_completion
# put bash_completion in the right location # put bash_completion in the right location
install -dm755 "$TERMUX_PREFIX/usr/share/bash-completion/completions" # install -dm755 "$TERMUX_PREFIX/share/bash-completion/completions"
mv "$TERMUX_PREFIX/usr/etc/bash_completion.d/pacman" "$TERMUX_PREFIX/usr/share/bash-completion/completions" # mv "$TERMUX_PREFIX/etc/bash_completion.d/pacman" "$TERMUX_PREFIX/share/bash-completion/completions"
rmdir "$TERMUX_PREFIX/usr/etc/bash_completion.d" # rmdir "$TERMUX_PREFIX/etc/bash_completion.d"
for f in makepkg pacman-key; do # for f in makepkg pacman-key; do
ln -s pacman "$TERMUX_PREFIX/usr/share/bash-completion/completions/$f" # ln -s pacman "$TERMUX_PREFIX/share/bash-completion/completions/$f"
done # done
install -Dm644 contrib/PKGBUILD.vim "$TERMUX_PREFIX/usr/share/vim/vimfiles/syntax/PKGBUILD.vim" install -Dm644 contrib/PKGBUILD.vim "$TERMUX_PREFIX/share/vim/vimfiles/syntax/PKGBUILD.vim"
} }

View File

@ -0,0 +1,12 @@
--- ./src/pacman/pacman.c 2015-12-23 19:50:37.093132801 -0300
+++ ./src/pacman/pacman.c 2015-12-23 23:30:17.986469980 -0300
@@ -1128,7 +1128,8 @@
} while(c != EOF);
free(line);
- if(!freopen(ctermid(NULL), "r", stdin)) {
+ //if(!freopen(ctermid(NULL), "r", stdin)) {
+ if(!freopen("/dev/tty", "r", stdin)) { // HACK termux doesn't have ctermid()
pm_printf(ALPM_LOG_ERROR, _("failed to reopen stdin for reading: (%s)\n"),
strerror(errno));
}