summaryrefslogtreecommitdiff
AgeCommit message (Collapse)AuthorFilesLines
2018-11-08abuild: print build start, end date and elapsed timeTimo Teräs1-1/+5
2018-10-11abuild-rmtemp: Do not follow symbolic linksSören Tempel1-1/+1
Symbolic links might point to files outside of the chroot and thus might delete files outside the chroot. This allows deletion of arbitrary directories on the host from a malicious APKBUILD. Following hard links shouldn't be a problem since hard links (usually) cannot refer to directories and since remove(3) removes the link, not the file it points to it shouldn't cause a problem. I noticed this because alpine-baselayout creates /var/run as a symlink to /run. Therefore causing /run to be deleted on the host when using abuild-rmtemp which in turn causes a bunch of software to no longer function properly (including OpenRC).
2018-10-03==== release 3.3.0_pre1 ====v3.3.0_pre1Natanael Copa1-1/+1
2018-10-03abuild: run build actions via runpartNatanael Copa1-11/+5
So we make sure chdir $builddir happens when it should.
2018-10-03abuild: do not run check in fakeroot by defaultNatanael Copa2-10/+9
Only run check in fakeroot if options="checkroot" is set. This makes options="!checkroot" the default. I expect most checks work as non-root, and if a testsuite requires root, it will likely fail in fakeroot too. Fakeroot has also shown lower performance for parallel builds.
2018-10-03abuild: print version of built package earlyNatanael Copa1-1/+1
instead of printing abuild version, print package version. This is to avoid confuse the abuild version with the package version.
2018-10-03abuild: chdir to $builddir if it existsNatanael Copa1-0/+6
chdir to $builddir before running prepare, build, package or check.
2018-10-03abuild: fix regression. run buildNatanael Copa1-1/+2
fix regression introduced in def219994d2dff3c2bd47eee76826dc79e042b2f
2018-10-03abuild: require package() functionNatanael Copa1-20/+5
make a missing function for package() a hard error. this means we never run build in fakeroot.
2018-10-03checkapk: remove temporary dir on SIGINT and exitSören Tempel1-2/+1
2018-10-03newapkbuild: fix checksums to be last in ABPKUILDNatanael Copa1-0/+3
ref https://github.com/alpinelinux/abuild/pull/42
2018-10-03abuild: fix checksum updateNatanael Copa1-3/+7
Fix case where 1) checksum is a single line and 2) there is a variable under the checksum that should be kept. For example: sha512sum="...." keepthis="..." Previously the `keepthis` variable would have been removed. ref https://github.com/alpinelinux/abuild/pull/41
2018-10-03move logic of curl's http range error to abuild-fetchNatanael Copa2-31/+32
Move the logic of deleting partial downloads to abuild-fetch, which knows if it is curl or wget that was executed.
2018-10-03Fix: incomplete partfile gets renamed to distfileOliver Smith2-14/+35
Abuild-fetch uses curl (fallback to wget) to download files. They are saved with a ".part" extension first, so they can be resumed if necessary. When the download is through, the ".part" extension gets removed. However, when the server does not support resume of downloads (e.g. GitHub's on the fly generated tarballs), then the ".part" extension got removed anyway. Abuild aborts in that case. But when running a third time, the distfile exists and it is assumed that this is the full download. Changes: * abuild-fetch: * Only remove the ".part" extension, when curl/wget exit with 0 * Pass the exit code from curl/wget as exit code of abuild-fetch * Wherever abuild-fetch would return an exit code on its own, the codes have been changed to be > 200 (so they don't collide with curl's as of now 92 exit codes) * Remove undocumented feature of downloading multiple source URLs at a time. This doesn't match with the usage description, was not used in abuild at all and it would have made it impossible to pass the exit code. * abuild: * After downloading, when curl is installed and abuild-fetch has 33 as exit code (curl's HTTP range error), then delete the partfile and try the download again.
2018-10-03newapkbuild.1: fix mdoc styleA. Wilcox1-70/+25
2018-10-03APKBUILD.5: fix mdoc syntax warningsA. Wilcox1-229/+170
2018-10-03docs: Add checkdepends variableA. Wilcox1-0/+4
2018-10-03man: Clarify arguments to install scriptsA. Wilcox1-3/+3
2018-10-03man: Better document install scriptsA. Wilcox1-2/+9
2018-10-03man: remove obsolete !libc_* optionsA. Wilcox1-9/+0
2018-10-03man: Write requested improvements to documentationA. Wilcox2-50/+183
2018-10-03Add initial manpage draftsA. Wilcox3-1/+719
2018-09-24sample.APKBUILD: use https for sourceforge download linksprspkt1-1/+1
2018-09-24newapkbuild: use https for sourceforge download linksprspkt1-1/+1
2018-07-29newapkbuild: fix default check function for python3Jakub Jirutka1-1/+1
`setup.py check` does not run package tests, it performs just some check of the package metadata. The correct command is `setup.py test`.
2018-06-22==== release 3.2.0 ====v3.2.0Natanael Copa1-1/+1
2018-06-21newapkbuild: check arguments and improve usage()Oliver Smith1-18/+44
Changes: * argument sanity checks: * `PKGNAME[-PKGVER] | SRCURL` * check if missing * check if specified more than once (see below) * specifying more than one buildtype flag * `-n` (set pkgname) without using SRCURL as last argument * `-s` (sourceforge source) without using PKGNAME as last argument * Typo fix: exist -> exists * `usage()`: * always print PKGNAME and PKGDESC (instead of NAME and DESC, NAME was used in one place and PKGNAME in another) * link to <https://spdx.org/licenses/> * `-m` (meson) flag was missing in short usage line at the top * indicate that the buildtypes are exclusive * `-c` flag: remove "to new directory" wording to make the message shorter (this should be obvious) * remove empty line at the end NOTE: Before this commit, the `PKGNAME[-PKGVER] | SRCURL` was allowed to be specified more than once, and the code looped over the arguments. But this was not documented in `usage()` and had unexpected results: ``` $ newapkbuild first second third $ tree . ___ first ___ APKBUILD ___ first ___ ___ APKBUILD ___ ___ first ___ ___ ___ APKBUILD ___ ___ ___ src ___ ___ src ___ src ```
2018-05-31==== release 3.2.0_rc2 ====v3.2.0_rc2Natanael Copa1-1/+1
2018-05-31abuild: fix race when strippingNatanael Copa1-0/+4
scanelf may pick up tempfiles created by strip or setfattr since it runs in spearate process and pipes the out to a subshell. This causes a race and may lead to the while loop attempt to strip seomthing that no longer exists. We fix that by test if file exists before try manipulate it. We could have written he file list to a temp file first, but this way we benefit from multiple cores working in parallel.
2018-05-24newapkbuild: move checksum call to after fetchA. Wilcox1-2/+1
unpack will no longer unpack without a checksum, even with -f. This means that newapkbuild will not be able to deduce what kind of build system is contained within, so the templates for CMake, Perl, etc are never used. This patch ensures checksumming is done right after fetch, so that unpack works properly.
2018-05-24newapkbuild: fix typoA. Wilcox1-1/+1
2018-05-07newapkbuild: create check() functionJakub Jirutka1-0/+30
2018-05-07newapkbuild: change python to python3Jakub Jirutka1-4/+4
2018-04-25abuild: Fix usage info about package commandJonathan Sieber1-1/+1
abuild package misleadingly stated that it will create packages in $REPODIR (suggesting that it actually creates apks).
2018-04-22abuild.in: don't fail if git describe failsSören Tempel1-1/+1
`git describe` by default looks for tags, but `git clone` does not clone tags by default which causes failures on travis currently. Also redirect `git describe` errors to /dev/null while being here.
2018-04-17==== release 3.2.0_rc1 ====v3.2.0_rc1Natanael Copa1-1/+1
2018-04-17abuild: fix unxz with threadingNatanael Copa1-1/+5
busybox unxz does not support --threads/-T option
2018-04-17abuild: simplify optional git usageNatanael Copa1-11/+5
set git=true if git is missing so all git commands are ignored. This simplifies the code a bit
2018-04-15abuild: add multithread decommpressing supportCarlo Landmeter1-3/+5
2018-04-11abuild: allow SPDX license operatorsCarlo Landmeter1-0/+2
valid operators are AND OR WITH
2018-04-11Make file missing in source var explicit.Manuel Tiago Pereira1-1/+1
I've forgot to add a patch file to the source variable in an APKBUILD, altought I did add it to the sums variable. The error message made it seem that I've forgot to add the file to the source directory, which led me to check if my build system was missing the files for some reason. Only after reading the `abuild.in` file did I understood what happened. Hopefully this change makes the message clearer and more helpful.
2018-04-11Fix a few typosJonathan Neuschäfer2-3/+3
2018-04-11abuild: check license for valid SPDX license identifiersCarlo Landmeter1-0/+16
licenses will be checked against the license.lst file provided by the spdx-licenses-list package when installed except when explicitly disabled by the !spdx options flag.
2018-03-20Don't print 'git: not found' errorsOliver Smith1-6/+13
abuild, as packaged in Alpine Linux, does not depend on git. But when you use it without git, it will print out errors like the following: /usr/bin/abuild: line 2554: git: not found With this commit, it saves the git_path in the beginning (just like abuild_path). Later in the code it does not try to run git if that variable is empty. Notably `abuild rootbld` is already checking whether `abuild-rootbld` is installed, and that subpackage of `abuild` does already depend on `git`. So no additional check was added before using `git ` inside `rootbld`. Fixes #32
2018-03-16abuild: Change -f (force) to not ignore checksums/init scriptsOliver Smith1-5/+3
The force flag used to skip the following functions, without any documentation in the help (-h) output: * verify (checksum verification) * initdcheck (check if the init scripts are openrc scripts) * check_arch (check if the target architecture is in "arch=") * check_libc (check if the target libc is masked in the options) This was counter-intuitive and could even be dangerous (when one relies on the checksum verification to prevent man-in-the-middle attacks, but always uses the -f flag). With this commit, it only skips check_arch and check_libc besides the package up to date check and the help output mentions this.
2018-03-11abuild: set arch for -openrc subpackage to noarchSören Tempel1-1/+1
2018-03-11abuild: add postcheck for -openrc subpackageSören Tempel1-0/+10
2018-03-11abuild.in: ensure that $triggers is not in $sourceSören Tempel1-0/+5
Since we already check that $install is not in $source is does make sense to also check that $triggers is not in $source.
2018-03-08rootbld: if networking is enabled, copy resolv.conf into the build rootWilliam Pitcock1-0/+4
2018-02-20abuild: fix typoNatanael Copa1-1/+1