summaryrefslogtreecommitdiffstats
path: root/abuild.in
Commit message (Collapse)AuthorAgeFilesLines
* change ~ to /home/pdietlPete Dietl2019-07-171-2/+2
|
* abuild.in: fixup flags and usage textPete Dietl2019-07-171-3/+3
|
* Better use license.lst in abuild sanitycheckKeith Maxwell2019-07-171-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Before this change an invalid licence= in an APKBUILD will pass `abuild sanitycheck`. '/usr/share/spdx/license.lst' contains one licence per line. `grep -x` will match partial lines whereas `grep -w` will only match whole lines. An simple demonstration is with 'GPL-3.0' which is not a valid SPDX licence identifier. 'GPL-3.0-only' and 'GPL-3.0-or-later' are valid licences. ``` $ grep --help BusyBox v1.30.1 (2019-04-26 06:26:16 UTC) multi-call binary. Usage: grep [-HhnlLoqvsriwFE] [-m N] [-A/B/C N] PATTERN/-e PATTERN.../-f FILE [FILE]... Search for PATTERN in FILEs (or stdin) ✂ -w Match whole words only -x Match whole lines only ✂ $ grep -w -F GPL-3.0 /usr/share/spdx/license.lst GPL-3.0-only GPL-3.0-or-later $ grep -x -F GPL-3.0 /usr/share/spdx/license.lst $ ```
* make default_static depend on depends_staticLeo2019-07-171-1/+1
| | | | keeps it in line with other default_ functions.
* abuild.in: make is_x_package functions reliant on being given a nameLeo2019-07-171-2/+2
|
* Fix condition check for adding static libraries to -dev package.Leo2019-07-081-1/+1
| | | | | This was the wrong way, we only want to add the static library to the -dev package when there isn't a -static package.
* abuild usage fix: fetch does not verify sourcesOliver Smith2019-06-121-1/+1
| | | | | | | | | Replace text in usage description of fetch that claims to verify sources with a suggestion to use 'abuild fetch verify', which will actually verify them. 'abuild fetch' alone will not verify sources, as it only executes the fetch() function.
* abuild: fix -openrc to work with multiple subpackagesNatanael Copa2019-05-031-1/+1
| | | | allow a single APKBUILD have multiple -openrc subpackages.
* abuild.in: fix warning with gawk-5.0Leo2019-04-301-1/+1
| | | | awk: cmd. line:1: warning: regexp escape sequence `\#' is not a known regexp operator
* abuild: cleanup default_dbgNatanael Copa2019-04-301-20/+18
| | | | | | | | | Run the loop in a subshell via a pipe so we dont need a subshell for each iteration. Use `if ...; then` to make code slightly more readable. Fix a whitespace before tab while at it.
* abuild: default_dbg: do not trigger trap with test failuretcely2019-04-301-0/+1
| | | | Resolves alpinelinux/abuild#71
* abuild.in: remove duplicate options_has callLeo2019-04-291-1/+1
|
* abuild: default_dbg: eliminate side effectstcely2019-04-291-17/+18
| | | | | | | | | | | - do not overwrite variables srcdir is very important for abuild operation - quoted various paths - use a sub-shell to contain directory changing Resolves alpinelinux/abuild#58
* abuild-clean: add option to make files writable before cleanupKevin Daudt2019-04-291-0/+3
| | | | | | | | | | | Some projects might leave files which are not writable for the current user. The cleanup process then fails and leaves files / directories behind. This can easily be fixed by making everything writable before removing the files. Add the option 'chmod-clean' which does just that.
* abuild: change word choice in commenttcely2019-04-291-1/+1
|
* abuild: fix whitespace before EOLNatanael Copa2019-04-291-1/+1
|
* abuild: provide a default_static() and static() functionsLeo2019-04-291-2/+37
| | | | - Also check for static archives and warn on lack of static subpackage
* Revert "abuild: replace command -v with which to fix build issues"Mike Sullivan2019-04-291-1/+1
| | | | | | This reverts commit 57f2830739e31f9c73d2edaf5103502fbdae6822. https://github.com/alpinelinux/aports/pull/7203 fixes the original problem
* Revert "abuild: unset depends for subpackages"Natanael Copa2019-04-251-1/+0
| | | | | | | | | | | | | | | Apparently there are many packages that does soemthing like: subpackages="$pkgname-foo:_foo" _foo() { depends="$depends something-else" } and thus depend on the previous behavior. We need to revert and plan this better. This reverts commit 8fbbffd201a28a06804c7f6d3a2b5cd948c6ce07.
* abuild: add depends_libs variable to default_libs()Sören Tempel2019-04-091-0/+1
| | | | | | | | | Other subpackage such as -dev, -doc and even -openrc allow adjusting depends of the subpackage through such a variable. This is, for instance, useful to remove a dependency of the origin package from the -libs subpackage. While at it document it in APKBUILD(5).
* abuild: -openrc should not inherit dependstcely2019-04-031-0/+1
|
* Add default_cleanup_srcdirChloe Kudryavtsev2019-04-031-1/+9
| | | | | | | | | | | | | | | | | | | | In some cases, a simple rm -rf is not sufficent to clean srcdir. One such case is the new go module system, that marks everything as read-only - thus only letting root rm -rf it without a chmod. There is a command intended to clean them - `go clean -modcache`. However, for that to work, GOPATH must be defined and existent. Running chmod for all srcdir cleanups makes no sense, nor does enforcing root, or putting global overrides just for go. This patch allows overriding what happens on `cleanup srcdir`, by overriding cleanup_srcdir, and allows the use of default_cleanup_srcdir. In our go example, it might be used as such: cleanup_srcdir() { go clean -modcache default_cleanup_srcdir }
* Make clean() use cleanup()Chloe Kudryavtsev2019-04-031-3/+2
| | | | Avoid DRY issues, and increase consistency.
* abuild: unset depends for subpackagesNatanael Copa2019-03-211-0/+1
| | | | make sure that subpackages does not inherit main package's depends.
* abuild: replace command -v with which to fix build issuesMike Sullivan2019-03-051-1/+1
|
* abuild: add support for pkg-config prefix pcprefixNatanael Copa2019-02-221-2/+12
| | | | | | | | | | | | | | | | | | | | | Fix issue when two -dev packages provides same pkg-config wil but with different versions. For example libressl-dev and openssl-dev both ships libssl.pc and libcrypto.pc, which resulted in automatic provides of pc:libssl and pc:libcrypto. apk would end up picking libressl-dev over openssl-dev for packages that had automatic pc:libssl depends (for example libssl2-dev), when openssl-dev was the one that was used during build. To fix this we add support for a pcprefix so we can set pcprefix="libressl:" in libressl APKBUILD which makes libressl-dev provide pc:libressl:libssl. This is similar to what we do with sonameprefix. We do not yet automatically detect when the prefixed variant should be used so for now we will have to explicitly add libressl-dev. ref #9959
* abuild: replace $0 with $abuild_path, add $forceroot where missingDisassembler2019-01-101-6/+6
|
* abuild: use pigz to compress control.tar.gz and manpagesNatanael Copa2019-01-101-2/+3
|
* abuild: avoid add depends to itselfNatanael Copa2019-01-091-1/+3
| | | | | | | | | packages should never depend on themselves which does not make sense. This may happen if main package depends on a subpackage, then the subpackages will inherit the global depends and the subpackage ends up depend on itself. Fix abuild to avoid this.
* abuild: fix typoCarlo Landmeter2018-12-021-1/+1
|
* abuild.in: add multithreaded compressionTiago Ilieve2018-11-081-1/+2
| | | | | | The 'Compressing data' step takes a significant amount of time when packaging software with huge binaries, like Kubernetes. This can certainly be shortened using multithreaded compression, like 'pigz'.
* abuild: print build start, end date and elapsed timeTimo Teräs2018-11-081-1/+5
|
* abuild: run build actions via runpartNatanael Copa2018-10-031-11/+5
| | | | So we make sure chdir $builddir happens when it should.
* abuild: do not run check in fakeroot by defaultNatanael Copa2018-10-031-6/+6
| | | | | | | | | 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.
* abuild: print version of built package earlyNatanael Copa2018-10-031-1/+1
| | | | | instead of printing abuild version, print package version. This is to avoid confuse the abuild version with the package version.
* abuild: chdir to $builddir if it existsNatanael Copa2018-10-031-0/+6
| | | | chdir to $builddir before running prepare, build, package or check.
* abuild: fix regression. run buildNatanael Copa2018-10-031-1/+2
| | | | fix regression introduced in def219994d2dff3c2bd47eee76826dc79e042b2f
* abuild: require package() functionNatanael Copa2018-10-031-20/+5
| | | | | | make a missing function for package() a hard error. this means we never run build in fakeroot.
* abuild: fix checksum updateNatanael Copa2018-10-031-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
* move logic of curl's http range error to abuild-fetchNatanael Copa2018-10-031-12/+1
| | | | | Move the logic of deleting partial downloads to abuild-fetch, which knows if it is curl or wget that was executed.
* Fix: incomplete partfile gets renamed to distfileOliver Smith2018-10-031-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | 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.
* abuild: fix race when strippingNatanael Copa2018-05-311-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.
* abuild: Fix usage info about package commandJonathan Sieber2018-04-251-1/+1
| | | | | abuild package misleadingly stated that it will create packages in $REPODIR (suggesting that it actually creates apks).
* abuild.in: don't fail if git describe failsSören Tempel2018-04-221-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.
* abuild: fix unxz with threadingNatanael Copa2018-04-171-1/+5
| | | | busybox unxz does not support --threads/-T option
* abuild: simplify optional git usageNatanael Copa2018-04-171-11/+5
| | | | | set git=true if git is missing so all git commands are ignored. This simplifies the code a bit
* abuild: add multithread decommpressing supportCarlo Landmeter2018-04-151-3/+5
|
* abuild: allow SPDX license operatorsCarlo Landmeter2018-04-111-0/+2
| | | | valid operators are AND OR WITH
* Make file missing in source var explicit.Manuel Tiago Pereira2018-04-111-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.
* Fix a few typosJonathan Neuschäfer2018-04-111-2/+2
|