diff options
author | Eric Joldasov <bratishkaerik@getgoogleoff.me> | 2023-06-14 15:26:17 +0600 |
---|---|---|
committer | Eric Joldasov <bratishkaerik@getgoogleoff.me> | 2023-06-14 15:26:17 +0600 |
commit | dfc2e100339eacc60c6fda3f436e3f8ea45729fe (patch) | |
tree | ecc4957cad96002275671ac28bc2d799640dfde2 | |
parent | sys-fs/btrfs-heatmap: rename dev-python/btrfs (diff) | |
download | guru-dfc2e100339eacc60c6fda3f436e3f8ea45729fe.tar.gz guru-dfc2e100339eacc60c6fda3f436e3f8ea45729fe.tar.bz2 guru-dfc2e100339eacc60c6fda3f436e3f8ea45729fe.zip |
app-benchmarks/poop: new package, add 9999
Signed-off-by: Eric Joldasov <bratishkaerik@getgoogleoff.me>
-rw-r--r-- | app-benchmarks/poop/metadata.xml | 12 | ||||
-rw-r--r-- | app-benchmarks/poop/poop-9999.ebuild | 120 |
2 files changed, 132 insertions, 0 deletions
diff --git a/app-benchmarks/poop/metadata.xml b/app-benchmarks/poop/metadata.xml new file mode 100644 index 000000000..0ec639e43 --- /dev/null +++ b/app-benchmarks/poop/metadata.xml @@ -0,0 +1,12 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> + <maintainer type="person"> + <email>bratishkaerik@getgoogleoff.me</email> + <name>Eric Joldasov</name> + </maintainer> + <upstream> + <remote-id type="github">andrewrk/poop</remote-id> + <bugs-to>https://github.com/andrewrk/poop/issues</bugs-to> + </upstream> +</pkgmetadata> diff --git a/app-benchmarks/poop/poop-9999.ebuild b/app-benchmarks/poop/poop-9999.ebuild new file mode 100644 index 000000000..a56a627a2 --- /dev/null +++ b/app-benchmarks/poop/poop-9999.ebuild @@ -0,0 +1,120 @@ +# Copyright 2022-2023 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +inherit edo git-r3 + +EGIT_REPO_URI="https://github.com/andrewrk/poop" + +DESCRIPTION="Performance Optimizer Observation Platform" +HOMEPAGE="https://github.com/andrewrk/poop" + +LICENSE="MIT" +SLOT="0" + +EZIG_MIN="9999" +EZIG_MAX_EXCLUSIVE="99991" + +DEPEND="dev-lang/zig:${EZIG_MIN}" +RDEPEND="${DEPEND}" + +# see https://github.com/ziglang/zig/issues/3382 +# For now, Zig Build System doesn't support CFLAGS/LDFLAGS/etc. +QA_FLAGS_IGNORED="usr/bin/poop" + +# : copied from sys-fs/ncdu : +# Many thanks to Florian Schmaus (Flowdalic)! +# Adapted from https://github.com/gentoo/gentoo/pull/28986 +# Set the EZIG environment variable. +zig-set_EZIG() { + [[ -n ${EZIG} ]] && return + + if [[ -n ${EZIG_OVERWRITE} ]]; then + export EZIG="${EZIG_OVERWRITE}" + return + fi + + local candidates candidate selected selected_ver + + candidates=$(compgen -c zig-) + + for candidate in ${candidates}; do + if [[ ! ${candidate} =~ zig(-bin)?-([.0-9]+) ]]; then + continue + fi + + local ver + if (( ${#BASH_REMATCH[@]} == 3 )); then + ver="${BASH_REMATCH[2]}" + else + ver="${BASH_REMATCH[1]}" + fi + + if [[ -n ${EZIG_EXACT_VER} ]]; then + ver_test "${ver}" -ne "${EZIG_EXACT_VER}" && continue + + selected="${candidate}" + selected_ver="${ver}" + break + fi + + if [[ -n ${EZIG_MIN} ]] \ + && ver_test "${ver}" -lt "${EZIG_MIN}"; then + # Candidate does not satisfy EZIG_MIN condition. + continue + fi + + if [[ -n ${EZIG_MAX_EXCLUSIVE} ]] \ + && ver_test "${ver}" -ge "${EZIG_MAX_EXCLUSIVE}"; then + # Candidate does not satisfy EZIG_MAX_EXCLUSIVE condition. + continue + fi + + if [[ -n ${selected_ver} ]] \ + && ver_test "${selected_ver}" -gt "${ver}"; then + # Candidate is older than the currently selected candidate. + continue + fi + + selected="${candidate}" + selected_ver="${ver}" + done + + if [[ -z ${selected} ]]; then + die "Could not find (suitable) zig installation in PATH" + fi + + export EZIG="${selected}" + export EZIG_VER="${ver}" +} + +# Invoke zig with the optionally provided arguments. +ezig() { + zig-set_EZIG + + # Unfortunately, we cannot add more args here, since syntax is different + # for every subcommands. Yes, even target/cpu :( f.i. : + # -target/-mcpu for zig build-exe vs -Dtarget/-Dcpu for zig build- + # -OReleaseSafe for zig build-exe vs -DReleaseSafe for zig build + # (or even none, if hardcoded by upstream so choice is -Drelease=true/false) + # Ofc we can patch this, but still... + + edo "${EZIG}" "${@}" +} + +src_unpack() { + git-r3_src_unpack + cd "${S}" || die + # "zig build" doesn't have "fetch" subcommand yet + ezig build --help || die "Fetching Zig modules failed" +} + +src_compile() { + ezig build -Doptimize=ReleaseSafe --verbose || die +} + +src_install() { + DESTDIR="${ED}" ezig build install --prefix /usr -Doptimize=ReleaseSafe --verbose || die + dodoc README.md +} |