summarylogtreecommitdiffstats
path: root/PKGBUILD
diff options
context:
space:
mode:
authorbartus2020-03-10 17:50:28 +0100
committerbartus2020-03-10 19:01:26 +0100
commitf8f9d9ff0ec2a000464df2afa8bdf67d3805d50d (patch)
tree20bf763043ce430d67d1d7d24b39b6d9ad1651d2 /PKGBUILD
parent1e9f368d94deec49a77582dd13eb20577188593e (diff)
downloadaur-f8f9d9ff0ec2a000464df2afa8bdf67d3805d50d.tar.gz
Refactor.
* switch to ninja build system. * build manpage.
Diffstat (limited to 'PKGBUILD')
-rw-r--r--PKGBUILD51
1 files changed, 30 insertions, 21 deletions
diff --git a/PKGBUILD b/PKGBUILD
index 91710f653f3c..5bcde715e9b9 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -1,4 +1,9 @@
+#!/bin/hint/bash
# Maintainer : bartus <arch-user-repoᘓbartus.33mail.com>
+# shellcheck disable=SC2034,SC2154 # unused/uninitialized variables.
+# shellcheck disable=SC2164 # unsafe cd.
+# shellcheck disable=SC2191 # unsafe array asignment.
+
####to disable cuda kernel comment out this line
_BUILD_CUDA="on"
@@ -6,7 +11,7 @@ name=colmap
#fragment="#commit=5bea89263bf5f3ed623b8e6e6a5f022a0ed9c1de"
fragment="#branch=dev"
pkgname=${name}-git
-pkgver=3.6.dev.3.r6.g9012bb0
+pkgver=3.6.dev.3.r22.gad7bd93
pkgrel=1
pkgdesc="COLMAP is a general-purpose Structure-from-Motion (SfM) and Multi-View Stereo (MVS) pipeline with a graphical and command-line interface."
arch=('i686' 'x86_64')
@@ -14,7 +19,7 @@ url="https://colmap.github.io/"
license=('GPL')
groups=()
depends=('cgal' 'ceres-solver' 'gflags' 'suitesparse' 'freeglut' 'glew' 'google-glog' 'freeimage' 'libjpeg' 'boost-libs' 'qt5-base')
-makedepends=('boost' 'git' 'cmake' 'eigen' )
+makedepends=('boost' 'cmake' 'eigen' 'git' 'ninja' 'python-sphinx' )
if [ "$_BUILD_CUDA" == "on" ] ; then
makedepends+=('cuda-sdk')
optdepends=('cuda-toolkit: for cuda sfm/mvs acceleration')
@@ -34,45 +39,49 @@ sha256sums=('SKIP'
'fb60f7ba8081ee5c278f03c62329a374d1b24136b374a49393b453db1529a8c6')
pkgver() {
- cd "$pkgname"
- git describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g'
+ git -C "$pkgname" describe --long --tags | sed 's/\([^-]*-g\)/r\1/;s/-/./g'
}
prepare() {
- cd ${srcdir}/${pkgname}
- git apply ${srcdir}/*.patch
+ git -C "$pkgname" apply -v "$srcdir"/*.patch
+ mkdir -p build
}
build() {
- cd ${srcdir}
-
export CFLAGS=${CFLAGS/-fno-plt/}
export CXXFLAGS=${CFLAGS/-fno-plt/}
# determine whether we can precompile CUDA kernels
- _CUDA_PKG=`pacman -Qsq cuda 2>/dev/null` || true
- if [ -n "$_CUDA_PKG" -a "$_BUILD_CUDA"=="on" ]; then
- _EXTRAOPTS="-DCUDA_ENABLED=ON -DCUDA_HOST_COMPILER=/opt/cuda/bin/gcc -DCUDA_TOOLKIT_ROOT_DIR=/opt/cuda"
+ _CUDA_PKG=$(pacman -Qsq cuda 2>/dev/null) || true
+ if [[ -n "$_CUDA_PKG" && "$_BUILD_CUDA" == "on" ]]; then
+ _CMAKE_FLAGS+=( -DCUDA_ENABLED=ON
+ -DCUDA_HOST_COMPILER=/opt/cuda/bin/gcc
+ -DCUDA_TOOLKIT_ROOT_DIR=/opt/cuda )
else
- _EXTRAOPTS="-DCUDA_ENABLED=OFF"
+ _CMAKE_FLAGS+=( -DCUDA_ENABLED=OFF )
fi
- mkdir -p build
- cd build
- cmake -DTESTS_ENABLED=OFF -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr ${_EXTRAOPTS} ../${pkgname}
- make
+ _CMAKE_FLAGS+=( -DTESTS_ENABLED=OFF
+ -DCMAKE_BUILD_TYPE=Release
+ -DCMAKE_INSTALL_PREFIX=/usr )
+ cmake "${_CMAKE_FLAGS[@]}" -G Ninja -S "$pkgname" -B build
+# shellcheck disable=SC2086 # allow MAKEFLAGS to carry multiple flags.
+ ninja -C build ${MAKEFLAGS:--j1}
}
package() {
- cd ${srcdir}/build
- make DESTDIR=${pkgdir} install
+ DESTDIR="${pkgdir}" ninja -C build install
+
+# build manpage
+ make -C "${pkgname}/doc" man BUILDDIR="$PWD" && \
+ install -Dm644 man/colmap.1 -t "${pkgdir}/usr/share/man/man1"
# install vocabulary trees for sequential,vocabulary matching
- install -d -m755 ${pkgdir}/usr/share/${name}
- for vocab_tree in ${srcdir}/vocabulary-tree-*.bin ; do
- install -m644 ${vocab_tree} ${pkgdir}/usr/share/${name}/${vocab_tree##*/}
+ install -d -m755 "${pkgdir}/usr/share/${name}"
+ for vocab_tree in "${srcdir}"/vocabulary-tree-*.bin ; do
+ install -m644 "${vocab_tree}" "${pkgdir}/usr/share/${name}/${vocab_tree##*/}"
done
}
# vim:set ts=2 sw=2 et: