From a16b7bce9545558c059c8844dbba355c5e412547 Mon Sep 17 00:00:00 2001 From: lleyton Date: Sat, 13 Jan 2024 17:40:35 -0800 Subject: [PATCH] chore: sync with Terra 39 (#877) * chore: sync with Terra 39 * fix: update mock-configs path * fix: use f38 specs for desktops * chore: move more lomiri/unity specific packages (#880) * Fix(ubuntu-sdk): update description & version (#878) Signed-off-by: cat-master21 <96554164+cat-master21@users.noreply.github.com> * fix: disable docs package (#887) * sync more changes from f39 * add keyd fixes --------- Signed-off-by: cat-master21 <96554164+cat-master21@users.noreply.github.com> Signed-off-by: lleyton Co-authored-by: cat-master21 <96554164+cat-master21@users.noreply.github.com> --- .github/workflows/autobuild.yml | 4 +- .github/workflows/bootstrap.yml | 2 +- .github/workflows/build.yml | 2 +- .github/workflows/json-build.yml | 2 +- anda/apps/anki-bin/anki-bin.spec | 29 +- .../blackbox-terminal/anda.hcl | 0 .../blackbox-terminal/blackbox-terminal.spec | 0 .../blackbox-terminal/update.rhai | 0 .../discord-canary-openasar.spec | 2 +- anda/apps/discord-canary/discord-canary.spec | 2 +- .../discord-openasar/discord-openasar.spec | 2 +- .../discord-ptb-openasar.spec | 2 +- anda/apps/discord-ptb/discord-ptb.spec | 2 +- anda/apps/discord/discord.spec | 2 +- anda/apps/sccache/anda.hcl | 5 + anda/apps/sccache/rust-sccache.spec | 601 +++++++ .../sccache/sccache-fix-metadata-auto.diff | 14 + .../vencord-desktop}/.gitignore | 0 anda/apps/vencord-desktop/anda.hcl | 5 + anda/apps/vencord-desktop/update.rhai | 1 + .../apps/vencord-desktop/vencord-desktop.spec | 74 + ...add-repository-entry-in-package.json.patch | 0 anda/{audio => apps}/voicevox/anda.hcl | 0 anda/{audio => apps}/voicevox/update.rhai | 0 anda/{audio => apps}/voicevox/voicevox.spec | 0 .../budgie/budgie-extras/budgie-extras.spec | 12 - .../elementary-files/elementary-files.spec | 2 +- .../elementary-icon-theme.spec | 6 +- .../elementary-onboarding.spec | 2 +- .../pantheon-session-settings.spec | 9 +- .../dark-theme-wallpaper.patch | 23 + .../switchboard-plug-pantheon-shell.spec | 1 + .../anda.hcl | 5 + ...gnome-shell-extension-appmenu-is-back.spec | 34 + .../update.rhai | 2 + ...ve-schema-handling-from-transpile.sh.patch | 34 + ....wm.keybindings.pop-shell.gschema.override | 18 + ...rg.gnome.mutter.pop-shell.gschema.override | 7 + ....mutter.wayland.pop-shell.gschema.override | 2 + ...gins.media-keys.pop-shell.gschema.override | 6 + ...org.gnome.shell.pop-shell.gschema.override | 18 + .../gnome-shell-extension-pop-shell/anda.hcl | 8 + ...terra-gnome-shell-extension-pop-shell.spec | 89 + .../update.rhai | 4 + .../latte-dock-nightly.spec | 2 +- .../lomiri-unity}/frame/anda.hcl | 0 .../lomiri-unity}/frame/frame.spec | 0 .../lomiri-unity}/frame/update.rhai | 0 .../lomiri-unity}/geis/anda.hcl | 0 .../lomiri-unity}/geis/geis.spec | 0 .../lomiri-unity}/geis/update.rhai | 0 .../gsettings-qt-lomiri/anda.hcl | 0 .../gsettings-qt-lomiri.spec | 0 .../lomiri-unity}/libunity-misc/anda.hcl | 0 .../libunity-misc/libunity-misc.spec | 0 .../lomiri-unity}/lomiri-api/anda.hcl | 0 .../lomiri-unity}/lomiri-api/lomiri-api.spec | 0 .../lomiri-unity}/lomiri-api/update.rhai | 0 .../lomiri-unity}/lomiri-app-launch/anda.hcl | 0 .../lomiri-app-launch/lomiri-app-launch.spec | 2 +- .../lomiri-app-launch/update.rhai | 0 .../lomiri-download-manager/anda.hcl | 0 .../lomiri-download-manager.spec | 0 .../lomiri-indicator-network/anda.hcl | 0 .../lomiri-indicator-network.spec | 4 +- .../lomiri-indicator-network/update.rhai | 7 + .../lomiri-unity}/lomiri-schemas/anda.hcl | 0 .../com.lomiri.Shell.gschema.xml | 0 .../lomiri-schemas/lomiri-schemas.spec | 0 .../lomiri-unity}/lomiri-schemas/update.rhai | 0 .../lomiri-unity}/lomiri-session/anda.hcl | 0 .../lomiri-session/lomiri-session.spec | 0 .../lomiri-settings-components/anda.hcl | 0 .../lomiri-settings-components.spec | 4 +- .../lomiri-settings-components/update.rhai | 7 + .../lomiri-unity}/lomiri-sounds/anda.hcl | 0 .../lomiri-sounds/lomiri-sounds.spec | 0 .../lomiri-system-settings/anda.hcl | 0 .../lomiri-system-settings.spec | 2 +- .../lomiri-system-settings/update.rhai | 0 .../lomiri-unity}/lomiri-ui-toolkit/anda.hcl | 0 .../lomiri-ui-toolkit/lomiri-ui-toolkit.spec | 2 +- .../lomiri-ui-toolkit/update.rhai | 0 .../lomiri-url-dispatcher/anda.hcl | 0 .../lomiri-url-dispatcher.spec | 2 +- .../lomiri-url-dispatcher/update.rhai | 0 ...both-older-qtmir-and-newer-qtmir-wit.patch | 0 .../{ => lomiri-unity}/lomiri/anda.hcl | 0 .../{ => lomiri-unity}/lomiri/lomiri.spec | 2 +- .../{ => lomiri-unity}/lomiri/update.rhai | 0 .../lomiri-unity}/nux/anda.hcl | 0 .../lomiri-unity}/nux/nux.spec | 0 .../lomiri-unity}/qtmir/anda.hcl | 0 .../lomiri-unity}/qtmir/qtmir.spec | 0 .../unity-greeter/0001-Remove-libido.patch | 0 .../lomiri-unity}/unity-greeter/anda.hcl | 0 .../unity-greeter/unity-greeter.spec | 0 .../lomiri-unity}/unity-greeter/update.rhai | 0 .../lomiri-unity}/unity-scope-home/anda.hcl | 0 .../unity-scope-home/unity-scope-home.spec | 0 .../lomiri-unity}/unity-session/anda.hcl | 0 .../unity-session/unity-session.spec | 0 .../lomiri-unity}/unity-session/update.rhai | 0 .../unity-settings-daemon/anda.hcl | 0 .../unity-settings-daemon.1 | 0 .../unity-settings-daemon.service | 0 .../unity-settings-daemon.spec | 0 .../0001-Remove-xpathselect-dependency.patch | 0 .../0002-Remove-ido-dependency.patch | 0 .../0003-Remove-social-scope.patch | 0 .../{ => lomiri-unity}/unity-shell/anda.hcl | 0 .../unity-shell/unity-shell.spec | 2 +- .../unity-shell/update.rhai | 0 .../0001-Remove-social-scope.patch | 0 .../{ => lomiri-unity}/unityx-shell/anda.hcl | 0 .../unityx-shell/unityx-shell.spec | 2 +- .../mate/indicators/datetime}/anda.hcl | 0 .../datetime}/ayatana-indicator-datetime.spec | 0 .../mate/indicators/datetime}/update.rhai | 0 .../mate/indicators/messages}/anda.hcl | 0 .../messages}/ayatana-indicator-messages.spec | 0 .../mate/indicators/messages}/update.rhai | 0 .../mate/indicators/notifications}/anda.hcl | 0 .../ayatana-indicator-notifications.spec | 0 .../indicators/notifications}/update.rhai | 0 .../0001-fix-tests-import-cstdint.patch | 0 .../mate/indicators/session}/anda.hcl | 0 .../session}/ayatana-indicator-session.spec | 3 +- .../mate/indicators/session}/update.rhai | 0 .../mate/indicators/sound}/anda.hcl | 0 .../sound}/ayatana-indicator-sound.spec | 0 .../mate/indicators/sound}/update.rhai | 0 anda/desktops/mate/tweak/mate-tweak.spec | 8 +- .../blueprint-compiler/anda.hcl | 0 .../terra-blueprint-compiler.spec | 0 .../blueprint-compiler/update.rhai | 0 anda/{tools => devs}/codium/anda.hcl | 0 anda/{tools => devs}/codium/codium.spec | 2 +- anda/{tools => devs}/codium/update.rhai | 0 anda/{apps => devs}/flutter/anda.hcl | 0 anda/{apps => devs}/flutter/flutter.spec | 5 +- anda/{apps => devs}/flutter/update.rhai | 0 anda/{rust => devs}/neovide/anda.hcl | 0 anda/{rust => devs}/neovide/neovide.spec | 4 +- anda/{rust => devs}/neovide/update.rhai | 0 anda/docker/containerd/.gitignore | 2 + .../0001-Add-reaper-StartLocked.patch | 33 + ...01-Revert-commit-for-Windows-metrics.patch | 157 ++ ...instead-of-github.com-gogo-protobuf-.patch | 1467 +++++++++++++++++ ...opencontainers-image-spec-v1.1.0-rc3.patch | 162 ++ .../0002-Remove-windows-only-dep.patch | 24 + anda/docker/containerd/anda.hcl | 5 + anda/docker/containerd/changelog | 167 ++ anda/docker/containerd/containerd.spec | 127 ++ anda/docker/containerd/containerd.toml | 9 + anda/docker/containerd/update.rhai | 1 + .../moby-buildx/anda.hcl | 0 .../moby-buildx/moby-buildx.spec | 2 +- .../moby-buildx/update.rhai | 0 .../moby-compose/anda.hcl | 0 .../moby-compose/moby-compose.spec | 2 +- .../moby-compose/update.rhai | 0 anda/docker/moby-engine/.gitignore | 59 + anda/docker/moby-engine/README.md | 3 + anda/docker/moby-engine/anda.hcl | 5 + anda/docker/moby-engine/docker.service | 38 + anda/docker/moby-engine/docker.sysconfig | 10 + anda/docker/moby-engine/generate-docs.sh | 12 + .../moby-engine-systemd-sysusers.conf | 2 + anda/docker/moby-engine/moby-engine.spec | 559 +++++++ .../moby-engine/moby-engine.spec.license | 9 + anda/docker/moby-engine/provides.spec.inc | 108 ++ anda/docker/moby-engine/sources | 3 + anda/docker/moby-engine/update.sh | 44 + anda/fonts/maple/anda.hcl | 6 + anda/fonts/maple/maple-fonts.spec | 40 + anda/fonts/maple/update.rhai | 1 + .../sarasa-gothic/sarasa-gothic-fonts.spec | 9 +- anda/{rust => games}/2048-rs/anda.hcl | 0 .../2048-rs/rust-game-2048.spec | 0 anda/{rust => games}/2048-rs/update.rhai | 0 .../prismlauncher-nightly.spec | 2 +- .../prismlauncher-qt5-nightly.spec | 2 +- anda/{rust => games}/typeracer/anda.hcl | 0 .../typeracer/rust-typeracer.spec | 0 anda/{rust => games}/typeracer/update.rhai | 0 anda/gleam/gleam.spec | 31 - anda/gleam/update.rhai | 1 - anda/{ => langs}/crystal/blahaj/anda.hcl | 0 anda/{ => langs}/crystal/blahaj/blahaj.spec | 2 +- anda/{ => langs}/crystal/blahaj/update.rhai | 0 anda/{ => langs}/crystal/crystal/anda.hcl | 0 anda/{ => langs}/crystal/crystal/crystal.spec | 2 +- anda/{ => langs}/crystal/crystal/update.rhai | 0 anda/{ => langs}/dart/anda.hcl | 0 anda/{ => langs}/dart/dart.spec | 2 +- anda/{ => langs}/dart/update.rhai | 0 anda/{ => langs}/go/curlie/anda.hcl | 0 .../go/curlie/golang-github-rs-curlie.spec | 0 anda/{ => langs}/go/curlie/update.rhai | 0 anda/{ => langs}/go/gendesk/anda.hcl | 0 .../golang-github-xyproto-gendesk.spec | 0 anda/{ => langs}/go/gendesk/update.rhai | 0 anda/langs/go/u-root/anda.hcl | 5 + .../langs/go/u-root/golang-github-u-root.spec | 78 + anda/langs/go/u-root/update.rhai | 1 + anda/{ => langs}/go/xyproto-env/anda.hcl | 0 .../golang-github-xyproto-env.spec | 2 +- anda/{ => langs}/go/xyproto-env/update.rhai | 0 anda/{ => langs}/go/xyproto-env/v1/anda.hcl | 0 .../v1/golang-github-xyproto-env.spec | 0 .../go/xyproto-textoutput/anda.hcl | 0 .../golang-github-xyproto-textoutput.spec | 2 +- .../go/xyproto-textoutput/update.rhai | 0 anda/{ => langs}/go/xyproto-vt100/anda.hcl | 0 .../golang-github-xyproto-vt100.spec | 2 +- anda/{ => langs}/go/xyproto-vt100/update.rhai | 0 anda/{ => langs}/go/yhat-scrape/anda.hcl | 0 .../golang-github-yhat-scrape.spec | 0 anda/{ => langs}/groovy/anda.hcl | 0 anda/{ => langs}/groovy/groovy-docs/anda.hcl | 0 .../groovy/groovy-docs/groovy-docs.spec | 2 +- .../groovy/groovy-docs/update.rhai | 0 anda/{ => langs}/groovy/groovy.spec | 2 +- anda/{ => langs}/groovy/update.rhai | 0 .../{ => langs}/kotlin/kotlin-native/anda.hcl | 0 .../kotlin/kotlin-native/kotlin-native.spec | 2 +- .../kotlin/kotlin-native/update.rhai | 0 anda/{ => langs}/kotlin/kotlin/anda.hcl | 0 anda/{ => langs}/kotlin/kotlin/kotlin.spec | 2 +- anda/{ => langs}/kotlin/kotlin/update.rhai | 0 anda/{ => langs}/nim/choosenim/anda.hcl | 0 anda/{ => langs}/nim/choosenim/choosenim.spec | 0 anda/{ => langs}/nim/choosenim/update.rhai | 0 anda/{ => langs}/nim/nim-nightly/anda.hcl | 0 .../nim/nim-nightly/nim-nightly.spec | 2 +- anda/{ => langs}/nim/nim-nightly/nim.1 | 0 anda/{ => langs}/nim/nim-nightly/nimble.1 | 0 anda/{ => langs}/nim/nim-nightly/nimgrep.1 | 0 anda/{ => langs}/nim/nim-nightly/nimsuggest.1 | 0 anda/{ => langs}/nim/nim-nightly/update.rhai | 0 anda/{ => langs}/nim/nim/anda.hcl | 0 anda/{ => langs}/nim/nim/nim.1 | 0 anda/{ => langs}/nim/nim/nim.spec | 2 +- anda/{ => langs}/nim/nim/nimble.1 | 0 anda/{ => langs}/nim/nim/nimgrep.1 | 0 anda/{ => langs}/nim/nim/nimsuggest.1 | 0 anda/{ => langs}/nim/nim/update.rhai | 0 .../ffmpeg => langs/python/mpv}/anda.hcl | 2 +- anda/langs/python/mpv/python-mpv.spec | 40 + anda/langs/python/mpv/update.rhai | 1 + anda/{ => langs}/python/protobuf/anda.hcl | 0 .../python/protobuf/python3-protobuf.spec | 2 +- anda/{ => langs}/python/protobuf/update.rhai | 0 anda/{ => langs}/python/ruff/anda.hcl | 0 .../{ => langs}/python/ruff/python3-ruff.spec | 16 +- anda/{ => langs}/python/ruff/update.rhai | 0 anda/{ => langs}/rust/bandwhich/anda.hcl | 0 .../bandwhich-fix-metadata-auto.diff | 0 .../rust/bandwhich/rust-bandwhich.spec | 0 anda/{ => langs}/rust/bandwhich/update.rhai | 0 anda/{ => langs}/rust/bat-extras/anda.hcl | 0 .../rust/bat-extras/bat-extras.spec | 0 anda/{ => langs}/rust/bat-extras/update.rhai | 0 anda/{ => langs}/rust/felix/anda.hcl | 0 anda/{ => langs}/rust/felix/rust-felix.spec | 2 +- anda/{ => langs}/rust/felix/update.rhai | 0 anda/{ => langs}/rust/gitoxide/anda.hcl | 0 .../rust/gitoxide/rust-gitoxide.spec | 4 +- anda/{ => langs}/rust/gitoxide/update.rhai | 0 anda/{ => langs}/rust/gping/anda.hcl | 0 anda/{ => langs}/rust/gping/rust-gping.spec | 0 anda/{ => langs}/rust/gping/update.rhai | 0 anda/{ => langs}/rust/joshuto/anda.hcl | 0 .../rust/joshuto/rust-joshuto.spec | 0 anda/{ => langs}/rust/joshuto/update.rhai | 0 anda/{ => langs}/rust/kondo-ui/anda.hcl | 0 .../rust/kondo-ui/rust-kondo-ui.spec | 2 +- anda/{ => langs}/rust/kondo-ui/update.rhai | 0 anda/{ => langs}/rust/kondo/anda.hcl | 0 anda/{ => langs}/rust/kondo/rust-kondo.spec | 2 +- anda/{ => langs}/rust/kondo/update.rhai | 0 anda/{ => langs}/rust/maturin/anda.hcl | 0 .../rust/maturin/rust-terra-maturin.spec | 0 anda/{ => langs}/rust/maturin/update.rhai | 0 anda/{ => langs}/rust/nushell/anda.hcl | 0 anda/{ => langs}/rust/nushell/nushell.spec | 5 +- anda/{ => langs}/rust/nushell/update.rhai | 0 anda/{ => langs}/rust/ouch/anda.hcl | 0 .../rust/ouch/ouch-fix-metadata-auto.diff | 8 + anda/{ => langs}/rust/ouch/rust-ouch.spec | 9 +- anda/{ => langs}/rust/ouch/update.rhai | 0 anda/{ => langs}/rust/oxipng/anda.hcl | 0 .../rust/oxipng/oxipng-fix-metadata-auto.diff | 0 anda/{ => langs}/rust/oxipng/rust-oxipng.spec | 0 anda/{ => langs}/rust/oxipng/update.rhai | 0 anda/{ => langs}/rust/pop-launcher/.gitignore | 0 .../0001-Copy-instead-of-symlink.patch | 0 .../0001-Remove-frozen-lock.patch | 0 anda/{ => langs}/rust/pop-launcher/anda.hcl | 0 .../rust/pop-launcher/pop-launcher.spec | 0 anda/{ => langs}/rust/pop-launcher/prepare.sh | 0 anda/{ => langs}/rust/pop-launcher/umpkg.cfg | 0 anda/{ => langs}/rust/pop-launcher/umpkg.toml | 0 .../{ => langs}/rust/pop-launcher/update.rhai | 0 anda/{ => langs}/rust/rnote/anda.hcl | 0 anda/{ => langs}/rust/rnote/rnote.spec | 2 +- anda/{ => langs}/rust/rnote/update.rhai | 0 anda/{ => langs}/rust/starship/anda.hcl | 0 .../rust/starship/rust-starship.spec | 2 +- .../starship/starship-fix-metadata-auto.diff | 0 anda/{ => langs}/rust/starship/update.rhai | 0 anda/{ => langs}/rust/tectonic/anda.hcl | 0 .../rust/tectonic/rust-tectonic.spec | 0 anda/{ => langs}/rust/tectonic/update.rhai | 0 anda/{ => langs}/rust/youki/anda.hcl | 0 anda/{ => langs}/rust/youki/dep-protobuf.diff | 0 anda/langs/rust/youki/rust-youki.spec | 58 + anda/{ => langs}/rust/youki/update.rhai | 0 anda/{ => langs}/rust/youki/youki.spec | 8 +- anda/{ => langs}/rust/zellij/.gitignore | 0 anda/{ => langs}/rust/zellij/anda.hcl | 0 anda/{ => langs}/rust/zellij/rust-zellij.spec | 2 + anda/{ => langs}/rust/zellij/umpkg.toml | 0 anda/{ => langs}/rust/zellij/update.rhai | 0 .../vala-language-server-nightly/anda.hcl | 0 .../vala-language-server-nightly/update.rhai | 0 .../vala-language-server-nightly.spec | 0 .../vala/vala-lint-nightly/anda.hcl | 0 .../vala/vala-lint-nightly/update.rhai | 0 .../vala-lint-nightly/vala-lint-nightly.spec | 7 +- anda/{ => langs}/vala/vala-nightly/anda.hcl | 0 .../{ => langs}/vala/vala-nightly/update.rhai | 0 .../vala/vala-nightly/vala-nightly.spec | 34 +- .../vala}/vala-panel-appmenu/anda.hcl | 0 .../vala}/vala-panel-appmenu/update.rhai | 0 .../vala-panel-appmenu.spec | 3 +- anda/{apps => langs/vala}/vala-panel/anda.hcl | 0 .../vala}/vala-panel/vala-panel.spec | 2 +- .../libayatana-common/libayatana-common.spec | 2 +- anda/lib/libhelium/libhelium.spec | 2 +- anda/lib/openh264/openh264.spec | 4 +- anda/lib/placebo/anda.hcl | 5 + anda/lib/placebo/terra-libplacebo.spec | 80 + anda/lib/placebo/update.rhai | 4 + anda/lib/tdlib/tdlib-nightly.spec | 4 +- anda/misc/alsa-ucm-cros/alsa-ucm-cros.spec | 30 + anda/misc/alsa-ucm-cros/anda.hcl | 6 + anda/misc/alsa-ucm-cros/update.rhai | 1 + anda/{others => misc}/click/anda.hcl | 0 anda/{others => misc}/click/click.spec | 4 +- anda/misc/click/update.rhai | 7 + anda/{audio => misc}/distrho/anda.hcl | 0 anda/{audio => misc}/distrho/distrho.spec | 0 .../gsettings-ubuntu-touch-schemas/anda.hcl | 0 .../gsettings-ubuntu-touch-schemas.spec | 0 .../update.rhai | 0 .../katsu-systemd-sysusers-presets/anda.hcl | 0 .../katsu-systemd-sysusers-presets.spec | 0 .../polkit.conf | 0 .../rpcbind.conf | 0 .../anda.hcl | 0 .../com.system76.Scheduler.dbusproxy.service | 2 +- .../kwin-system76-scheduler-integration.spec | 8 +- .../system76-scheduler-dbus-proxy.sh | 0 .../update.rhai | 0 anda/misc/opentabletdriver/anda.hcl | 5 + .../opentabletdriver/opentabletdriver.spec | 63 + anda/misc/opentabletdriver/update.rhai | 1 + anda/misc/opentabletdriver/v0.6.3.0.tar.gz | Bin 0 -> 272028 bytes .../rustdesk-selinux/anda.hcl | 0 .../rustdesk-selinux/rustdesk-selinux.spec | 0 .../rustdesk-selinux/rustdesk.te | 0 anda/{others => misc}/sass/anda.hcl | 0 anda/{others => misc}/sass/sass.spec | 2 +- anda/{others => misc}/sass/update.rhai | 0 .../system76-scheduler/anda.hcl | 0 .../system76-scheduler.spec | 3 +- .../system76-scheduler/update.rhai | 0 .../systemd-sysusers-presets/anda.hcl | 0 .../systemd-sysusers-presets/polkit.conf | 0 .../systemd-sysusers-presets/rpcbind.conf | 0 .../systemd-sysusers-presets.spec | 9 +- anda/{others => misc}/ubuntu-sdk/anda.hcl | 0 .../ubuntu-sdk/ubuntu-sdk.spec | 6 +- anda/{others => misc}/uwufetch/anda.hcl | 0 anda/{others => misc}/uwufetch/update.rhai | 0 anda/{others => misc}/uwufetch/uwufetch.spec | 0 anda/{others => misc}/uxplay/anda.hcl | 0 anda/{others => misc}/uxplay/update.rhai | 0 anda/{others => misc}/uxplay/uxplay.spec | 2 +- .../terra-fractureiser-detector/anda.hcl | 6 - .../terra-fractureiser-detector/detect.py | 76 - .../terra-fractureiser-detector/dialog.py | 92 -- .../fyra-fractureiser-detector.service | 6 - .../fyra-fractureiser-detector.timer | 10 - .../terra-fractureiser-detector.spec | 75 - anda/rust/ouch/ouch-fix-metadata-auto.diff | 8 - anda/srpm-macros/macros.cargo_extra | 35 - anda/system/avstplg/anda.hcl | 8 + anda/system/avstplg/avstplg.spec | 44 + anda/system/avstplg/update.rhai | 6 + anda/system/depthcharge-tools/anda.hcl | 5 + .../depthcharge-tools/depthcharge-tools.spec | 47 + anda/system/depthcharge-tools/update.rhai | 1 + anda/{tools => system}/limine/anda.hcl | 0 anda/{tools => system}/limine/limine.spec | 2 +- anda/{tools => system}/limine/update.rhai | 0 anda/system/nvidia-patch/anda.hcl | 6 + anda/system/nvidia-patch/nvidia-patch.spec | 76 + anda/system/nvidia-patch/update.rhai | 4 + anda/{gleam => system/submarine}/anda.hcl | 2 +- anda/system/submarine/submarine.spec | 35 + anda/system/submarine/update.rhai | 1 + anda/system/uutils-coreutils/.gitignore | 1 + .../uutils-coreutils/anda.hcl | 0 .../uutils-coreutils/update.rhai | 0 .../uutils-coreutils/uutils-coreutils.spec | 4 +- anda/{others => system}/xpadneo/anda.hcl | 0 .../xpadneo/modules-load-d-xpadneo.conf | 0 anda/{others => system}/xpadneo/update.rhai | 0 anda/{others => system}/xpadneo/xpadneo.spec | 0 anda/{ => terra}/mock-configs/anda.hcl | 0 .../mock-configs/terra-38-aarch64.cfg | 0 .../mock-configs/terra-38-x86_64.cfg | 0 anda/terra/mock-configs/terra-39-aarch64.cfg | 5 + anda/terra/mock-configs/terra-39-x86_64.cfg | 5 + .../mock-configs/terra-mock-configs.spec | 22 +- anda/{ => terra}/mock-configs/terra.tpl | 45 +- .../{terra-release => terra/release}/anda.hcl | 0 .../release}/terra-release.spec | 0 .../release}/terra.repo | 0 .../srpm-macros/anda-srpm-macros.spec | 0 anda/{ => terra}/srpm-macros/anda.hcl | 0 anda/{ => terra}/srpm-macros/macros.anda | 0 anda/{ => terra}/srpm-macros/macros.caching | 4 +- anda/terra/srpm-macros/macros.cargo_extra | 116 ++ anda/{ => terra}/srpm-macros/macros.go_extra | 0 anda/{ => terra}/srpm-macros/umpkg.toml | 0 anda/{others => themes}/tau-helium/anda.hcl | 0 .../tau-helium/tau-helium.spec | 0 .../{others => themes}/tau-helium/update.rhai | 0 anda/{others => themes}/tau-hydrogen/anda.hcl | 0 .../tau-hydrogen/tau-hydrogen.spec | 0 .../tau-hydrogen/update.rhai | 0 ...ile-Remove-unused-Makefile-variables.patch | 22 + anda/tools/amdctl/amdctl.spec | 79 + anda/tools/amdctl/anda.hcl | 6 + anda/tools/amdctl/update.rhai | 1 + anda/tools/{ => buildsys}/anda/anda.hcl | 0 anda/tools/{ => buildsys}/anda/rust-anda.spec | 0 anda/tools/{ => buildsys}/anda/update.rhai | 0 anda/tools/{ => buildsys}/gradle/anda.hcl | 0 anda/tools/{ => buildsys}/gradle/gradle.spec | 0 anda/tools/{ => buildsys}/gradle/update.rhai | 0 anda/tools/{ => buildsys}/katsu/anda.hcl | 0 anda/tools/{ => buildsys}/katsu/katsu.spec | 2 +- anda/tools/{ => buildsys}/katsu/update.rhai | 0 anda/tools/{ => buildsys}/muon/anda.hcl | 0 anda/tools/{ => buildsys}/muon/muon.spec | 0 anda/tools/{ => buildsys}/ops2deb/anda.hcl | 0 .../tools/{ => buildsys}/ops2deb/ops2deb.spec | 4 +- anda/tools/{ => buildsys}/ops2deb/update.rhai | 0 anda/tools/{ => buildsys}/subatomic/anda.hcl | 0 .../{ => buildsys}/subatomic/subatomic.spec | 0 .../{ => buildsys}/subatomic/update.rhai | 0 anda/tools/chromium-ectool/anda.hcl | 5 + .../chromium-ectool/chromium-ectool.spec | 35 + anda/tools/electron/electron.spec | 2 +- ...ops-clip-constants-used-with-shift-i.patch | 76 - ...f_libplacebo-remove-deprecated-field.patch | 73 - ...lacebo-wrap-deprecated-opts-in-FF_AP.patch | 76 - ...ilter-initialize-the-o-to-silence-th.patch | 30 - anda/tools/ffmpeg/ffmpeg.spec | 540 ------ anda/tools/graalvm/graalvm.spec | 4 +- anda/tools/keyd/keyd.spec | 27 +- anda/tools/umstellar/.gitignore | 1 + anda/tools/umstellar/anda.hcl | 5 + anda/tools/umstellar/umstellar.spec | 63 + anda/tools/umstellar/update.rhai | 1 + 480 files changed, 5203 insertions(+), 1360 deletions(-) rename anda/{others => apps}/blackbox-terminal/anda.hcl (100%) rename anda/{others => apps}/blackbox-terminal/blackbox-terminal.spec (100%) rename anda/{others => apps}/blackbox-terminal/update.rhai (100%) create mode 100644 anda/apps/sccache/anda.hcl create mode 100644 anda/apps/sccache/rust-sccache.spec create mode 100644 anda/apps/sccache/sccache-fix-metadata-auto.diff rename anda/{tools/uutils-coreutils => apps/vencord-desktop}/.gitignore (100%) create mode 100644 anda/apps/vencord-desktop/anda.hcl create mode 100644 anda/apps/vencord-desktop/update.rhai create mode 100644 anda/apps/vencord-desktop/vencord-desktop.spec rename anda/{audio => apps}/voicevox/0001-feat-add-repository-entry-in-package.json.patch (100%) rename anda/{audio => apps}/voicevox/anda.hcl (100%) rename anda/{audio => apps}/voicevox/update.rhai (100%) rename anda/{audio => apps}/voicevox/voicevox.spec (100%) create mode 100644 anda/desktops/elementary/switchboard-plug-pantheon-shell/dark-theme-wallpaper.patch create mode 100644 anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/anda.hcl create mode 100644 anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/gnome-shell-extension-appmenu-is-back.spec create mode 100644 anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/update.rhai create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/0001-Remove-schema-handling-from-transpile.sh.patch create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.desktop.wm.keybindings.pop-shell.gschema.override create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.pop-shell.gschema.override create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.wayland.pop-shell.gschema.override create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.settings-daemon.plugins.media-keys.pop-shell.gschema.override create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.shell.pop-shell.gschema.override create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/anda.hcl create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/terra-gnome-shell-extension-pop-shell.spec create mode 100644 anda/desktops/gnome/gnome-shell-extension-pop-shell/update.rhai rename anda/{lib => desktops/lomiri-unity}/frame/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/frame/frame.spec (100%) rename anda/{lib => desktops/lomiri-unity}/frame/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/geis/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/geis/geis.spec (100%) rename anda/{lib => desktops/lomiri-unity}/geis/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/gsettings-qt-lomiri/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/gsettings-qt-lomiri/gsettings-qt-lomiri.spec (100%) rename anda/{lib => desktops/lomiri-unity}/libunity-misc/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/libunity-misc/libunity-misc.spec (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-api/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-api/lomiri-api.spec (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-api/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-app-launch/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-app-launch/lomiri-app-launch.spec (97%) rename anda/{lib => desktops/lomiri-unity}/lomiri-app-launch/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-download-manager/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-download-manager/lomiri-download-manager.spec (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-indicator-network/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-indicator-network/lomiri-indicator-network.spec (97%) create mode 100644 anda/desktops/lomiri-unity/lomiri-indicator-network/update.rhai rename anda/{others => desktops/lomiri-unity}/lomiri-schemas/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-schemas/com.lomiri.Shell.gschema.xml (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-schemas/lomiri-schemas.spec (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-schemas/update.rhai (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-session/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-session/lomiri-session.spec (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-settings-components/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-settings-components/lomiri-settings-components.spec (93%) create mode 100644 anda/desktops/lomiri-unity/lomiri-settings-components/update.rhai rename anda/{others => desktops/lomiri-unity}/lomiri-sounds/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/lomiri-sounds/lomiri-sounds.spec (100%) rename anda/{apps => desktops/lomiri-unity}/lomiri-system-settings/anda.hcl (100%) rename anda/{apps => desktops/lomiri-unity}/lomiri-system-settings/lomiri-system-settings.spec (98%) rename anda/{apps => desktops/lomiri-unity}/lomiri-system-settings/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-ui-toolkit/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-ui-toolkit/lomiri-ui-toolkit.spec (98%) rename anda/{lib => desktops/lomiri-unity}/lomiri-ui-toolkit/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-url-dispatcher/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/lomiri-url-dispatcher/lomiri-url-dispatcher.spec (98%) rename anda/{lib => desktops/lomiri-unity}/lomiri-url-dispatcher/update.rhai (100%) rename anda/desktops/{ => lomiri-unity}/lomiri/0001-Add-support-for-both-older-qtmir-and-newer-qtmir-wit.patch (100%) rename anda/desktops/{ => lomiri-unity}/lomiri/anda.hcl (100%) rename anda/desktops/{ => lomiri-unity}/lomiri/lomiri.spec (99%) rename anda/desktops/{ => lomiri-unity}/lomiri/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/nux/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/nux/nux.spec (100%) rename anda/{lib => desktops/lomiri-unity}/qtmir/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/qtmir/qtmir.spec (100%) rename anda/{others => desktops/lomiri-unity}/unity-greeter/0001-Remove-libido.patch (100%) rename anda/{others => desktops/lomiri-unity}/unity-greeter/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/unity-greeter/unity-greeter.spec (100%) rename anda/{others => desktops/lomiri-unity}/unity-greeter/update.rhai (100%) rename anda/{others => desktops/lomiri-unity}/unity-scope-home/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/unity-scope-home/unity-scope-home.spec (100%) rename anda/{others => desktops/lomiri-unity}/unity-session/anda.hcl (100%) rename anda/{others => desktops/lomiri-unity}/unity-session/unity-session.spec (100%) rename anda/{others => desktops/lomiri-unity}/unity-session/update.rhai (100%) rename anda/{lib => desktops/lomiri-unity}/unity-settings-daemon/anda.hcl (100%) rename anda/{lib => desktops/lomiri-unity}/unity-settings-daemon/unity-settings-daemon.1 (100%) rename anda/{lib => desktops/lomiri-unity}/unity-settings-daemon/unity-settings-daemon.service (100%) rename anda/{lib => desktops/lomiri-unity}/unity-settings-daemon/unity-settings-daemon.spec (100%) rename anda/desktops/{ => lomiri-unity}/unity-shell/0001-Remove-xpathselect-dependency.patch (100%) rename anda/desktops/{ => lomiri-unity}/unity-shell/0002-Remove-ido-dependency.patch (100%) rename anda/desktops/{ => lomiri-unity}/unity-shell/0003-Remove-social-scope.patch (100%) rename anda/desktops/{ => lomiri-unity}/unity-shell/anda.hcl (100%) rename anda/desktops/{ => lomiri-unity}/unity-shell/unity-shell.spec (99%) rename anda/desktops/{ => lomiri-unity}/unity-shell/update.rhai (100%) rename anda/desktops/{ => lomiri-unity}/unityx-shell/0001-Remove-social-scope.patch (100%) rename anda/desktops/{ => lomiri-unity}/unityx-shell/anda.hcl (100%) rename anda/desktops/{ => lomiri-unity}/unityx-shell/unityx-shell.spec (99%) rename anda/{lib/ayatana-indicator-datetime => desktops/mate/indicators/datetime}/anda.hcl (100%) rename anda/{lib/ayatana-indicator-datetime => desktops/mate/indicators/datetime}/ayatana-indicator-datetime.spec (100%) rename anda/{lib/ayatana-indicator-datetime => desktops/mate/indicators/datetime}/update.rhai (100%) rename anda/{lib/ayatana-indicator-messages => desktops/mate/indicators/messages}/anda.hcl (100%) rename anda/{lib/ayatana-indicator-messages => desktops/mate/indicators/messages}/ayatana-indicator-messages.spec (100%) rename anda/{lib/ayatana-indicator-messages => desktops/mate/indicators/messages}/update.rhai (100%) rename anda/{indicators/ayatana-indicator-notifications => desktops/mate/indicators/notifications}/anda.hcl (100%) rename anda/{indicators/ayatana-indicator-notifications => desktops/mate/indicators/notifications}/ayatana-indicator-notifications.spec (100%) rename anda/{indicators/ayatana-indicator-notifications => desktops/mate/indicators/notifications}/update.rhai (100%) rename anda/{indicators/ayatana-indicator-session => desktops/mate/indicators/session}/0001-fix-tests-import-cstdint.patch (100%) rename anda/{indicators/ayatana-indicator-session => desktops/mate/indicators/session}/anda.hcl (100%) rename anda/{indicators/ayatana-indicator-session => desktops/mate/indicators/session}/ayatana-indicator-session.spec (97%) rename anda/{indicators/ayatana-indicator-session => desktops/mate/indicators/session}/update.rhai (100%) rename anda/{indicators/ayatana-indicator-sound => desktops/mate/indicators/sound}/anda.hcl (100%) rename anda/{indicators/ayatana-indicator-sound => desktops/mate/indicators/sound}/ayatana-indicator-sound.spec (100%) rename anda/{indicators/ayatana-indicator-sound => desktops/mate/indicators/sound}/update.rhai (100%) rename anda/{tools => devs}/blueprint-compiler/anda.hcl (100%) rename anda/{tools => devs}/blueprint-compiler/terra-blueprint-compiler.spec (100%) rename anda/{tools => devs}/blueprint-compiler/update.rhai (100%) rename anda/{tools => devs}/codium/anda.hcl (100%) rename anda/{tools => devs}/codium/codium.spec (99%) rename anda/{tools => devs}/codium/update.rhai (100%) rename anda/{apps => devs}/flutter/anda.hcl (100%) rename anda/{apps => devs}/flutter/flutter.spec (88%) rename anda/{apps => devs}/flutter/update.rhai (100%) rename anda/{rust => devs}/neovide/anda.hcl (100%) rename anda/{rust => devs}/neovide/neovide.spec (93%) rename anda/{rust => devs}/neovide/update.rhai (100%) create mode 100644 anda/docker/containerd/.gitignore create mode 100644 anda/docker/containerd/0001-Add-reaper-StartLocked.patch create mode 100644 anda/docker/containerd/0001-Revert-commit-for-Windows-metrics.patch create mode 100644 anda/docker/containerd/0001-Use-typeurl.Any-instead-of-github.com-gogo-protobuf-.patch create mode 100644 anda/docker/containerd/0001-opencontainers-image-spec-v1.1.0-rc3.patch create mode 100644 anda/docker/containerd/0002-Remove-windows-only-dep.patch create mode 100644 anda/docker/containerd/anda.hcl create mode 100644 anda/docker/containerd/changelog create mode 100644 anda/docker/containerd/containerd.spec create mode 100644 anda/docker/containerd/containerd.toml create mode 100644 anda/docker/containerd/update.rhai rename anda/{moby-extras => docker}/moby-buildx/anda.hcl (100%) rename anda/{moby-extras => docker}/moby-buildx/moby-buildx.spec (97%) rename anda/{moby-extras => docker}/moby-buildx/update.rhai (100%) rename anda/{moby-extras => docker}/moby-compose/anda.hcl (100%) rename anda/{moby-extras => docker}/moby-compose/moby-compose.spec (98%) rename anda/{moby-extras => docker}/moby-compose/update.rhai (100%) create mode 100644 anda/docker/moby-engine/.gitignore create mode 100644 anda/docker/moby-engine/README.md create mode 100644 anda/docker/moby-engine/anda.hcl create mode 100644 anda/docker/moby-engine/docker.service create mode 100644 anda/docker/moby-engine/docker.sysconfig create mode 100644 anda/docker/moby-engine/generate-docs.sh create mode 100644 anda/docker/moby-engine/moby-engine-systemd-sysusers.conf create mode 100644 anda/docker/moby-engine/moby-engine.spec create mode 100644 anda/docker/moby-engine/moby-engine.spec.license create mode 100644 anda/docker/moby-engine/provides.spec.inc create mode 100644 anda/docker/moby-engine/sources create mode 100755 anda/docker/moby-engine/update.sh create mode 100644 anda/fonts/maple/anda.hcl create mode 100644 anda/fonts/maple/maple-fonts.spec create mode 100644 anda/fonts/maple/update.rhai rename anda/{rust => games}/2048-rs/anda.hcl (100%) rename anda/{rust => games}/2048-rs/rust-game-2048.spec (100%) rename anda/{rust => games}/2048-rs/update.rhai (100%) rename anda/{rust => games}/typeracer/anda.hcl (100%) rename anda/{rust => games}/typeracer/rust-typeracer.spec (100%) rename anda/{rust => games}/typeracer/update.rhai (100%) delete mode 100644 anda/gleam/gleam.spec delete mode 100644 anda/gleam/update.rhai rename anda/{ => langs}/crystal/blahaj/anda.hcl (100%) rename anda/{ => langs}/crystal/blahaj/blahaj.spec (98%) rename anda/{ => langs}/crystal/blahaj/update.rhai (100%) rename anda/{ => langs}/crystal/crystal/anda.hcl (100%) rename anda/{ => langs}/crystal/crystal/crystal.spec (98%) rename anda/{ => langs}/crystal/crystal/update.rhai (100%) rename anda/{ => langs}/dart/anda.hcl (100%) rename anda/{ => langs}/dart/dart.spec (98%) rename anda/{ => langs}/dart/update.rhai (100%) rename anda/{ => langs}/go/curlie/anda.hcl (100%) rename anda/{ => langs}/go/curlie/golang-github-rs-curlie.spec (100%) rename anda/{ => langs}/go/curlie/update.rhai (100%) rename anda/{ => langs}/go/gendesk/anda.hcl (100%) rename anda/{ => langs}/go/gendesk/golang-github-xyproto-gendesk.spec (100%) rename anda/{ => langs}/go/gendesk/update.rhai (100%) create mode 100644 anda/langs/go/u-root/anda.hcl create mode 100644 anda/langs/go/u-root/golang-github-u-root.spec create mode 100644 anda/langs/go/u-root/update.rhai rename anda/{ => langs}/go/xyproto-env/anda.hcl (100%) rename anda/{ => langs}/go/xyproto-env/golang-github-xyproto-env.spec (96%) rename anda/{ => langs}/go/xyproto-env/update.rhai (100%) rename anda/{ => langs}/go/xyproto-env/v1/anda.hcl (100%) rename anda/{ => langs}/go/xyproto-env/v1/golang-github-xyproto-env.spec (100%) rename anda/{ => langs}/go/xyproto-textoutput/anda.hcl (100%) rename anda/{ => langs}/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec (96%) rename anda/{ => langs}/go/xyproto-textoutput/update.rhai (100%) rename anda/{ => langs}/go/xyproto-vt100/anda.hcl (100%) rename anda/{ => langs}/go/xyproto-vt100/golang-github-xyproto-vt100.spec (97%) rename anda/{ => langs}/go/xyproto-vt100/update.rhai (100%) rename anda/{ => langs}/go/yhat-scrape/anda.hcl (100%) rename anda/{ => langs}/go/yhat-scrape/golang-github-yhat-scrape.spec (100%) rename anda/{ => langs}/groovy/anda.hcl (100%) rename anda/{ => langs}/groovy/groovy-docs/anda.hcl (100%) rename anda/{ => langs}/groovy/groovy-docs/groovy-docs.spec (97%) rename anda/{ => langs}/groovy/groovy-docs/update.rhai (100%) rename anda/{ => langs}/groovy/groovy.spec (99%) rename anda/{ => langs}/groovy/update.rhai (100%) rename anda/{ => langs}/kotlin/kotlin-native/anda.hcl (100%) rename anda/{ => langs}/kotlin/kotlin-native/kotlin-native.spec (99%) rename anda/{ => langs}/kotlin/kotlin-native/update.rhai (100%) rename anda/{ => langs}/kotlin/kotlin/anda.hcl (100%) rename anda/{ => langs}/kotlin/kotlin/kotlin.spec (99%) rename anda/{ => langs}/kotlin/kotlin/update.rhai (100%) rename anda/{ => langs}/nim/choosenim/anda.hcl (100%) rename anda/{ => langs}/nim/choosenim/choosenim.spec (100%) rename anda/{ => langs}/nim/choosenim/update.rhai (100%) rename anda/{ => langs}/nim/nim-nightly/anda.hcl (100%) rename anda/{ => langs}/nim/nim-nightly/nim-nightly.spec (98%) rename anda/{ => langs}/nim/nim-nightly/nim.1 (100%) rename anda/{ => langs}/nim/nim-nightly/nimble.1 (100%) rename anda/{ => langs}/nim/nim-nightly/nimgrep.1 (100%) rename anda/{ => langs}/nim/nim-nightly/nimsuggest.1 (100%) rename anda/{ => langs}/nim/nim-nightly/update.rhai (100%) rename anda/{ => langs}/nim/nim/anda.hcl (100%) rename anda/{ => langs}/nim/nim/nim.1 (100%) rename anda/{ => langs}/nim/nim/nim.spec (99%) rename anda/{ => langs}/nim/nim/nimble.1 (100%) rename anda/{ => langs}/nim/nim/nimgrep.1 (100%) rename anda/{ => langs}/nim/nim/nimsuggest.1 (100%) rename anda/{ => langs}/nim/nim/update.rhai (100%) rename anda/{tools/ffmpeg => langs/python/mpv}/anda.hcl (51%) create mode 100644 anda/langs/python/mpv/python-mpv.spec create mode 100644 anda/langs/python/mpv/update.rhai rename anda/{ => langs}/python/protobuf/anda.hcl (100%) rename anda/{ => langs}/python/protobuf/python3-protobuf.spec (98%) rename anda/{ => langs}/python/protobuf/update.rhai (100%) rename anda/{ => langs}/python/ruff/anda.hcl (100%) rename anda/{ => langs}/python/ruff/python3-ruff.spec (66%) rename anda/{ => langs}/python/ruff/update.rhai (100%) rename anda/{ => langs}/rust/bandwhich/anda.hcl (100%) rename anda/{ => langs}/rust/bandwhich/bandwhich-fix-metadata-auto.diff (100%) rename anda/{ => langs}/rust/bandwhich/rust-bandwhich.spec (100%) rename anda/{ => langs}/rust/bandwhich/update.rhai (100%) rename anda/{ => langs}/rust/bat-extras/anda.hcl (100%) rename anda/{ => langs}/rust/bat-extras/bat-extras.spec (100%) rename anda/{ => langs}/rust/bat-extras/update.rhai (100%) rename anda/{ => langs}/rust/felix/anda.hcl (100%) rename anda/{ => langs}/rust/felix/rust-felix.spec (97%) rename anda/{ => langs}/rust/felix/update.rhai (100%) rename anda/{ => langs}/rust/gitoxide/anda.hcl (100%) rename anda/{ => langs}/rust/gitoxide/rust-gitoxide.spec (99%) rename anda/{ => langs}/rust/gitoxide/update.rhai (100%) rename anda/{ => langs}/rust/gping/anda.hcl (100%) rename anda/{ => langs}/rust/gping/rust-gping.spec (100%) rename anda/{ => langs}/rust/gping/update.rhai (100%) rename anda/{ => langs}/rust/joshuto/anda.hcl (100%) rename anda/{ => langs}/rust/joshuto/rust-joshuto.spec (100%) rename anda/{ => langs}/rust/joshuto/update.rhai (100%) rename anda/{ => langs}/rust/kondo-ui/anda.hcl (100%) rename anda/{ => langs}/rust/kondo-ui/rust-kondo-ui.spec (98%) rename anda/{ => langs}/rust/kondo-ui/update.rhai (100%) rename anda/{ => langs}/rust/kondo/anda.hcl (100%) rename anda/{ => langs}/rust/kondo/rust-kondo.spec (98%) rename anda/{ => langs}/rust/kondo/update.rhai (100%) rename anda/{ => langs}/rust/maturin/anda.hcl (100%) rename anda/{ => langs}/rust/maturin/rust-terra-maturin.spec (100%) rename anda/{ => langs}/rust/maturin/update.rhai (100%) rename anda/{ => langs}/rust/nushell/anda.hcl (100%) rename anda/{ => langs}/rust/nushell/nushell.spec (94%) rename anda/{ => langs}/rust/nushell/update.rhai (100%) rename anda/{ => langs}/rust/ouch/anda.hcl (100%) create mode 100644 anda/langs/rust/ouch/ouch-fix-metadata-auto.diff rename anda/{ => langs}/rust/ouch/rust-ouch.spec (79%) rename anda/{ => langs}/rust/ouch/update.rhai (100%) rename anda/{ => langs}/rust/oxipng/anda.hcl (100%) rename anda/{ => langs}/rust/oxipng/oxipng-fix-metadata-auto.diff (100%) rename anda/{ => langs}/rust/oxipng/rust-oxipng.spec (100%) rename anda/{ => langs}/rust/oxipng/update.rhai (100%) rename anda/{ => langs}/rust/pop-launcher/.gitignore (100%) rename anda/{ => langs}/rust/pop-launcher/0001-Copy-instead-of-symlink.patch (100%) rename anda/{ => langs}/rust/pop-launcher/0001-Remove-frozen-lock.patch (100%) rename anda/{ => langs}/rust/pop-launcher/anda.hcl (100%) rename anda/{ => langs}/rust/pop-launcher/pop-launcher.spec (100%) rename anda/{ => langs}/rust/pop-launcher/prepare.sh (100%) rename anda/{ => langs}/rust/pop-launcher/umpkg.cfg (100%) rename anda/{ => langs}/rust/pop-launcher/umpkg.toml (100%) rename anda/{ => langs}/rust/pop-launcher/update.rhai (100%) rename anda/{ => langs}/rust/rnote/anda.hcl (100%) rename anda/{ => langs}/rust/rnote/rnote.spec (98%) rename anda/{ => langs}/rust/rnote/update.rhai (100%) rename anda/{ => langs}/rust/starship/anda.hcl (100%) rename anda/{ => langs}/rust/starship/rust-starship.spec (99%) rename anda/{ => langs}/rust/starship/starship-fix-metadata-auto.diff (100%) rename anda/{ => langs}/rust/starship/update.rhai (100%) rename anda/{ => langs}/rust/tectonic/anda.hcl (100%) rename anda/{ => langs}/rust/tectonic/rust-tectonic.spec (100%) rename anda/{ => langs}/rust/tectonic/update.rhai (100%) rename anda/{ => langs}/rust/youki/anda.hcl (100%) rename anda/{ => langs}/rust/youki/dep-protobuf.diff (100%) create mode 100644 anda/langs/rust/youki/rust-youki.spec rename anda/{ => langs}/rust/youki/update.rhai (100%) rename anda/{ => langs}/rust/youki/youki.spec (87%) rename anda/{ => langs}/rust/zellij/.gitignore (100%) rename anda/{ => langs}/rust/zellij/anda.hcl (100%) rename anda/{ => langs}/rust/zellij/rust-zellij.spec (95%) rename anda/{ => langs}/rust/zellij/umpkg.toml (100%) rename anda/{ => langs}/rust/zellij/update.rhai (100%) rename anda/{ => langs}/vala/vala-language-server-nightly/anda.hcl (100%) rename anda/{ => langs}/vala/vala-language-server-nightly/update.rhai (100%) rename anda/{ => langs}/vala/vala-language-server-nightly/vala-language-server-nightly.spec (100%) rename anda/{ => langs}/vala/vala-lint-nightly/anda.hcl (100%) rename anda/{ => langs}/vala/vala-lint-nightly/update.rhai (100%) rename anda/{ => langs}/vala/vala-lint-nightly/vala-lint-nightly.spec (90%) rename anda/{ => langs}/vala/vala-nightly/anda.hcl (100%) rename anda/{ => langs}/vala/vala-nightly/update.rhai (100%) rename anda/{ => langs}/vala/vala-nightly/vala-nightly.spec (86%) rename anda/{apps => langs/vala}/vala-panel-appmenu/anda.hcl (100%) rename anda/{apps => langs/vala}/vala-panel-appmenu/update.rhai (100%) rename anda/{apps => langs/vala}/vala-panel-appmenu/vala-panel-appmenu.spec (98%) rename anda/{apps => langs/vala}/vala-panel/anda.hcl (100%) rename anda/{apps => langs/vala}/vala-panel/vala-panel.spec (98%) create mode 100644 anda/lib/placebo/anda.hcl create mode 100644 anda/lib/placebo/terra-libplacebo.spec create mode 100644 anda/lib/placebo/update.rhai create mode 100644 anda/misc/alsa-ucm-cros/alsa-ucm-cros.spec create mode 100644 anda/misc/alsa-ucm-cros/anda.hcl create mode 100644 anda/misc/alsa-ucm-cros/update.rhai rename anda/{others => misc}/click/anda.hcl (100%) rename anda/{others => misc}/click/click.spec (98%) create mode 100644 anda/misc/click/update.rhai rename anda/{audio => misc}/distrho/anda.hcl (100%) rename anda/{audio => misc}/distrho/distrho.spec (100%) rename anda/{others => misc}/gsettings-ubuntu-touch-schemas/anda.hcl (100%) rename anda/{others => misc}/gsettings-ubuntu-touch-schemas/gsettings-ubuntu-touch-schemas.spec (100%) rename anda/{others => misc}/gsettings-ubuntu-touch-schemas/update.rhai (100%) rename anda/{others => misc}/katsu-systemd-sysusers-presets/anda.hcl (100%) rename anda/{others => misc}/katsu-systemd-sysusers-presets/katsu-systemd-sysusers-presets.spec (100%) rename anda/{others => misc}/katsu-systemd-sysusers-presets/polkit.conf (100%) rename anda/{others => misc}/katsu-systemd-sysusers-presets/rpcbind.conf (100%) rename anda/{others => misc}/kwin-system76-scheduler-integration/anda.hcl (100%) rename anda/{others => misc}/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service (75%) rename anda/{others => misc}/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec (87%) rename anda/{others => misc}/kwin-system76-scheduler-integration/system76-scheduler-dbus-proxy.sh (100%) rename anda/{others => misc}/kwin-system76-scheduler-integration/update.rhai (100%) create mode 100644 anda/misc/opentabletdriver/anda.hcl create mode 100644 anda/misc/opentabletdriver/opentabletdriver.spec create mode 100644 anda/misc/opentabletdriver/update.rhai create mode 100644 anda/misc/opentabletdriver/v0.6.3.0.tar.gz rename anda/{others => misc}/rustdesk-selinux/anda.hcl (100%) rename anda/{others => misc}/rustdesk-selinux/rustdesk-selinux.spec (100%) rename anda/{others => misc}/rustdesk-selinux/rustdesk.te (100%) rename anda/{others => misc}/sass/anda.hcl (100%) rename anda/{others => misc}/sass/sass.spec (98%) rename anda/{others => misc}/sass/update.rhai (100%) rename anda/{others => misc}/system76-scheduler/anda.hcl (100%) rename anda/{others => misc}/system76-scheduler/system76-scheduler.spec (91%) rename anda/{others => misc}/system76-scheduler/update.rhai (100%) rename anda/{others => misc}/systemd-sysusers-presets/anda.hcl (100%) rename anda/{others => misc}/systemd-sysusers-presets/polkit.conf (100%) rename anda/{others => misc}/systemd-sysusers-presets/rpcbind.conf (100%) rename anda/{others => misc}/systemd-sysusers-presets/systemd-sysusers-presets.spec (94%) rename anda/{others => misc}/ubuntu-sdk/anda.hcl (100%) rename anda/{others => misc}/ubuntu-sdk/ubuntu-sdk.spec (89%) rename anda/{others => misc}/uwufetch/anda.hcl (100%) rename anda/{others => misc}/uwufetch/update.rhai (100%) rename anda/{others => misc}/uwufetch/uwufetch.spec (100%) rename anda/{others => misc}/uxplay/anda.hcl (100%) rename anda/{others => misc}/uxplay/update.rhai (100%) rename anda/{others => misc}/uxplay/uxplay.spec (98%) delete mode 100644 anda/others/terra-fractureiser-detector/anda.hcl delete mode 100644 anda/others/terra-fractureiser-detector/detect.py delete mode 100644 anda/others/terra-fractureiser-detector/dialog.py delete mode 100644 anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.service delete mode 100644 anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.timer delete mode 100644 anda/others/terra-fractureiser-detector/terra-fractureiser-detector.spec delete mode 100644 anda/rust/ouch/ouch-fix-metadata-auto.diff delete mode 100644 anda/srpm-macros/macros.cargo_extra create mode 100644 anda/system/avstplg/anda.hcl create mode 100644 anda/system/avstplg/avstplg.spec create mode 100644 anda/system/avstplg/update.rhai create mode 100644 anda/system/depthcharge-tools/anda.hcl create mode 100644 anda/system/depthcharge-tools/depthcharge-tools.spec create mode 100644 anda/system/depthcharge-tools/update.rhai rename anda/{tools => system}/limine/anda.hcl (100%) rename anda/{tools => system}/limine/limine.spec (97%) rename anda/{tools => system}/limine/update.rhai (100%) create mode 100644 anda/system/nvidia-patch/anda.hcl create mode 100644 anda/system/nvidia-patch/nvidia-patch.spec create mode 100644 anda/system/nvidia-patch/update.rhai rename anda/{gleam => system/submarine}/anda.hcl (52%) create mode 100644 anda/system/submarine/submarine.spec create mode 100644 anda/system/submarine/update.rhai create mode 100644 anda/system/uutils-coreutils/.gitignore rename anda/{tools => system}/uutils-coreutils/anda.hcl (100%) rename anda/{tools => system}/uutils-coreutils/update.rhai (100%) rename anda/{tools => system}/uutils-coreutils/uutils-coreutils.spec (99%) rename anda/{others => system}/xpadneo/anda.hcl (100%) rename anda/{others => system}/xpadneo/modules-load-d-xpadneo.conf (100%) rename anda/{others => system}/xpadneo/update.rhai (100%) rename anda/{others => system}/xpadneo/xpadneo.spec (100%) rename anda/{ => terra}/mock-configs/anda.hcl (100%) rename anda/{ => terra}/mock-configs/terra-38-aarch64.cfg (100%) rename anda/{ => terra}/mock-configs/terra-38-x86_64.cfg (100%) create mode 100644 anda/terra/mock-configs/terra-39-aarch64.cfg create mode 100644 anda/terra/mock-configs/terra-39-x86_64.cfg rename anda/{ => terra}/mock-configs/terra-mock-configs.spec (70%) rename anda/{ => terra}/mock-configs/terra.tpl (80%) rename anda/{terra-release => terra/release}/anda.hcl (100%) rename anda/{terra-release => terra/release}/terra-release.spec (100%) rename anda/{terra-release => terra/release}/terra.repo (100%) rename anda/{ => terra}/srpm-macros/anda-srpm-macros.spec (100%) rename anda/{ => terra}/srpm-macros/anda.hcl (100%) rename anda/{ => terra}/srpm-macros/macros.anda (100%) rename anda/{ => terra}/srpm-macros/macros.caching (92%) create mode 100644 anda/terra/srpm-macros/macros.cargo_extra rename anda/{ => terra}/srpm-macros/macros.go_extra (100%) rename anda/{ => terra}/srpm-macros/umpkg.toml (100%) rename anda/{others => themes}/tau-helium/anda.hcl (100%) rename anda/{others => themes}/tau-helium/tau-helium.spec (100%) rename anda/{others => themes}/tau-helium/update.rhai (100%) rename anda/{others => themes}/tau-hydrogen/anda.hcl (100%) rename anda/{others => themes}/tau-hydrogen/tau-hydrogen.spec (100%) rename anda/{others => themes}/tau-hydrogen/update.rhai (100%) create mode 100644 anda/tools/amdctl/0001-RPM-makefile-Remove-unused-Makefile-variables.patch create mode 100644 anda/tools/amdctl/amdctl.spec create mode 100644 anda/tools/amdctl/anda.hcl create mode 100644 anda/tools/amdctl/update.rhai rename anda/tools/{ => buildsys}/anda/anda.hcl (100%) rename anda/tools/{ => buildsys}/anda/rust-anda.spec (100%) rename anda/tools/{ => buildsys}/anda/update.rhai (100%) rename anda/tools/{ => buildsys}/gradle/anda.hcl (100%) rename anda/tools/{ => buildsys}/gradle/gradle.spec (100%) rename anda/tools/{ => buildsys}/gradle/update.rhai (100%) rename anda/tools/{ => buildsys}/katsu/anda.hcl (100%) rename anda/tools/{ => buildsys}/katsu/katsu.spec (95%) rename anda/tools/{ => buildsys}/katsu/update.rhai (100%) rename anda/tools/{ => buildsys}/muon/anda.hcl (100%) rename anda/tools/{ => buildsys}/muon/muon.spec (100%) rename anda/tools/{ => buildsys}/ops2deb/anda.hcl (100%) rename anda/tools/{ => buildsys}/ops2deb/ops2deb.spec (96%) rename anda/tools/{ => buildsys}/ops2deb/update.rhai (100%) rename anda/tools/{ => buildsys}/subatomic/anda.hcl (100%) rename anda/tools/{ => buildsys}/subatomic/subatomic.spec (100%) rename anda/tools/{ => buildsys}/subatomic/update.rhai (100%) create mode 100644 anda/tools/chromium-ectool/anda.hcl create mode 100644 anda/tools/chromium-ectool/chromium-ectool.spec delete mode 100644 anda/tools/ffmpeg/0001-avcodec-x86-mathops-clip-constants-used-with-shift-i.patch delete mode 100644 anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-remove-deprecated-field.patch delete mode 100644 anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-wrap-deprecated-opts-in-FF_AP.patch delete mode 100644 anda/tools/ffmpeg/0001-fftools-ffmpeg_filter-initialize-the-o-to-silence-th.patch delete mode 100644 anda/tools/ffmpeg/ffmpeg.spec create mode 100644 anda/tools/umstellar/.gitignore create mode 100644 anda/tools/umstellar/anda.hcl create mode 100644 anda/tools/umstellar/umstellar.spec create mode 100644 anda/tools/umstellar/update.rhai diff --git a/.github/workflows/autobuild.yml b/.github/workflows/autobuild.yml index d0bb87f02a..2638f69b71 100644 --- a/.github/workflows/autobuild.yml +++ b/.github/workflows/autobuild.yml @@ -63,10 +63,10 @@ jobs: - name: Include custom build template instead of package default run: | - cp -v anda/mock-configs/terra.tpl /etc/mock/templates/terra.tpl + cp -v anda/terra/mock-configs/terra.tpl /etc/mock/templates/terra.tpl - name: Build with Andaman - run: anda build ${{ matrix.pkg.pkg }} --package rpm -c anda/mock-configs/terra-${{ matrix.version }}-${{ matrix.pkg.arch }}.cfg + run: anda build ${{ matrix.pkg.pkg }} --package rpm -c anda/terra/mock-configs/terra-${{ matrix.version }}-${{ matrix.pkg.arch }}.cfg - name: Generating artifact name id: art diff --git a/.github/workflows/bootstrap.yml b/.github/workflows/bootstrap.yml index 845af65129..380b4ea672 100644 --- a/.github/workflows/bootstrap.yml +++ b/.github/workflows/bootstrap.yml @@ -42,7 +42,7 @@ jobs: - name: Build terra-mock-configs run: | git config --global --add safe.directory "$GITHUB_WORKSPACE" - anda build -c fedora-${{ matrix.version }}-${{ matrix.arch }} anda/mock-configs/pkg -p rpm + anda build -c fedora-${{ matrix.version }}-${{ matrix.arch }} anda/terra/mock-configs/pkg -p rpm - name: Install terra-mock-configs run: sudo dnf install -y anda-build/rpm/rpms/terra-mock-configs*.rpm diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 8bab8ab4cd..50d35fcae9 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -44,7 +44,7 @@ jobs: key: ${{ runner.os }}-br-${{ matrix.version }}-${{ matrix.arch }}-${{ matrix.pkg }} - name: Build with Andaman - run: anda build anda/${{ matrix.pkg }}pkg --package rpm -c anda/mock-configs/terra-${{ matrix.version }}-${{ matrix.arch }}.cfg + run: anda build anda/${{ matrix.pkg }}pkg --package rpm -c anda/terra/mock-configs/terra-${{ matrix.version }}-${{ matrix.arch }}.cfg - name: Generating artifact name id: art diff --git a/.github/workflows/json-build.yml b/.github/workflows/json-build.yml index 986f6da5c7..851f72e7ae 100644 --- a/.github/workflows/json-build.yml +++ b/.github/workflows/json-build.yml @@ -33,7 +33,7 @@ jobs: key: ${{ runner.os }}-br-${{ matrix.version }}-${{ matrix.pkg.arch }}-${{ matrix.pkg.pkg }} - name: Build with Andaman - run: anda build ${{ matrix.pkg.pkg }} --package rpm -c anda/mock-configs/terra-${{ matrix.version }}-${{ matrix.pkg.arch }}.cfg + run: anda build ${{ matrix.pkg.pkg }} --package rpm -c anda/terra/mock-configs/terra-${{ matrix.version }}-${{ matrix.pkg.arch }}.cfg - name: Generating artifact name id: art diff --git a/anda/apps/anki-bin/anki-bin.spec b/anda/apps/anki-bin/anki-bin.spec index 0b12dde112..893936a1ff 100644 --- a/anda/apps/anki-bin/anki-bin.spec +++ b/anda/apps/anki-bin/anki-bin.spec @@ -4,7 +4,7 @@ Release: 1%{?dist} Summary: Flashcard program for using space repetition learning (Installed with wheel) License: AGPL-3.0-or-later AND GPL-3.0-or-later AND LGPL-3.0-or-later AND MIT AND BSD-3-Clause AND CC-BY-SA-3.0 AND CC-BY-3.0 AND Apache-2.0 AND CC-BY-2.5 URL: https://apps.ankiweb.net/ -BuildRequires: python3-installer python3.11 rpm_macro(fdupes) +BuildRequires: python3-pip rpm_macro(fdupes) Requires: python3-sqlalchemy python3-simplejson python3-matplotlib python3-decorator python3-markdown python3-orjson Requires: python3-requests python3-pygame python3-beautifulsoup4 python3-httplib2 python3-pyaudio python3-jsonschema Requires: python3-flask-cors python3-protobuf python3-requests python3-waitress python3-pyqt6-webengine python3-send2trash @@ -29,28 +29,33 @@ Anki is based on a theory called spaced repetition. %build %install -python3.11 -m installer --destdir="%{buildroot}" %{SOURCE0} -python3.11 -m installer --destdir="%{buildroot}" %{SOURCE1} +pip3 install --root=%{buildroot} %SOURCE0 %SOURCE1 install -Dm755 %{SOURCE2} "%{buildroot}/usr/bin/anki" install -Dm644 %{SOURCE3} "%{buildroot}/usr/share/applications/anki.desktop" install -Dm644 %{SOURCE4} "%{buildroot}/usr/share/pixmaps/anki.png" install -Dm644 %{SOURCE5} "%{buildroot}/%{_datadir}/licenses/%{name}/LICENSE" install -Dm644 %{SOURCE6} "%{buildroot}/%{_datadir}/doc/%{name}/README.md" -%fdupes %_libdir/python*/site-packages/_aqt/data/ +cp -r %buildroot%_libdir/python3*/site-packages/{_aqt,anki*,aqt*} . +rm -rf %buildroot{%_libdir,/usr/lib}/python3*/site-packages/* +cp -r ./{_aqt,anki*,aqt*} %buildroot/usr/lib/python3*/site-packages/ + +rm -rf %buildroot%_bindir/{distro,flask,jsonschema,markdown_py,normalizer,send2trash,waitress-serve} + +%fdupes %buildroot%_libdir/python*/site-packages/_aqt/data/ %files %license LICENSE %doc README.md -/usr/bin/anki -/usr/lib64/python*/site-packages/_aqt/ -/usr/lib64/python*/site-packages/anki-%{version}.dist-info/ -/usr/lib64/python*/site-packages/anki/ -/usr/lib64/python*/site-packages/aqt-%{version}.dist-info/ -/usr/lib64/python*/site-packages/aqt/ -/usr/share/applications/anki.desktop -/usr/share/pixmaps/anki.png +%_bindir/anki +/usr/lib/python*/site-packages/_aqt/ +/usr/lib/python*/site-packages/anki-%{version}.dist-info/ +/usr/lib/python*/site-packages/anki/ +/usr/lib/python*/site-packages/aqt-%{version}.dist-info/ +/usr/lib/python*/site-packages/aqt/ +%_datadir/applications/anki.desktop +%_datadir/pixmaps/anki.png %changelog * Fri Nov 10 2023 hazel-bunny - 23.10-2 diff --git a/anda/others/blackbox-terminal/anda.hcl b/anda/apps/blackbox-terminal/anda.hcl similarity index 100% rename from anda/others/blackbox-terminal/anda.hcl rename to anda/apps/blackbox-terminal/anda.hcl diff --git a/anda/others/blackbox-terminal/blackbox-terminal.spec b/anda/apps/blackbox-terminal/blackbox-terminal.spec similarity index 100% rename from anda/others/blackbox-terminal/blackbox-terminal.spec rename to anda/apps/blackbox-terminal/blackbox-terminal.spec diff --git a/anda/others/blackbox-terminal/update.rhai b/anda/apps/blackbox-terminal/update.rhai similarity index 100% rename from anda/others/blackbox-terminal/update.rhai rename to anda/apps/blackbox-terminal/update.rhai diff --git a/anda/apps/discord-canary-openasar/discord-canary-openasar.spec b/anda/apps/discord-canary-openasar/discord-canary-openasar.spec index ae62f3caf2..cc510df40c 100644 --- a/anda/apps/discord-canary-openasar/discord-canary-openasar.spec +++ b/anda/apps/discord-canary-openasar/discord-canary-openasar.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord-canary-openasar -Version: 0.0.209 +Version: 0.0.248 Release: 1%{?dist} Summary: A snappier Discord rewrite with features like further customization and theming License: MIT AND https://discord.com/terms diff --git a/anda/apps/discord-canary/discord-canary.spec b/anda/apps/discord-canary/discord-canary.spec index db633b8a00..73c46142f4 100644 --- a/anda/apps/discord-canary/discord-canary.spec +++ b/anda/apps/discord-canary/discord-canary.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord-canary -Version: 0.0.209 +Version: 0.0.248 Release: 1%{?dist} Summary: Free Voice and Text Chat for Gamers URL: discord.com diff --git a/anda/apps/discord-openasar/discord-openasar.spec b/anda/apps/discord-openasar/discord-openasar.spec index 70f32a2f6c..525870ca40 100644 --- a/anda/apps/discord-openasar/discord-openasar.spec +++ b/anda/apps/discord-openasar/discord-openasar.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord-openasar -Version: 0.0.34 +Version: 0.0.40 Release: 1%{?dist} Summary: A snappier Discord rewrite with features like further customization and theming License: MIT AND https://discord.com/terms diff --git a/anda/apps/discord-ptb-openasar/discord-ptb-openasar.spec b/anda/apps/discord-ptb-openasar/discord-ptb-openasar.spec index 58cc84f192..f1e8fde71e 100644 --- a/anda/apps/discord-ptb-openasar/discord-ptb-openasar.spec +++ b/anda/apps/discord-ptb-openasar/discord-ptb-openasar.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord-ptb-openasar -Version: 0.0.58 +Version: 0.0.64 Release: 1%{?dist} Summary: A snappier Discord rewrite with features like further customization and theming License: MIT AND https://discord.com/terms diff --git a/anda/apps/discord-ptb/discord-ptb.spec b/anda/apps/discord-ptb/discord-ptb.spec index 5c5f55fdaf..7691d967e7 100644 --- a/anda/apps/discord-ptb/discord-ptb.spec +++ b/anda/apps/discord-ptb/discord-ptb.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord-ptb -Version: 0.0.58 +Version: 0.0.64 Release: 1%{?dist} Summary: Free Voice and Text Chat for Gamers. URL: https://discord.com diff --git a/anda/apps/discord/discord.spec b/anda/apps/discord/discord.spec index 36ed22a3d8..6cef67eb6a 100644 --- a/anda/apps/discord/discord.spec +++ b/anda/apps/discord/discord.spec @@ -6,7 +6,7 @@ %global __provides_exclude_from %{_datadir}/%{name}/.*\\.so Name: discord -Version: 0.0.34 +Version: 0.0.40 Release: 1%{?dist} Summary: Free Voice and Text Chat for Gamers URL: https://discord.com diff --git a/anda/apps/sccache/anda.hcl b/anda/apps/sccache/anda.hcl new file mode 100644 index 0000000000..665fb9cf1a --- /dev/null +++ b/anda/apps/sccache/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "rust-sccache.spec" + } +} diff --git a/anda/apps/sccache/rust-sccache.spec b/anda/apps/sccache/rust-sccache.spec new file mode 100644 index 0000000000..ae15a5a33a --- /dev/null +++ b/anda/apps/sccache/rust-sccache.spec @@ -0,0 +1,601 @@ +# Generated by rust2rpm 25 +%bcond_with check +# aarch64 dist is not available +%ifarch aarch64 +%bcond_with dist_server +%else +%bcond_without dist_server +%endif + +# Don't mangle shebangs +%global __brp_mangle_shebangs %{nil} + +%global crate sccache + +Name: rust-sccache +Version: 0.7.4 +Release: 1%{?dist} +Summary: Ccache-like tool + +License: Apache-2.0 +URL: https://crates.io/crates/sccache +Source: %{crates_source} +# Automatically generated patch to strip dependencies and normalize metadata +Patch: sccache-fix-metadata-auto.diff + +ExclusiveArch: %{rust_arches} + +BuildRequires: cargo-rpm-macros >= 24 +BuildRequires: anda-srpm-macros +BuildRequires: openssl-devel +BuildRequires: gcc +BuildRequires: perl +BuildRequires: rust-packaging + +%global _description %{expand: +Sccache is a ccache-like tool. It is used as a compiler wrapper and +avoids compilation when possible, storing a cache in a remote storage +using various cloud storage.} + +%description %{_description} + +%package -n %{crate} +Summary: %{summary} +# FIXME: paste output of %%cargo_license_summary here +License: # FIXME +# LICENSE.dependencies contains a full license breakdown + +%description -n %{crate} %{_description} + +%files -n %{crate} +%license LICENSE +%doc CODE_OF_CONDUCT.md +%doc README.md +%{_bindir}/sccache +%if %{with dist_server} +%{_bindir}/sccache-dist +%endif + +%package devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache) = 0.7.4 +Requires: cargo +Requires: rust >= 1.67.1 + +%description devel %{_description} + +This package contains library source intended for building other packages which +use the "%{crate}" crate. + +%files devel +%license %{crate_instdir}/LICENSE +%doc %{crate_instdir}/CODE_OF_CONDUCT.md +%doc %{crate_instdir}/README.md +%{crate_instdir}/ + +%package -n %{name}+default-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/default) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/all) = 0.7.4 + +%description -n %{name}+default-devel %{_description} + +This package contains library source intended for building other packages which +use the "default" feature of the "%{crate}" crate. + +%files -n %{name}+default-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+all-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/all) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/azure) = 0.7.4 +Requires: crate(sccache/dist-client) = 0.7.4 +Requires: crate(sccache/gcs) = 0.7.4 +Requires: crate(sccache/gha) = 0.7.4 +Requires: crate(sccache/memcached) = 0.7.4 +Requires: crate(sccache/redis) = 0.7.4 +Requires: crate(sccache/s3) = 0.7.4 +Requires: crate(sccache/webdav) = 0.7.4 + +%description -n %{name}+all-devel %{_description} + +This package contains library source intended for building other packages which +use the "all" feature of the "%{crate}" crate. + +%files -n %{name}+all-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+azure-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/azure) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+azure-devel %{_description} + +This package contains library source intended for building other packages which +use the "azure" feature of the "%{crate}" crate. + +%files -n %{name}+azure-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+dist-client-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/dist-client) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+dist-client-devel %{_description} + +This package contains library source intended for building other packages which +use the "dist-client" feature of the "%{crate}" crate. + +%files -n %{name}+dist-client-devel +%ghost %{crate_instdir}/Cargo.toml +%if %{with dist_server} +%package -n %{name}+dist-server-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/dist-server) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+dist-server-devel %{_description} + +This package contains library source intended for building other packages which +use the "dist-server" feature of the "%{crate}" crate. + +%files -n %{name}+dist-server-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+dist-tests-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/dist-tests) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/dist-client) = 0.7.4 +Requires: crate(sccache/dist-server) = 0.7.4 + +%description -n %{name}+dist-tests-devel %{_description} + +This package contains library source intended for building other packages which +use the "dist-tests" feature of the "%{crate}" crate. + +%files -n %{name}+dist-tests-devel +%ghost %{crate_instdir}/Cargo.toml +%endif +%package -n %{name}+flate2-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/flate2) = 0.7.4 +Requires: (crate(flate2) >= 1.0.0 with crate(flate2) < 2.0.0~) +Requires: (crate(flate2/rust_backend) >= 1.0.0 with crate(flate2/rust_backend) < 2.0.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+flate2-devel %{_description} + +This package contains library source intended for building other packages which +use the "flate2" feature of the "%{crate}" crate. + +%files -n %{name}+flate2-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+gcs-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/gcs) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+gcs-devel %{_description} + +This package contains library source intended for building other packages which +use the "gcs" feature of the "%{crate}" crate. + +%files -n %{name}+gcs-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+gha-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/gha) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/opendal) = 0.7.4 + +%description -n %{name}+gha-devel %{_description} + +This package contains library source intended for building other packages which +use the "gha" feature of the "%{crate}" crate. + +%files -n %{name}+gha-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+hyper-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/hyper) = 0.7.4 +Requires: (crate(hyper/default) >= 0.14.27 with crate(hyper/default) < 0.15.0~) +Requires: (crate(hyper/server) >= 0.14.27 with crate(hyper/server) < 0.15.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+hyper-devel %{_description} + +This package contains library source intended for building other packages which +use the "hyper" feature of the "%{crate}" crate. + +%files -n %{name}+hyper-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+jwt-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/jwt) = 0.7.4 +Requires: (crate(jsonwebtoken/default) >= 8.0.0 with crate(jsonwebtoken/default) < 9.0.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+jwt-devel %{_description} + +This package contains library source intended for building other packages which +use the "jwt" feature of the "%{crate}" crate. + +%files -n %{name}+jwt-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+libmount-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/libmount) = 0.7.4 +Requires: (crate(libmount/default) >= 0.1.10 with crate(libmount/default) < 0.2.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+libmount-devel %{_description} + +This package contains library source intended for building other packages which +use the "libmount" feature of the "%{crate}" crate. + +%files -n %{name}+libmount-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+memcached-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/memcached) = 0.7.4 +Requires: (crate(opendal/default) >= 0.40.0 with crate(opendal/default) < 0.41.0~) +Requires: (crate(opendal/services-memcached) >= 0.40.0 with crate(opendal/services-memcached) < 0.41.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+memcached-devel %{_description} + +This package contains library source intended for building other packages which +use the "memcached" feature of the "%{crate}" crate. + +%files -n %{name}+memcached-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+native-zlib-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/native-zlib) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+native-zlib-devel %{_description} + +This package contains library source intended for building other packages which +use the "native-zlib" feature of the "%{crate}" crate. + +%files -n %{name}+native-zlib-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+nix-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/nix) = 0.7.4 +Requires: (crate(nix/default) >= 0.26.2 with crate(nix/default) < 0.27.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+nix-devel %{_description} + +This package contains library source intended for building other packages which +use the "nix" feature of the "%{crate}" crate. + +%files -n %{name}+nix-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+opendal-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/opendal) = 0.7.4 +Requires: (crate(opendal/default) >= 0.40.0 with crate(opendal/default) < 0.41.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+opendal-devel %{_description} + +This package contains library source intended for building other packages which +use the "opendal" feature of the "%{crate}" crate. + +%files -n %{name}+opendal-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+openssl-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/openssl) = 0.7.4 +Requires: (crate(openssl/default) >= 0.10.55 with crate(openssl/default) < 0.11.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+openssl-devel %{_description} + +This package contains library source intended for building other packages which +use the "openssl" feature of the "%{crate}" crate. + +%files -n %{name}+openssl-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+redis-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/redis) = 0.7.4 +Requires: (crate(opendal/default) >= 0.40.0 with crate(opendal/default) < 0.41.0~) +Requires: (crate(opendal/services-redis) >= 0.40.0 with crate(opendal/services-redis) < 0.41.0~) +Requires: (crate(opendal/services-redis-rustls) >= 0.40.0 with crate(opendal/services-redis-rustls) < 0.41.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/url) = 0.7.4 + +%description -n %{name}+redis-devel %{_description} + +This package contains library source intended for building other packages which +use the "redis" feature of the "%{crate}" crate. + +%files -n %{name}+redis-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+reqsign-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/reqsign) = 0.7.4 +Requires: (crate(reqsign/default) >= 0.14.1 with crate(reqsign/default) < 0.15.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+reqsign-devel %{_description} + +This package contains library source intended for building other packages which +use the "reqsign" feature of the "%{crate}" crate. + +%files -n %{name}+reqsign-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+reqwest-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/reqwest) = 0.7.4 +Requires: (crate(reqwest/blocking) >= 0.11.0 with crate(reqwest/blocking) < 0.12.0~) +Requires: (crate(reqwest/default) >= 0.11.0 with crate(reqwest/default) < 0.12.0~) +Requires: (crate(reqwest/json) >= 0.11.0 with crate(reqwest/json) < 0.12.0~) +Requires: (crate(reqwest/rustls-tls) >= 0.11.0 with crate(reqwest/rustls-tls) < 0.12.0~) +Requires: (crate(reqwest/stream) >= 0.11.0 with crate(reqwest/stream) < 0.12.0~) +Requires: (crate(reqwest/trust-dns) >= 0.11.0 with crate(reqwest/trust-dns) < 0.12.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+reqwest-devel %{_description} + +This package contains library source intended for building other packages which +use the "reqwest" feature of the "%{crate}" crate. + +%files -n %{name}+reqwest-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+rouille-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/rouille) = 0.7.4 +Requires: (crate(rouille) >= 3.6.0 with crate(rouille) < 4.0.0~) +Requires: (crate(rouille/ssl) >= 3.6.0 with crate(rouille/ssl) < 4.0.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+rouille-devel %{_description} + +This package contains library source intended for building other packages which +use the "rouille" feature of the "%{crate}" crate. + +%files -n %{name}+rouille-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+s3-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/s3) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/opendal) = 0.7.4 +Requires: crate(sccache/reqsign) = 0.7.4 + +%description -n %{name}+s3-devel %{_description} + +This package contains library source intended for building other packages which +use the "s3" feature of the "%{crate}" crate. + +%files -n %{name}+s3-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+sha2-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/sha2) = 0.7.4 +Requires: (crate(sha2/default) >= 0.10.6 with crate(sha2/default) < 0.11.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+sha2-devel %{_description} + +This package contains library source intended for building other packages which +use the "sha2" feature of the "%{crate}" crate. + +%files -n %{name}+sha2-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+syslog-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/syslog) = 0.7.4 +Requires: (crate(syslog/default) >= 6.0.0 with crate(syslog/default) < 7.0.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+syslog-devel %{_description} + +This package contains library source intended for building other packages which +use the "syslog" feature of the "%{crate}" crate. + +%files -n %{name}+syslog-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+trust-dns-resolver-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/trust-dns-resolver) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+trust-dns-resolver-devel %{_description} + +This package contains library source intended for building other packages which +use the "trust-dns-resolver" feature of the "%{crate}" crate. + +%files -n %{name}+trust-dns-resolver-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+unstable-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/unstable) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+unstable-devel %{_description} + +This package contains library source intended for building other packages which +use the "unstable" feature of the "%{crate}" crate. + +%files -n %{name}+unstable-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+url-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/url) = 0.7.4 +Requires: (crate(url/default) >= 2.0.0 with crate(url/default) < 3.0.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+url-devel %{_description} + +This package contains library source intended for building other packages which +use the "url" feature of the "%{crate}" crate. + +%files -n %{name}+url-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+vendored-openssl-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/vendored-openssl) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+vendored-openssl-devel %{_description} + +This package contains library source intended for building other packages which +use the "vendored-openssl" feature of the "%{crate}" crate. + +%files -n %{name}+vendored-openssl-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+version-compare-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/version-compare) = 0.7.4 +Requires: (crate(version-compare/default) >= 0.1.1 with crate(version-compare/default) < 0.2.0~) +Requires: cargo +Requires: crate(sccache) = 0.7.4 + +%description -n %{name}+version-compare-devel %{_description} + +This package contains library source intended for building other packages which +use the "version-compare" feature of the "%{crate}" crate. + +%files -n %{name}+version-compare-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+webdav-devel +Summary: %{summary} +BuildArch: noarch +Provides: crate(sccache/webdav) = 0.7.4 +Requires: cargo +Requires: crate(sccache) = 0.7.4 +Requires: crate(sccache/opendal) = 0.7.4 + +%description -n %{name}+webdav-devel %{_description} + +This package contains library source intended for building other packages which +use the "webdav" feature of the "%{crate}" crate. + +%files -n %{name}+webdav-devel +%ghost %{crate_instdir}/Cargo.toml + +%prep +%autosetup -n %{crate}-%{version} -p1 +%cargo_prep_online + + +%build +%if %{with dist_server} +%cargo_build -f dist-server +%else +%cargo_build +%endif + +%install +%if %{with dist_server} +%cargo_install -f dist-server +%else +%cargo_install +%endif + +%if %{with check} +%check +%if %{with dist_server} +%cargo_test -f dist-server +%else +%cargo_test +%endif + +%endif + +%changelog +* Mon Dec 18 2023 Cappy Ishihara - 0.7.4-1 +- Initial package diff --git a/anda/apps/sccache/sccache-fix-metadata-auto.diff b/anda/apps/sccache/sccache-fix-metadata-auto.diff new file mode 100644 index 0000000000..9b96ebe2e2 --- /dev/null +++ b/anda/apps/sccache/sccache-fix-metadata-auto.diff @@ -0,0 +1,14 @@ +--- sccache-0.7.4/Cargo.toml 1970-01-01T00:00:01+00:00 ++++ sccache-0.7.4/Cargo.toml 2023-12-18T06:08:52.420382+00:00 +@@ -384,11 +384,3 @@ + [target."cfg(unix)".dependencies.daemonize] + version = "0.5" + +-[target."cfg(windows)".dependencies.winapi] +-version = "0.3" +-features = [ +- "fileapi", +- "handleapi", +- "stringapiset", +- "winnls", +-] diff --git a/anda/tools/uutils-coreutils/.gitignore b/anda/apps/vencord-desktop/.gitignore similarity index 100% rename from anda/tools/uutils-coreutils/.gitignore rename to anda/apps/vencord-desktop/.gitignore diff --git a/anda/apps/vencord-desktop/anda.hcl b/anda/apps/vencord-desktop/anda.hcl new file mode 100644 index 0000000000..3c5a144b6a --- /dev/null +++ b/anda/apps/vencord-desktop/anda.hcl @@ -0,0 +1,5 @@ +project "pkg" { + rpm { + spec = "vencord-desktop.spec" + } +} \ No newline at end of file diff --git a/anda/apps/vencord-desktop/update.rhai b/anda/apps/vencord-desktop/update.rhai new file mode 100644 index 0000000000..f0b5f6ecf3 --- /dev/null +++ b/anda/apps/vencord-desktop/update.rhai @@ -0,0 +1 @@ +rpm.version(gh_tag("Vencord/Vesktop")); \ No newline at end of file diff --git a/anda/apps/vencord-desktop/vencord-desktop.spec b/anda/apps/vencord-desktop/vencord-desktop.spec new file mode 100644 index 0000000000..507a91e602 --- /dev/null +++ b/anda/apps/vencord-desktop/vencord-desktop.spec @@ -0,0 +1,74 @@ +%define debug_package %nil + +# Exclude private libraries +%global __requires_exclude libffmpeg.so +%global __provides_exclude_from %{_datadir}/vesktop/.*\\.so + +Name: vencord-desktop +Provides: VencordDesktop = %{version}-%{release} +Version: 0.4.4 +Release: 1%{?dist} +License: GPL-3.0 +Summary: Vesktop is a cross platform desktop app aiming to give you a snappier Discord experience with Vencord pre-installed +URL: https://github.com/Vencord/Vesktop +Group: Applications/Internet +#Source1: launch.sh +Source0: https://github.com/Vencord/Vesktop/archive/refs/tags/v%{version}.tar.gz +Requires: xdg-utils +BuildRequires: nodejs-npm git +# Conflicts: vesktop-bin + +%description +vesktop is a custom client designed to enhance your Discord experience +while keeping everything lightweight. + +%prep +git init +git remote add origin %url || : +git reset --hard +git fetch +git checkout v%version + +cat < vesktop.desktop +[Desktop Entry] +Name=Vesktop +Comment=%summary +GenericName=Internet Messenger +Type=Application +Exec=/usr/bin/vencorddesktop +Icon=vesktop +Categories=Network;InstantMessaging; +StartupWMClass=VencordDesktop + +Keywords=discord;vesktop;vencord;shelter;armcord;electron; +EOF + + +%build +npx pnpm@8 install --no-frozen-lockfile +npx pnpm@8 package:dir + + +%install + +mkdir -p %buildroot/usr/share/vesktop +cp -r dist/*-unpacked/. %buildroot/usr/share/vesktop/. + +install -Dm755 dist/*-unpacked/vencorddesktop %buildroot/usr/bin/vencorddesktop +ln -sf /usr/share/vesktop/vencorddesktop %buildroot/usr/bin/vencorddesktop +install -Dm644 vesktop.desktop %buildroot/usr/share/applications/vesktop.desktop +install -Dm644 build/icon.png %buildroot/usr/share/pixmaps/vesktop.png + +%files +%doc README.md +%license LICENSE +/usr/bin/vencorddesktop +/usr/share/applications/vesktop.desktop +/usr/share/pixmaps/vesktop.png +/usr/share/vesktop/* + +%changelog +* Tue Nov 07 2023 Cappy Ishihara - 0.4.3-1 +- Initial package + + diff --git a/anda/audio/voicevox/0001-feat-add-repository-entry-in-package.json.patch b/anda/apps/voicevox/0001-feat-add-repository-entry-in-package.json.patch similarity index 100% rename from anda/audio/voicevox/0001-feat-add-repository-entry-in-package.json.patch rename to anda/apps/voicevox/0001-feat-add-repository-entry-in-package.json.patch diff --git a/anda/audio/voicevox/anda.hcl b/anda/apps/voicevox/anda.hcl similarity index 100% rename from anda/audio/voicevox/anda.hcl rename to anda/apps/voicevox/anda.hcl diff --git a/anda/audio/voicevox/update.rhai b/anda/apps/voicevox/update.rhai similarity index 100% rename from anda/audio/voicevox/update.rhai rename to anda/apps/voicevox/update.rhai diff --git a/anda/audio/voicevox/voicevox.spec b/anda/apps/voicevox/voicevox.spec similarity index 100% rename from anda/audio/voicevox/voicevox.spec rename to anda/apps/voicevox/voicevox.spec diff --git a/anda/desktops/budgie/budgie-extras/budgie-extras.spec b/anda/desktops/budgie/budgie-extras/budgie-extras.spec index c386178868..05c6970173 100644 --- a/anda/desktops/budgie/budgie-extras/budgie-extras.spec +++ b/anda/desktops/budgie/budgie-extras/budgie-extras.spec @@ -51,7 +51,6 @@ Requires: budgie-applet-recentlyused Requires: budgie-applet-rotation-lock Requires: budgie-applet-showtime Requires: budgie-applet-takeabreak -Requires: budgie-applet-trash Requires: budgie-applet-visualspace Requires: budgie-applet-wallstreet Requires: budgie-applet-window-shuffler @@ -208,14 +207,6 @@ upside down, dim the screen, lock screen or show a countdown message on break time. The applet can be accessed quickly from the panel to temporarily switch it off. -%package -n budgie-applet-trash -Requires: budgie-extras-common -Summary: Applet allows access to trash capabilities for the Budgie Desktop -%description -n budgie-applet-trash -The trash applet allows the user access the desktop trash capabilities -from the panel including the ability to delete and restore files stored -in the trash folder. - %package -n budgie-applet-visualspace Requires: budgie-extras-common Summary: Shows the current workspace(s), as bullet(s) @@ -393,9 +384,6 @@ rm -f %{buildroot}%{_bindir}/quickchar %{_datadir}/glib-2.0/schemas/org.ubuntubudgie.plugins.takeabreak.gschema.xml %{_datadir}/pixmaps/takeabreak*.svg -%files -n budgie-applet-trash -%{_libdir}/budgie-desktop/plugins/budgie-trash - %files -n budgie-applet-visualspace %config %{_sysconfdir}/xdg/autostart/visualspace-autostart.desktop %{_libdir}/budgie-desktop/plugins/budgie-visualspace diff --git a/anda/desktops/elementary/elementary-files/elementary-files.spec b/anda/desktops/elementary/elementary-files/elementary-files.spec index f834e23e2d..aa00286e73 100644 --- a/anda/desktops/elementary/elementary-files/elementary-files.spec +++ b/anda/desktops/elementary/elementary-files/elementary-files.spec @@ -5,7 +5,7 @@ Name: elementary-files Summary: File manager from elementary -Version: 6.5.2 +Version: 6.5.3 Release: 1%{?dist} License: GPL-3.0 diff --git a/anda/desktops/elementary/elementary-icon-theme/elementary-icon-theme.spec b/anda/desktops/elementary/elementary-icon-theme/elementary-icon-theme.spec index 5a6d6ff03f..7a3bbb3242 100644 --- a/anda/desktops/elementary/elementary-icon-theme/elementary-icon-theme.spec +++ b/anda/desktops/elementary/elementary-icon-theme/elementary-icon-theme.spec @@ -4,7 +4,7 @@ Name: elementary-icon-theme Summary: Icons from the Elementary Project Version: 7.3.1 -Release: 1%{?dist} +Release: 2%{?dist} License: GPL-3.0-or-later URL: https://github.com/elementary/icons @@ -89,9 +89,7 @@ gtk-update-icon-cache --force %{_datadir}/icons/elementary &>/dev/null || : %dir %{_datadir}/icons/elementary %ghost %{_datadir}/icons/elementary/icon-theme.cache -%{_datadir}/icons/elementary/*/ -%{_datadir}/icons/elementary/*@2x -%{_datadir}/icons/elementary/*@3x +%{_datadir}/icons/elementary/* %{_datadir}/icons/elementary/cursor.theme %{_datadir}/icons/elementary/index.theme diff --git a/anda/desktops/elementary/elementary-onboarding/elementary-onboarding.spec b/anda/desktops/elementary/elementary-onboarding/elementary-onboarding.spec index 1c8b0cd882..90fe9558d5 100644 --- a/anda/desktops/elementary/elementary-onboarding/elementary-onboarding.spec +++ b/anda/desktops/elementary/elementary-onboarding/elementary-onboarding.spec @@ -4,7 +4,7 @@ Name: elementary-onboarding Summary: Onboarding app for new users Version: 7.2.0 -Release: 1%{?dist} +Release: 2%{?dist} License: GPL-3.0-or-later URL: https://github.com/elementary/onboarding diff --git a/anda/desktops/elementary/pantheon-session-settings/pantheon-session-settings.spec b/anda/desktops/elementary/pantheon-session-settings/pantheon-session-settings.spec index de173d65ad..251119d0fb 100644 --- a/anda/desktops/elementary/pantheon-session-settings/pantheon-session-settings.spec +++ b/anda/desktops/elementary/pantheon-session-settings/pantheon-session-settings.spec @@ -13,10 +13,11 @@ BuildArch: noarch Requires: elementary-settings-daemon Requires: gala +# Gala has a hard runtime dependency on... GNOME Disks' DBus service!?! Requires: gnome-disk-utility Requires: gnome-keyring Requires: gnome-session -Requires: gnome-session-xsession +#Requires: gnome-session-xsession # this pulls in gnome-shell Requires: gnome-settings-daemon Requires: orca Requires: pantheon-agent-geoclue2 @@ -41,6 +42,8 @@ Requires: elementary-sound-theme Requires: elementary-theme Requires: open-sans-fonts +Source1: https://github.com/elementary/default-settings/raw/master/xdg-desktop-portal/pantheon-portals.conf + %description Configuration files and settings overrides for the Pantheon desktop session. @@ -84,6 +87,9 @@ mkdir -p %{buildroot}/%{_datadir}/accountsservice/interfaces ln -s ../../dbus-1/interfaces/io.elementary.pantheon.AccountsService.xml \ %{buildroot}/%{_datadir}/accountsservice/interfaces/io.elementary.pantheon.AccountsService.xml +mkdir -p %{buildroot}/%{_datadir}/xdg-desktop-portal +install -m 644 %{SOURCE1} %{buildroot}/%{_datadir}/xdg-desktop-portal/ + # these scriptlets are apparently still necessary, because # .override files don't seem to trigger schema recompilation @@ -109,6 +115,7 @@ fi %{_datadir}/gnome-session/sessions/pantheon.session %{_datadir}/polkit-1/actions/io.elementary.pantheon.AccountsService.policy %{_datadir}/xsessions/pantheon.desktop +%{_datadir}/xdg-desktop-portal/pantheon-portals.conf %changelog diff --git a/anda/desktops/elementary/switchboard-plug-pantheon-shell/dark-theme-wallpaper.patch b/anda/desktops/elementary/switchboard-plug-pantheon-shell/dark-theme-wallpaper.patch new file mode 100644 index 0000000000..ff00a8aeb5 --- /dev/null +++ b/anda/desktops/elementary/switchboard-plug-pantheon-shell/dark-theme-wallpaper.patch @@ -0,0 +1,23 @@ +From a3be778d1c4137d30af6ed9a08d0b54ee828687f Mon Sep 17 00:00:00 2001 +From: madomado +Date: Tue, 21 Nov 2023 19:45:14 +0800 +Subject: [PATCH] fix(wallpaper): change wallpaper for dark theme settings + +Previously before the fix, the wallpaper cannot be changed via settings because it only sets the wallpaper for the light theme, not the dark theme. +This fixes the issue. +--- + src/Views/Wallpaper.vala | 1 + + 1 file changed, 1 insertion(+) + +diff --git a/src/Views/Wallpaper.vala b/src/Views/Wallpaper.vala +index 07251444..7141cad8 100644 +--- a/src/Views/Wallpaper.vala ++++ b/src/Views/Wallpaper.vala +@@ -206,6 +206,7 @@ public class PantheonShell.Wallpaper : Gtk.Box { + } + + gnome_background_settings.set_string ("picture-uri", uri); ++ gnome_background_settings.set_string ("picture-uri-dark", uri); + } + + private void update_checked_wallpaper (Gtk.FlowBox box, Gtk.FlowBoxChild child) { diff --git a/anda/desktops/elementary/switchboard-plug-pantheon-shell/switchboard-plug-pantheon-shell.spec b/anda/desktops/elementary/switchboard-plug-pantheon-shell/switchboard-plug-pantheon-shell.spec index eadfa19306..dbafb315db 100644 --- a/anda/desktops/elementary/switchboard-plug-pantheon-shell/switchboard-plug-pantheon-shell.spec +++ b/anda/desktops/elementary/switchboard-plug-pantheon-shell/switchboard-plug-pantheon-shell.spec @@ -14,6 +14,7 @@ License: GPL-3.0 URL: https://github.com/elementary/switchboard-plug-pantheon-shell Source0: %{url}/archive/%{version}/%{srcname}-%{version}.tar.gz +Patch0: dark-theme-wallpaper.patch BuildRequires: gettext BuildRequires: libappstream-glib diff --git a/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/anda.hcl b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/anda.hcl new file mode 100644 index 0000000000..ede91daf20 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "gnome-shell-extension-appmenu-is-back.spec" + } +} diff --git a/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/gnome-shell-extension-appmenu-is-back.spec b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/gnome-shell-extension-appmenu-is-back.spec new file mode 100644 index 0000000000..a7a3ab0f8d --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/gnome-shell-extension-appmenu-is-back.spec @@ -0,0 +1,34 @@ +%global extension appmenu-is-back +%global uuid %{extension}@fthx + +Name: gnome-shell-extension-%{extension} +Version: 2 +Release: 1%{?dist} +Summary: GNOME Shell extension to bring back the app menu +License: GPL-3.0-only +URL: https://github.com/fthx/appmenu-is-back + +BuildArch: noarch + +Source0: https://github.com/fthx/appmenu-is-back/archive/refs/tags/v%{version}.tar.gz + +Requires: (gnome-shell >= 45~ with gnome-shell < 46~) +Recommends: gnome-extensions-app + +%description +This extension brings back the app menu in the top panel, for GNOME 45 and later. + +%prep +%autosetup -n appmenu-is-back-%{version} + +%install +install -Dm644 metadata.json %{buildroot}%{_datadir}/gnome-shell/extensions/%{uuid}/metadata.json +install -Dm644 extension.js %{buildroot}%{_datadir}/gnome-shell/extensions/%{uuid}/extension.js + +%files +%license LICENSE +%{_datadir}/gnome-shell/extensions/%{uuid} + +%changelog +* Thu Nov 16 2023 Lleyton Gray - 2-1 +- Initial Release diff --git a/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/update.rhai b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/update.rhai new file mode 100644 index 0000000000..56ea942c51 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-appmenu-is-back/update.rhai @@ -0,0 +1,2 @@ +let version = find("v(.+)", gh("fthx/appmenu-is-back"), 1); +rpm.version(version); diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/0001-Remove-schema-handling-from-transpile.sh.patch b/anda/desktops/gnome/gnome-shell-extension-pop-shell/0001-Remove-schema-handling-from-transpile.sh.patch new file mode 100644 index 0000000000..eb41bed4d5 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/0001-Remove-schema-handling-from-transpile.sh.patch @@ -0,0 +1,34 @@ +From 3f8b19139bf3f13b4285fd9d949cb5460a0909df Mon Sep 17 00:00:00 2001 +From: Carl George +Date: Fri, 25 Jun 2021 22:26:50 -0500 +Subject: [PATCH] Remove schema handling from transpile.sh + +--- + scripts/transpile.sh | 4 +--- + 1 file changed, 1 insertion(+), 3 deletions(-) + +diff --git a/scripts/transpile.sh b/scripts/transpile.sh +index e619a8c..8977c29 100755 +--- a/scripts/transpile.sh ++++ b/scripts/transpile.sh +@@ -15,8 +15,6 @@ transpile() { + + rm -rf _build + +-glib-compile-schemas schemas & +- + # Transpile to JavaScript + + for proj in ${PROJECTS}; do +@@ -30,7 +28,7 @@ wait + + # Convert JS to GJS-compatible scripts + +-cp -r metadata.json icons schemas *.css _build & ++cp -r metadata.json icons *.css _build & + + for src in $(find target -name '*.js'); do + dest=$(echo "$src" | sed s#target#_build#g) +-- +2.31.1 + diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.desktop.wm.keybindings.pop-shell.gschema.override b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.desktop.wm.keybindings.pop-shell.gschema.override new file mode 100644 index 0000000000..ca2303ab0d --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.desktop.wm.keybindings.pop-shell.gschema.override @@ -0,0 +1,18 @@ +[org.gnome.desktop.wm.keybindings] +close = ['F4', 'q'] +maximize = [] +minimize = [] +move-to-monitor-down = [] +move-to-monitor-left = [] +move-to-monitor-right = [] +move-to-monitor-up = [] +move-to-workspace-down = [] +move-to-workspace-left = [] +move-to-workspace-right = [] +move-to-workspace-up = [] +switch-to-workspace-down = ['Down', 'KP_Down', 'j'] +switch-to-workspace-left = [] +switch-to-workspace-right = [] +switch-to-workspace-up = ['Up', 'KP_Up', 'k'] +toggle-maximized = ['m'] +unmaximize = [] diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.pop-shell.gschema.override b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.pop-shell.gschema.override new file mode 100644 index 0000000000..4238624854 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.pop-shell.gschema.override @@ -0,0 +1,7 @@ +[org.gnome.mutter:GNOME] +attach-modal-dialogs = false +workspaces-only-on-primary = false + +[org.gnome.mutter.keybindings] +toggle-tiled-left = ['Left', 'KP_Left', 'h'] +toggle-tiled-right = ['Right', 'KP_Right', 'l'] diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.wayland.pop-shell.gschema.override b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.wayland.pop-shell.gschema.override new file mode 100644 index 0000000000..18566ed983 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.mutter.wayland.pop-shell.gschema.override @@ -0,0 +1,2 @@ +[org.gnome.mutter.wayland.keybindings] +restore-shortcuts = [] diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.settings-daemon.plugins.media-keys.pop-shell.gschema.override b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.settings-daemon.plugins.media-keys.pop-shell.gschema.override new file mode 100644 index 0000000000..bee7aa9219 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.settings-daemon.plugins.media-keys.pop-shell.gschema.override @@ -0,0 +1,6 @@ +[org.gnome.settings-daemon.plugins.media-keys] +email = ['e'] +home = ['f'] +screensaver = ['Escape'] +www = ['b'] +rotate-video-lock-static = ['XF86RotationLockToggle'] diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.shell.pop-shell.gschema.override b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.shell.pop-shell.gschema.override new file mode 100644 index 0000000000..03ba5c5f8b --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/50_org.gnome.shell.pop-shell.gschema.override @@ -0,0 +1,18 @@ +[org.gnome.shell.keybindings] +open-application-menu = [] +shift-overview-down = [] +shift-overview-up = [] +switch-to-application-1 = [] +switch-to-application-2 = [] +switch-to-application-3 = [] +switch-to-application-4 = [] +switch-to-application-5 = [] +switch-to-application-6 = [] +switch-to-application-7 = [] +switch-to-application-8 = [] +switch-to-application-9 = [] +toggle-message-tray = ['v'] + +[org.gnome.shell.overrides] +attach-modal-dialogs = false +workspaces-only-on-primary = false diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/anda.hcl b/anda/desktops/gnome/gnome-shell-extension-pop-shell/anda.hcl new file mode 100644 index 0000000000..8acef3b5c2 --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/anda.hcl @@ -0,0 +1,8 @@ +project pkg { + rpm { + spec = "terra-gnome-shell-extension-pop-shell.spec" + } + labels { + nightly = "1" + } +} diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/terra-gnome-shell-extension-pop-shell.spec b/anda/desktops/gnome/gnome-shell-extension-pop-shell/terra-gnome-shell-extension-pop-shell.spec new file mode 100644 index 0000000000..aea3bb6e3b --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/terra-gnome-shell-extension-pop-shell.spec @@ -0,0 +1,89 @@ +# from Fedora upstream +%global extension pop-shell +%global uuid %{extension}@system76.com +%global commit cf3c932b55d5c247906efe9d81f988ee092d9f51 +%global shortcommit %{lua:print(macros.commit:sub(1,7))} +%global ver 1.2.0 + +Name: terra-gnome-shell-extension-%{extension} +Version: %{ver}^%{shortcommit} +Release: 1%?dist +Summary: GNOME Shell extension for advanced tiling window management +License: GPL-3.0-only +URL: https://github.com/pop-os/shell +BuildArch: noarch + +Source0: %{url}/archive/%{commit}/%{extension}-%{shortcommit}.tar.gz +Source1: 50_org.gnome.desktop.wm.keybindings.%{extension}.gschema.override +Source2: 50_org.gnome.mutter.%{extension}.gschema.override +Source3: 50_org.gnome.mutter.wayland.%{extension}.gschema.override +Source4: 50_org.gnome.settings-daemon.plugins.media-keys.%{extension}.gschema.override +Source5: 50_org.gnome.shell.%{extension}.gschema.override +# downstream-only +Patch0: 0001-Remove-schema-handling-from-transpile.sh.patch + +BuildRequires: typescript >= 3.8 +BuildRequires: make + +Requires: (gnome-shell >= 45~ with gnome-shell < 46~) +Recommends: gnome-extensions-app +Recommends: %{name}-shortcut-overrides = %{version}-%{release} +Provides: %{extension} = %{version}-%{release} + + +%description +Pop Shell is a keyboard-driven layer for GNOME Shell which allows for quick and +sensible navigation and management of windows. The core feature of Pop Shell +is the addition of advanced tiling window management - a feature that has been +highly sought within our community. For many - ourselves included - i3wm has +become the leading competitor to the GNOME desktop. + + +%package shortcut-overrides +Summary: Shortcut overrides for %{name} + + +%description shortcut-overrides +Shortcut overrides for %{name}. + + +%prep +%autosetup -p 1 -n shell-%{commit} + + +%build +%make_build compile + + +%install +# install main extension files +%make_install + +# install the schema file +install -D -p -m 0644 \ + schemas/org.gnome.shell.extensions.%{extension}.gschema.xml \ + %{buildroot}%{_datadir}/glib-2.0/schemas/org.gnome.shell.extensions.%{extension}.gschema.xml + +# install the gnome-control-center keybindings +install -d -m 0755 %{buildroot}%{_datadir}/gnome-control-center/keybindings +install -p -m 0644 keybindings/*.xml %{buildroot}%{_datadir}/gnome-control-center/keybindings/ + +# install the schema override files +install -d -m 0755 %{buildroot}%{_datadir}/glib-2.0/schemas +install -p -m 0644 %{S:1} %{S:2} %{S:3} %{S:4} %{S:5} %{buildroot}%{_datadir}/glib-2.0/schemas/ + + +%files +%license LICENSE +%doc README.md +%{_datadir}/gnome-shell/extensions/%{uuid} +%{_datadir}/glib-2.0/schemas/org.gnome.shell.extensions.%{extension}.gschema.xml +%{_datadir}/gnome-control-center/keybindings/*.xml + + +%files shortcut-overrides +%{_datadir}/glib-2.0/schemas/*.%{extension}.gschema.override + + +%changelog +%autochangelog diff --git a/anda/desktops/gnome/gnome-shell-extension-pop-shell/update.rhai b/anda/desktops/gnome/gnome-shell-extension-pop-shell/update.rhai new file mode 100644 index 0000000000..5c4ac207fe --- /dev/null +++ b/anda/desktops/gnome/gnome-shell-extension-pop-shell/update.rhai @@ -0,0 +1,4 @@ +if filters.contains("nightly") { + rpm.global("commit", get("https://api.github.com/repos/pop-os/shell/commits/HEAD").json().sha); + rpm.global("ver", gh("pop-os/shell")); +} diff --git a/anda/desktops/kde/latte-dock-nightly/latte-dock-nightly.spec b/anda/desktops/kde/latte-dock-nightly/latte-dock-nightly.spec index 0ca9dc84db..2334eb4d8c 100644 --- a/anda/desktops/kde/latte-dock-nightly/latte-dock-nightly.spec +++ b/anda/desktops/kde/latte-dock-nightly/latte-dock-nightly.spec @@ -1,6 +1,6 @@ %global forgeurl https://github.com/KDE/latte-dock/ -%global commit 755676d75272b51202bf31409ee013bc612a7f69 +%global commit df36844edd1924d835d414f4a61102677dc7187e %global shortcommit %(c=%{commit}; echo ${c:0:7}) %global commit_date %(date '+%Y%m%d') %global snapshot_info %{commit_date}.%{shortcommit} diff --git a/anda/lib/frame/anda.hcl b/anda/desktops/lomiri-unity/frame/anda.hcl similarity index 100% rename from anda/lib/frame/anda.hcl rename to anda/desktops/lomiri-unity/frame/anda.hcl diff --git a/anda/lib/frame/frame.spec b/anda/desktops/lomiri-unity/frame/frame.spec similarity index 100% rename from anda/lib/frame/frame.spec rename to anda/desktops/lomiri-unity/frame/frame.spec diff --git a/anda/lib/frame/update.rhai b/anda/desktops/lomiri-unity/frame/update.rhai similarity index 100% rename from anda/lib/frame/update.rhai rename to anda/desktops/lomiri-unity/frame/update.rhai diff --git a/anda/lib/geis/anda.hcl b/anda/desktops/lomiri-unity/geis/anda.hcl similarity index 100% rename from anda/lib/geis/anda.hcl rename to anda/desktops/lomiri-unity/geis/anda.hcl diff --git a/anda/lib/geis/geis.spec b/anda/desktops/lomiri-unity/geis/geis.spec similarity index 100% rename from anda/lib/geis/geis.spec rename to anda/desktops/lomiri-unity/geis/geis.spec diff --git a/anda/lib/geis/update.rhai b/anda/desktops/lomiri-unity/geis/update.rhai similarity index 100% rename from anda/lib/geis/update.rhai rename to anda/desktops/lomiri-unity/geis/update.rhai diff --git a/anda/lib/gsettings-qt-lomiri/anda.hcl b/anda/desktops/lomiri-unity/gsettings-qt-lomiri/anda.hcl similarity index 100% rename from anda/lib/gsettings-qt-lomiri/anda.hcl rename to anda/desktops/lomiri-unity/gsettings-qt-lomiri/anda.hcl diff --git a/anda/lib/gsettings-qt-lomiri/gsettings-qt-lomiri.spec b/anda/desktops/lomiri-unity/gsettings-qt-lomiri/gsettings-qt-lomiri.spec similarity index 100% rename from anda/lib/gsettings-qt-lomiri/gsettings-qt-lomiri.spec rename to anda/desktops/lomiri-unity/gsettings-qt-lomiri/gsettings-qt-lomiri.spec diff --git a/anda/lib/libunity-misc/anda.hcl b/anda/desktops/lomiri-unity/libunity-misc/anda.hcl similarity index 100% rename from anda/lib/libunity-misc/anda.hcl rename to anda/desktops/lomiri-unity/libunity-misc/anda.hcl diff --git a/anda/lib/libunity-misc/libunity-misc.spec b/anda/desktops/lomiri-unity/libunity-misc/libunity-misc.spec similarity index 100% rename from anda/lib/libunity-misc/libunity-misc.spec rename to anda/desktops/lomiri-unity/libunity-misc/libunity-misc.spec diff --git a/anda/lib/lomiri-api/anda.hcl b/anda/desktops/lomiri-unity/lomiri-api/anda.hcl similarity index 100% rename from anda/lib/lomiri-api/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-api/anda.hcl diff --git a/anda/lib/lomiri-api/lomiri-api.spec b/anda/desktops/lomiri-unity/lomiri-api/lomiri-api.spec similarity index 100% rename from anda/lib/lomiri-api/lomiri-api.spec rename to anda/desktops/lomiri-unity/lomiri-api/lomiri-api.spec diff --git a/anda/lib/lomiri-api/update.rhai b/anda/desktops/lomiri-unity/lomiri-api/update.rhai similarity index 100% rename from anda/lib/lomiri-api/update.rhai rename to anda/desktops/lomiri-unity/lomiri-api/update.rhai diff --git a/anda/lib/lomiri-app-launch/anda.hcl b/anda/desktops/lomiri-unity/lomiri-app-launch/anda.hcl similarity index 100% rename from anda/lib/lomiri-app-launch/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-app-launch/anda.hcl diff --git a/anda/lib/lomiri-app-launch/lomiri-app-launch.spec b/anda/desktops/lomiri-unity/lomiri-app-launch/lomiri-app-launch.spec similarity index 97% rename from anda/lib/lomiri-app-launch/lomiri-app-launch.spec rename to anda/desktops/lomiri-unity/lomiri-app-launch/lomiri-app-launch.spec index 3420f74c0e..3caa745e7d 100644 --- a/anda/lib/lomiri-app-launch/lomiri-app-launch.spec +++ b/anda/desktops/lomiri-unity/lomiri-app-launch/lomiri-app-launch.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-app-launch -%global commit fc4bfff014a3b83640d0fca787aeefc84c055614 +%global commit 1a7a0ef6a8ab966b664f3515aba539b422f35849 %forgemeta Name: lomiri-app-launch diff --git a/anda/lib/lomiri-app-launch/update.rhai b/anda/desktops/lomiri-unity/lomiri-app-launch/update.rhai similarity index 100% rename from anda/lib/lomiri-app-launch/update.rhai rename to anda/desktops/lomiri-unity/lomiri-app-launch/update.rhai diff --git a/anda/lib/lomiri-download-manager/anda.hcl b/anda/desktops/lomiri-unity/lomiri-download-manager/anda.hcl similarity index 100% rename from anda/lib/lomiri-download-manager/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-download-manager/anda.hcl diff --git a/anda/lib/lomiri-download-manager/lomiri-download-manager.spec b/anda/desktops/lomiri-unity/lomiri-download-manager/lomiri-download-manager.spec similarity index 100% rename from anda/lib/lomiri-download-manager/lomiri-download-manager.spec rename to anda/desktops/lomiri-unity/lomiri-download-manager/lomiri-download-manager.spec diff --git a/anda/lib/lomiri-indicator-network/anda.hcl b/anda/desktops/lomiri-unity/lomiri-indicator-network/anda.hcl similarity index 100% rename from anda/lib/lomiri-indicator-network/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-indicator-network/anda.hcl diff --git a/anda/lib/lomiri-indicator-network/lomiri-indicator-network.spec b/anda/desktops/lomiri-unity/lomiri-indicator-network/lomiri-indicator-network.spec similarity index 97% rename from anda/lib/lomiri-indicator-network/lomiri-indicator-network.spec rename to anda/desktops/lomiri-unity/lomiri-indicator-network/lomiri-indicator-network.spec index 768f6eb8f7..1766b5074b 100644 --- a/anda/lib/lomiri-indicator-network/lomiri-indicator-network.spec +++ b/anda/desktops/lomiri-unity/lomiri-indicator-network/lomiri-indicator-network.spec @@ -1,9 +1,9 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-indicator-network -%global commit ac0ae8ec8968c934f81c2664879ab10f76ab0fc2 +%global commit 7d0fd44108cfb74da3fcb26e7de07f7610302f5c %forgemeta Name: lomiri-indicator-network -Version: 1.0.0 +Version: 1.0.1 Release: %autorelease Summary: The Network indicator for Ubuntu Touch License: GPL-3.0 AND LGPL-3.0 diff --git a/anda/desktops/lomiri-unity/lomiri-indicator-network/update.rhai b/anda/desktops/lomiri-unity/lomiri-indicator-network/update.rhai new file mode 100644 index 0000000000..297a4e1eeb --- /dev/null +++ b/anda/desktops/lomiri-unity/lomiri-indicator-network/update.rhai @@ -0,0 +1,7 @@ +let o = get("https://gitlab.com/api/v4/projects/31038307/repository/tags").json_arr()[0]; +let f = rpm.f; +rpm.version(o.name); +// check if changed +if rpm.f != f { + rpm.global("commit", o.commit.id); +} diff --git a/anda/others/lomiri-schemas/anda.hcl b/anda/desktops/lomiri-unity/lomiri-schemas/anda.hcl similarity index 100% rename from anda/others/lomiri-schemas/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-schemas/anda.hcl diff --git a/anda/others/lomiri-schemas/com.lomiri.Shell.gschema.xml b/anda/desktops/lomiri-unity/lomiri-schemas/com.lomiri.Shell.gschema.xml similarity index 100% rename from anda/others/lomiri-schemas/com.lomiri.Shell.gschema.xml rename to anda/desktops/lomiri-unity/lomiri-schemas/com.lomiri.Shell.gschema.xml diff --git a/anda/others/lomiri-schemas/lomiri-schemas.spec b/anda/desktops/lomiri-unity/lomiri-schemas/lomiri-schemas.spec similarity index 100% rename from anda/others/lomiri-schemas/lomiri-schemas.spec rename to anda/desktops/lomiri-unity/lomiri-schemas/lomiri-schemas.spec diff --git a/anda/others/lomiri-schemas/update.rhai b/anda/desktops/lomiri-unity/lomiri-schemas/update.rhai similarity index 100% rename from anda/others/lomiri-schemas/update.rhai rename to anda/desktops/lomiri-unity/lomiri-schemas/update.rhai diff --git a/anda/others/lomiri-session/anda.hcl b/anda/desktops/lomiri-unity/lomiri-session/anda.hcl similarity index 100% rename from anda/others/lomiri-session/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-session/anda.hcl diff --git a/anda/others/lomiri-session/lomiri-session.spec b/anda/desktops/lomiri-unity/lomiri-session/lomiri-session.spec similarity index 100% rename from anda/others/lomiri-session/lomiri-session.spec rename to anda/desktops/lomiri-unity/lomiri-session/lomiri-session.spec diff --git a/anda/lib/lomiri-settings-components/anda.hcl b/anda/desktops/lomiri-unity/lomiri-settings-components/anda.hcl similarity index 100% rename from anda/lib/lomiri-settings-components/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-settings-components/anda.hcl diff --git a/anda/lib/lomiri-settings-components/lomiri-settings-components.spec b/anda/desktops/lomiri-unity/lomiri-settings-components/lomiri-settings-components.spec similarity index 93% rename from anda/lib/lomiri-settings-components/lomiri-settings-components.spec rename to anda/desktops/lomiri-unity/lomiri-settings-components/lomiri-settings-components.spec index 83431340f8..00cbb0027c 100644 --- a/anda/lib/lomiri-settings-components/lomiri-settings-components.spec +++ b/anda/desktops/lomiri-unity/lomiri-settings-components/lomiri-settings-components.spec @@ -1,9 +1,9 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-settings-components -%global commit 5041243d56fb7aaab270b4d07284687ec33f75c6 +%global commit a2ce1155d385218a4b493f801867a45d2a41df02 %forgemeta Name: lomiri-settings-components -Version: 1.0.1 +Version: 1.1.0 Release: %autorelease Summary: The system settings components for Lomiri License: GPLv3 AND LGPLv3 diff --git a/anda/desktops/lomiri-unity/lomiri-settings-components/update.rhai b/anda/desktops/lomiri-unity/lomiri-settings-components/update.rhai new file mode 100644 index 0000000000..a58f909140 --- /dev/null +++ b/anda/desktops/lomiri-unity/lomiri-settings-components/update.rhai @@ -0,0 +1,7 @@ +let o = get("https://gitlab.com/api/v4/projects/25770169/repository/tags").json_arr()[0]; +let f = rpm.f; +rpm.version(o.name); +// check if changed +if rpm.f != f { + rpm.global("commit", o.commit.id); +} diff --git a/anda/others/lomiri-sounds/anda.hcl b/anda/desktops/lomiri-unity/lomiri-sounds/anda.hcl similarity index 100% rename from anda/others/lomiri-sounds/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-sounds/anda.hcl diff --git a/anda/others/lomiri-sounds/lomiri-sounds.spec b/anda/desktops/lomiri-unity/lomiri-sounds/lomiri-sounds.spec similarity index 100% rename from anda/others/lomiri-sounds/lomiri-sounds.spec rename to anda/desktops/lomiri-unity/lomiri-sounds/lomiri-sounds.spec diff --git a/anda/apps/lomiri-system-settings/anda.hcl b/anda/desktops/lomiri-unity/lomiri-system-settings/anda.hcl similarity index 100% rename from anda/apps/lomiri-system-settings/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-system-settings/anda.hcl diff --git a/anda/apps/lomiri-system-settings/lomiri-system-settings.spec b/anda/desktops/lomiri-unity/lomiri-system-settings/lomiri-system-settings.spec similarity index 98% rename from anda/apps/lomiri-system-settings/lomiri-system-settings.spec rename to anda/desktops/lomiri-unity/lomiri-system-settings/lomiri-system-settings.spec index 44f7e9c29e..ad7d0943a4 100644 --- a/anda/apps/lomiri-system-settings/lomiri-system-settings.spec +++ b/anda/desktops/lomiri-unity/lomiri-system-settings/lomiri-system-settings.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-system-settings -%global commit 87ffe4bf29b3b220f66e34611f381e0d15054a89 +%global commit 2abbbdaedf243fc1629628b6c1ba764db4253840 %forgemeta Name: lomiri-system-settings diff --git a/anda/apps/lomiri-system-settings/update.rhai b/anda/desktops/lomiri-unity/lomiri-system-settings/update.rhai similarity index 100% rename from anda/apps/lomiri-system-settings/update.rhai rename to anda/desktops/lomiri-unity/lomiri-system-settings/update.rhai diff --git a/anda/lib/lomiri-ui-toolkit/anda.hcl b/anda/desktops/lomiri-unity/lomiri-ui-toolkit/anda.hcl similarity index 100% rename from anda/lib/lomiri-ui-toolkit/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-ui-toolkit/anda.hcl diff --git a/anda/lib/lomiri-ui-toolkit/lomiri-ui-toolkit.spec b/anda/desktops/lomiri-unity/lomiri-ui-toolkit/lomiri-ui-toolkit.spec similarity index 98% rename from anda/lib/lomiri-ui-toolkit/lomiri-ui-toolkit.spec rename to anda/desktops/lomiri-unity/lomiri-ui-toolkit/lomiri-ui-toolkit.spec index 4b84a4a3a1..3a98295ef1 100644 --- a/anda/lib/lomiri-ui-toolkit/lomiri-ui-toolkit.spec +++ b/anda/desktops/lomiri-unity/lomiri-ui-toolkit/lomiri-ui-toolkit.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-ui-toolkit -%global commit c8062dca48c6ce3fc26a243f0641e4f0ed4b6e3a +%global commit d09e76d2b3040b6d23fc42c6114db81332298c8e %forgemeta Name: lomiri-ui-toolkit diff --git a/anda/lib/lomiri-ui-toolkit/update.rhai b/anda/desktops/lomiri-unity/lomiri-ui-toolkit/update.rhai similarity index 100% rename from anda/lib/lomiri-ui-toolkit/update.rhai rename to anda/desktops/lomiri-unity/lomiri-ui-toolkit/update.rhai diff --git a/anda/lib/lomiri-url-dispatcher/anda.hcl b/anda/desktops/lomiri-unity/lomiri-url-dispatcher/anda.hcl similarity index 100% rename from anda/lib/lomiri-url-dispatcher/anda.hcl rename to anda/desktops/lomiri-unity/lomiri-url-dispatcher/anda.hcl diff --git a/anda/lib/lomiri-url-dispatcher/lomiri-url-dispatcher.spec b/anda/desktops/lomiri-unity/lomiri-url-dispatcher/lomiri-url-dispatcher.spec similarity index 98% rename from anda/lib/lomiri-url-dispatcher/lomiri-url-dispatcher.spec rename to anda/desktops/lomiri-unity/lomiri-url-dispatcher/lomiri-url-dispatcher.spec index bda29ec7d1..8181cc05ce 100644 --- a/anda/lib/lomiri-url-dispatcher/lomiri-url-dispatcher.spec +++ b/anda/desktops/lomiri-unity/lomiri-url-dispatcher/lomiri-url-dispatcher.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri-url-dispatcher -%global commit 1ac312239a088e5a797b786a22bec42cb0037039 +%global commit 6b6f2277e2a63fe0893c1fddd1cc75da5da87eb7 %forgemeta Name: lomiri-url-dispatcher diff --git a/anda/lib/lomiri-url-dispatcher/update.rhai b/anda/desktops/lomiri-unity/lomiri-url-dispatcher/update.rhai similarity index 100% rename from anda/lib/lomiri-url-dispatcher/update.rhai rename to anda/desktops/lomiri-unity/lomiri-url-dispatcher/update.rhai diff --git a/anda/desktops/lomiri/0001-Add-support-for-both-older-qtmir-and-newer-qtmir-wit.patch b/anda/desktops/lomiri-unity/lomiri/0001-Add-support-for-both-older-qtmir-and-newer-qtmir-wit.patch similarity index 100% rename from anda/desktops/lomiri/0001-Add-support-for-both-older-qtmir-and-newer-qtmir-wit.patch rename to anda/desktops/lomiri-unity/lomiri/0001-Add-support-for-both-older-qtmir-and-newer-qtmir-wit.patch diff --git a/anda/desktops/lomiri/anda.hcl b/anda/desktops/lomiri-unity/lomiri/anda.hcl similarity index 100% rename from anda/desktops/lomiri/anda.hcl rename to anda/desktops/lomiri-unity/lomiri/anda.hcl diff --git a/anda/desktops/lomiri/lomiri.spec b/anda/desktops/lomiri-unity/lomiri/lomiri.spec similarity index 99% rename from anda/desktops/lomiri/lomiri.spec rename to anda/desktops/lomiri-unity/lomiri/lomiri.spec index 0385bc0161..5867c7234a 100644 --- a/anda/desktops/lomiri/lomiri.spec +++ b/anda/desktops/lomiri-unity/lomiri/lomiri.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/ubports/development/core/lomiri -%global commit de472d04a682e1dc3d317c94b08a14facdf673e7 +%global commit ec65759f56e7eba4f084ecf031bde5d64da1cf35 %forgemeta Name: lomiri diff --git a/anda/desktops/lomiri/update.rhai b/anda/desktops/lomiri-unity/lomiri/update.rhai similarity index 100% rename from anda/desktops/lomiri/update.rhai rename to anda/desktops/lomiri-unity/lomiri/update.rhai diff --git a/anda/lib/nux/anda.hcl b/anda/desktops/lomiri-unity/nux/anda.hcl similarity index 100% rename from anda/lib/nux/anda.hcl rename to anda/desktops/lomiri-unity/nux/anda.hcl diff --git a/anda/lib/nux/nux.spec b/anda/desktops/lomiri-unity/nux/nux.spec similarity index 100% rename from anda/lib/nux/nux.spec rename to anda/desktops/lomiri-unity/nux/nux.spec diff --git a/anda/lib/qtmir/anda.hcl b/anda/desktops/lomiri-unity/qtmir/anda.hcl similarity index 100% rename from anda/lib/qtmir/anda.hcl rename to anda/desktops/lomiri-unity/qtmir/anda.hcl diff --git a/anda/lib/qtmir/qtmir.spec b/anda/desktops/lomiri-unity/qtmir/qtmir.spec similarity index 100% rename from anda/lib/qtmir/qtmir.spec rename to anda/desktops/lomiri-unity/qtmir/qtmir.spec diff --git a/anda/others/unity-greeter/0001-Remove-libido.patch b/anda/desktops/lomiri-unity/unity-greeter/0001-Remove-libido.patch similarity index 100% rename from anda/others/unity-greeter/0001-Remove-libido.patch rename to anda/desktops/lomiri-unity/unity-greeter/0001-Remove-libido.patch diff --git a/anda/others/unity-greeter/anda.hcl b/anda/desktops/lomiri-unity/unity-greeter/anda.hcl similarity index 100% rename from anda/others/unity-greeter/anda.hcl rename to anda/desktops/lomiri-unity/unity-greeter/anda.hcl diff --git a/anda/others/unity-greeter/unity-greeter.spec b/anda/desktops/lomiri-unity/unity-greeter/unity-greeter.spec similarity index 100% rename from anda/others/unity-greeter/unity-greeter.spec rename to anda/desktops/lomiri-unity/unity-greeter/unity-greeter.spec diff --git a/anda/others/unity-greeter/update.rhai b/anda/desktops/lomiri-unity/unity-greeter/update.rhai similarity index 100% rename from anda/others/unity-greeter/update.rhai rename to anda/desktops/lomiri-unity/unity-greeter/update.rhai diff --git a/anda/others/unity-scope-home/anda.hcl b/anda/desktops/lomiri-unity/unity-scope-home/anda.hcl similarity index 100% rename from anda/others/unity-scope-home/anda.hcl rename to anda/desktops/lomiri-unity/unity-scope-home/anda.hcl diff --git a/anda/others/unity-scope-home/unity-scope-home.spec b/anda/desktops/lomiri-unity/unity-scope-home/unity-scope-home.spec similarity index 100% rename from anda/others/unity-scope-home/unity-scope-home.spec rename to anda/desktops/lomiri-unity/unity-scope-home/unity-scope-home.spec diff --git a/anda/others/unity-session/anda.hcl b/anda/desktops/lomiri-unity/unity-session/anda.hcl similarity index 100% rename from anda/others/unity-session/anda.hcl rename to anda/desktops/lomiri-unity/unity-session/anda.hcl diff --git a/anda/others/unity-session/unity-session.spec b/anda/desktops/lomiri-unity/unity-session/unity-session.spec similarity index 100% rename from anda/others/unity-session/unity-session.spec rename to anda/desktops/lomiri-unity/unity-session/unity-session.spec diff --git a/anda/others/unity-session/update.rhai b/anda/desktops/lomiri-unity/unity-session/update.rhai similarity index 100% rename from anda/others/unity-session/update.rhai rename to anda/desktops/lomiri-unity/unity-session/update.rhai diff --git a/anda/lib/unity-settings-daemon/anda.hcl b/anda/desktops/lomiri-unity/unity-settings-daemon/anda.hcl similarity index 100% rename from anda/lib/unity-settings-daemon/anda.hcl rename to anda/desktops/lomiri-unity/unity-settings-daemon/anda.hcl diff --git a/anda/lib/unity-settings-daemon/unity-settings-daemon.1 b/anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.1 similarity index 100% rename from anda/lib/unity-settings-daemon/unity-settings-daemon.1 rename to anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.1 diff --git a/anda/lib/unity-settings-daemon/unity-settings-daemon.service b/anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.service similarity index 100% rename from anda/lib/unity-settings-daemon/unity-settings-daemon.service rename to anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.service diff --git a/anda/lib/unity-settings-daemon/unity-settings-daemon.spec b/anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.spec similarity index 100% rename from anda/lib/unity-settings-daemon/unity-settings-daemon.spec rename to anda/desktops/lomiri-unity/unity-settings-daemon/unity-settings-daemon.spec diff --git a/anda/desktops/unity-shell/0001-Remove-xpathselect-dependency.patch b/anda/desktops/lomiri-unity/unity-shell/0001-Remove-xpathselect-dependency.patch similarity index 100% rename from anda/desktops/unity-shell/0001-Remove-xpathselect-dependency.patch rename to anda/desktops/lomiri-unity/unity-shell/0001-Remove-xpathselect-dependency.patch diff --git a/anda/desktops/unity-shell/0002-Remove-ido-dependency.patch b/anda/desktops/lomiri-unity/unity-shell/0002-Remove-ido-dependency.patch similarity index 100% rename from anda/desktops/unity-shell/0002-Remove-ido-dependency.patch rename to anda/desktops/lomiri-unity/unity-shell/0002-Remove-ido-dependency.patch diff --git a/anda/desktops/unity-shell/0003-Remove-social-scope.patch b/anda/desktops/lomiri-unity/unity-shell/0003-Remove-social-scope.patch similarity index 100% rename from anda/desktops/unity-shell/0003-Remove-social-scope.patch rename to anda/desktops/lomiri-unity/unity-shell/0003-Remove-social-scope.patch diff --git a/anda/desktops/unity-shell/anda.hcl b/anda/desktops/lomiri-unity/unity-shell/anda.hcl similarity index 100% rename from anda/desktops/unity-shell/anda.hcl rename to anda/desktops/lomiri-unity/unity-shell/anda.hcl diff --git a/anda/desktops/unity-shell/unity-shell.spec b/anda/desktops/lomiri-unity/unity-shell/unity-shell.spec similarity index 99% rename from anda/desktops/unity-shell/unity-shell.spec rename to anda/desktops/lomiri-unity/unity-shell/unity-shell.spec index 47f233e22b..ebe040278a 100644 --- a/anda/desktops/unity-shell/unity-shell.spec +++ b/anda/desktops/lomiri-unity/unity-shell/unity-shell.spec @@ -2,7 +2,7 @@ Name: unity-shell Version: 7.7.0 -Release: %autorelease +Release: 1%?dist Summary: Unity is a shell that sings License: GPL-3.0-or-later diff --git a/anda/desktops/unity-shell/update.rhai b/anda/desktops/lomiri-unity/unity-shell/update.rhai similarity index 100% rename from anda/desktops/unity-shell/update.rhai rename to anda/desktops/lomiri-unity/unity-shell/update.rhai diff --git a/anda/desktops/unityx-shell/0001-Remove-social-scope.patch b/anda/desktops/lomiri-unity/unityx-shell/0001-Remove-social-scope.patch similarity index 100% rename from anda/desktops/unityx-shell/0001-Remove-social-scope.patch rename to anda/desktops/lomiri-unity/unityx-shell/0001-Remove-social-scope.patch diff --git a/anda/desktops/unityx-shell/anda.hcl b/anda/desktops/lomiri-unity/unityx-shell/anda.hcl similarity index 100% rename from anda/desktops/unityx-shell/anda.hcl rename to anda/desktops/lomiri-unity/unityx-shell/anda.hcl diff --git a/anda/desktops/unityx-shell/unityx-shell.spec b/anda/desktops/lomiri-unity/unityx-shell/unityx-shell.spec similarity index 99% rename from anda/desktops/unityx-shell/unityx-shell.spec rename to anda/desktops/lomiri-unity/unityx-shell/unityx-shell.spec index 2c52fd5bac..08f800c1ac 100644 --- a/anda/desktops/unityx-shell/unityx-shell.spec +++ b/anda/desktops/lomiri-unity/unityx-shell/unityx-shell.spec @@ -6,7 +6,7 @@ Name: unityx-shell Version: 1.7.7 -Release: 2%?dist +Release: 1%?dist Summary: UnityX is a smaller shell based on Unity7 License: GPL-3.0 AND LGPL-3.0 diff --git a/anda/lib/ayatana-indicator-datetime/anda.hcl b/anda/desktops/mate/indicators/datetime/anda.hcl similarity index 100% rename from anda/lib/ayatana-indicator-datetime/anda.hcl rename to anda/desktops/mate/indicators/datetime/anda.hcl diff --git a/anda/lib/ayatana-indicator-datetime/ayatana-indicator-datetime.spec b/anda/desktops/mate/indicators/datetime/ayatana-indicator-datetime.spec similarity index 100% rename from anda/lib/ayatana-indicator-datetime/ayatana-indicator-datetime.spec rename to anda/desktops/mate/indicators/datetime/ayatana-indicator-datetime.spec diff --git a/anda/lib/ayatana-indicator-datetime/update.rhai b/anda/desktops/mate/indicators/datetime/update.rhai similarity index 100% rename from anda/lib/ayatana-indicator-datetime/update.rhai rename to anda/desktops/mate/indicators/datetime/update.rhai diff --git a/anda/lib/ayatana-indicator-messages/anda.hcl b/anda/desktops/mate/indicators/messages/anda.hcl similarity index 100% rename from anda/lib/ayatana-indicator-messages/anda.hcl rename to anda/desktops/mate/indicators/messages/anda.hcl diff --git a/anda/lib/ayatana-indicator-messages/ayatana-indicator-messages.spec b/anda/desktops/mate/indicators/messages/ayatana-indicator-messages.spec similarity index 100% rename from anda/lib/ayatana-indicator-messages/ayatana-indicator-messages.spec rename to anda/desktops/mate/indicators/messages/ayatana-indicator-messages.spec diff --git a/anda/lib/ayatana-indicator-messages/update.rhai b/anda/desktops/mate/indicators/messages/update.rhai similarity index 100% rename from anda/lib/ayatana-indicator-messages/update.rhai rename to anda/desktops/mate/indicators/messages/update.rhai diff --git a/anda/indicators/ayatana-indicator-notifications/anda.hcl b/anda/desktops/mate/indicators/notifications/anda.hcl similarity index 100% rename from anda/indicators/ayatana-indicator-notifications/anda.hcl rename to anda/desktops/mate/indicators/notifications/anda.hcl diff --git a/anda/indicators/ayatana-indicator-notifications/ayatana-indicator-notifications.spec b/anda/desktops/mate/indicators/notifications/ayatana-indicator-notifications.spec similarity index 100% rename from anda/indicators/ayatana-indicator-notifications/ayatana-indicator-notifications.spec rename to anda/desktops/mate/indicators/notifications/ayatana-indicator-notifications.spec diff --git a/anda/indicators/ayatana-indicator-notifications/update.rhai b/anda/desktops/mate/indicators/notifications/update.rhai similarity index 100% rename from anda/indicators/ayatana-indicator-notifications/update.rhai rename to anda/desktops/mate/indicators/notifications/update.rhai diff --git a/anda/indicators/ayatana-indicator-session/0001-fix-tests-import-cstdint.patch b/anda/desktops/mate/indicators/session/0001-fix-tests-import-cstdint.patch similarity index 100% rename from anda/indicators/ayatana-indicator-session/0001-fix-tests-import-cstdint.patch rename to anda/desktops/mate/indicators/session/0001-fix-tests-import-cstdint.patch diff --git a/anda/indicators/ayatana-indicator-session/anda.hcl b/anda/desktops/mate/indicators/session/anda.hcl similarity index 100% rename from anda/indicators/ayatana-indicator-session/anda.hcl rename to anda/desktops/mate/indicators/session/anda.hcl diff --git a/anda/indicators/ayatana-indicator-session/ayatana-indicator-session.spec b/anda/desktops/mate/indicators/session/ayatana-indicator-session.spec similarity index 97% rename from anda/indicators/ayatana-indicator-session/ayatana-indicator-session.spec rename to anda/desktops/mate/indicators/session/ayatana-indicator-session.spec index 6f44975ab6..c53dda622d 100644 --- a/anda/indicators/ayatana-indicator-session/ayatana-indicator-session.spec +++ b/anda/desktops/mate/indicators/session/ayatana-indicator-session.spec @@ -1,6 +1,6 @@ Name: ayatana-indicator-session Summary: Ayatana Indicator Session Applet -Version: 23.10.2 +Version: 23.10.3 Release: 1%{?dist} License: GPL-3.0 URL: https://github.com/AyatanaIndicators/ayatana-indicator-session @@ -18,6 +18,7 @@ BuildRequires: pkgconfig(dbustest-1) BuildRequires: pkgconfig(gee-0.8) BuildRequires: pkgconfig(libxml-2.0) BuildRequires: pkgconfig(systemd) +BuildRequires: pkgconfig(rda) BuildRequires: intltool %description diff --git a/anda/indicators/ayatana-indicator-session/update.rhai b/anda/desktops/mate/indicators/session/update.rhai similarity index 100% rename from anda/indicators/ayatana-indicator-session/update.rhai rename to anda/desktops/mate/indicators/session/update.rhai diff --git a/anda/indicators/ayatana-indicator-sound/anda.hcl b/anda/desktops/mate/indicators/sound/anda.hcl similarity index 100% rename from anda/indicators/ayatana-indicator-sound/anda.hcl rename to anda/desktops/mate/indicators/sound/anda.hcl diff --git a/anda/indicators/ayatana-indicator-sound/ayatana-indicator-sound.spec b/anda/desktops/mate/indicators/sound/ayatana-indicator-sound.spec similarity index 100% rename from anda/indicators/ayatana-indicator-sound/ayatana-indicator-sound.spec rename to anda/desktops/mate/indicators/sound/ayatana-indicator-sound.spec diff --git a/anda/indicators/ayatana-indicator-sound/update.rhai b/anda/desktops/mate/indicators/sound/update.rhai similarity index 100% rename from anda/indicators/ayatana-indicator-sound/update.rhai rename to anda/desktops/mate/indicators/sound/update.rhai diff --git a/anda/desktops/mate/tweak/mate-tweak.spec b/anda/desktops/mate/tweak/mate-tweak.spec index 69f0099d3b..3a84b0eea5 100644 --- a/anda/desktops/mate/tweak/mate-tweak.spec +++ b/anda/desktops/mate/tweak/mate-tweak.spec @@ -2,7 +2,7 @@ Name: mate-tweak Version: 22.10.0 -Release: 1%?dist +Release: 2%?dist Summary: Tweak tool for the MATE Desktop License: GPL-2.0 URL: https://github.com/ubuntu-mate/mate-tweak @@ -39,9 +39,9 @@ desktop-file-validate %buildroot%_datadir/applications/*.desktop %_datadir/applications/%name.desktop %_datadir/applications/marco-{glx,no-composite,xr_glx_hybrid,xrender}.desktop %_datadir/polkit-1/actions/org.mate.%name.policy -%ghost %_prefix/lib/python3.11/site-packages/__pycache__ -%ghost %_prefix/lib/python3.11/site-packages/setup.py -%ghost %_prefix/lib/python3.11/site-packages/mate_tweak-%version-py%python3_version.egg-info/ +%ghost %_prefix/lib/python3.*/site-packages/__pycache__ +%ghost %_prefix/lib/python3.*/site-packages/setup.py +%ghost %_prefix/lib/python3.*/site-packages/mate_tweak-%version-py3.*.egg-info/ %changelog %autochangelog diff --git a/anda/tools/blueprint-compiler/anda.hcl b/anda/devs/blueprint-compiler/anda.hcl similarity index 100% rename from anda/tools/blueprint-compiler/anda.hcl rename to anda/devs/blueprint-compiler/anda.hcl diff --git a/anda/tools/blueprint-compiler/terra-blueprint-compiler.spec b/anda/devs/blueprint-compiler/terra-blueprint-compiler.spec similarity index 100% rename from anda/tools/blueprint-compiler/terra-blueprint-compiler.spec rename to anda/devs/blueprint-compiler/terra-blueprint-compiler.spec diff --git a/anda/tools/blueprint-compiler/update.rhai b/anda/devs/blueprint-compiler/update.rhai similarity index 100% rename from anda/tools/blueprint-compiler/update.rhai rename to anda/devs/blueprint-compiler/update.rhai diff --git a/anda/tools/codium/anda.hcl b/anda/devs/codium/anda.hcl similarity index 100% rename from anda/tools/codium/anda.hcl rename to anda/devs/codium/anda.hcl diff --git a/anda/tools/codium/codium.spec b/anda/devs/codium/codium.spec similarity index 99% rename from anda/tools/codium/codium.spec rename to anda/devs/codium/codium.spec index 6989389df8..d0994f4177 100644 --- a/anda/tools/codium/codium.spec +++ b/anda/devs/codium/codium.spec @@ -12,7 +12,7 @@ %endif Name: codium -Version: 1.84.2.23314 +Version: 1.85.1.23348 Release: 1%{?dist} Summary: Code editing. Redefined. License: MIT diff --git a/anda/tools/codium/update.rhai b/anda/devs/codium/update.rhai similarity index 100% rename from anda/tools/codium/update.rhai rename to anda/devs/codium/update.rhai diff --git a/anda/apps/flutter/anda.hcl b/anda/devs/flutter/anda.hcl similarity index 100% rename from anda/apps/flutter/anda.hcl rename to anda/devs/flutter/anda.hcl diff --git a/anda/apps/flutter/flutter.spec b/anda/devs/flutter/flutter.spec similarity index 88% rename from anda/apps/flutter/flutter.spec rename to anda/devs/flutter/flutter.spec index b72cf549fe..0a5f63a086 100644 --- a/anda/apps/flutter/flutter.spec +++ b/anda/devs/flutter/flutter.spec @@ -1,11 +1,12 @@ Name: flutter -Version: 3.16.0.0.5.pre +Version: 3.16.7 Release: 1%{?dist} Summary: SDK for crafting beautiful, fast user experiences from a single codebase License: BSD-3-Clause URL: https://flutter.dev +Group: Development/Building Source0: https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_%version-stable.tar.xz -Requires: bash curl git file which zip xz-utils +Requires: bash curl git file which zip xz Recommends: mesa-libGLU %description diff --git a/anda/apps/flutter/update.rhai b/anda/devs/flutter/update.rhai similarity index 100% rename from anda/apps/flutter/update.rhai rename to anda/devs/flutter/update.rhai diff --git a/anda/rust/neovide/anda.hcl b/anda/devs/neovide/anda.hcl similarity index 100% rename from anda/rust/neovide/anda.hcl rename to anda/devs/neovide/anda.hcl diff --git a/anda/rust/neovide/neovide.spec b/anda/devs/neovide/neovide.spec similarity index 93% rename from anda/rust/neovide/neovide.spec rename to anda/devs/neovide/neovide.spec index a60536edd3..16e3697e67 100644 --- a/anda/rust/neovide/neovide.spec +++ b/anda/devs/neovide/neovide.spec @@ -1,7 +1,7 @@ %define debug_package %nil Name: neovide -Version: 0.11.2 +Version: 0.12.1 Release: 1%{?dist} Summary: No Nonsense Neovim Client in Rust License: MIT @@ -27,7 +27,7 @@ but functionally it should act like the terminal UI. %install %cargo_install -install -Dm755 -t %buildroot%_bindir target/release/%name +%dnl install -Dm755 -t %buildroot%_bindir target/rpm/%name install -Dm644 -t %buildroot%_datadir/applications/ assets/%name.desktop for px in 16 32 48 256; do install -Dm644 assets/%name-${px}x${px}.png %buildroot%_datadir/icons/hicolor/${px}x${px}/apps/%name.png diff --git a/anda/rust/neovide/update.rhai b/anda/devs/neovide/update.rhai similarity index 100% rename from anda/rust/neovide/update.rhai rename to anda/devs/neovide/update.rhai diff --git a/anda/docker/containerd/.gitignore b/anda/docker/containerd/.gitignore new file mode 100644 index 0000000000..cd976ef07f --- /dev/null +++ b/anda/docker/containerd/.gitignore @@ -0,0 +1,2 @@ +containerd-*.tar.gz +clog diff --git a/anda/docker/containerd/0001-Add-reaper-StartLocked.patch b/anda/docker/containerd/0001-Add-reaper-StartLocked.patch new file mode 100644 index 0000000000..610ec0005d --- /dev/null +++ b/anda/docker/containerd/0001-Add-reaper-StartLocked.patch @@ -0,0 +1,33 @@ +From 788f2f928c1d0099d3861553bf82e83169811a29 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Robert-Andr=C3=A9=20Mauchin?= +Date: Tue, 1 Nov 2022 22:09:38 +0100 +Subject: [PATCH] Add reaper StartLocked + +--- + sys/reaper/reaper_unix.go | 10 ++++++++++ + 1 file changed, 10 insertions(+) + +diff --git a/sys/reaper/reaper_unix.go b/sys/reaper/reaper_unix.go +index 6c4f13b90..a6d6a1e77 100644 +--- a/sys/reaper/reaper_unix.go ++++ b/sys/reaper/reaper_unix.go +@@ -101,6 +101,16 @@ func (m *Monitor) Start(c *exec.Cmd) (chan runc.Exit, error) { + return ec, nil + } + ++// StartLocked starts the command a registers the process with the reaper ++func (m *Monitor) StartLocked(c *exec.Cmd) (chan runc.Exit, error) { ++ ec := m.Subscribe() ++ if err := c.Start(); err != nil { ++ m.Unsubscribe(ec) ++ return nil, err ++ } ++ return ec, nil ++} ++ + // Wait blocks until a process is signal as dead. + // User should rely on the value of the exit status to determine if the + // command was successful or not. +-- +2.38.1 + diff --git a/anda/docker/containerd/0001-Revert-commit-for-Windows-metrics.patch b/anda/docker/containerd/0001-Revert-commit-for-Windows-metrics.patch new file mode 100644 index 0000000000..568f98ff13 --- /dev/null +++ b/anda/docker/containerd/0001-Revert-commit-for-Windows-metrics.patch @@ -0,0 +1,157 @@ +From beb23ffb0624b40b2ee1bc56730e54943bd3020f Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Robert-Andr=C3=A9=20Mauchin?= +Date: Thu, 1 Oct 2020 07:19:45 +0200 +Subject: [PATCH] Revert commit for Windows metrics +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Signed-off-by: Robert-André Mauchin +--- + cmd/ctr/commands/tasks/metrics.go | 113 ------------------------------ + 1 file changed, 113 deletions(-) + +diff --git a/cmd/ctr/commands/tasks/metrics.go b/cmd/ctr/commands/tasks/metrics.go +index a83e45ef..f8371401 100644 +--- a/cmd/ctr/commands/tasks/metrics.go ++++ b/cmd/ctr/commands/tasks/metrics.go +@@ -23,9 +23,6 @@ import ( + "os" + "text/tabwriter" + +- wstats "github.com/Microsoft/hcsshim/cmd/containerd-shim-runhcs-v1/stats" +- v1 "github.com/containerd/cgroups/stats/v1" +- v2 "github.com/containerd/cgroups/v2/stats" + "github.com/containerd/containerd/cmd/ctr/commands" + "github.com/containerd/typeurl" + "github.com/urfave/cli" +@@ -77,42 +74,12 @@ var metricsCommand = cli.Command{ + if err != nil { + return err + } +- var ( +- data *v1.Metrics +- data2 *v2.Metrics +- windowsStats *wstats.Statistics +- ) +- switch v := anydata.(type) { +- case *v1.Metrics: +- data = v +- case *v2.Metrics: +- data2 = v +- case *wstats.Statistics: +- windowsStats = v +- default: +- return errors.New("cannot convert metric data to cgroups.Metrics or windows.Statistics") +- } + + switch context.String(formatFlag) { + case formatTable: + w := tabwriter.NewWriter(os.Stdout, 1, 8, 4, ' ', 0) + fmt.Fprintf(w, "ID\tTIMESTAMP\t\n") + fmt.Fprintf(w, "%s\t%s\t\n\n", metric.ID, metric.Timestamp) +- if data != nil { +- printCgroupMetricsTable(w, data) +- } else if data2 != nil { +- printCgroup2MetricsTable(w, data2) +- } else { +- if windowsStats.GetLinux() != nil { +- printCgroupMetricsTable(w, windowsStats.GetLinux()) +- } else if windowsStats.GetWindows() != nil { +- printWindowsContainerStatistics(w, windowsStats.GetWindows()) +- } +- // Print VM stats if its isolated +- if windowsStats.VM != nil { +- printWindowsVMStatistics(w, windowsStats.VM) +- } +- } + return w.Flush() + case formatJSON: + marshaledJSON, err := json.MarshalIndent(anydata, "", " ") +@@ -126,83 +93,3 @@ var metricsCommand = cli.Command{ + } + }, + } +- +-func printCgroupMetricsTable(w *tabwriter.Writer, data *v1.Metrics) { +- fmt.Fprintf(w, "METRIC\tVALUE\t\n") +- if data.Memory != nil { +- fmt.Fprintf(w, "memory.usage_in_bytes\t%d\t\n", data.Memory.Usage.Usage) +- fmt.Fprintf(w, "memory.limit_in_bytes\t%d\t\n", data.Memory.Usage.Limit) +- fmt.Fprintf(w, "memory.stat.cache\t%d\t\n", data.Memory.TotalCache) +- } +- if data.CPU != nil { +- fmt.Fprintf(w, "cpuacct.usage\t%d\t\n", data.CPU.Usage.Total) +- fmt.Fprintf(w, "cpuacct.usage_percpu\t%v\t\n", data.CPU.Usage.PerCPU) +- } +- if data.Pids != nil { +- fmt.Fprintf(w, "pids.current\t%v\t\n", data.Pids.Current) +- fmt.Fprintf(w, "pids.limit\t%v\t\n", data.Pids.Limit) +- } +-} +- +-func printCgroup2MetricsTable(w *tabwriter.Writer, data *v2.Metrics) { +- fmt.Fprintf(w, "METRIC\tVALUE\t\n") +- if data.Pids != nil { +- fmt.Fprintf(w, "pids.current\t%v\t\n", data.Pids.Current) +- fmt.Fprintf(w, "pids.limit\t%v\t\n", data.Pids.Limit) +- } +- if data.CPU != nil { +- fmt.Fprintf(w, "cpu.usage_usec\t%v\t\n", data.CPU.UsageUsec) +- fmt.Fprintf(w, "cpu.user_usec\t%v\t\n", data.CPU.UserUsec) +- fmt.Fprintf(w, "cpu.system_usec\t%v\t\n", data.CPU.SystemUsec) +- fmt.Fprintf(w, "cpu.nr_periods\t%v\t\n", data.CPU.NrPeriods) +- fmt.Fprintf(w, "cpu.nr_throttled\t%v\t\n", data.CPU.NrThrottled) +- fmt.Fprintf(w, "cpu.throttled_usec\t%v\t\n", data.CPU.ThrottledUsec) +- } +- if data.Memory != nil { +- fmt.Fprintf(w, "memory.usage\t%v\t\n", data.Memory.Usage) +- fmt.Fprintf(w, "memory.usage_limit\t%v\t\n", data.Memory.UsageLimit) +- fmt.Fprintf(w, "memory.swap_usage\t%v\t\n", data.Memory.SwapUsage) +- fmt.Fprintf(w, "memory.swap_limit\t%v\t\n", data.Memory.SwapLimit) +- } +-} +- +-func printWindowsContainerStatistics(w *tabwriter.Writer, stats *wstats.WindowsContainerStatistics) { +- fmt.Fprintf(w, "METRIC\tVALUE\t\n") +- fmt.Fprintf(w, "timestamp\t%s\t\n", stats.Timestamp) +- fmt.Fprintf(w, "start_time\t%s\t\n", stats.ContainerStartTime) +- fmt.Fprintf(w, "uptime_ns\t%d\t\n", stats.UptimeNS) +- if stats.Processor != nil { +- fmt.Fprintf(w, "cpu.total_runtime_ns\t%d\t\n", stats.Processor.TotalRuntimeNS) +- fmt.Fprintf(w, "cpu.runtime_user_ns\t%d\t\n", stats.Processor.RuntimeUserNS) +- fmt.Fprintf(w, "cpu.runtime_kernel_ns\t%d\t\n", stats.Processor.RuntimeKernelNS) +- } +- if stats.Memory != nil { +- fmt.Fprintf(w, "memory.commit_bytes\t%d\t\n", stats.Memory.MemoryUsageCommitBytes) +- fmt.Fprintf(w, "memory.commit_peak_bytes\t%d\t\n", stats.Memory.MemoryUsageCommitPeakBytes) +- fmt.Fprintf(w, "memory.private_working_set_bytes\t%d\t\n", stats.Memory.MemoryUsagePrivateWorkingSetBytes) +- } +- if stats.Storage != nil { +- fmt.Fprintf(w, "storage.read_count_normalized\t%d\t\n", stats.Storage.ReadCountNormalized) +- fmt.Fprintf(w, "storage.read_size_bytes\t%d\t\n", stats.Storage.ReadSizeBytes) +- fmt.Fprintf(w, "storage.write_count_normalized\t%d\t\n", stats.Storage.WriteCountNormalized) +- fmt.Fprintf(w, "storage.write_size_bytes\t%d\t\n", stats.Storage.WriteSizeBytes) +- } +-} +- +-func printWindowsVMStatistics(w *tabwriter.Writer, stats *wstats.VirtualMachineStatistics) { +- fmt.Fprintf(w, "METRIC\tVALUE\t\n") +- if stats.Processor != nil { +- fmt.Fprintf(w, "vm.cpu.total_runtime_ns\t%d\t\n", stats.Processor.TotalRuntimeNS) +- } +- if stats.Memory != nil { +- fmt.Fprintf(w, "vm.memory.working_set_bytes\t%d\t\n", stats.Memory.WorkingSetBytes) +- fmt.Fprintf(w, "vm.memory.virtual_node_count\t%d\t\n", stats.Memory.VirtualNodeCount) +- fmt.Fprintf(w, "vm.memory.available\t%d\t\n", stats.Memory.VmMemory.AvailableMemory) +- fmt.Fprintf(w, "vm.memory.available_buffer\t%d\t\n", stats.Memory.VmMemory.AvailableMemoryBuffer) +- fmt.Fprintf(w, "vm.memory.reserved\t%d\t\n", stats.Memory.VmMemory.ReservedMemory) +- fmt.Fprintf(w, "vm.memory.assigned\t%d\t\n", stats.Memory.VmMemory.AssignedMemory) +- fmt.Fprintf(w, "vm.memory.slp_active\t%t\t\n", stats.Memory.VmMemory.SlpActive) +- fmt.Fprintf(w, "vm.memory.balancing_enabled\t%t\t\n", stats.Memory.VmMemory.BalancingEnabled) +- fmt.Fprintf(w, "vm.memory.dm_operation_in_progress\t%t\t\n", stats.Memory.VmMemory.DmOperationInProgress) +- } +-} +-- +2.28.0 + diff --git a/anda/docker/containerd/0001-Use-typeurl.Any-instead-of-github.com-gogo-protobuf-.patch b/anda/docker/containerd/0001-Use-typeurl.Any-instead-of-github.com-gogo-protobuf-.patch new file mode 100644 index 0000000000..5577569579 --- /dev/null +++ b/anda/docker/containerd/0001-Use-typeurl.Any-instead-of-github.com-gogo-protobuf-.patch @@ -0,0 +1,1467 @@ +From 92d2d9b8ed28b3918ad902219245b6c737e9dee4 Mon Sep 17 00:00:00 2001 +From: Davanum Srinivas +Date: Fri, 25 Aug 2023 11:11:35 -0400 +Subject: [PATCH] [PATCH] Use typeurl.Any instead of + github.com/gogo/protobuf/types.Any + +This commit upgrades github.com/containerd/typeurl to use typeurl.Any. +The interface hides gogo/protobuf/types.Any from containerd's Go client. + +Signed-off-by: Kazuyoshi Kato +Signed-off-by: Davanum Srinivas +--- + cmd/containerd-shim/main_unix.go | 4 +- + cmd/ctr/commands/containers/containers.go | 2 +- + container.go | 10 +-- + container_checkpoint_opts.go | 8 +-- + container_opts.go | 10 +-- + containers/containers.go | 8 +-- + containerstore.go | 19 ++++-- + events.go | 5 +- + events/events.go | 3 +- + events/exchange/exchange.go | 8 +-- + go.mod | 2 +- + go.sum | 3 +- + integration/client/container_test.go | 8 +-- + integration/client/go.mod | 2 +- + integration/client/go.sum | 3 +- + metadata/boltutil/helpers.go | 21 +++--- + metadata/containers.go | 3 +- + metadata/containers_test.go | 83 ++++++++++++++--------- + metrics/cgroups/metrics_test.go | 6 +- + pkg/cri/server/events.go | 3 +- + pkg/cri/server/helpers.go | 5 +- + pkg/cri/server/helpers_test.go | 13 ++++ + pkg/cri/server/restart.go | 4 +- + protobuf/any.go | 47 +++++++++++++ + protobuf/any_test.go | 26 +++++++ + runtime/runtime.go | 8 +-- + runtime/v1/linux/runtime.go | 9 +-- + runtime/v1/linux/task.go | 4 +- + runtime/v1/shim/service.go | 3 +- + runtime/v2/manager.go | 7 +- + runtime/v2/runc/container.go | 6 +- + runtime/v2/runc/task/service.go | 5 +- + runtime/v2/runc/v1/service.go | 5 +- + runtime/v2/shim.go | 5 +- + runtime/v2/shim/publisher.go | 4 +- + services/containers/helpers.go | 20 ++++-- + services/events/service.go | 3 +- + services/tasks/local.go | 5 +- + task.go | 7 +- + 39 files changed, 270 insertions(+), 127 deletions(-) + create mode 100644 protobuf/any.go + create mode 100644 protobuf/any_test.go + +diff --git a/cmd/containerd-shim/main_unix.go b/cmd/containerd-shim/main_unix.go +index 024611bf3bdf..ef32ae38bb51 100644 +--- a/cmd/containerd-shim/main_unix.go ++++ b/cmd/containerd-shim/main_unix.go +@@ -38,12 +38,12 @@ import ( + "github.com/containerd/containerd/events" + "github.com/containerd/containerd/namespaces" + "github.com/containerd/containerd/pkg/process" ++ "github.com/containerd/containerd/protobuf" + shimlog "github.com/containerd/containerd/runtime/v1" + "github.com/containerd/containerd/runtime/v1/shim" + shimapi "github.com/containerd/containerd/runtime/v1/shim/v1" + "github.com/containerd/containerd/sys/reaper" + "github.com/containerd/ttrpc" +- "github.com/containerd/typeurl" + ptypes "github.com/gogo/protobuf/types" + "github.com/sirupsen/logrus" + exec "golang.org/x/sys/execabs" +@@ -286,7 +286,7 @@ type remoteEventsPublisher struct { + + func (l *remoteEventsPublisher) Publish(ctx context.Context, topic string, event events.Event) error { + ns, _ := namespaces.Namespace(ctx) +- encoded, err := typeurl.MarshalAny(event) ++ encoded, err := protobuf.MarshalAnyToProto(event) + if err != nil { + return err + } +diff --git a/cmd/ctr/commands/containers/containers.go b/cmd/ctr/commands/containers/containers.go +index d1025344e0a0..3f2d55d6c10c 100644 +--- a/cmd/ctr/commands/containers/containers.go ++++ b/cmd/ctr/commands/containers/containers.go +@@ -280,7 +280,7 @@ var infoCommand = cli.Command{ + return nil + } + +- if info.Spec != nil && info.Spec.Value != nil { ++ if info.Spec != nil && info.Spec.GetValue() != nil { + v, err := typeurl.UnmarshalAny(info.Spec) + if err != nil { + return err +diff --git a/container.go b/container.go +index 2cf15666f132..8511d863dc1c 100644 +--- a/container.go ++++ b/container.go +@@ -32,10 +32,10 @@ import ( + "github.com/containerd/containerd/errdefs" + "github.com/containerd/containerd/images" + "github.com/containerd/containerd/oci" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime/v2/runc/options" + "github.com/containerd/fifo" + "github.com/containerd/typeurl" +- prototypes "github.com/gogo/protobuf/types" + ver "github.com/opencontainers/image-spec/specs-go" + ocispec "github.com/opencontainers/image-spec/specs-go/v1" + "github.com/opencontainers/selinux/go-selinux/label" +@@ -74,7 +74,7 @@ type Container interface { + // SetLabels sets the provided labels for the container and returns the final label set + SetLabels(context.Context, map[string]string) (map[string]string, error) + // Extensions returns the extensions set on the container +- Extensions(context.Context) (map[string]prototypes.Any, error) ++ Extensions(context.Context) (map[string]typeurl.Any, error) + // Update a container + Update(context.Context, ...UpdateContainerOpts) error + // Checkpoint creates a checkpoint image of the current container +@@ -120,7 +120,7 @@ func (c *container) Info(ctx context.Context, opts ...InfoOpts) (containers.Cont + return c.metadata, nil + } + +-func (c *container) Extensions(ctx context.Context) (map[string]prototypes.Any, error) { ++func (c *container) Extensions(ctx context.Context) (map[string]typeurl.Any, error) { + r, err := c.get(ctx) + if err != nil { + return nil, err +@@ -163,7 +163,7 @@ func (c *container) Spec(ctx context.Context) (*oci.Spec, error) { + return nil, err + } + var s oci.Spec +- if err := json.Unmarshal(r.Spec.Value, &s); err != nil { ++ if err := json.Unmarshal(r.Spec.GetValue(), &s); err != nil { + return nil, err + } + return &s, nil +@@ -285,7 +285,7 @@ func (c *container) NewTask(ctx context.Context, ioCreate cio.Creator, opts ...N + if err != nil { + return nil, err + } +- request.Options = any ++ request.Options = protobuf.FromAny(any) + } + t := &task{ + client: c.client, +diff --git a/container_checkpoint_opts.go b/container_checkpoint_opts.go +index a64ef618ba62..ee2fa1b977eb 100644 +--- a/container_checkpoint_opts.go ++++ b/container_checkpoint_opts.go +@@ -28,9 +28,9 @@ import ( + "github.com/containerd/containerd/diff" + "github.com/containerd/containerd/images" + "github.com/containerd/containerd/platforms" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/rootfs" + "github.com/containerd/containerd/runtime/v2/runc/options" +- "github.com/containerd/typeurl" + imagespec "github.com/opencontainers/image-spec/specs-go/v1" + ) + +@@ -56,7 +56,7 @@ func WithCheckpointImage(ctx context.Context, client *Client, c *containers.Cont + + // WithCheckpointTask includes the running task + func WithCheckpointTask(ctx context.Context, client *Client, c *containers.Container, index *imagespec.Index, copts *options.CheckpointOptions) error { +- any, err := typeurl.MarshalAny(copts) ++ any, err := protobuf.MarshalAnyToProto(copts) + if err != nil { + return nil + } +@@ -97,8 +97,8 @@ func WithCheckpointTask(ctx context.Context, client *Client, c *containers.Conta + + // WithCheckpointRuntime includes the container runtime info + func WithCheckpointRuntime(ctx context.Context, client *Client, c *containers.Container, index *imagespec.Index, copts *options.CheckpointOptions) error { +- if c.Runtime.Options != nil { +- data, err := c.Runtime.Options.Marshal() ++ if c.Runtime.Options != nil && c.Runtime.Options.GetValue() != nil { ++ data, err := protobuf.FromAny(c.Runtime.Options).Marshal() + if err != nil { + return err + } +diff --git a/container_opts.go b/container_opts.go +index 4d630ea6c9d2..f005fe1c7730 100644 +--- a/container_opts.go ++++ b/container_opts.go +@@ -27,9 +27,9 @@ import ( + "github.com/containerd/containerd/errdefs" + "github.com/containerd/containerd/images" + "github.com/containerd/containerd/oci" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/snapshots" + "github.com/containerd/typeurl" +- "github.com/gogo/protobuf/types" + "github.com/opencontainers/image-spec/identity" + v1 "github.com/opencontainers/image-spec/specs-go/v1" + ) +@@ -57,7 +57,7 @@ type InfoConfig struct { + func WithRuntime(name string, options interface{}) NewContainerOpts { + return func(ctx context.Context, client *Client, c *containers.Container) error { + var ( +- any *types.Any ++ any typeurl.Any + err error + ) + if options != nil { +@@ -288,9 +288,9 @@ func WithContainerExtension(name string, extension interface{}) NewContainerOpts + } + + if c.Extensions == nil { +- c.Extensions = make(map[string]types.Any) ++ c.Extensions = make(map[string]typeurl.Any) + } +- c.Extensions[name] = *any ++ c.Extensions[name] = any + return nil + } + } +@@ -315,7 +315,7 @@ func WithSpec(s *oci.Spec, opts ...oci.SpecOpts) NewContainerOpts { + } + + var err error +- c.Spec, err = typeurl.MarshalAny(s) ++ c.Spec, err = protobuf.MarshalAnyToProto(s) + return err + } + } +diff --git a/containers/containers.go b/containers/containers.go +index 7174bbd6aa6f..275f8069ea12 100644 +--- a/containers/containers.go ++++ b/containers/containers.go +@@ -20,7 +20,7 @@ import ( + "context" + "time" + +- "github.com/gogo/protobuf/types" ++ "github.com/containerd/typeurl" + ) + + // Container represents the set of data pinned by a container. Unless otherwise +@@ -53,7 +53,7 @@ type Container struct { + // container. + // + // This field is required but mutable. +- Spec *types.Any ++ Spec typeurl.Any + + // SnapshotKey specifies the snapshot key to use for the container's root + // filesystem. When starting a task from this container, a caller should +@@ -75,13 +75,13 @@ type Container struct { + UpdatedAt time.Time + + // Extensions stores client-specified metadata +- Extensions map[string]types.Any ++ Extensions map[string]typeurl.Any + } + + // RuntimeInfo holds runtime specific information + type RuntimeInfo struct { + Name string +- Options *types.Any ++ Options typeurl.Any + } + + // Store interacts with the underlying container storage +diff --git a/containerstore.go b/containerstore.go +index bdd1c6066a79..2a154e26590d 100644 +--- a/containerstore.go ++++ b/containerstore.go +@@ -24,6 +24,8 @@ import ( + containersapi "github.com/containerd/containerd/api/services/containers/v1" + "github.com/containerd/containerd/containers" + "github.com/containerd/containerd/errdefs" ++ "github.com/containerd/containerd/protobuf" ++ "github.com/containerd/typeurl" + ptypes "github.com/gogo/protobuf/types" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" +@@ -148,18 +150,22 @@ func (r *remoteContainers) Delete(ctx context.Context, id string) error { + } + + func containerToProto(container *containers.Container) containersapi.Container { ++ extensions := make(map[string]ptypes.Any) ++ for k, v := range container.Extensions { ++ extensions[k] = *protobuf.FromAny(v) ++ } + return containersapi.Container{ + ID: container.ID, + Labels: container.Labels, + Image: container.Image, + Runtime: &containersapi.Container_Runtime{ + Name: container.Runtime.Name, +- Options: container.Runtime.Options, ++ Options: protobuf.FromAny(container.Runtime.Options), + }, +- Spec: container.Spec, ++ Spec: protobuf.FromAny(container.Spec), + Snapshotter: container.Snapshotter, + SnapshotKey: container.SnapshotKey, +- Extensions: container.Extensions, ++ Extensions: extensions, + } + } + +@@ -171,6 +177,11 @@ func containerFromProto(containerpb *containersapi.Container) containers.Contain + Options: containerpb.Runtime.Options, + } + } ++ extensions := make(map[string]typeurl.Any) ++ for k, v := range containerpb.Extensions { ++ v := v ++ extensions[k] = &v ++ } + return containers.Container{ + ID: containerpb.ID, + Labels: containerpb.Labels, +@@ -181,7 +192,7 @@ func containerFromProto(containerpb *containersapi.Container) containers.Contain + SnapshotKey: containerpb.SnapshotKey, + CreatedAt: containerpb.CreatedAt, + UpdatedAt: containerpb.UpdatedAt, +- Extensions: containerpb.Extensions, ++ Extensions: extensions, + } + } + +diff --git a/events.go b/events.go +index 3577b7c3a9fc..d6499ad3b3a8 100644 +--- a/events.go ++++ b/events.go +@@ -22,6 +22,7 @@ import ( + eventsapi "github.com/containerd/containerd/api/services/events/v1" + "github.com/containerd/containerd/errdefs" + "github.com/containerd/containerd/events" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/typeurl" + ) + +@@ -51,7 +52,7 @@ func (e *eventRemote) Publish(ctx context.Context, topic string, event events.Ev + } + req := &eventsapi.PublishRequest{ + Topic: topic, +- Event: any, ++ Event: protobuf.FromAny(any), + } + if _, err := e.client.Publish(ctx, req); err != nil { + return errdefs.FromGRPC(err) +@@ -65,7 +66,7 @@ func (e *eventRemote) Forward(ctx context.Context, envelope *events.Envelope) er + Timestamp: envelope.Timestamp, + Namespace: envelope.Namespace, + Topic: envelope.Topic, +- Event: envelope.Event, ++ Event: protobuf.FromAny(envelope.Event), + }, + } + if _, err := e.client.Forward(ctx, req); err != nil { +diff --git a/events/events.go b/events/events.go +index b7eb86f1eb65..8af0ec03a483 100644 +--- a/events/events.go ++++ b/events/events.go +@@ -21,7 +21,6 @@ import ( + "time" + + "github.com/containerd/typeurl" +- "github.com/gogo/protobuf/types" + ) + + // Envelope provides the packaging for an event. +@@ -29,7 +28,7 @@ type Envelope struct { + Timestamp time.Time + Namespace string + Topic string +- Event *types.Any ++ Event typeurl.Any + } + + // Field returns the value for the given fieldpath as a string, if defined. +diff --git a/events/exchange/exchange.go b/events/exchange/exchange.go +index a1f385d7abd3..7f085dc91774 100644 +--- a/events/exchange/exchange.go ++++ b/events/exchange/exchange.go +@@ -30,7 +30,6 @@ import ( + "github.com/containerd/containerd/namespaces" + "github.com/containerd/typeurl" + goevents "github.com/docker/go-events" +- "github.com/gogo/protobuf/types" + "github.com/sirupsen/logrus" + ) + +@@ -63,7 +62,7 @@ func (e *Exchange) Forward(ctx context.Context, envelope *events.Envelope) (err + logger := log.G(ctx).WithFields(logrus.Fields{ + "topic": envelope.Topic, + "ns": envelope.Namespace, +- "type": envelope.Event.TypeUrl, ++ "type": envelope.Event.GetTypeUrl(), + }) + + if err != nil { +@@ -82,7 +81,6 @@ func (e *Exchange) Forward(ctx context.Context, envelope *events.Envelope) (err + func (e *Exchange) Publish(ctx context.Context, topic string, event events.Event) (err error) { + var ( + namespace string +- encoded *types.Any + envelope events.Envelope + ) + +@@ -94,7 +92,7 @@ func (e *Exchange) Publish(ctx context.Context, topic string, event events.Event + return fmt.Errorf("envelope topic %q: %w", topic, err) + } + +- encoded, err = typeurl.MarshalAny(event) ++ encoded, err := typeurl.MarshalAny(event) + if err != nil { + return err + } +@@ -108,7 +106,7 @@ func (e *Exchange) Publish(ctx context.Context, topic string, event events.Event + logger := log.G(ctx).WithFields(logrus.Fields{ + "topic": envelope.Topic, + "ns": envelope.Namespace, +- "type": envelope.Event.TypeUrl, ++ "type": envelope.Event.GetTypeUrl(), + }) + + if err != nil { +diff --git a/go.mod b/go.mod +index 26b0ae08bcc9..fc5ebe10e783 100644 +--- a/go.mod ++++ b/go.mod +@@ -17,7 +17,7 @@ require ( + github.com/containerd/imgcrypt v1.1.4 + github.com/containerd/nri v0.1.0 + github.com/containerd/ttrpc v1.1.2 +- github.com/containerd/typeurl v1.0.2 ++ github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259 + github.com/containerd/zfs v1.1.0 + github.com/containernetworking/cni v1.1.1 + github.com/containernetworking/plugins v1.1.1 +diff --git a/go.sum b/go.sum +index 7f42e83a3b68..0bf0cb6c63e1 100644 +--- a/go.sum ++++ b/go.sum +@@ -260,8 +260,9 @@ github.com/containerd/ttrpc v1.1.2/go.mod h1:XX4ZTnoOId4HklF4edwc4DcqskFZuvXB1Ev + github.com/containerd/typeurl v0.0.0-20180627222232-a93fcdb778cd/go.mod h1:Cm3kwCdlkCfMSHURc+r6fwoGH6/F1hH3S4sg0rLFWPc= + github.com/containerd/typeurl v0.0.0-20190911142611-5eb25027c9fd/go.mod h1:GeKYzf2pQcqv7tJ0AoCuuhtnqhva5LNU3U+OyKxxJpk= + github.com/containerd/typeurl v1.0.1/go.mod h1:TB1hUtrpaiO88KEK56ijojHS1+NeF0izUACaJW2mdXg= +-github.com/containerd/typeurl v1.0.2 h1:Chlt8zIieDbzQFzXzAeBEF92KhExuE4p9p92/QmY7aY= + github.com/containerd/typeurl v1.0.2/go.mod h1:9trJWW2sRlGub4wZJRTW83VtbOLS6hwcDZXTn6oPz9s= ++github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259 h1:bJv9qgjarrsdd4XIIczeRdYXON88Fgn3GdXVfnQjcSo= ++github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259/go.mod h1:HDkcKOXRnX6yKnXv3P0QrogFi0DoiauK/LpQi961f0A= + github.com/containerd/zfs v0.0.0-20200918131355-0a33824f23a2/go.mod h1:8IgZOBdv8fAgXddBT4dBXJPtxyRsejFIpXoklgxgEjw= + github.com/containerd/zfs v0.0.0-20210301145711-11e8f1707f62/go.mod h1:A9zfAbMlQwE+/is6hi0Xw8ktpL+6glmqZYtevJgaB8Y= + github.com/containerd/zfs v0.0.0-20210315114300-dde8f0fda960/go.mod h1:m+m51S1DvAP6r3FcmYCp54bQ34pyOwTieQDNRIRHsFY= +diff --git a/integration/client/container_test.go b/integration/client/container_test.go +index 53cffb6874d1..cdf3c1fd0296 100644 +--- a/integration/client/container_test.go ++++ b/integration/client/container_test.go +@@ -1570,11 +1570,11 @@ func TestContainerExtensions(t *testing.T) { + if len(cExts) != 1 { + t.Errorf("expected 1 container extension") + } +- if cExts["hello"].TypeUrl != ext.TypeUrl { +- t.Errorf("got unexpected type url for extension: %s", cExts["hello"].TypeUrl) ++ if actual := cExts["hello"].GetTypeUrl(); actual != ext.TypeUrl { ++ t.Errorf("got unexpected type url for extension: %s", actual) + } +- if !bytes.Equal(cExts["hello"].Value, ext.Value) { +- t.Errorf("expected extension value %q, got: %q", ext.Value, cExts["hello"].Value) ++ if actual := cExts["hello"].GetValue(); !bytes.Equal(actual, ext.Value) { ++ t.Errorf("expected extension value %q, got: %q", ext.Value, actual) + } + } + +diff --git a/integration/client/go.mod b/integration/client/go.mod +index f5defa51018c..fcbbdee846ee 100644 +--- a/integration/client/go.mod ++++ b/integration/client/go.mod +@@ -11,7 +11,7 @@ require ( + github.com/containerd/continuity v0.3.0 + github.com/containerd/go-runc v1.0.0 + github.com/containerd/ttrpc v1.1.2 +- github.com/containerd/typeurl v1.0.2 ++ github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259 + github.com/gogo/protobuf v1.3.2 + github.com/opencontainers/go-digest v1.0.0 + github.com/opencontainers/image-spec v1.1.0-rc2.0.20221005185240-3a7f492d3f1b +diff --git a/integration/client/go.sum b/integration/client/go.sum +index 5e37298cff45..8c3099b3f5f6 100644 +--- a/integration/client/go.sum ++++ b/integration/client/go.sum +@@ -148,8 +148,9 @@ github.com/containerd/ttrpc v1.1.0/go.mod h1:XX4ZTnoOId4HklF4edwc4DcqskFZuvXB1Ev + github.com/containerd/ttrpc v1.1.2 h1:4jH6OQDQqjfVD2b5TJS5TxmGuLGmp5WW7KtW2TWOP7c= + github.com/containerd/ttrpc v1.1.2/go.mod h1:XX4ZTnoOId4HklF4edwc4DcqskFZuvXB1Evzy5KFQpQ= + github.com/containerd/typeurl v1.0.1/go.mod h1:TB1hUtrpaiO88KEK56ijojHS1+NeF0izUACaJW2mdXg= +-github.com/containerd/typeurl v1.0.2 h1:Chlt8zIieDbzQFzXzAeBEF92KhExuE4p9p92/QmY7aY= + github.com/containerd/typeurl v1.0.2/go.mod h1:9trJWW2sRlGub4wZJRTW83VtbOLS6hwcDZXTn6oPz9s= ++github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259 h1:bJv9qgjarrsdd4XIIczeRdYXON88Fgn3GdXVfnQjcSo= ++github.com/containerd/typeurl v1.0.3-0.20220324183432-6193a0e03259/go.mod h1:HDkcKOXRnX6yKnXv3P0QrogFi0DoiauK/LpQi961f0A= + github.com/containerd/zfs v1.1.0/go.mod h1:oZF9wBnrnQjpWLaPKEinrx3TQ9a+W/RJO7Zb41d8YLE= + github.com/containernetworking/cni v1.0.1/go.mod h1:AKuhXbN5EzmD4yTNtfSsX3tPcmtrBI6QcRV0NiNt15Y= + github.com/containernetworking/cni v1.1.1/go.mod h1:sDpYKmGVENF3s6uvMvGgldDWeG8dMxakj/u+i9ht9vw= +diff --git a/metadata/boltutil/helpers.go b/metadata/boltutil/helpers.go +index 4201d7ba9ee1..2b2b0ad1e523 100644 +--- a/metadata/boltutil/helpers.go ++++ b/metadata/boltutil/helpers.go +@@ -20,6 +20,8 @@ import ( + "fmt" + "time" + ++ "github.com/containerd/containerd/protobuf" ++ "github.com/containerd/typeurl" + "github.com/gogo/protobuf/proto" + "github.com/gogo/protobuf/types" + bolt "go.etcd.io/bbolt" +@@ -151,7 +153,7 @@ func WriteTimestamps(bkt *bolt.Bucket, created, updated time.Time) error { + + // WriteExtensions will write a KV map to the given bucket, + // where `K` is a string key and `V` is a protobuf's Any type that represents a generic extension. +-func WriteExtensions(bkt *bolt.Bucket, extensions map[string]types.Any) error { ++func WriteExtensions(bkt *bolt.Bucket, extensions map[string]typeurl.Any) error { + if len(extensions) == 0 { + return nil + } +@@ -162,8 +164,8 @@ func WriteExtensions(bkt *bolt.Bucket, extensions map[string]types.Any) error { + } + + for name, ext := range extensions { +- ext := ext +- p, err := proto.Marshal(&ext) ++ ext := protobuf.FromAny(ext) ++ p, err := proto.Marshal(ext) + if err != nil { + return err + } +@@ -177,9 +179,9 @@ func WriteExtensions(bkt *bolt.Bucket, extensions map[string]types.Any) error { + } + + // ReadExtensions will read back a map of extensions from the given bucket, previously written by WriteExtensions +-func ReadExtensions(bkt *bolt.Bucket) (map[string]types.Any, error) { ++func ReadExtensions(bkt *bolt.Bucket) (map[string]typeurl.Any, error) { + var ( +- extensions = make(map[string]types.Any) ++ extensions = make(map[string]typeurl.Any) + ebkt = bkt.Bucket(bucketKeyExtensions) + ) + +@@ -193,7 +195,7 @@ func ReadExtensions(bkt *bolt.Bucket) (map[string]types.Any, error) { + return err + } + +- extensions[string(k)] = t ++ extensions[string(k)] = &t + return nil + }); err != nil { + return nil, err +@@ -203,12 +205,13 @@ func ReadExtensions(bkt *bolt.Bucket) (map[string]types.Any, error) { + } + + // WriteAny write a protobuf's Any type to the bucket +-func WriteAny(bkt *bolt.Bucket, name []byte, any *types.Any) error { +- if any == nil { ++func WriteAny(bkt *bolt.Bucket, name []byte, any typeurl.Any) error { ++ pbany := protobuf.FromAny(any) ++ if pbany == nil { + return nil + } + +- data, err := proto.Marshal(any) ++ data, err := proto.Marshal(pbany) + if err != nil { + return err + } +diff --git a/metadata/containers.go b/metadata/containers.go +index 97002e5886e1..b27dc0f87208 100644 +--- a/metadata/containers.go ++++ b/metadata/containers.go +@@ -30,6 +30,7 @@ import ( + "github.com/containerd/containerd/labels" + "github.com/containerd/containerd/metadata/boltutil" + "github.com/containerd/containerd/namespaces" ++ "github.com/containerd/typeurl" + "github.com/gogo/protobuf/proto" + "github.com/gogo/protobuf/types" + bolt "go.etcd.io/bbolt" +@@ -211,7 +212,7 @@ func (s *containerStore) Update(ctx context.Context, container containers.Contai + + if strings.HasPrefix(path, "extensions.") { + if updated.Extensions == nil { +- updated.Extensions = map[string]types.Any{} ++ updated.Extensions = map[string]typeurl.Any{} + } + key := strings.TrimPrefix(path, "extensions.") + updated.Extensions[key] = container.Extensions[key] +diff --git a/metadata/containers_test.go b/metadata/containers_test.go +index b45d54cf5234..409bd8478763 100644 +--- a/metadata/containers_test.go ++++ b/metadata/containers_test.go +@@ -31,10 +31,13 @@ import ( + "github.com/containerd/containerd/filters" + "github.com/containerd/containerd/log/logtest" + "github.com/containerd/containerd/namespaces" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/typeurl" + "github.com/gogo/protobuf/types" ++ "github.com/google/go-cmp/cmp" + specs "github.com/opencontainers/runtime-spec/specs-go" + bolt "go.etcd.io/bbolt" ++ "gotest.tools/v3/assert" + ) + + func init() { +@@ -48,7 +51,7 @@ func TestContainersList(t *testing.T) { + store := NewContainerStore(NewDB(db, nil, nil)) + + spec := &specs.Spec{} +- encoded, err := typeurl.MarshalAny(spec) ++ encoded, err := protobuf.MarshalAnyToProto(spec) + if err != nil { + t.Fatal(err) + } +@@ -180,13 +183,13 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + store := NewContainerStore(NewDB(db, nil, nil)) + + spec := &specs.Spec{} +- encoded, err := typeurl.MarshalAny(spec) ++ encoded, err := protobuf.MarshalAnyToProto(spec) + if err != nil { + t.Fatal(err) + } + + spec.Annotations = map[string]string{"updated": "true"} +- encodedUpdated, err := typeurl.MarshalAny(spec) ++ encodedUpdated, err := protobuf.MarshalAnyToProto(spec) + if err != nil { + t.Fatal(err) + } +@@ -468,8 +471,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), + }, +@@ -480,8 +483,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("world"), + }, +@@ -492,8 +495,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("world"), + }, +@@ -507,8 +510,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), + }, +@@ -519,8 +522,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("world"), + }, +@@ -532,8 +535,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), + }, +@@ -547,8 +550,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), + }, +@@ -558,8 +561,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Labels: map[string]string{ + "foo": "one", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("world"), + }, +@@ -571,8 +574,8 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("world"), + }, +@@ -586,21 +589,21 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ ++ Extensions: map[string]typeurl.Any{ + // leaves hello in place. +- "hello": { ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), + }, + }, + }, + input: containers.Container{ +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("universe"), // this will be ignored + }, +- "bar": { ++ "bar": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("foo"), // this will be added + }, +@@ -612,12 +615,12 @@ func TestContainersCreateUpdateDelete(t *testing.T) { + Runtime: containers.RuntimeInfo{ + Name: "testruntime", + }, +- Extensions: map[string]types.Any{ +- "hello": { ++ Extensions: map[string]typeurl.Any{ ++ "hello": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("hello"), // remains as world + }, +- "bar": { ++ "bar": &types.Any{ + TypeUrl: "test.update.extensions", + Value: []byte("foo"), // this will be added + }, +@@ -708,10 +711,26 @@ func checkContainerTimestamps(t *testing.T, c *containers.Container, now time.Ti + } + } + +-func checkContainersEqual(t *testing.T, a, b *containers.Container, format string, args ...interface{}) { +- if !reflect.DeepEqual(a, b) { +- t.Fatalf("containers not equal \n\t%v != \n\t%v: "+format, append([]interface{}{a, b}, args...)...) ++// isNil returns true if the given parameter is nil or typed nil. ++func isNil(x interface{}) bool { ++ if x == nil { ++ return true + } ++ v := reflect.ValueOf(x) ++ return v.Kind() == reflect.Ptr && v.IsNil() ++} ++ ++func checkContainersEqual(t *testing.T, a, b *containers.Container, format string, args ...interface{}) { ++ // Ignore the difference of nil and typed nil. ++ opt := cmp.FilterValues( ++ func(x, y interface{}) bool { ++ return isNil(x) && isNil(y) ++ }, ++ cmp.Comparer(func(_, _ interface{}) bool { ++ return true ++ }), ++ ) ++ assert.DeepEqual(t, a, b, opt) + } + + func testEnv(t *testing.T) (context.Context, *bolt.DB, func()) { +diff --git a/metrics/cgroups/metrics_test.go b/metrics/cgroups/metrics_test.go +index c71ea60a523a..c362ea3b9d65 100644 +--- a/metrics/cgroups/metrics_test.go ++++ b/metrics/cgroups/metrics_test.go +@@ -32,7 +32,7 @@ import ( + v2 "github.com/containerd/containerd/metrics/cgroups/v2" + v1types "github.com/containerd/containerd/metrics/types/v1" + v2types "github.com/containerd/containerd/metrics/types/v2" +- "github.com/containerd/typeurl" ++ "github.com/containerd/containerd/protobuf" + "github.com/prometheus/client_golang/prometheus" + + metrics "github.com/docker/go-metrics" +@@ -152,7 +152,7 @@ func (t *mockStatT) Namespace() string { + + func (t *mockStatT) Stats(context.Context) (*types.Any, error) { + if t.isV1 { +- return typeurl.MarshalAny(&v1types.Metrics{}) ++ return protobuf.MarshalAnyToProto(&v1types.Metrics{}) + } +- return typeurl.MarshalAny(&v2types.Metrics{}) ++ return protobuf.MarshalAnyToProto(&v2types.Metrics{}) + } +diff --git a/pkg/cri/server/events.go b/pkg/cri/server/events.go +index c8ffdadbfd21..fbecb29a049a 100644 +--- a/pkg/cri/server/events.go ++++ b/pkg/cri/server/events.go +@@ -32,7 +32,6 @@ import ( + sandboxstore "github.com/containerd/containerd/pkg/cri/store/sandbox" + ctrdutil "github.com/containerd/containerd/pkg/cri/util" + "github.com/containerd/typeurl" +- gogotypes "github.com/gogo/protobuf/types" + "github.com/sirupsen/logrus" + "golang.org/x/net/context" + "k8s.io/utils/clock" +@@ -207,7 +206,7 @@ func (em *eventMonitor) startContainerExitMonitor(ctx context.Context, id string + return stopCh + } + +-func convertEvent(e *gogotypes.Any) (string, interface{}, error) { ++func convertEvent(e typeurl.Any) (string, interface{}, error) { + id := "" + evt, err := typeurl.UnmarshalAny(e) + if err != nil { +diff --git a/pkg/cri/server/helpers.go b/pkg/cri/server/helpers.go +index 4ee0ae8ffc12..8937739540a5 100644 +--- a/pkg/cri/server/helpers.go ++++ b/pkg/cri/server/helpers.go +@@ -371,10 +371,11 @@ func getRuntimeOptionsType(t string) interface{} { + + // getRuntimeOptions get runtime options from container metadata. + func getRuntimeOptions(c containers.Container) (interface{}, error) { +- if c.Runtime.Options == nil { ++ from := c.Runtime.Options ++ if from == nil || from.GetValue() == nil { + return nil, nil + } +- opts, err := typeurl.UnmarshalAny(c.Runtime.Options) ++ opts, err := typeurl.UnmarshalAny(from) + if err != nil { + return nil, err + } +diff --git a/pkg/cri/server/helpers_test.go b/pkg/cri/server/helpers_test.go +index f73e174dcc47..8fa9af8c1767 100644 +--- a/pkg/cri/server/helpers_test.go ++++ b/pkg/cri/server/helpers_test.go +@@ -23,6 +23,7 @@ import ( + "testing" + "time" + ++ "github.com/containerd/containerd/containers" + "github.com/containerd/containerd/errdefs" + "github.com/containerd/containerd/oci" + criconfig "github.com/containerd/containerd/pkg/cri/config" +@@ -32,6 +33,8 @@ import ( + "github.com/containerd/containerd/reference/docker" + "github.com/containerd/containerd/runtime/linux/runctypes" + runcoptions "github.com/containerd/containerd/runtime/v2/runc/options" ++ "github.com/containerd/typeurl" ++ "github.com/gogo/protobuf/types" + + imagedigest "github.com/opencontainers/go-digest" + runtimespec "github.com/opencontainers/runtime-spec/specs-go" +@@ -599,3 +602,13 @@ func TestValidateTargetContainer(t *testing.T) { + } + + } ++ ++func TestGetRuntimeOptions(t *testing.T) { ++ _, err := getRuntimeOptions(containers.Container{}) ++ require.NoError(t, err) ++ ++ var pbany *types.Any // This is nil. ++ var typeurlAny typeurl.Any = pbany // This is typed nil. ++ _, err = getRuntimeOptions(containers.Container{Runtime: containers.RuntimeInfo{Options: typeurlAny}}) ++ require.NoError(t, err) ++} +diff --git a/pkg/cri/server/restart.go b/pkg/cri/server/restart.go +index f5f3e5083e2c..f7db3f7b3064 100644 +--- a/pkg/cri/server/restart.go ++++ b/pkg/cri/server/restart.go +@@ -166,7 +166,7 @@ func (c *criService) loadContainer(ctx context.Context, cntr containerd.Containe + if !ok { + return container, fmt.Errorf("metadata extension %q not found", containerMetadataExtension) + } +- data, err := typeurl.UnmarshalAny(&ext) ++ data, err := typeurl.UnmarshalAny(ext) + if err != nil { + return container, fmt.Errorf("failed to unmarshal metadata extension %q: %w", ext, err) + } +@@ -335,7 +335,7 @@ func (c *criService) loadSandbox(ctx context.Context, cntr containerd.Container) + if !ok { + return sandbox, fmt.Errorf("metadata extension %q not found", sandboxMetadataExtension) + } +- data, err := typeurl.UnmarshalAny(&ext) ++ data, err := typeurl.UnmarshalAny(ext) + if err != nil { + return sandbox, fmt.Errorf("failed to unmarshal metadata extension %q: %w", ext, err) + } +diff --git a/protobuf/any.go b/protobuf/any.go +new file mode 100644 +index 000000000000..0f667176502e +--- /dev/null ++++ b/protobuf/any.go +@@ -0,0 +1,47 @@ ++/* ++ Copyright The containerd Authors. ++ ++ Licensed under the Apache License, Version 2.0 (the "License"); ++ you may not use this file except in compliance with the License. ++ You may obtain a copy of the License at ++ ++ http://www.apache.org/licenses/LICENSE-2.0 ++ ++ Unless required by applicable law or agreed to in writing, software ++ distributed under the License is distributed on an "AS IS" BASIS, ++ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ++ See the License for the specific language governing permissions and ++ limitations under the License. ++*/ ++ ++package protobuf ++ ++import ( ++ "github.com/containerd/typeurl" ++ "github.com/gogo/protobuf/types" ++) ++ ++// FromAny converts typeurl.Any to github.com/gogo/protobuf/types.Any. ++func FromAny(from typeurl.Any) *types.Any { ++ if from == nil { ++ return nil ++ } ++ ++ if pbany, ok := from.(*types.Any); ok { ++ return pbany ++ } ++ ++ return &types.Any{ ++ TypeUrl: from.GetTypeUrl(), ++ Value: from.GetValue(), ++ } ++} ++ ++// FromAny converts an arbitrary interface to github.com/gogo/protobuf/types.Any. ++func MarshalAnyToProto(from interface{}) (*types.Any, error) { ++ any, err := typeurl.MarshalAny(from) ++ if err != nil { ++ return nil, err ++ } ++ return FromAny(any), nil ++} +diff --git a/protobuf/any_test.go b/protobuf/any_test.go +new file mode 100644 +index 000000000000..7a74ec16c28b +--- /dev/null ++++ b/protobuf/any_test.go +@@ -0,0 +1,26 @@ ++/* ++ Copyright The containerd Authors. ++ ++ Licensed under the Apache License, Version 2.0 (the "License"); ++ you may not use this file except in compliance with the License. ++ You may obtain a copy of the License at ++ ++ http://www.apache.org/licenses/LICENSE-2.0 ++ ++ Unless required by applicable law or agreed to in writing, software ++ distributed under the License is distributed on an "AS IS" BASIS, ++ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ++ See the License for the specific language governing permissions and ++ limitations under the License. ++*/ ++ ++package protobuf ++ ++import "testing" ++ ++func TestFromAny(t *testing.T) { ++ actual := FromAny(nil) ++ if actual != nil { ++ t.Fatalf("expected nil, got %v", actual) ++ } ++} +diff --git a/runtime/runtime.go b/runtime/runtime.go +index 84aaa8ac67f5..1ca22ee2bccc 100644 +--- a/runtime/runtime.go ++++ b/runtime/runtime.go +@@ -21,7 +21,7 @@ import ( + "time" + + "github.com/containerd/containerd/mount" +- "github.com/gogo/protobuf/types" ++ "github.com/containerd/typeurl" + ) + + // IO holds process IO information +@@ -35,7 +35,7 @@ type IO struct { + // CreateOpts contains task creation data + type CreateOpts struct { + // Spec is the OCI runtime spec +- Spec *types.Any ++ Spec typeurl.Any + // Rootfs mounts to perform to gain access to the container's filesystem + Rootfs []mount.Mount + // IO for the container's main process +@@ -43,9 +43,9 @@ type CreateOpts struct { + // Checkpoint digest to restore container state + Checkpoint string + // RuntimeOptions for the runtime +- RuntimeOptions *types.Any ++ RuntimeOptions typeurl.Any + // TaskOptions received for the task +- TaskOptions *types.Any ++ TaskOptions typeurl.Any + // Runtime name to use (e.g. `io.containerd.NAME.VERSION`). + // As an alternative full abs path to binary may be specified instead. + Runtime string +diff --git a/runtime/v1/linux/runtime.go b/runtime/v1/linux/runtime.go +index b6d53820a859..ad7a0b67ec0b 100644 +--- a/runtime/v1/linux/runtime.go ++++ b/runtime/v1/linux/runtime.go +@@ -41,6 +41,7 @@ import ( + "github.com/containerd/containerd/pkg/process" + "github.com/containerd/containerd/platforms" + "github.com/containerd/containerd/plugin" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + "github.com/containerd/containerd/runtime/linux/runctypes" + v1 "github.com/containerd/containerd/runtime/v1" +@@ -178,7 +179,7 @@ func (r *Runtime) Create(ctx context.Context, id string, opts runtime.CreateOpts + bundle, err := newBundle(id, + filepath.Join(r.state, namespace), + filepath.Join(r.root, namespace), +- opts.Spec.Value) ++ opts.Spec.GetValue()) + if err != nil { + return nil, err + } +@@ -191,7 +192,7 @@ func (r *Runtime) Create(ctx context.Context, id string, opts runtime.CreateOpts + shimopt := ShimLocal(r.config, r.events) + if !r.config.NoShim { + var cgroup string +- if opts.TaskOptions != nil { ++ if opts.TaskOptions != nil && opts.TaskOptions.GetValue() != nil { + v, err := typeurl.UnmarshalAny(opts.TaskOptions) + if err != nil { + return nil, err +@@ -244,7 +245,7 @@ func (r *Runtime) Create(ctx context.Context, id string, opts runtime.CreateOpts + Stderr: opts.IO.Stderr, + Terminal: opts.IO.Terminal, + Checkpoint: opts.Checkpoint, +- Options: opts.TaskOptions, ++ Options: protobuf.FromAny(opts.TaskOptions), + } + for _, m := range opts.Rootfs { + sopts.Rootfs = append(sopts.Rootfs, &types.Mount{ +@@ -537,7 +538,7 @@ func (r *Runtime) getRuncOptions(ctx context.Context, id string) (*runctypes.Run + return nil, err + } + +- if container.Runtime.Options != nil { ++ if container.Runtime.Options != nil && container.Runtime.Options.GetValue() != nil { + v, err := typeurl.UnmarshalAny(container.Runtime.Options) + if err != nil { + return nil, err +diff --git a/runtime/v1/linux/task.go b/runtime/v1/linux/task.go +index 3ac7839ff02b..44c89e5c27c2 100644 +--- a/runtime/v1/linux/task.go ++++ b/runtime/v1/linux/task.go +@@ -32,11 +32,11 @@ import ( + "github.com/containerd/containerd/events/exchange" + "github.com/containerd/containerd/identifiers" + "github.com/containerd/containerd/log" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + "github.com/containerd/containerd/runtime/v1/shim/client" + "github.com/containerd/containerd/runtime/v1/shim/v1" + "github.com/containerd/ttrpc" +- "github.com/containerd/typeurl" + "github.com/gogo/protobuf/types" + ) + +@@ -340,7 +340,7 @@ func (t *Task) Stats(ctx context.Context) (*types.Any, error) { + if err != nil { + return nil, err + } +- return typeurl.MarshalAny(stats) ++ return protobuf.MarshalAnyToProto(stats) + } + + // Cgroup returns the underlying cgroup for a linux task +diff --git a/runtime/v1/shim/service.go b/runtime/v1/shim/service.go +index a08757d0a7b9..926134821d38 100644 +--- a/runtime/v1/shim/service.go ++++ b/runtime/v1/shim/service.go +@@ -37,6 +37,7 @@ import ( + "github.com/containerd/containerd/namespaces" + "github.com/containerd/containerd/pkg/process" + "github.com/containerd/containerd/pkg/stdio" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + "github.com/containerd/containerd/runtime/linux/runctypes" + shimapi "github.com/containerd/containerd/runtime/v1/shim/v1" +@@ -412,7 +413,7 @@ func (s *Service) ListPids(ctx context.Context, r *shimapi.ListPidsRequest) (*sh + if err != nil { + return nil, fmt.Errorf("failed to marshal process %d info: %w", pid, err) + } +- pInfo.Info = a ++ pInfo.Info = protobuf.FromAny(a) + break + } + } +diff --git a/runtime/v2/manager.go b/runtime/v2/manager.go +index 1927cbb3f0c3..505d5d896995 100644 +--- a/runtime/v2/manager.go ++++ b/runtime/v2/manager.go +@@ -33,6 +33,7 @@ import ( + "github.com/containerd/containerd/pkg/timeout" + "github.com/containerd/containerd/platforms" + "github.com/containerd/containerd/plugin" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + shimbinary "github.com/containerd/containerd/runtime/v2/shim" + "github.com/containerd/containerd/runtime/v2/task" +@@ -156,7 +157,7 @@ func (m *ShimManager) ID() string { + + // Start launches a new shim instance + func (m *ShimManager) Start(ctx context.Context, id string, opts runtime.CreateOpts) (_ ShimProcess, retErr error) { +- bundle, err := NewBundle(ctx, m.root, m.state, id, opts.Spec.Value) ++ bundle, err := NewBundle(ctx, m.root, m.state, id, opts.Spec.GetValue()) + if err != nil { + return nil, err + } +@@ -197,7 +198,7 @@ func (m *ShimManager) startShim(ctx context.Context, bundle *Bundle, id string, + } + + topts := opts.TaskOptions +- if topts == nil { ++ if topts == nil || topts.GetValue() == nil { + topts = opts.RuntimeOptions + } + +@@ -212,7 +213,7 @@ func (m *ShimManager) startShim(ctx context.Context, bundle *Bundle, id string, + ttrpcAddress: m.containerdTTRPCAddress, + schedCore: m.schedCore, + }) +- shim, err := b.Start(ctx, topts, func() { ++ shim, err := b.Start(ctx, protobuf.FromAny(topts), func() { + log.G(ctx).WithField("id", id).Info("shim disconnected") + + cleanupAfterDeadShim(context.Background(), id, ns, m.shims, m.events, b) +diff --git a/runtime/v2/runc/container.go b/runtime/v2/runc/container.go +index aac9dad7e916..c7e82b610695 100644 +--- a/runtime/v2/runc/container.go ++++ b/runtime/v2/runc/container.go +@@ -49,12 +49,14 @@ func NewContainer(ctx context.Context, platform stdio.Platform, r *task.CreateTa + } + + var opts options.Options +- if r.Options != nil && r.Options.GetTypeUrl() != "" { ++ if r.Options.GetValue() != nil { + v, err := typeurl.UnmarshalAny(r.Options) + if err != nil { + return nil, err + } +- opts = *v.(*options.Options) ++ if v != nil { ++ opts = *v.(*options.Options) ++ } + } + + var mounts []process.Mount +diff --git a/runtime/v2/runc/task/service.go b/runtime/v2/runc/task/service.go +index d6af20fb03f0..25ec6d1f9df5 100644 +--- a/runtime/v2/runc/task/service.go ++++ b/runtime/v2/runc/task/service.go +@@ -38,6 +38,7 @@ import ( + "github.com/containerd/containerd/pkg/shutdown" + "github.com/containerd/containerd/pkg/stdio" + "github.com/containerd/containerd/pkg/userns" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime/v2/runc" + "github.com/containerd/containerd/runtime/v2/runc/options" + "github.com/containerd/containerd/runtime/v2/shim" +@@ -475,7 +476,7 @@ func (s *service) Pids(ctx context.Context, r *taskAPI.PidsRequest) (*taskAPI.Pi + d := &options.ProcessDetails{ + ExecID: p.ID(), + } +- a, err := typeurl.MarshalAny(d) ++ a, err := protobuf.MarshalAnyToProto(d) + if err != nil { + return nil, fmt.Errorf("failed to marshal process %d info: %w", pid, err) + } +@@ -603,7 +604,7 @@ func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI. + return nil, err + } + return &taskAPI.StatsResponse{ +- Stats: data, ++ Stats: protobuf.FromAny(data), + }, nil + } + +diff --git a/runtime/v2/runc/v1/service.go b/runtime/v2/runc/v1/service.go +index 8c473430e218..8fdac3f8a2fd 100644 +--- a/runtime/v2/runc/v1/service.go ++++ b/runtime/v2/runc/v1/service.go +@@ -41,6 +41,7 @@ import ( + "github.com/containerd/containerd/pkg/process" + "github.com/containerd/containerd/pkg/schedcore" + "github.com/containerd/containerd/pkg/stdio" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime/v2/runc" + "github.com/containerd/containerd/runtime/v2/runc/options" + "github.com/containerd/containerd/runtime/v2/shim" +@@ -507,7 +508,7 @@ func (s *service) Pids(ctx context.Context, r *taskAPI.PidsRequest) (*taskAPI.Pi + d := &options.ProcessDetails{ + ExecID: p.ID(), + } +- a, err := typeurl.MarshalAny(d) ++ a, err := protobuf.MarshalAnyToProto(d) + if err != nil { + return nil, fmt.Errorf("failed to marshal process %d info: %w", pid, err) + } +@@ -621,7 +622,7 @@ func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI. + return nil, err + } + return &taskAPI.StatsResponse{ +- Stats: data, ++ Stats: protobuf.FromAny(data), + }, nil + } + +diff --git a/runtime/v2/shim.go b/runtime/v2/shim.go +index 456ffb4409bd..18cc9a0ed6cc 100644 +--- a/runtime/v2/shim.go ++++ b/runtime/v2/shim.go +@@ -34,6 +34,7 @@ import ( + "github.com/containerd/containerd/log" + "github.com/containerd/containerd/namespaces" + "github.com/containerd/containerd/pkg/timeout" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + client "github.com/containerd/containerd/runtime/v2/shim" + "github.com/containerd/containerd/runtime/v2/task" +@@ -324,7 +325,7 @@ func (s *shimTask) delete(ctx context.Context, removeTask func(ctx context.Conte + + func (s *shimTask) Create(ctx context.Context, opts runtime.CreateOpts) (runtime.Task, error) { + topts := opts.TaskOptions +- if topts == nil { ++ if topts == nil || topts.GetValue() == nil { + topts = opts.RuntimeOptions + } + request := &task.CreateTaskRequest{ +@@ -335,7 +336,7 @@ func (s *shimTask) Create(ctx context.Context, opts runtime.CreateOpts) (runtime + Stderr: opts.IO.Stderr, + Terminal: opts.IO.Terminal, + Checkpoint: opts.Checkpoint, +- Options: topts, ++ Options: protobuf.FromAny(topts), + } + for _, m := range opts.Rootfs { + request.Rootfs = append(request.Rootfs, &types.Mount{ +diff --git a/runtime/v2/shim/publisher.go b/runtime/v2/shim/publisher.go +index ed1ebdd58b9c..20856f115bd6 100644 +--- a/runtime/v2/shim/publisher.go ++++ b/runtime/v2/shim/publisher.go +@@ -25,8 +25,8 @@ import ( + "github.com/containerd/containerd/events" + "github.com/containerd/containerd/namespaces" + "github.com/containerd/containerd/pkg/ttrpcutil" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/ttrpc" +- "github.com/containerd/typeurl" + "github.com/sirupsen/logrus" + ) + +@@ -110,7 +110,7 @@ func (l *RemoteEventsPublisher) Publish(ctx context.Context, topic string, event + if err != nil { + return err + } +- any, err := typeurl.MarshalAny(event) ++ any, err := protobuf.MarshalAnyToProto(event) + if err != nil { + return err + } +diff --git a/services/containers/helpers.go b/services/containers/helpers.go +index aece9ca41471..a75d5d62bbc0 100644 +--- a/services/containers/helpers.go ++++ b/services/containers/helpers.go +@@ -19,6 +19,9 @@ package containers + import ( + api "github.com/containerd/containerd/api/services/containers/v1" + "github.com/containerd/containerd/containers" ++ "github.com/containerd/containerd/protobuf" ++ "github.com/containerd/typeurl" ++ "github.com/gogo/protobuf/types" + ) + + func containersToProto(containers []containers.Container) []api.Container { +@@ -33,20 +36,24 @@ func containersToProto(containers []containers.Container) []api.Container { + } + + func containerToProto(container *containers.Container) api.Container { ++ extensions := make(map[string]types.Any) ++ for k, v := range container.Extensions { ++ extensions[k] = *protobuf.FromAny(v) ++ } + return api.Container{ + ID: container.ID, + Labels: container.Labels, + Image: container.Image, + Runtime: &api.Container_Runtime{ + Name: container.Runtime.Name, +- Options: container.Runtime.Options, ++ Options: protobuf.FromAny(container.Runtime.Options), + }, +- Spec: container.Spec, ++ Spec: protobuf.FromAny(container.Spec), + Snapshotter: container.Snapshotter, + SnapshotKey: container.SnapshotKey, + CreatedAt: container.CreatedAt, + UpdatedAt: container.UpdatedAt, +- Extensions: container.Extensions, ++ Extensions: extensions, + } + } + +@@ -58,6 +65,11 @@ func containerFromProto(containerpb *api.Container) containers.Container { + Options: containerpb.Runtime.Options, + } + } ++ extensions := make(map[string]typeurl.Any) ++ for k, v := range containerpb.Extensions { ++ v := v ++ extensions[k] = &v ++ } + return containers.Container{ + ID: containerpb.ID, + Labels: containerpb.Labels, +@@ -66,6 +78,6 @@ func containerFromProto(containerpb *api.Container) containers.Container { + Spec: containerpb.Spec, + Snapshotter: containerpb.Snapshotter, + SnapshotKey: containerpb.SnapshotKey, +- Extensions: containerpb.Extensions, ++ Extensions: extensions, + } + } +diff --git a/services/events/service.go b/services/events/service.go +index 3b5f811382b7..b1992a1ab716 100644 +--- a/services/events/service.go ++++ b/services/events/service.go +@@ -26,6 +26,7 @@ import ( + "github.com/containerd/containerd/events" + "github.com/containerd/containerd/events/exchange" + "github.com/containerd/containerd/plugin" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/ttrpc" + ptypes "github.com/gogo/protobuf/types" + "google.golang.org/grpc" +@@ -115,7 +116,7 @@ func toProto(env *events.Envelope) *api.Envelope { + Timestamp: env.Timestamp, + Namespace: env.Namespace, + Topic: env.Topic, +- Event: env.Event, ++ Event: protobuf.FromAny(env.Event), + } + } + +diff --git a/services/tasks/local.go b/services/tasks/local.go +index 96ed36ca4a34..34cb23d1672c 100644 +--- a/services/tasks/local.go ++++ b/services/tasks/local.go +@@ -41,6 +41,7 @@ import ( + "github.com/containerd/containerd/mount" + "github.com/containerd/containerd/pkg/timeout" + "github.com/containerd/containerd/plugin" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/runtime" + "github.com/containerd/containerd/runtime/linux/runctypes" + "github.com/containerd/containerd/runtime/v2/runc/options" +@@ -461,7 +462,7 @@ func (l *local) ListPids(ctx context.Context, r *api.ListPidsRequest, _ ...grpc. + Pid: p.Pid, + } + if p.Info != nil { +- a, err := typeurl.MarshalAny(p.Info) ++ a, err := protobuf.MarshalAnyToProto(p.Info) + if err != nil { + return nil, fmt.Errorf("failed to marshal process %d info: %w", p.Pid, err) + } +@@ -576,7 +577,7 @@ func (l *local) Checkpoint(ctx context.Context, r *api.CheckpointTaskRequest, _ + return nil, err + } + // write the config to the content store +- data, err := container.Spec.Marshal() ++ data, err := protobuf.FromAny(container.Spec).Marshal() + if err != nil { + return nil, err + } +diff --git a/task.go b/task.go +index ef8cd44942cf..bcb522c52e30 100644 +--- a/task.go ++++ b/task.go +@@ -38,6 +38,7 @@ import ( + "github.com/containerd/containerd/mount" + "github.com/containerd/containerd/oci" + "github.com/containerd/containerd/plugin" ++ "github.com/containerd/containerd/protobuf" + "github.com/containerd/containerd/rootfs" + "github.com/containerd/containerd/runtime/linux/runctypes" + "github.com/containerd/containerd/runtime/v2/runc/options" +@@ -365,7 +366,7 @@ func (t *task) Exec(ctx context.Context, id string, spec *specs.Process, ioCreat + i.Close() + } + }() +- any, err := typeurl.MarshalAny(spec) ++ any, err := protobuf.MarshalAnyToProto(spec) + if err != nil { + return nil, err + } +@@ -465,7 +466,7 @@ func (t *task) Checkpoint(ctx context.Context, opts ...CheckpointTaskOpts) (Imag + } + request.ParentCheckpoint = i.ParentCheckpoint + if i.Options != nil { +- any, err := typeurl.MarshalAny(i.Options) ++ any, err := protobuf.MarshalAnyToProto(i.Options) + if err != nil { + return nil, err + } +@@ -554,7 +555,7 @@ func (t *task) Update(ctx context.Context, opts ...UpdateTaskOpts) error { + if err != nil { + return err + } +- request.Resources = any ++ request.Resources = protobuf.FromAny(any) + } + if i.Annotations != nil { + request.Annotations = i.Annotations +-- +2.41.0 + diff --git a/anda/docker/containerd/0001-opencontainers-image-spec-v1.1.0-rc3.patch b/anda/docker/containerd/0001-opencontainers-image-spec-v1.1.0-rc3.patch new file mode 100644 index 0000000000..dafb32e536 --- /dev/null +++ b/anda/docker/containerd/0001-opencontainers-image-spec-v1.1.0-rc3.patch @@ -0,0 +1,162 @@ +From 4347fc8bc2ac225117a3280c0445e855ca7a69f3 Mon Sep 17 00:00:00 2001 +From: Akihiro Suda +Date: Tue, 9 May 2023 22:24:47 +0900 +Subject: [PATCH] go.mod: github.com/opencontainers/image-spec v1.1.0-rc3 + +Signed-off-by: Akihiro Suda +--- + go.mod | 2 +- + go.sum | 4 +-- + images/converter/default.go | 4 +-- + images/converter/uncompress/uncompress.go | 6 ++-- + images/diffid.go | 2 +- + images/mediatypes.go | 2 +- + integration/client/go.mod | 2 +- + integration/client/go.sum | 4 +-- + integration/client/import_test.go | 8 +++-- + oci/spec_opts.go | 1 + + pkg/cri/opts/spec_windows.go | 4 +-- + remotes/handlers_test.go | 1 + + .../image-spec/specs-go/v1/annotations.go | 3 -- + .../image-spec/specs-go/v1/artifact.go | 34 ------------------- + .../image-spec/specs-go/v1/config.go | 34 ++++++------------- + .../image-spec/specs-go/v1/manifest.go | 11 ++++++ + .../image-spec/specs-go/v1/mediatype.go | 19 +++++++++-- + .../image-spec/specs-go/version.go | 2 +- + vendor/modules.txt | 4 +-- + 19 files changed, 64 insertions(+), 83 deletions(-) + delete mode 100644 vendor/github.com/opencontainers/image-spec/specs-go/v1/artifact.go + +diff --git a/images/converter/default.go b/images/converter/default.go +index c67617e4ccfc..4a887242ce40 100644 +--- a/images/converter/default.go ++++ b/images/converter/default.go +@@ -431,11 +431,11 @@ func ConvertDockerMediaTypeToOCI(mt stri + case images.MediaTypeDockerSchema2LayerGzip: + return ocispec.MediaTypeImageLayerGzip + case images.MediaTypeDockerSchema2LayerForeignGzip: +- return ocispec.MediaTypeImageLayerNonDistributableGzip ++ return ocispec.MediaTypeImageLayerNonDistributableGzip //nolint:staticcheck // deprecated + case images.MediaTypeDockerSchema2Layer: + return ocispec.MediaTypeImageLayer + case images.MediaTypeDockerSchema2LayerForeign: +- return ocispec.MediaTypeImageLayerNonDistributable ++ return ocispec.MediaTypeImageLayerNonDistributable //nolint:staticcheck // deprecated + case images.MediaTypeDockerSchema2Config: + return ocispec.MediaTypeImageConfig + default: +diff --git a/images/converter/uncompress/uncompress.go b/images/converter/uncompress/uncompress.go +index 30ae02cf5ef9..ceb998fb8ff6 100644 +--- a/images/converter/uncompress/uncompress.go ++++ b/images/converter/uncompress/uncompress.go +@@ -99,7 +99,7 @@ func IsUncompressedType(mt string) bool + images.MediaTypeDockerSchema2Layer, + images.MediaTypeDockerSchema2LayerForeign, + ocispec.MediaTypeImageLayer, +- ocispec.MediaTypeImageLayerNonDistributable: ++ ocispec.MediaTypeImageLayerNonDistributable: //nolint:staticcheck // deprecated + return true + default: + return false +@@ -114,8 +114,8 @@ func convertMediaType(mt string) string + return images.MediaTypeDockerSchema2LayerForeign + case ocispec.MediaTypeImageLayerGzip, ocispec.MediaTypeImageLayerZstd: + return ocispec.MediaTypeImageLayer +- case ocispec.MediaTypeImageLayerNonDistributableGzip, ocispec.MediaTypeImageLayerNonDistributableZstd: +- return ocispec.MediaTypeImageLayerNonDistributable ++ case ocispec.MediaTypeImageLayerNonDistributableGzip, ocispec.MediaTypeImageLayerNonDistributableZstd: //nolint:staticcheck // deprecated ++ return ocispec.MediaTypeImageLayerNonDistributable //nolint:staticcheck // deprecated + default: + return mt + } +diff --git a/images/diffid.go b/images/diffid.go +index 1bd5256e2b37..c031f8e36377 100644 +--- a/images/diffid.go ++++ b/images/diffid.go +@@ -36,7 +36,7 @@ func GetDiffID(ctx context.Context, cs c + MediaTypeDockerSchema2Layer, + ocispec.MediaTypeImageLayer, + MediaTypeDockerSchema2LayerForeign, +- ocispec.MediaTypeImageLayerNonDistributable: ++ ocispec.MediaTypeImageLayerNonDistributable: //nolint:staticcheck // deprecated + return desc.Digest, nil + } + info, err := cs.Info(ctx, desc.Digest) +diff --git a/images/mediatypes.go b/images/mediatypes.go +index 067963babba1..d3b28d42dc61 100644 +--- a/images/mediatypes.go ++++ b/images/mediatypes.go +@@ -76,7 +76,7 @@ func DiffCompression(ctx context.Context + return "", nil + } + return "gzip", nil +- case ocispec.MediaTypeImageLayer, ocispec.MediaTypeImageLayerNonDistributable: ++ case ocispec.MediaTypeImageLayer, ocispec.MediaTypeImageLayerNonDistributable: //nolint:staticcheck // Non-distributable layers are deprecated + if len(ext) > 0 { + switch ext[len(ext)-1] { + case "gzip": +diff --git a/integration/client/import_test.go b/integration/client/import_test.go +index f2ba3db35f89..9f2cc46e624e 100644 +--- a/integration/client/import_test.go ++++ b/integration/client/import_test.go +@@ -370,9 +370,11 @@ func createContent(size int64, seed int6 + + func createConfig(osName, archName string) ([]byte, digest.Digest) { + image := ocispec.Image{ +- OS: osName, +- Architecture: archName, +- Author: "test", ++ Platform: ocispec.Platform{ ++ OS: osName, ++ Architecture: archName, ++ }, ++ Author: author, + } + b, _ := json.Marshal(image) + +diff --git a/oci/spec_opts.go b/oci/spec_opts.go +index f38828988577..8c4abd0bd876 100644 +--- a/oci/spec_opts.go ++++ b/oci/spec_opts.go +@@ -446,6 +446,7 @@ func WithImageConfigArgs(image Image, ar + return errors.New("no arguments specified") + } + ++ //nolint:staticcheck // ArgsEscaped is deprecated + if config.ArgsEscaped && (len(config.Entrypoint) > 0 || cmdFromImage) { + s.Process.Args = nil + s.Process.CommandLine = cmd[0] +diff --git a/pkg/cri/opts/spec_windows.go b/pkg/cri/opts/spec_windows.go +index 0964084ca107..0f7307bd0a6f 100644 +--- a/pkg/cri/opts/spec_windows.go ++++ b/pkg/cri/opts/spec_windows.go +@@ -260,7 +260,7 @@ func escapeAndCombineArgsWindows(args [] + // If image.ArgsEscaped field is set, this function sets the process command line and if not, it sets the + // process args field + func WithProcessCommandLineOrArgsForWindows(config *runtime.ContainerConfig, image *imagespec.ImageConfig) oci.SpecOpts { +- if image.ArgsEscaped { ++ if image.ArgsEscaped { //nolint:staticcheck // ArgsEscaped is deprecated + return func(ctx context.Context, client oci.Client, c *containers.Container, s *runtimespec.Spec) (err error) { + // firstArgFromImg is a flag that is returned to indicate that the first arg in the slice comes from either the + // image Entrypoint or Cmd. If the first arg instead comes from the container config (e.g. overriding the image values), +@@ -273,7 +273,7 @@ func WithProcessCommandLineOrArgsForWind + } + + var cmdLine string +- if image.ArgsEscaped && firstArgFromImg { ++ if image.ArgsEscaped && firstArgFromImg { //nolint:staticcheck // ArgsEscaped is deprecated + cmdLine = args[0] + if len(args) > 1 { + cmdLine += " " + escapeAndCombineArgsWindows(args[1:]) +diff --git a/remotes/handlers_test.go b/remotes/handlers_test.go +index c0446e1a52e6..9acf54680bf3 100644 +--- a/remotes/handlers_test.go ++++ b/remotes/handlers_test.go +@@ -78,6 +78,7 @@ func TestContextCustomKeyPrefix(t *testi + }) + } + ++//nolint:staticcheck // Non-distributable layers are deprecated + func TestSkipNonDistributableBlobs(t *testing.T) { + ctx := context.Background() + diff --git a/anda/docker/containerd/0002-Remove-windows-only-dep.patch b/anda/docker/containerd/0002-Remove-windows-only-dep.patch new file mode 100644 index 0000000000..92a2856cfb --- /dev/null +++ b/anda/docker/containerd/0002-Remove-windows-only-dep.patch @@ -0,0 +1,24 @@ +diff --git a/pkg/cri/server/helpers.go b/pkg/cri/server/helpers.go +index a8498116d..3682be668 100644 +--- a/pkg/cri/server/helpers.go ++++ b/pkg/cri/server/helpers.go +@@ -40,7 +40,7 @@ import ( + runtimespec "github.com/opencontainers/runtime-spec/specs-go" + "github.com/sirupsen/logrus" + +- runhcsoptions "github.com/Microsoft/hcsshim/cmd/containerd-shim-runhcs-v1/options" ++ // runhcsoptions "github.com/Microsoft/hcsshim/cmd/containerd-shim-runhcs-v1/options" + imagedigest "github.com/opencontainers/go-digest" + "github.com/pelletier/go-toml" + "golang.org/x/net/context" +@@ -366,8 +366,8 @@ func getRuntimeOptionsType(t string) interface{} { + return &runcoptions.Options{} + case plugin.RuntimeLinuxV1: + return &runctypes.RuncOptions{} +- case runtimeRunhcsV1: +- return &runhcsoptions.Options{} ++ // case runtimeRunhcsV1: ++ // return &runhcsoptions.Options{} + default: + return &runtimeoptions.Options{} + } diff --git a/anda/docker/containerd/anda.hcl b/anda/docker/containerd/anda.hcl new file mode 100644 index 0000000000..595cb36095 --- /dev/null +++ b/anda/docker/containerd/anda.hcl @@ -0,0 +1,5 @@ +project "pkg" { + rpm { + spec = "containerd.spec" + } +} \ No newline at end of file diff --git a/anda/docker/containerd/changelog b/anda/docker/containerd/changelog new file mode 100644 index 0000000000..eef50d4496 --- /dev/null +++ b/anda/docker/containerd/changelog @@ -0,0 +1,167 @@ +* Mon Jun 06 2022 Maxwell G 1.6.6-1 +- Update to 1.6.6. +- Mitigates GHSA-5ffw-gxpp-mxpf / CVE-2022-31030. + +* Sun Jun 05 2022 Maxwell G 1.6.5-2 +- Bump release + +* Sat Jun 04 2022 Maxwell G 1.6.5-1 +- Update to 1.6.5. Fixes rhbz#2093608. + +* Wed May 11 2022 Maxwell G 1.6.4-1 +- Update to 1.6.4. Fixes rhbz#079050 and rhbz#2079779. + +* Sat Apr 16 2022 Fabio Alessandro Locati 1.6.2-2 +- Rebuilt for CVE-2022-27191 + +* Sun Apr 03 2022 Maxwell G 1.6.2-1 +- Update to 1.6.2 (rhbz#2068277). Mitigates CVE-2022-24769 / + GHSA-c9cp-9c75-9v8c. + +* Sat Mar 12 2022 Maxwell G 1.6.1-1 +- Update to 1.6.1 (rhbz#2060228). Mitigates CVE-2022-23648. + +* Thu Feb 17 2022 Maxwell G 1.6.0-1 +- Update to 1.6.0 (rhbz#2054935). Use unbundled deps. + +* Sun Feb 06 2022 Robert-André Mauchin 1.6.0~rc.2-2 +- Disable platform tests + +* Sat Feb 05 2022 Robert-André Mauchin 1.6.0~rc.2-1 +- Update to 1.6.0~rc.2 Close: rhbz#1731597 Close: rhbz#1798419 + +* Mon Jan 31 2022 Maxwell G - 1.5.9-1 +- Update to 1.5.9. Fixes FTBFS. Closes rhbz#2045277. +- Mitigates CVE-2021-43816. Closes rhbz#2044434. Closes rhbz#2044436. +- Temporarily build using vendored dependencies. + +* Wed Jan 19 2022 Fedora Release Engineering - 1.5.8-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild + +* Mon Nov 22 2021 Olivier Lemasle - 1.5.8-1 +- Update to upstream 1.5.8 (fixes rhbz#2013807) +- Mitigate CVE-2021-41190 (fixes GHSA-5j5w-g665-5m35, fixes rhbz#2024941) + +* Sun Oct 10 2021 Olivier Lemasle - 1.5.7-1 +- Update to upstream 1.5.7 (fixes rhbz#2009149) +- Fixes CVE-2021-41103 (fixes rhbz#2011014, rhbz#2011007) + +* Sun Aug 15 2021 Olivier Lemasle - 1.5.5-1 +- Update to upstream 1.5.5 (fixes rhbz#1983820) +- Fixes CVE-2021-32760 (rhbz#1983932) + +* Wed Jul 21 2021 Fedora Release Engineering - 1.5.3-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild + +* Wed Jul 14 11:28:54 CEST 2021 Olivier Lemasle - 1.5.3-1 +- Update to upstream 1.5.3 (fixes rhbz#1956638) + +* Tue May 04 2021 Olivier Lemasle - 1.5.0-1 +- Update to upstream 1.5.0 (#1956638) + +* Mon Apr 19 2021 Olivier Lemasle - 1.5.0~rc.1-1 +- Update to 1.5.0~rc.1 (#1948041) + +* Wed Mar 17 2021 Olivier Lemasle - 1.5.0~beta.4-1 +- Update to upstream 1.5.0-beta.4 + +* Sat Mar 06 2021 Olivier Lemasle - 1.5.0~beta.3-1 +- Update to upstream 1.5.0-beta.3 + +* Tue Mar 02 2021 Zbigniew Jędrzejewski-Szmek - 1.5.0~beta.0-2 +- Rebuilt for updated systemd-rpm-macros + See https://pagure.io/fesco/issue/2583. + +* Thu Jan 28 2021 Olivier Lemasle 1.5.0~beta.0-1 +- Update to 1.5.0~beta.0 (#1918993) + +* Tue Jan 26 2021 Fedora Release Engineering - 1.4.3-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Tue Dec 01 2020 Olivier Lemasle - 1.4.3-1 +- Fix CVE-2020-15257 (#1903050) +- Update to latest upstream - 1.4.3 (#1901908) + +* Mon Nov 2 23:23:57 CET 2020 Olivier Lemasle - 1.4.1-2 +- Fix man pages + +* Wed Sep 30 2020 Robert-André Mauchin - 1.4.1-1 +- Update to 1.4.1 + +* Sat Aug 01 2020 Fedora Release Engineering - 1.3.3-3 +- Second attempt - Rebuilt for + https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Mon Jul 27 2020 Fedora Release Engineering - 1.3.3-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Wed Apr 01 2020 Olivier Lemasle - 1.3.3-1 +- Update to 1.3.3 + +* Sun Mar 22 2020 Olivier Lemasle - 1.2.13-2 +- Remove version requirement on golang-github-containerd-cri + +* Sun Mar 22 2020 Olivier Lemasle - 1.2.13-1 +- Exclude failing integration tests +- Update to containerd 1.2.13 + +* Tue Jan 28 2020 Fedora Release Engineering - 1.2.6-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Wed Jul 24 2019 Fedora Release Engineering - 1.2.6-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Wed May 01 15:33:19 CEST 2019 Robert-André Mauchin - 1.2.6-1.20190501gitd68b593 +- Release 1.2.6, commit d68b593de4ab10bb8b4fd64560e10d43c7156db2 + +* Tue Feb 26 2019 Carl George - 1.2.4-1 +- Latest upstream + +* Thu Jan 31 2019 Fedora Release Engineering - 1.2.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Thu Jan 03 2019 Carl George - 1.2.1-1 +- Latest upstream +- Run test suite (except on el7 or %%arm) + +* Thu Oct 25 2018 Carl George - 1.2.0-1 +- Latest upstream + +* Mon Aug 13 2018 Carl George - 1.1.2-1 +- Latest upstream + +* Thu Jul 12 2018 Fedora Release Engineering - 1.1.0-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild + +* Thu Apr 26 2018 Carl George - 1.1.0-1 +- Latest upstream +- Build and include man pages + +* Wed Apr 04 2018 Carl George - 1.0.3-1 +- Latest upstream + +* Wed Feb 07 2018 Fedora Release Engineering - 1.0.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Mon Jan 22 2018 Carl George - 1.0.1-1 +- Latest upstream + +* Wed Dec 06 2017 Carl George - 1.0.0-1 +- Latest upstream + +* Fri Nov 10 2017 Carl George - 1.0.0-0.5.beta.3 +- Latest upstream + +* Thu Oct 19 2017 Carl George - 1.0.0-0.4.beta.2 +- Own /etc/containerd + +* Thu Oct 12 2017 Carl George - 1.0.0-0.3.beta.2 +- Latest upstream +- Require runc 1.0.0 https://github.com/containerd/containerd/issues/1508#issuecomment-335566293 + +* Mon Oct 09 2017 Carl George - 1.0.0-0.2.beta.1 +- Add provides for vendored dependencies +- Add ctr command + +* Wed Oct 04 2017 Carl George - 1.0.0-0.1.beta.1 +- Initial package diff --git a/anda/docker/containerd/containerd.spec b/anda/docker/containerd/containerd.spec new file mode 100644 index 0000000000..d2f0d5f8d6 --- /dev/null +++ b/anda/docker/containerd/containerd.spec @@ -0,0 +1,127 @@ +# This is a simplified version of the containerd.spec file from Fedora +# designed to build from upstream containerd, not Fedora + +# Created due to https://bugzilla.redhat.com/show_bug.cgi?id=2237396 + +%global debug_package %{nil} + +# https://github.com/containerd/containerd +%global goipath github.com/containerd/containerd +Version: 1.6.27 + +%gometa + +%global goname containerd +%global godevelname containerd-devel + +%global common_description %{expand: +Containerd is an industry-standard container runtime with an emphasis on +simplicity, robustness and portability. It is available as a daemon for Linux +and Windows, which can manage the complete container lifecycle of its host +system: image transfer and storage, container execution and supervision, +low-level storage and network attachments, etc.} + +%global golicenses LICENSE NOTICE +%global godocs docs ROADMAP.md SCOPE.md code-of-conduct.md\\\ + BUILDING.md README.md RELEASES.md + +Name: %{goname} +Release: 1%{?dist} +Summary: Open and reliable container runtime + +License: Apache-2.0 +URL: https://github.com/containerd/containerd +Source0: %{url}/archive/refs/tags/v%{version}.tar.gz#/containerd-%{version}.tar.gz +Source2: containerd.toml +# Carve out code requiring github.com/Microsoft/hcsshim +#Patch0: 0001-Revert-commit-for-Windows-metrics.patch +#Patch1: 0002-Remove-windows-only-dep.patch +# Backport for github.com/containerd/typeurl update +#Patch2: 0001-Use-typeurl.Any-instead-of-github.com-gogo-protobuf-.patch +# To use with latest go-runc +#Patch3: 0001-Add-reaper-StartLocked.patch +# To use with latest opencontainers/image-spec +#Patch4: 0001-opencontainers-image-spec-v1.1.0-rc3.patch + +BuildRequires: btrfs-progs-devel +BuildRequires: go-md2man +BuildRequires: systemd-rpm-macros +BuildRequires: git-core + +Requires: runc + +%description +%{common_description} + +%package devel +Summary: Development files for %{name} +Requires: %{name}%{?_isa} = %{version}-%{release} + + +%description devel +%{common_description} + +This package contains library source intended for +building other packages which use import path with +%{goname} prefix. + +%prep +%autosetup -p1 -n %{goname}-%{version} +# Used only for generation: +#rm -rf cmd/protoc-gen-gogoctrd +# Replace default bin directory +sed -i "s|/usr/local/bin/containerd|/usr/bin/containerd|" containerd.service + +%build +#pushd containerd +export GOFLAGS="-buildmode=pie -v -x" +%make_build +mkdir _man +go-md2man -in docs/man/containerd-config.8.md -out _man/containerd-config.8 +go-md2man -in docs/man/containerd-config.toml.5.md -out _man/containerd-config.toml.5 +go run cmd/gen-manpages/main.go containerd.8 _man +go run cmd/gen-manpages/main.go ctr.8 _man + +%install +export GOFLAGS="-buildmode=pie -v -x" +%make_install PREFIX=%{_prefix} DESTDIR=%{buildroot} + + + +install -D -p -m 0644 _man/containerd.8 %{buildroot}%{_mandir}/man8/containerd.8 +install -D -p -m 0644 _man/containerd-config.8 %{buildroot}%{_mandir}/man8/containerd-config.8 +install -D -p -m 0644 _man/ctr.8 %{buildroot}%{_mandir}/man8/ctr.8 +install -D -p -m 0644 _man/containerd-config.toml.5 %{buildroot}%{_mandir}/man5/containerd-config.toml.5 +install -D -p -m 0644 containerd.service %{buildroot}%{_unitdir}/containerd.service +install -D -p -m 0644 %{S:2} %{buildroot}%{_sysconfdir}/containerd/config.toml +mkdir -p %{buildroot}%{_sharedstatedir}/containerd/opt + +%post +%systemd_post containerd.service + +%preun +%systemd_preun containerd.service + +%postun +%systemd_postun_with_restart containerd.service + + + +%files +%license LICENSE NOTICE +%doc docs ROADMAP.md SCOPE.md code-of-conduct.md BUILDING.md +%doc README.md RELEASES.md +%{_bindir}/* +%{_mandir}/man8/containerd.8* +%{_mandir}/man8/containerd-config.8* +%{_mandir}/man8/ctr.8* +%{_mandir}/man5/containerd-config.toml.5* +%{_unitdir}/containerd.service +%dir %{_sysconfdir}/containerd +%config(noreplace) %{_sysconfdir}/containerd/config.toml +%dir %{_sharedstatedir}/containerd +%dir %{_sharedstatedir}/containerd/opt + + +%changelog +%autochangelog diff --git a/anda/docker/containerd/containerd.toml b/anda/docker/containerd/containerd.toml new file mode 100644 index 0000000000..4a76ac46c2 --- /dev/null +++ b/anda/docker/containerd/containerd.toml @@ -0,0 +1,9 @@ +version = 2 + +[plugins] + [plugins."io.containerd.grpc.v1.cri"] + [plugins."io.containerd.grpc.v1.cri".cni] + bin_dir = "/usr/libexec/cni/" + conf_dir = "/etc/cni/net.d" + [plugins."io.containerd.internal.v1.opt"] + path = "/var/lib/containerd/opt" diff --git a/anda/docker/containerd/update.rhai b/anda/docker/containerd/update.rhai new file mode 100644 index 0000000000..2ff7c6b2db --- /dev/null +++ b/anda/docker/containerd/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("containerd/containerd")); diff --git a/anda/moby-extras/moby-buildx/anda.hcl b/anda/docker/moby-buildx/anda.hcl similarity index 100% rename from anda/moby-extras/moby-buildx/anda.hcl rename to anda/docker/moby-buildx/anda.hcl diff --git a/anda/moby-extras/moby-buildx/moby-buildx.spec b/anda/docker/moby-buildx/moby-buildx.spec similarity index 97% rename from anda/moby-extras/moby-buildx/moby-buildx.spec rename to anda/docker/moby-buildx/moby-buildx.spec index 5da7572b65..39bb779ce1 100644 --- a/anda/moby-extras/moby-buildx/moby-buildx.spec +++ b/anda/docker/moby-buildx/moby-buildx.spec @@ -1,7 +1,7 @@ %define debug_package %nil Name: moby-buildx -Version: 0.12.0 +Version: 0.12.1 Release: 1%{?dist} Summary: Docker CLI plugin for extended build capabilities with BuildKit diff --git a/anda/moby-extras/moby-buildx/update.rhai b/anda/docker/moby-buildx/update.rhai similarity index 100% rename from anda/moby-extras/moby-buildx/update.rhai rename to anda/docker/moby-buildx/update.rhai diff --git a/anda/moby-extras/moby-compose/anda.hcl b/anda/docker/moby-compose/anda.hcl similarity index 100% rename from anda/moby-extras/moby-compose/anda.hcl rename to anda/docker/moby-compose/anda.hcl diff --git a/anda/moby-extras/moby-compose/moby-compose.spec b/anda/docker/moby-compose/moby-compose.spec similarity index 98% rename from anda/moby-extras/moby-compose/moby-compose.spec rename to anda/docker/moby-compose/moby-compose.spec index cec8f78e98..6070176851 100644 --- a/anda/moby-extras/moby-compose/moby-compose.spec +++ b/anda/docker/moby-compose/moby-compose.spec @@ -1,7 +1,7 @@ %define debug_package %{nil} Name: moby-compose -Version: 2.23.1 +Version: 2.24.0 Release: 1%{?dist} Summary: Define and run multi-container applications with Docker diff --git a/anda/moby-extras/moby-compose/update.rhai b/anda/docker/moby-compose/update.rhai similarity index 100% rename from anda/moby-extras/moby-compose/update.rhai rename to anda/docker/moby-compose/update.rhai diff --git a/anda/docker/moby-engine/.gitignore b/anda/docker/moby-engine/.gitignore new file mode 100644 index 0000000000..d310b090e3 --- /dev/null +++ b/anda/docker/moby-engine/.gitignore @@ -0,0 +1,59 @@ +/2d0083d657f82c47044c8d3948ba434b622fe2fd.tar.gz +/425e105d5a03fabd737a126ad93d62a9eeede87f.tar.gz +/894b81a4b802e4eb2a91d1ce216b8817763c29fb.tar.gz +/e7933d41e7b206756115aa9df5e0599fc5169742.tar.gz +/fec3683b971d9c3ef73f284f176672c44b448662.tar.gz +/0dd43dd87fd530113bf44c9bba9ad8b20ce4637f.tar.gz +/7141c199a2edb2a90b778175f836f9dd2a22c95a.tar.gz +/264bffcb88c1b6b7471c04e3c6b3f301233a544b.tar.gz +/afacb8b7f0d8d4f9d2a8e8736e9c993e672b41f3.tar.gz +/bf2bd42abc0a3734f12b5ec724e571434e42c669.tar.gz +/2e24aed516bd5c836e11378bb457dd612aa868ed.tar.gz +/42e35e61f352e527082521280d5ea3761f0dee50.tar.gz +/4484c46d9d1a2d10b8fc662923ad586daeedb04f.tar.gz +/026aabaa659832804b01754aaadd2c0f420c68b6.tar.gz +/de40ad007797e0dcd8b7126f27bb87401d224240.tar.gz +/moby-v20.10.5.tar.gz +/cli-v20.10.5.tar.gz +/moby-v20.10.6.tar.gz +/cli-v20.10.6.tar.gz +/moby-v20.10.7.tar.gz +/cli-v20.10.7.tar.gz +/cli-v20.10.8.tar.gz +/moby-v20.10.8.tar.gz +/cli-v20.10.9.tar.gz +/moby-v20.10.9.tar.gz +/cli-v20.10.10.tar.gz +moby-v20.10.10.tar.gz +/cli-v20.10.11.tar.gz +/moby-v20.10.11.tar.gz +/cli-v20.10.12.tar.gz +/moby-v20.10.12.tar.gz +/cli-20.10.12.tar.gz +/moby-20.10.12.tar.gz +/tini-de40ad0.tar.gz +/cli-20.10.14.tar.gz +/moby-20.10.14.tar.gz +/cli-20.10.15.tar.gz +/moby-20.10.15.tar.gz +/cli-20.10.16.tar.gz +/moby-20.10.16.tar.gz +/cli-20.10.17.tar.gz +/moby-20.10.17.tar.gz +/cli-20.10.18.tar.gz +/moby-20.10.18.tar.gz +/cli-20.10.19.tar.gz +/moby-20.10.19.tar.gz +/cli-20.10.20.tar.gz +/moby-20.10.20.tar.gz +/cli-20.10.21.tar.gz +/moby-20.10.21.tar.gz +/cli-20.10.22.tar.gz +/moby-20.10.22.tar.gz +/moby-20.10.23.tar.gz +/cli-20.10.23.tar.gz +/moby-23.0.4.tar.gz +/cli-23.0.4.tar.gz +/tini-0b44d36.tar.gz +/cli-24.0.5.tar.gz +/moby-24.0.5.tar.gz diff --git a/anda/docker/moby-engine/README.md b/anda/docker/moby-engine/README.md new file mode 100644 index 0000000000..57607ed02e --- /dev/null +++ b/anda/docker/moby-engine/README.md @@ -0,0 +1,3 @@ +# moby-engine + +The moby-engine package \ No newline at end of file diff --git a/anda/docker/moby-engine/anda.hcl b/anda/docker/moby-engine/anda.hcl new file mode 100644 index 0000000000..be47166b46 --- /dev/null +++ b/anda/docker/moby-engine/anda.hcl @@ -0,0 +1,5 @@ +project "pkg" { + rpm { + spec = "moby-engine.spec" + } +} \ No newline at end of file diff --git a/anda/docker/moby-engine/docker.service b/anda/docker/moby-engine/docker.service new file mode 100644 index 0000000000..41cb0e397e --- /dev/null +++ b/anda/docker/moby-engine/docker.service @@ -0,0 +1,38 @@ +[Unit] +Description=Docker Application Container Engine +Documentation=https://docs.docker.com +After=docker.socket network-online.target firewalld.service +Requires=docker.socket +Wants=network-online.target + +[Service] +Type=notify +EnvironmentFile=-/etc/sysconfig/docker +# the default is not to use systemd for cgroups because the delegate issues still +# exists and systemd currently does not support the cgroup feature set required +# for containers run by docker +ExecStart=/usr/bin/dockerd \ + --host=fd:// \ + --exec-opt native.cgroupdriver=systemd \ + $OPTIONS +ExecReload=/bin/kill -s HUP $MAINPID +# Having non-zero Limit*s causes performance problems due to accounting overhead +# in the kernel. We recommend using cgroups to do container-local accounting. +LimitNOFILE=infinity +LimitNPROC=infinity +LimitCORE=infinity +# Uncomment TasksMax if your systemd version supports it. +# Only systemd 226 and above support this version. +#TasksMax=infinity +TimeoutStartSec=0 +# set delegate yes so that systemd does not reset the cgroups of docker containers +#Delegate=yes +# kill only the docker process, not all processes in the cgroup +KillMode=process +# restart the docker process if it exits prematurely +Restart=on-failure +StartLimitBurst=3 +StartLimitInterval=60s + +[Install] +WantedBy=multi-user.target diff --git a/anda/docker/moby-engine/docker.sysconfig b/anda/docker/moby-engine/docker.sysconfig new file mode 100644 index 0000000000..6ba9fd7e8c --- /dev/null +++ b/anda/docker/moby-engine/docker.sysconfig @@ -0,0 +1,10 @@ +# /etc/sysconfig/docker + +# Modify these options if you want to change the way the docker daemon runs +OPTIONS="--selinux-enabled \ + --log-driver=journald \ + --live-restore \ + --default-ulimit nofile=1024:1024 \ + --init-path /usr/libexec/docker/docker-init \ + --userland-proxy-path /usr/libexec/docker/docker-proxy \ +" diff --git a/anda/docker/moby-engine/generate-docs.sh b/anda/docker/moby-engine/generate-docs.sh new file mode 100644 index 0000000000..09fb5cb7bd --- /dev/null +++ b/anda/docker/moby-engine/generate-docs.sh @@ -0,0 +1,12 @@ +cd man +for FILE in *.md; do + base="$(basename "$FILE")" + name="${base%.md}" + num="${name##*.}" + if [ -z "$num" ] || [ "$name" = "$num" ]; then + # skip files that aren't of the format xxxx.N.md (like README.md) + continue + fi + mkdir -p "./man${num}" + (set -x ;go-md2man -in "$FILE" -out "./man${num}/${name}") +done diff --git a/anda/docker/moby-engine/moby-engine-systemd-sysusers.conf b/anda/docker/moby-engine/moby-engine-systemd-sysusers.conf new file mode 100644 index 0000000000..fafc51244a --- /dev/null +++ b/anda/docker/moby-engine/moby-engine-systemd-sysusers.conf @@ -0,0 +1,2 @@ +#Type Name ID +g docker - diff --git a/anda/docker/moby-engine/moby-engine.spec b/anda/docker/moby-engine/moby-engine.spec new file mode 100644 index 0000000000..3dfaa45ece --- /dev/null +++ b/anda/docker/moby-engine/moby-engine.spec @@ -0,0 +1,559 @@ +# This specfile is licensed under: +# SPDX-License-Identifier: MIT +# SPDX-FileCopyrightText: Fedora Project Authors +# SPDX-FileCopyrightText: 2022 Maxwell G +# See %%{name}.spec.license for the full license text. + +# disable debuginfo for now +%global debug_package %{nil} + +# moby +%global goipath_moby github.com/docker/docker +%global git_moby https://%%{goipath_moby} +#%%global commit_moby 9fdeb9c3de2f2d9f5799be373f27b2f9df44609d +#%%global shortcommit_moby %%(c=%%{commit_moby}; echo ${c:0:7}) + +# cli +%global goipath_cli github.com/docker/cli +%global git_cli https://%%{goipath_cli} +#%%global commit_cli baeda1f82a10204ec5708d5fbba130ad76cfee49 +#%%global shortcommit_cli %%(c=%%{commit_cli}; echo ${c:0:7}) + +# tini +%global git_tini https://github.com/krallin/tini +%global commit_tini 0b44d3665869e46ccbac7414241b8256d6234dc4 +%global shortcommit_tini %(c=%{commit_tini}; echo ${c:0:7}) + +%global anda_go_build go build -buildmode=pie -v -x + +Name: moby-engine +Version: 24.0.5 +Release: 1%{?dist} +Summary: The open-source application container engine +License: Apache-2.0 +Source0: %{git_moby}/archive/v%{version}/moby-%{version}.tar.gz +Source1: %{git_cli}/archive/v%{version}/cli-%{version}.tar.gz +Source2: %{git_tini}/archive/%{commit_tini}/tini-%{shortcommit_tini}.tar.gz +Source3: docker.service +Source4: docker.sysconfig +Source5: moby-engine-systemd-sysusers.conf +Source6: generate-docs.sh + +# Seperate file containing virtual provides for bundled deps that's %%include'd in the specfile. +#Source100: provides.spec.inc +# Specfile license +Source200: moby-engine.spec.license + +URL: https://www.docker.com + +ExclusiveArch: %{golang_arches} + +BuildRequires: pkgconfig(libbtrfsutil) +BuildRequires: pkgconfig(devmapper) +BuildRequires: golang +BuildRequires: go-rpm-macros +BuildRequires: go-md2man +BuildRequires: pkgconfig(libseccomp) >= 2.3.0 +BuildRequires: make +BuildRequires: pkgconfig(audit) +BuildRequires: pkgconfig(systemd) +BuildRequires: systemd-rpm-macros +BuildRequires: firewalld-filesystem + +# Build dependencies for tini +BuildRequires: cmake +BuildRequires: glibc-static + +# required packages on install +Requires: container-selinux +Requires: containerd +Requires: iptables +Requires: pigz +Requires: runc +Requires: systemd +Requires: tar +Requires: xz + +# Resolves: rhbz#1165615 +Requires: device-mapper-libs >= 1.02.90-1 + +# Replace the old Docker packages +Provides: docker = %{version}-%{release} +Provides: docker-latest = %{version}-%{release} + +# conflicting packages +Conflicts: docker-ce +Conflicts: docker-ce-cli +Conflicts: docker-common +Conflicts: docker-ee +Conflicts: docker-engine-cs +Conflicts: docker-io +Conflicts: podman-docker + +%description +Docker is an open source project to build, ship and run any application as a +lightweight container. + +Docker containers are both hardware-agnostic and platform-agnostic. This means +they can run anywhere, from your laptop to the largest EC2 compute instance and +everything in between - and they don't require you to use a particular +language, framework or packaging system. That makes them great building blocks +for deploying and scaling web apps, databases, and backend services without +depending on a particular stack or provider. + +%package fish-completion +Summary: Fish completion files for %{name} +BuildArch: noarch +Requires: %{name} = %{version}-%{release} +Requires: fish +Provides: docker-fish-completion = %{version}-%{release} + +%description fish-completion +This package installs %{summary}. + +%package zsh-completion +Summary: Zsh completion files for %{name} +BuildArch: noarch +Requires: %{name} = %{version}-%{release} +Requires: zsh +Provides: docker-zsh-completion = %{version}-%{release} + +%description zsh-completion +This package installs %{summary}. + +%package nano +Summary: GNU nano syntax highlighting files for Moby +BuildArch: noarch +Requires: %{name} = %{version}-%{release} +Requires: nano + +%description nano +This package installs %{summary}. + +%prep +%setup -q -a 1 -a 2 -n moby-%{version} +ln -s vendor.mod go.mod +#export GOPATH="$PWD" +#go get -x +#go mod vendor +# correct rpmlint errors for bash completion +sed -i '/env bash/d' cli-%{version}/contrib/completion/bash/docker +cp %{SOURCE6} cli-%{version}/scripts/docs/generate-man.sh +%build +mkdir -p _build/bin +export CGO_ENABLED=1 + +export DISABLE_WARN_OUTSIDE_CONTAINER=1 + +#go mod download + + +# build docker-proxy / libnetwork +( + + # Link source and vendored deps into local GOPATH. + #ln -fns ../../.. src/%{goipath_moby} + #export GOPATH="${PWD}" + %anda_go_build -o _build/bin/docker-proxy github.com/docker/docker/cmd/docker-proxy +) + +# build tini (installed as docker-init) +( + cd tini-%{commit_tini} + %cmake + make tini-static -C "%{__cmake_builddir}" +) + +%global buildtime %(date --utc --date="@${SOURCE_DATE_EPOCH:-$(date +%s)}" +"%Y-%m-%dT%H:%M:%SZ") +# build engine +( + mkdir -p src/github.com/docker + # Link source and vendored deps into local GOPATH. + ln -fns ../../.. src/%{goipath_moby} + # Build using source and vendored deps in local GOPATH. + export GOPATH="${PWD}" + export GO111MODULE=off + export LDFLAGS="-w" + export LDFLAGS+=" -X github.com/docker/docker/dockerversion.Version=%{version}" + export LDFLAGS+=" -X github.com/docker/docker/dockerversion.GitCommit=%{shortcommit_moby}" + export LDFLAGS+=" -X github.com/docker/docker/dockerversion.IAmStatic=false" + export LDFLAGS+=" -X 'github.com/docker/docker/dockerversion.BuildTime=%{buildtime}'" + export DOCKER_BUILDTAGS="seccomp selinux journald" + export BUILDTAGS="${DOCKER_BUILDTAGS}" + export GOBUILDTAGS="${BUILDTAGS}" + %anda_go_build -o _build/bin/dockerd %{goipath_moby}/cmd/dockerd + # VERSION=%%{version} DOCKER_GITCOMMIT=%%{shortcommit_moby} bash sh dynbinary + # mv bundles/dynbinary-daemon/dockerd-%%{version} _build/bin/dockerd +) + +# build cli +( + cd cli-%{version} + mkdir -p src/github.com/docker + # Link source and vendored deps into local GOPATH. + ln -fns ../../.. src/%{goipath_cli} + # export DISABLE_WARN_OUTSIDE_CONTAINER=1 + # Build using source and vendored deps in local GOPATH. + export GOPATH="${PWD}" + export GO111MODULE=off + export LDFLAGS="\ + -w \ + -X \"github.com/docker/cli/cli/version.GitCommit=%{shortcommit_cli}\" \ + -X \"github.com/docker/cli/cli/version.BuildTime=%{buildtime}\" \ + -X \"github.com/docker/cli/cli/version.Version=%{version}\" \ + " + export BUILDTAGS="pkcs11" + export GOBUILDTAGS="${BUILDTAGS}" + %anda_go_build -o ../_build/bin/docker %{goipath_cli}/cmd/docker + # make VERSION=%%{version} GITCOMMIT=%%{shortcommit_cli} dynbinary + + scripts/docs/generate-man.sh +) + +%install +# install binary +install -Dpm 755 _build/bin/docker _build/bin/dockerd -t %{buildroot}%{_bindir}/ + +# install proxy +install -Dpm 755 _build/bin/docker-proxy -t %{buildroot}%{_libexecdir}/docker/ + +# install tini +install -Dpm 755 tini-%{commit_tini}/%{__cmake_builddir}/tini-static %{buildroot}%{_libexecdir}/docker/docker-init + +# install udev rules +install -Dpm 644 contrib/udev/80-docker.rules -t %{buildroot}%{_usr}/lib/udev/rules.d/ + +# add init scripts +install -Dpm 644 %{SOURCE3} contrib/init/systemd/docker.socket -t %{buildroot}%{_unitdir}/ + +# for additional args +install -Dpm 644 %{SOURCE4} %{buildroot}%{_sysconfdir}/sysconfig/docker + +# Install sysusers configuration +install -Dpm 0644 %{SOURCE5} %{buildroot}%{_sysusersdir}/moby-engine.conf + +# add bash, zsh, and fish completions +install -Dpm 644 cli-%{version}/contrib/completion/bash/docker -t %{buildroot}%{_datadir}/bash-completion/completions/ +install -Dpm 644 cli-%{version}/contrib/completion/zsh/_docker -t %{buildroot}%{_datadir}/zsh/site-functions/ +install -Dpm 644 cli-%{version}/contrib/completion/fish/docker.fish -t %{buildroot}%{_datadir}/fish/vendor_completions.d/ + +# install manpages +install -Dpm 644 cli-%{version}/man/man1/*.1 -t %{buildroot}%{_mandir}/man1/ +install -Dpm 644 cli-%{version}/man/man5/*.5 -t %{buildroot}%{_mandir}/man5/ +install -Dpm 644 cli-%{version}/man/man8/*.8 -t %{buildroot}%{_mandir}/man8/ + +# add nano files +install -Dpm 644 contrib/syntax/nano/Dockerfile.nanorc -t %{buildroot}%{_datadir}/nano/ + +for cli_file in LICENSE MAINTAINERS NOTICE README.md; do + cp "cli-%{version}/$cli_file" "cli-$cli_file" +done + +%pre +%sysusers_create_compat %{SOURCE5} + +%post +%systemd_post docker.service docker.socket +%firewalld_reload + +%preun +%systemd_preun docker.service docker.socket + +%postun +%systemd_postun_with_restart docker.service + +%files +%license LICENSE cli-LICENSE +%doc AUTHORS CONTRIBUTING.md MAINTAINERS NOTICE README.md +%doc cli-MAINTAINERS cli-NOTICE cli-README.md +%config(noreplace) %{_sysconfdir}/sysconfig/docker +%{_bindir}/docker +%{_bindir}/dockerd +%dir %{_libexecdir}/docker/ +%{_libexecdir}/docker/docker-proxy +%{_libexecdir}/docker/docker-init +%{_usr}/lib/udev/rules.d/80-docker.rules +%{_unitdir}/docker.service +%{_unitdir}/docker.socket +%{_sysusersdir}/moby-engine.conf +%{_datadir}/bash-completion/completions/docker +%{_mandir}/man1/docker*.1* +%{_mandir}/man5/{Dockerfile,docker-config-json}.5* +%{_mandir}/man8/dockerd.8* + +%files zsh-completion +%{_datadir}/zsh/site-functions/_docker + +%files fish-completion +%{_datadir}/fish/vendor_completions.d/docker.fish + +%files nano +%dir %{_datadir}/nano +%{_datadir}/nano/Dockerfile.nanorc + +%changelog +* Wed Aug 23 2023 LuK1337 - 24.0.5-1 +- Update moby-engine to 24.0.5 + +* Thu Jul 20 2023 Fedora Release Engineering +- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild + +* Sun Jan 29 2023 John Ghatas +- Update moby-engine to 23.0.4 + +* Sun Jan 29 2023 Sérgio Basto +- Update moby-engine to 20.10.23 + +* Thu Jan 19 2023 Fedora Release Engineering +- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild + +* Sun Jan 01 2023 Sérgio Basto +- Update moby-engine to 20.10.22 + +* Wed Dec 14 2022 Dan Čermák - 20.10.21-1 +- Update to 20.10.21 +- Fix build, use libnetwork from golang-github-docker-0:22.06.0~beta + +* Thu Oct 20 2022 Jan Kuparinen - 20.10.20-1 +- Update to 20.10.20. +- Mitigates CVE-2022-39253 + +* Tue Oct 18 2022 Jan Kuparinen - 20.10.19-1 +- Update to 20.10.19. + +* Sat Sep 10 2022 Maxwell G - 20.10.18-1 +- Update to 20.10.18. +- Mitigates CVE-2022-36109 / GHSA-rc4r-wh2q-q6c4 + +* Tue Aug 30 2022 Luca BRUNO - 20.10.17-8 +- Move 'docker' group creation logic to a sysusers.d fragment + Resolves: rhbz#1745936 + +* Fri Aug 05 2022 Maxwell G - 20.10.17-7 +- Migrate to SPDX license identifiers +- Generate debuginfo +- Specfile improvements + +* Thu Jul 21 2022 Fedora Release Engineering +- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild + +* Tue Jul 19 2022 Maxwell G - 20.10.17-5 +- Rebuild for CVE-2022-{1705,32148,30631,30633,28131,30635,30632,30630,1962} in + golang + +* Mon Jul 04 2022 Maxwell G - 20.10.17-4 +- Only build on %%golang_arches (i.e. where golang is available). + +* Sun Jun 19 2022 Maxwell G - 20.10.17-3 +- Rebuilt for CVE-2022-1996, CVE-2022-24675, CVE-2022-28327, CVE-2022-27191, + CVE-2022-29526, CVE-2022-30629. + +* Sat Jun 11 2022 Maxwell G - 20.10.17-2 +- Rebuild for new golang-github-docker-libnetwork + +* Fri Jun 10 2022 Maxwell G - 20.10.17-1 +- Update to 20.10.17. Fixes rhbz#2095714. + +* Fri May 13 2022 Maxwell G - 20.10.16-1 +- Update to 20.10.16. + +* Sat May 07 2022 Maxwell G - 20.10.15-1 +- Update to 20.10.15 (rhbz#2082501). +- Fix BUILDTAGS (rhbz#2082924). +- Make non-binary subpackages noarch. + +* Mon Apr 11 2022 Maxwell G - 20.10.14-1 +- Update to 20.10.14. Fixes rhbz#2063052. +- Mitigate CVE-2022-24769. + +* Mon Jan 31 2022 Maxwell G - 20.10.12-3 +- Fixes FTBFS. Closes rhbz#2046748. +- Use %%anda_go_build instead of Makefile to build binaries +- Add explanatory comments. +- Normalize install commands +- Make compliant with SourceURL Guidelines +- Remove no longer necessary `ExcludeArch: ppc64`. + +* Thu Jan 20 2022 Fedora Release Engineering - 20.10.12-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild + +* Tue Jan 11 2022 Maxwell G - 20.10.12-1 +- Update to 20.10.12. Fixes rhbz#2032534. +- Install zsh completions to the correct directory. Fixes rhbz#2038888. + +* Mon Nov 22 2021 Olivier Lemasle - 20.10-11-1 +- Update to upstream 20.10.11 (fixes rhbz#2024384) +- Mitigates CVE-2021-41190 (fixes rhbz#2024940) + +* Fri Oct 29 2021 Maxwell G - 20.10.10-1 +- Update to 20.10.10 (fixes rhbz#2015385) +- Update virtual provides + +* Fri Oct 08 2021 Maxwell G - 20.10.9-1 +- Update to 20.10.9 (fixes rhbz#2010508) +- Patch seccomp policy to fix clone3() issue (fixes rhbz#2011523 and rhbz#1988199) + +* Sun Aug 15 2021 Olivier Lemasle - 20.10.8-1 +- Update to upstream 20.10.8 (fixes rhbz#1990148) +- Fix seccomp support (fixes rhbz#1986092) + +* Sun Aug 15 2021 Dusty Mabe - 20.10.7-3 +- Remove `Requires(post)` on firewalld-filesystem. + +* Thu Jul 22 2021 Fedora Release Engineering - 20.10.7-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild + +* Fri Jul 16 2021 Olivier Lemasle - 20.10.7-1 +- Update to upstream 20.10.7 (fixes rhbz#1967390) + +* Tue May 04 2021 Olivier Lemasle - 20.10.6-2 +- Add conflict with podman-docker + +* Tue Apr 20 2021 Olivier Lemasle - 20.10.6-1 +- Update to upstream 20.10.6 (#1948605) +- Re-bundle moby dependencies to fix gRPC issues with Swarm + (https://github.com/coreos/fedora-coreos-tracker/issues/793) + +* Sun Mar 14 2021 Olivier Lemasle - 20.10.5-1 +- Update to latest upstream 20.10.5 - fixes #1903426 +- Upstream brings compatibility with cgroups v2 - fixes #1746355 +- Remove package moby-engine-vim (dockerfile.vim has been merged in upstream vim) +- Remove firewalld docker zone, since dockerd can now communicate with firewalld - fixes #1852680 +- Build dockerd and docker-proxy from unbundled source packages +- Remove fixed storage-driver (cf. https://src.fedoraproject.org/rpms/moby-engine/pull-request/6) + +* Tue Mar 02 2021 Zbigniew Jędrzejewski-Szmek - 19.03.13-3.ce.git4484c46 +- Rebuilt for updated systemd-rpm-macros + See https://pagure.io/fesco/issue/2583. + +* Tue Jan 26 2021 Fedora Release Engineering - 19.03.13-2.ce.git4484c46 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Fri Oct 02 2020 Olivier Lemasle - 19.03.13-1.ce.git4484c46 +- Update to upstream 19.03.13 (#1837641) + +* Fri Oct 02 2020 Olivier Lemasle - 19.03.11-4.ce.git42e35e6 +- Fix FTBFS: adapt to change to CMake builds (#1864160) + +* Sat Aug 01 2020 Fedora Release Engineering - 19.03.11-3.ce.git42e35e6 +- Second attempt - Rebuilt for + https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Tue Jul 28 2020 Fedora Release Engineering - 19.03.11-2.ce.git42e35e6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Sun Jun 07 2020 Olivier Lemasle - 19.03.11-1.ce.git42e35e6 +- Update to upstream 19.03.11 to prevent CVE-2020-13401 + +* Thu May 07 2020 Olivier Lemasle - 19.03.8-2.ce.gitafacb8b +- Configure storage-driver explicitely (fixes #1832301) +- Add firewalld zone: trust interface docker0, as firewalld now uses nftables + by default and docker communicates with iptables (fixes #1817022) + +* Mon Mar 16 2020 Olivier Lemasle - 19.03.8-1.ce.gitafacb8b +- Update to latest upstream release - Docker CE 19.03.8 +- Prune unused BuildRequires + +* Sun Mar 8 2020 Olivier Lemasle - 19.03.7-2.ce.git7141c19 +- Add Conflicts with docker-ce-cli and Obsoletes docker-common + +* Sat Mar 7 2020 Olivier Lemasle - 19.03.7-1.ce.git7141c19 +- Update to latest upstream release - Docker CE 19.03.7 +- Add Epoch: 2 to Obsoletes for docker and docker-latest + +* Wed Jan 29 2020 Fedora Release Engineering - 18.09.8-3.ce.git0dd43dd +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Thu Jul 25 2019 Fedora Release Engineering - 18.09.8-2.ce.git0dd43dd +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Thu Jul 18 2019 Olivier Lemasle - 18.09.8-1.ce.git0dd43dd +- Update to latest upstream release - Docker CE 18.09.8 + +* Sat Jul 13 2019 Olivier Lemasle - 18.09.7-5.ce.git2d0083d +- Move docker-init and docker-proxy to /usr/libexec/docker +- Update moby-engine-nano summary to follow guidelines + +* Sat Jul 13 2019 Olivier Lemasle - 18.09.7-4.ce.git2d0083d +- Add nofile ulimit to default docker daemon options (#1715254, #1708115) + +* Fri Jul 12 2019 Olivier Lemasle - 18.09.7-3.ce.git2d0083d +- rebuilt + +* Fri Jul 12 2019 Olivier Lemasle - 18.09.7-2.ce.git2d0083d +- Depend on packaged versions "runc" and "containerd" instead of building them. + +* Thu Jun 27 2019 David Michael - 18.09.7-1.ce.git2d0083d +- Update docker-ce to commit 2d0083d (version 18.09.7). +- Update runc to commit 425e105. +- Update containerd to commit 894b81a (1.2.6). +- Update docker-proxy to commit e7933d4. + +* Tue May 14 2019 David Michael - 18.09.6-1.ce.git481bc77 +- Update docker-ce to commit 481bc77 (version 18.09.6). +- Update docker-proxy to commit 872f0a8. +- Obsolete and provide the docker and docker-latest packages. (#1700006) + +* Thu Apr 11 2019 David Michael - 18.09.5-1.ce.gite8ff056 +- Update docker-ce to commit e8ff056 (version 18.09.5). +- Update docker-runc to commit 2b18fe1. +- Update docker-containerd to commit bb71b10 (version 1.2.5). +- Update docker-proxy to commit 4725f21. +- Report the correct engine version. +- Install symlinks to unprefixed runc/containerd program names. + +* Thu Mar 28 2019 David Michael - 18.06.3-2.ce.gitd7080c1 +- Conflict with docker-common. (#1693397) + +* Thu Feb 21 2019 David Michael - 18.06.3-1.ce.gitd7080c1 +- Update docker-ce to commit d7080c1 (version 18.06.3). + +* Tue Feb 12 2019 David Michael - 18.06.2-1.ce.git6d37f41 +- Update docker-ce to commit 6d37f41 (version 18.06.2). +- Update docker-runc to commit a592beb. + +* Mon Feb 11 2019 David Michael - 18.06.1-3.ce.gite68fc7a +- Apply a runc patch for CVE-2019-5736. + +* Fri Feb 01 2019 Fedora Release Engineering - 18.06.1-2.ce.gite68fc7a +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Thu Nov 29 2018 David Michael - 18.06.1-1.ce.gite68fc7a +- Update docker-ce to commit e68fc7a (version 18.06.1). +- Update docker-runc to commit 69663f0. +- Update docker-containerd to commit 468a545 (version 1.1.2). +- Update docker-proxy to commit 3ac297b. +- Backport a fix for mounting named volumes. +- Create a "docker" group for non-root Docker access. +- Support systemd socket-activation. +- Make runc and containerd commit IDs match their expected values. +- Preserve containerd debuginfo. + +* Mon Nov 12 2018 Marcin Skarbek - 18.06.0-2.ce.git0ffa825 +- add configuration file +- update service file + +* Sat Aug 18 2018 Lokesh Mandvekar - 18.06.0-1.ce.git0ffa825 +- Resolves: #1539161 - first upload to Fedora +- built docker-ce commit 0ffa825 +- built docker-runc commit ad0f5255 +- built docker-containerd commit a88b631 +- built docker-proxy commit a79d368 +- built docker-init commit fec3683 + +* Tue Mar 20 2018 Lokesh Mandvekar - 17.03.2-4.ce.gitf5ec1e2 +- correct some rpmlint errors + +* Wed Feb 21 2018 Lokesh Mandvekar - 17.03.2-3.ce +- docker-* symlinks to moby-* (RE: gh PR 34226) + +* Wed Feb 21 2018 Lokesh Mandvekar - 17.03.2-2.ce +- rename binaries as per upstream gh PR 34226 + +* Fri Jan 26 2018 Lokesh Mandvekar - 17.03.2-1 +- initial build +- built moby commit f5ec1e2 +- built cli commit 4b61f56 +- built docker-runc commit 2d41c047 +- built docker-containerd commit 3addd84 +- built docker-proxy commit 7b2b1fe diff --git a/anda/docker/moby-engine/moby-engine.spec.license b/anda/docker/moby-engine/moby-engine.spec.license new file mode 100644 index 0000000000..2071b23b0e --- /dev/null +++ b/anda/docker/moby-engine/moby-engine.spec.license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/anda/docker/moby-engine/provides.spec.inc b/anda/docker/moby-engine/provides.spec.inc new file mode 100644 index 0000000000..847f007ed0 --- /dev/null +++ b/anda/docker/moby-engine/provides.spec.inc @@ -0,0 +1,108 @@ +# Bundled dependencies +Provides: bundled(tini-static) +Provides: bundled(golang(github.com/docker/docker)) +Provides: bundled(golang(github.com/docker/cli)) +# grep -v -e '^$' -e '^#' cli-24.0.5/vendor/github.com/docker/distribution/vendor.conf | sort | awk '{print "Provides: bundled(golang("$1")) = "$2}' +Provides: bundled(golang(github.com/aws/aws-sdk-go)) = f831d5a0822a1ad72420ab18c6269bca1ddaf490 +Provides: bundled(golang(github.com/Azure/azure-sdk-for-go)) = 4650843026a7fdec254a8d9cf893693a254edd0b +Provides: bundled(golang(github.com/Azure/go-autorest)) = eaa7994b2278094c904d31993d26f56324db3052 +Provides: bundled(golang(github.com/beorn7/perks)) = 4c0e84591b9aa9e6dcfdf3e020114cd81f89d5f9 +Provides: bundled(golang(github.com/bshuster-repo/logrus-logstash-hook)) = d2c0ecc1836d91814e15e23bb5dc309c3ef51f4a +Provides: bundled(golang(github.com/bugsnag/bugsnag-go)) = b1d153021fcd90ca3f080db36bec96dc690fb274 +Provides: bundled(golang(github.com/bugsnag/osext)) = 0dd3f918b21bec95ace9dc86c7e70266cfc5c702 +Provides: bundled(golang(github.com/bugsnag/panicwrap)) = e2c28503fcd0675329da73bf48b33404db873782 +Provides: bundled(golang(github.com/denverdino/aliyungo)) = afedced274aa9a7fcdd47ac97018f0f8db4e5de2 +Provides: bundled(golang(github.com/dgrijalva/jwt-go)) = 4bbdd8ac624fc7a9ef7aec841c43d99b5fe65a29 +Provides: bundled(golang(github.com/docker/go-metrics)) = 399ea8c73916000c64c2c76e8da00ca82f8387ab +Provides: bundled(golang(github.com/docker/libtrust)) = fa567046d9b14f6aa788882a950d69651d230b21 +Provides: bundled(golang(github.com/garyburd/redigo)) = 535138d7bcd717d6531c701ef5933d98b1866257 +Provides: bundled(golang(github.com/go-ini/ini)) = 2ba15ac2dc9cdf88c110ec2dc0ced7fa45f5678c +Provides: bundled(golang(github.com/golang/protobuf)) = 8d92cf5fc15a4382f8964b08e1f42a75c0591aa3 +Provides: bundled(golang(github.com/gorilla/handlers)) = 60c7bfde3e33c201519a200a4507a158cc03a17b +Provides: bundled(golang(github.com/gorilla/mux)) = 599cba5e7b6137d46ddf58fb1765f5d928e69604 +Provides: bundled(golang(github.com/inconshreveable/mousetrap)) = 76626ae9c91c4f2a10f34cad8ce83ea42c93bb75 +Provides: bundled(golang(github.com/jmespath/go-jmespath)) = bd40a432e4c76585ef6b72d3fd96fb9b6dc7b68d +Provides: bundled(golang(github.com/marstr/guid)) = 8bd9a64bf37eb297b492a4101fb28e80ac0b290f +Provides: bundled(golang(github.com/matttproud/golang_protobuf_extensions)) = c12348ce28de40eed0136aa2b644d0ee0650e56c +Provides: bundled(golang(github.com/miekg/dns)) = 271c58e0c14f552178ea321a545ff9af38930f39 +Provides: bundled(golang(github.com/mitchellh/mapstructure)) = 482a9fd5fa83e8c4e7817413b80f3eb8feec03ef +Provides: bundled(golang(github.com/ncw/swift)) = a0320860b16212c2b59b4912bb6508cda1d7cee6 +Provides: bundled(golang(github.com/opencontainers/go-digest)) = a6d0ee40d4207ea02364bd3b9e8e77b9159ba1eb +Provides: bundled(golang(github.com/opencontainers/image-spec)) = 67d2d5658fe0476ab9bf414cec164077ebff3920 +Provides: bundled(golang(github.com/prometheus/client_golang)) = c332b6f63c0658a65eca15c0e5247ded801cf564 +Provides: bundled(golang(github.com/prometheus/client_model)) = 99fa1f4be8e564e8a6b613da7fa6f46c9edafc6c +Provides: bundled(golang(github.com/prometheus/common)) = 89604d197083d4781071d3c65855d24ecfb0a563 +Provides: bundled(golang(github.com/prometheus/procfs)) = cb4147076ac75738c9a7d279075a253c0cc5acbd +Provides: bundled(golang(github.com/satori/go.uuid)) = f58768cc1a7a7e77a3bd49e98cdd21419399b6a3 +Provides: bundled(golang(github.com/Shopify/logrus-bugsnag)) = 577dee27f20dd8f1a529f82210094af593be12bd +Provides: bundled(golang(github.com/sirupsen/logrus)) = 3d4380f53a34dcdc95f0c1db702615992b38d9a4 +Provides: bundled(golang(github.com/spf13/cobra)) = 312092086bed4968099259622145a0c9ae280064 +Provides: bundled(golang(github.com/spf13/pflag)) = 5644820622454e71517561946e3d94b9f9db6842 +Provides: bundled(golang(github.com/xenolf/lego)) = a9d8cec0e6563575e5868a005359ac97911b5985 +Provides: bundled(golang(github.com/yvasiyarov/go-metrics)) = 57bccd1ccd43f94bb17fdd8bf3007059b802f85e +Provides: bundled(golang(github.com/yvasiyarov/gorelic)) = a9bba5b9ab508a086f9a12b8c51fab68478e2128 +Provides: bundled(golang(github.com/yvasiyarov/newrelic_platform_go)) = b21fdbd4370f3717f3bbd2bf41c223bc273068e6 +Provides: bundled(golang(golang.org/x/crypto)) = c10c31b5e94b6f7a0283272dc2bb27163dcea24b +Provides: bundled(golang(golang.org/x/net)) = 4876518f9e71663000c348837735820161a42df7 +Provides: bundled(golang(golang.org/x/oauth2)) = 045497edb6234273d67dbc25da3f2ddbc4c4cacf +Provides: bundled(golang(golang.org/x/time)) = a4bde12657593d5e90d0533a3e4fd95e635124cb +Provides: bundled(golang(google.golang.org/api)) = 9bf6e6e569ff057f75d9604a46c52928f17d2b54 +Provides: bundled(golang(google.golang.org/appengine)) = 12d5545dc1cfa6047a286d5e853841b6471f4c19 +Provides: bundled(golang(google.golang.org/cloud)) = 975617b05ea8a58727e6c1a06b6161ff4185a9f2 +Provides: bundled(golang(google.golang.org/grpc)) = d3ddb4469d5a1b949fc7a7da7c1d6a0d1b6de994 +Provides: bundled(golang(gopkg.in/check.v1)) = 64131543e7896d5bcc6bd5a76287eb75ea96c673 +Provides: bundled(golang(gopkg.in/square/go-jose.v1)) = 40d457b439244b546f023d056628e5184136899b +Provides: bundled(golang(gopkg.in/yaml.v2)) = v2.2.1 +Provides: bundled(golang(rsc.io/letsencrypt)) = e770c10b0f1a64775ae91d240407ce00d1a5bdeb +# grep -v -e '^$' -e '^#' moby-24.0.5/vendor/github.com/docker/distribution/vendor.conf | sort | awk '{print "Provides: bundled(golang("$1")) = "$2}' +Provides: bundled(golang(github.com/aws/aws-sdk-go)) = f831d5a0822a1ad72420ab18c6269bca1ddaf490 +Provides: bundled(golang(github.com/Azure/azure-sdk-for-go)) = 4650843026a7fdec254a8d9cf893693a254edd0b +Provides: bundled(golang(github.com/Azure/go-autorest)) = eaa7994b2278094c904d31993d26f56324db3052 +Provides: bundled(golang(github.com/beorn7/perks)) = 4c0e84591b9aa9e6dcfdf3e020114cd81f89d5f9 +Provides: bundled(golang(github.com/bshuster-repo/logrus-logstash-hook)) = d2c0ecc1836d91814e15e23bb5dc309c3ef51f4a +Provides: bundled(golang(github.com/bugsnag/bugsnag-go)) = b1d153021fcd90ca3f080db36bec96dc690fb274 +Provides: bundled(golang(github.com/bugsnag/osext)) = 0dd3f918b21bec95ace9dc86c7e70266cfc5c702 +Provides: bundled(golang(github.com/bugsnag/panicwrap)) = e2c28503fcd0675329da73bf48b33404db873782 +Provides: bundled(golang(github.com/denverdino/aliyungo)) = afedced274aa9a7fcdd47ac97018f0f8db4e5de2 +Provides: bundled(golang(github.com/dgrijalva/jwt-go)) = 4bbdd8ac624fc7a9ef7aec841c43d99b5fe65a29 +Provides: bundled(golang(github.com/docker/go-metrics)) = 399ea8c73916000c64c2c76e8da00ca82f8387ab +Provides: bundled(golang(github.com/docker/libtrust)) = fa567046d9b14f6aa788882a950d69651d230b21 +Provides: bundled(golang(github.com/garyburd/redigo)) = 535138d7bcd717d6531c701ef5933d98b1866257 +Provides: bundled(golang(github.com/go-ini/ini)) = 2ba15ac2dc9cdf88c110ec2dc0ced7fa45f5678c +Provides: bundled(golang(github.com/golang/protobuf)) = 8d92cf5fc15a4382f8964b08e1f42a75c0591aa3 +Provides: bundled(golang(github.com/gorilla/handlers)) = 60c7bfde3e33c201519a200a4507a158cc03a17b +Provides: bundled(golang(github.com/gorilla/mux)) = 599cba5e7b6137d46ddf58fb1765f5d928e69604 +Provides: bundled(golang(github.com/inconshreveable/mousetrap)) = 76626ae9c91c4f2a10f34cad8ce83ea42c93bb75 +Provides: bundled(golang(github.com/jmespath/go-jmespath)) = bd40a432e4c76585ef6b72d3fd96fb9b6dc7b68d +Provides: bundled(golang(github.com/marstr/guid)) = 8bd9a64bf37eb297b492a4101fb28e80ac0b290f +Provides: bundled(golang(github.com/matttproud/golang_protobuf_extensions)) = c12348ce28de40eed0136aa2b644d0ee0650e56c +Provides: bundled(golang(github.com/miekg/dns)) = 271c58e0c14f552178ea321a545ff9af38930f39 +Provides: bundled(golang(github.com/mitchellh/mapstructure)) = 482a9fd5fa83e8c4e7817413b80f3eb8feec03ef +Provides: bundled(golang(github.com/ncw/swift)) = a0320860b16212c2b59b4912bb6508cda1d7cee6 +Provides: bundled(golang(github.com/opencontainers/go-digest)) = a6d0ee40d4207ea02364bd3b9e8e77b9159ba1eb +Provides: bundled(golang(github.com/opencontainers/image-spec)) = 67d2d5658fe0476ab9bf414cec164077ebff3920 +Provides: bundled(golang(github.com/prometheus/client_golang)) = c332b6f63c0658a65eca15c0e5247ded801cf564 +Provides: bundled(golang(github.com/prometheus/client_model)) = 99fa1f4be8e564e8a6b613da7fa6f46c9edafc6c +Provides: bundled(golang(github.com/prometheus/common)) = 89604d197083d4781071d3c65855d24ecfb0a563 +Provides: bundled(golang(github.com/prometheus/procfs)) = cb4147076ac75738c9a7d279075a253c0cc5acbd +Provides: bundled(golang(github.com/satori/go.uuid)) = f58768cc1a7a7e77a3bd49e98cdd21419399b6a3 +Provides: bundled(golang(github.com/Shopify/logrus-bugsnag)) = 577dee27f20dd8f1a529f82210094af593be12bd +Provides: bundled(golang(github.com/sirupsen/logrus)) = 3d4380f53a34dcdc95f0c1db702615992b38d9a4 +Provides: bundled(golang(github.com/spf13/cobra)) = 312092086bed4968099259622145a0c9ae280064 +Provides: bundled(golang(github.com/spf13/pflag)) = 5644820622454e71517561946e3d94b9f9db6842 +Provides: bundled(golang(github.com/xenolf/lego)) = a9d8cec0e6563575e5868a005359ac97911b5985 +Provides: bundled(golang(github.com/yvasiyarov/go-metrics)) = 57bccd1ccd43f94bb17fdd8bf3007059b802f85e +Provides: bundled(golang(github.com/yvasiyarov/gorelic)) = a9bba5b9ab508a086f9a12b8c51fab68478e2128 +Provides: bundled(golang(github.com/yvasiyarov/newrelic_platform_go)) = b21fdbd4370f3717f3bbd2bf41c223bc273068e6 +Provides: bundled(golang(golang.org/x/crypto)) = c10c31b5e94b6f7a0283272dc2bb27163dcea24b +Provides: bundled(golang(golang.org/x/net)) = 4876518f9e71663000c348837735820161a42df7 +Provides: bundled(golang(golang.org/x/oauth2)) = 045497edb6234273d67dbc25da3f2ddbc4c4cacf +Provides: bundled(golang(golang.org/x/time)) = a4bde12657593d5e90d0533a3e4fd95e635124cb +Provides: bundled(golang(google.golang.org/api)) = 9bf6e6e569ff057f75d9604a46c52928f17d2b54 +Provides: bundled(golang(google.golang.org/appengine)) = 12d5545dc1cfa6047a286d5e853841b6471f4c19 +Provides: bundled(golang(google.golang.org/cloud)) = 975617b05ea8a58727e6c1a06b6161ff4185a9f2 +Provides: bundled(golang(google.golang.org/grpc)) = d3ddb4469d5a1b949fc7a7da7c1d6a0d1b6de994 +Provides: bundled(golang(gopkg.in/check.v1)) = 64131543e7896d5bcc6bd5a76287eb75ea96c673 +Provides: bundled(golang(gopkg.in/square/go-jose.v1)) = 40d457b439244b546f023d056628e5184136899b +Provides: bundled(golang(gopkg.in/yaml.v2)) = v2.2.1 +Provides: bundled(golang(rsc.io/letsencrypt)) = e770c10b0f1a64775ae91d240407ce00d1a5bdeb diff --git a/anda/docker/moby-engine/sources b/anda/docker/moby-engine/sources new file mode 100644 index 0000000000..185f3bb5a2 --- /dev/null +++ b/anda/docker/moby-engine/sources @@ -0,0 +1,3 @@ +SHA512 (cli-24.0.5.tar.gz) = 765c67634d91d248b156d3e407398b98b7a0a89507bbac0310d4a68b95aa1a05e3af43c8b90bc10166748749d8cc36670619fc9efca110beefbdcd4385dc96be +SHA512 (moby-24.0.5.tar.gz) = cde2e47e7658b153399ee29154ec21eebf54b292185e07d43b968895dcfdfead95e4507fefb713859a4540f21d8007116d3ebeaa1fb7ba305fb2a0449ba1bee6 +SHA512 (tini-0b44d36.tar.gz) = 5294e877c369177b09c2a34f759e911f612f6977e960a63d46b6e5ebea790455dad972e91ca10c478693da637a5479d4e0b904efcfb5ae291e87e7e66674c752 diff --git a/anda/docker/moby-engine/update.sh b/anda/docker/moby-engine/update.sh new file mode 100755 index 0000000000..3089ca4027 --- /dev/null +++ b/anda/docker/moby-engine/update.sh @@ -0,0 +1,44 @@ +#!/usr/bin/env bash +# SPDX-FileCopyrightText: 2022 Maxwell G (@gotmax23) +# SPDX-License-Identifier: MIT + +# USAGE: After bumping the version in moby-engine.spec and downloading the new +# sources, run this script in moby-engine's distgit repository to update the +# package's virtual Provides. + +set -euo pipefail + +# Note(gotmax23): I have a separate update.sh script in my $PATH. +# When that exists, this script will run that first. +# You can ignore this. +if command -v update.sh && [ "$#" -gt 0 ]; then + update.sh "$@" +fi + +spectool -g moby-engine.spec --define "_sourcedir ." +fedpkg prep + +version="$(rpmspec -D '_sourcedir %(pwd)' -q --srpm --qf '%{version}\n' *.spec)" + +cat << EOF > provides.spec.inc +# Bundled dependencies +Provides: bundled(tini-static) +Provides: bundled(golang(github.com/docker/docker)) +Provides: bundled(golang(github.com/docker/cli)) +# grep -v -e '^$' -e '^#' cli-${version}/vendor/github.com/docker/distribution/vendor.conf | sort | awk '{print "Provides: bundled(golang("\$1")) = "\$2}' +EOF + +grep -v -e '^$' -e '^#' "moby-${version}/cli-${version}/vendor/github.com/docker/distribution/vendor.conf" | sort | awk '{print "Provides: bundled(golang("$1")) = "$2}' >> provides.spec.inc + +cat << EOF >> provides.spec.inc +# grep -v -e '^$' -e '^#' moby-${version}/vendor/github.com/docker/distribution/vendor.conf | sort | awk '{print "Provides: bundled(golang("\$1")) = "\$2}' +EOF + +grep -v -e '^$' -e '^#' "moby-${version}/vendor/github.com/docker/distribution/vendor.conf" | sort | awk '{print "Provides: bundled(golang("$1")) = "$2}' >> provides.spec.inc + +# Note(gotmax23): Ignore this also. My script commits the specfile, +# and then this ammends that commit to add the updated provides.spec.inc. +if command -v update.sh && [ "$#" -gt 0 ]; then + git add provides.spec.inc + git commit --gpg-sign --amend --no-edit +fi diff --git a/anda/fonts/maple/anda.hcl b/anda/fonts/maple/anda.hcl new file mode 100644 index 0000000000..8f35f91125 --- /dev/null +++ b/anda/fonts/maple/anda.hcl @@ -0,0 +1,6 @@ +project pkg { + arches = ["x86_64"] + rpm { + spec = "maple-fonts.spec" + } +} \ No newline at end of file diff --git a/anda/fonts/maple/maple-fonts.spec b/anda/fonts/maple/maple-fonts.spec new file mode 100644 index 0000000000..2da3872a72 --- /dev/null +++ b/anda/fonts/maple/maple-fonts.spec @@ -0,0 +1,40 @@ +%define debug_package %nil +%define _ttfontsdir %{_datadir}/fonts/maple + +Name: maple-fonts +Version: 6.4 +Release: %autorelease +Summary: Open source monospace & nerd font with round corner and ligatures. +License: OFL-1.1 +URL: https://github.com/subframe7536/Maple-font +Source0: %{url}/releases/download/v%{version}/MapleMono-SC-NF.zip +Source1: %{url}/releases/download/v%{version}/MapleMono-ttf.zip +Source2: %{url}/releases/download/v%{version}/MapleMono-NF.zip +Source3: https://raw.githubusercontent.com/subframe7536/maple-font/main/OFL.txt +BuildArch: noarch +BuildRequires: unzip + +%description +%summary + +%prep +%setup -q -c -n %{name}-%{version} +unzip %{S:1} +unzip %{S:2} +cp %{S:3} . + +%build + +%install +install -d %{buildroot}%{_ttfontsdir} +# by default install command uses 755 umask +install -m 644 *.ttf %{buildroot}%{_ttfontsdir} + +%files +%license OFL.txt +%dir %{_ttfontsdir} +%{_ttfontsdir}/*.ttf + +%changelog +* Tue Dec 26 2023 madoka773 - 6.4 +- Initial package diff --git a/anda/fonts/maple/update.rhai b/anda/fonts/maple/update.rhai new file mode 100644 index 0000000000..4e3626dc03 --- /dev/null +++ b/anda/fonts/maple/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("subframe7536/Maple-font")); \ No newline at end of file diff --git a/anda/fonts/sarasa-gothic/sarasa-gothic-fonts.spec b/anda/fonts/sarasa-gothic/sarasa-gothic-fonts.spec index 11cb2772cf..a8776105e6 100644 --- a/anda/fonts/sarasa-gothic/sarasa-gothic-fonts.spec +++ b/anda/fonts/sarasa-gothic/sarasa-gothic-fonts.spec @@ -1,9 +1,9 @@ Name: sarasa-gothic-fonts -Version: 1.0.0 +Version: 1.0.3 Release: 1%{?dist} URL: https://github.com/be5invis/Sarasa-Gothic -Source0: %url/releases/download/v%version/sarasa-gothic-ttc-%version.7z -Source1: %url/releases/download/v%version/sarasa-gothic-super-ttc-%version.7z +Source0: %url/releases/download/v%version/Sarasa-TTC-%version.7z +Source1: %url/releases/download/v%version/Sarasa-SuperTTC-%version.7z Source2: https://raw.githubusercontent.com/be5invis/Sarasa-Gothic/v%version/LICENSE Source3: https://raw.githubusercontent.com/be5invis/Sarasa-Gothic/v%version/README.md License: OFL-1.1 @@ -57,5 +57,4 @@ install -Dm644 %SOURCE3 %buildroot/%_datadir/doc/sarasa-gothic-super-fonts/ /%{_datadir}/fonts/sarasa-gothic-super/ %changelog -* Wed Apr 26 2023 windowsboy111 - 0.40.6-1 -- Initial package +%autochangelog diff --git a/anda/rust/2048-rs/anda.hcl b/anda/games/2048-rs/anda.hcl similarity index 100% rename from anda/rust/2048-rs/anda.hcl rename to anda/games/2048-rs/anda.hcl diff --git a/anda/rust/2048-rs/rust-game-2048.spec b/anda/games/2048-rs/rust-game-2048.spec similarity index 100% rename from anda/rust/2048-rs/rust-game-2048.spec rename to anda/games/2048-rs/rust-game-2048.spec diff --git a/anda/rust/2048-rs/update.rhai b/anda/games/2048-rs/update.rhai similarity index 100% rename from anda/rust/2048-rs/update.rhai rename to anda/games/2048-rs/update.rhai diff --git a/anda/games/prismlauncher-nightly/prismlauncher-nightly.spec b/anda/games/prismlauncher-nightly/prismlauncher-nightly.spec index d52ffd1dae..ce0b1ab61a 100644 --- a/anda/games/prismlauncher-nightly/prismlauncher-nightly.spec +++ b/anda/games/prismlauncher-nightly/prismlauncher-nightly.spec @@ -1,7 +1,7 @@ %global real_name prismlauncher %global nice_name PrismLauncher -%global commit a991d48c762dbc0432b6ec24bcab335fad76c945 +%global commit f931890e953f2f80c794d68a1fed94863424e126 %global shortcommit %(c=%{commit}; echo ${c:0:7}) %global libnbtplusplus_commit a5e8fd52b8bf4ab5d5bcc042b2a247867589985f %global quazip_commit 6117161af08e366c37499895b00ef62f93adc345 diff --git a/anda/games/prismlauncher-qt5-nightly/prismlauncher-qt5-nightly.spec b/anda/games/prismlauncher-qt5-nightly/prismlauncher-qt5-nightly.spec index b6125648b9..699e5bffb0 100644 --- a/anda/games/prismlauncher-qt5-nightly/prismlauncher-qt5-nightly.spec +++ b/anda/games/prismlauncher-qt5-nightly/prismlauncher-qt5-nightly.spec @@ -1,7 +1,7 @@ %global real_name prismlauncher %global nice_name PrismLauncher -%global commit a991d48c762dbc0432b6ec24bcab335fad76c945 +%global commit f931890e953f2f80c794d68a1fed94863424e126 %global shortcommit %(c=%{commit}; echo ${c:0:7}) %global libnbtplusplus_commit a5e8fd52b8bf4ab5d5bcc042b2a247867589985f %global quazip_commit 6117161af08e366c37499895b00ef62f93adc345 diff --git a/anda/rust/typeracer/anda.hcl b/anda/games/typeracer/anda.hcl similarity index 100% rename from anda/rust/typeracer/anda.hcl rename to anda/games/typeracer/anda.hcl diff --git a/anda/rust/typeracer/rust-typeracer.spec b/anda/games/typeracer/rust-typeracer.spec similarity index 100% rename from anda/rust/typeracer/rust-typeracer.spec rename to anda/games/typeracer/rust-typeracer.spec diff --git a/anda/rust/typeracer/update.rhai b/anda/games/typeracer/update.rhai similarity index 100% rename from anda/rust/typeracer/update.rhai rename to anda/games/typeracer/update.rhai diff --git a/anda/gleam/gleam.spec b/anda/gleam/gleam.spec deleted file mode 100644 index f8ca10dc2a..0000000000 --- a/anda/gleam/gleam.spec +++ /dev/null @@ -1,31 +0,0 @@ -%undefine __brp_mangle_shebangs - -Name: gleam -Version: 0.32.4 -Release: 1%{?dist} -Summary: A friendly language for building type-safe, scalable systems -License: Apache-2.0 -URL: https://gleam.run/ -Source0: https://github.com/gleam-lang/gleam/archive/v%version.tar.gz -Requires: erlang elixir -BuildRequires: cargo-rpm-macros anda-srpm-macros - -%description -Gleam is a friendly language for building type-safe, scalable systems! -It compiles to Erlang (or JavaScript) and has straightforward interop with other BEAM languages such as Erlang, Elixir, and LFE. - -%prep -%autosetup -%cargo_prep_online - -%build -%cargo_build - -%install -install -Dm755 target/rpm/gleam %buildroot%_bindir/gleam - -%files -%_bindir/gleam - -%changelog -%autochangelog diff --git a/anda/gleam/update.rhai b/anda/gleam/update.rhai deleted file mode 100644 index 503768b86f..0000000000 --- a/anda/gleam/update.rhai +++ /dev/null @@ -1 +0,0 @@ -rpm.version(gh("gleam-lang/gleam")); diff --git a/anda/crystal/blahaj/anda.hcl b/anda/langs/crystal/blahaj/anda.hcl similarity index 100% rename from anda/crystal/blahaj/anda.hcl rename to anda/langs/crystal/blahaj/anda.hcl diff --git a/anda/crystal/blahaj/blahaj.spec b/anda/langs/crystal/blahaj/blahaj.spec similarity index 98% rename from anda/crystal/blahaj/blahaj.spec rename to anda/langs/crystal/blahaj/blahaj.spec index 6a73152c84..c867a022a9 100644 --- a/anda/crystal/blahaj/blahaj.spec +++ b/anda/langs/crystal/blahaj/blahaj.spec @@ -1,7 +1,7 @@ %define debug_package %nil Name: blahaj -Version: 2.1.0 +Version: 2.2.0 Release: 1%{?dist} Summary: Gay sharks at your local terminal - lolcat-like CLI tool License: BSD-2-Clause diff --git a/anda/crystal/blahaj/update.rhai b/anda/langs/crystal/blahaj/update.rhai similarity index 100% rename from anda/crystal/blahaj/update.rhai rename to anda/langs/crystal/blahaj/update.rhai diff --git a/anda/crystal/crystal/anda.hcl b/anda/langs/crystal/crystal/anda.hcl similarity index 100% rename from anda/crystal/crystal/anda.hcl rename to anda/langs/crystal/crystal/anda.hcl diff --git a/anda/crystal/crystal/crystal.spec b/anda/langs/crystal/crystal/crystal.spec similarity index 98% rename from anda/crystal/crystal/crystal.spec rename to anda/langs/crystal/crystal/crystal.spec index e11241d8b2..ffce554f29 100644 --- a/anda/crystal/crystal/crystal.spec +++ b/anda/langs/crystal/crystal/crystal.spec @@ -1,7 +1,7 @@ %define debug_package %nil Name: crystal -Version: 1.10.1 +Version: 1.11.1 Release: 1%{?dist} Summary: The Crystal Programming Language License: Apache-2.0 diff --git a/anda/crystal/crystal/update.rhai b/anda/langs/crystal/crystal/update.rhai similarity index 100% rename from anda/crystal/crystal/update.rhai rename to anda/langs/crystal/crystal/update.rhai diff --git a/anda/dart/anda.hcl b/anda/langs/dart/anda.hcl similarity index 100% rename from anda/dart/anda.hcl rename to anda/langs/dart/anda.hcl diff --git a/anda/dart/dart.spec b/anda/langs/dart/dart.spec similarity index 98% rename from anda/dart/dart.spec rename to anda/langs/dart/dart.spec index 26248a279f..721191434d 100644 --- a/anda/dart/dart.spec +++ b/anda/langs/dart/dart.spec @@ -1,7 +1,7 @@ %define debug_package %{nil} Name: dart -Version: 3.2.3 +Version: 3.2.4 Release: 1%{?dist} Summary: The Dart Language License: BSD-3-Clause diff --git a/anda/dart/update.rhai b/anda/langs/dart/update.rhai similarity index 100% rename from anda/dart/update.rhai rename to anda/langs/dart/update.rhai diff --git a/anda/go/curlie/anda.hcl b/anda/langs/go/curlie/anda.hcl similarity index 100% rename from anda/go/curlie/anda.hcl rename to anda/langs/go/curlie/anda.hcl diff --git a/anda/go/curlie/golang-github-rs-curlie.spec b/anda/langs/go/curlie/golang-github-rs-curlie.spec similarity index 100% rename from anda/go/curlie/golang-github-rs-curlie.spec rename to anda/langs/go/curlie/golang-github-rs-curlie.spec diff --git a/anda/go/curlie/update.rhai b/anda/langs/go/curlie/update.rhai similarity index 100% rename from anda/go/curlie/update.rhai rename to anda/langs/go/curlie/update.rhai diff --git a/anda/go/gendesk/anda.hcl b/anda/langs/go/gendesk/anda.hcl similarity index 100% rename from anda/go/gendesk/anda.hcl rename to anda/langs/go/gendesk/anda.hcl diff --git a/anda/go/gendesk/golang-github-xyproto-gendesk.spec b/anda/langs/go/gendesk/golang-github-xyproto-gendesk.spec similarity index 100% rename from anda/go/gendesk/golang-github-xyproto-gendesk.spec rename to anda/langs/go/gendesk/golang-github-xyproto-gendesk.spec diff --git a/anda/go/gendesk/update.rhai b/anda/langs/go/gendesk/update.rhai similarity index 100% rename from anda/go/gendesk/update.rhai rename to anda/langs/go/gendesk/update.rhai diff --git a/anda/langs/go/u-root/anda.hcl b/anda/langs/go/u-root/anda.hcl new file mode 100644 index 0000000000..1f398cf712 --- /dev/null +++ b/anda/langs/go/u-root/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "golang-github-u-root.spec" + } +} diff --git a/anda/langs/go/u-root/golang-github-u-root.spec b/anda/langs/go/u-root/golang-github-u-root.spec new file mode 100644 index 0000000000..752d553cc1 --- /dev/null +++ b/anda/langs/go/u-root/golang-github-u-root.spec @@ -0,0 +1,78 @@ +# Generated by go2rpm 1.9.0 +%bcond_without check +%define debug_package %nil + +# https://github.com/u-root/u-root +%global goipath github.com/u-root/u-root +Version: 0.12.0 + +%gometa -f + + +%global common_description %{expand: +A fully Go userland with Linux bootloaders! u-root can create a one-binary root +file system (initramfs) containing a busybox-like set of tools written in Go.} + +%global golicenses LICENSE +%global godocs docs examples AUTHORS SECURITY.md tricksandtips.md\\\ + CONTRIBUTING.md README.md roadmap.md\\\ + cmds/core/tail/test_samples/read_backwards.txt\\\ + cmds/core/tail/test_samples/read_from_beginning.txt\\\ + cmds/exp/esxiboot/README.md\\\ + configs/README.md\\\ + configs/amd64_config.txt configs/arm_config.txt\\\ + configs/generic_config.txt integration/README.md\\\ + pkg/boot/systembooter/README.md pkg/smbios/README.md\\\ + pkg/tarutil/test2.txt pkg/tarutil/test0/a.txt\\\ + pkg/tarutil/test0/dir/b.txt pkg/tarutil/test1/a1.txt\\\ + tools/golang_patched_dce/README.md + +Name: %{goname} +Release: 1%{?dist} +Summary: A fully Go userland with Linux bootloaders! u-root can create a one-binary root file system (initramfs) containing a busybox-like set of tools written in Go + +License: BSD-3-Clause +URL: %{gourl} +Source: %{gosource} + +BuildRequires: anda-srpm-macros + +%description %{common_description} + +%gopkg + +%prep +%goprep +%autopatch -p1 + +go mod download + +%build +go build -ldflags "-B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \n') -s -w -extldflags '--static-pie'" -buildmode=pie -tags 'osusergo,netgo,static_build' -v -x -o %{gobuilddir}/bin/u-root %{goipath} + +%install +%gopkginstall +install -m 0755 -vd %{buildroot}%{_bindir} +install -m 0755 -vp %{gobuilddir}/bin/* %{buildroot}%{_bindir}/ + +# if {with check} +# check +# gocheck +# endif + +%files +%license LICENSE +%doc docs examples AUTHORS SECURITY.md tricksandtips.md CONTRIBUTING.md +%doc README.md roadmap.md cmds/core/tail/test_samples/read_backwards.txt +%doc cmds/core/tail/test_samples/read_from_beginning.txt +%doc configs/README.md +%doc configs/amd64_config.txt configs/arm_config.txt configs/generic_config.txt +%doc integration/README.md pkg/boot/systembooter/README.md pkg/smbios/README.md +%doc pkg/tarutil/test2.txt pkg/tarutil/test0/a.txt pkg/tarutil/test0/dir/b.txt +%doc pkg/tarutil/test1/a1.txt tools/golang_patched_dce/README.md +%{_bindir}/* + +%gopkgfiles + +%changelog +%autochangelog diff --git a/anda/langs/go/u-root/update.rhai b/anda/langs/go/u-root/update.rhai new file mode 100644 index 0000000000..d510f97887 --- /dev/null +++ b/anda/langs/go/u-root/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("u-root/u-root")); diff --git a/anda/go/xyproto-env/anda.hcl b/anda/langs/go/xyproto-env/anda.hcl similarity index 100% rename from anda/go/xyproto-env/anda.hcl rename to anda/langs/go/xyproto-env/anda.hcl diff --git a/anda/go/xyproto-env/golang-github-xyproto-env.spec b/anda/langs/go/xyproto-env/golang-github-xyproto-env.spec similarity index 96% rename from anda/go/xyproto-env/golang-github-xyproto-env.spec rename to anda/langs/go/xyproto-env/golang-github-xyproto-env.spec index 3f9995f5f7..82afcff3c7 100644 --- a/anda/go/xyproto-env/golang-github-xyproto-env.spec +++ b/anda/langs/go/xyproto-env/golang-github-xyproto-env.spec @@ -4,7 +4,7 @@ # https://github.com/xyproto/env %global goipath github.com/xyproto/env -Version: 2.2.4 +Version: 2.2.5 %gometa -f diff --git a/anda/go/xyproto-env/update.rhai b/anda/langs/go/xyproto-env/update.rhai similarity index 100% rename from anda/go/xyproto-env/update.rhai rename to anda/langs/go/xyproto-env/update.rhai diff --git a/anda/go/xyproto-env/v1/anda.hcl b/anda/langs/go/xyproto-env/v1/anda.hcl similarity index 100% rename from anda/go/xyproto-env/v1/anda.hcl rename to anda/langs/go/xyproto-env/v1/anda.hcl diff --git a/anda/go/xyproto-env/v1/golang-github-xyproto-env.spec b/anda/langs/go/xyproto-env/v1/golang-github-xyproto-env.spec similarity index 100% rename from anda/go/xyproto-env/v1/golang-github-xyproto-env.spec rename to anda/langs/go/xyproto-env/v1/golang-github-xyproto-env.spec diff --git a/anda/go/xyproto-textoutput/anda.hcl b/anda/langs/go/xyproto-textoutput/anda.hcl similarity index 100% rename from anda/go/xyproto-textoutput/anda.hcl rename to anda/langs/go/xyproto-textoutput/anda.hcl diff --git a/anda/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec b/anda/langs/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec similarity index 96% rename from anda/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec rename to anda/langs/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec index 1d6f5b5a10..7667e0d0eb 100644 --- a/anda/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec +++ b/anda/langs/go/xyproto-textoutput/golang-github-xyproto-textoutput.spec @@ -3,7 +3,7 @@ # https://github.com/xyproto/textoutput %global goipath github.com/xyproto/textoutput -Version: 1.15.10 +Version: 1.16.2 %gometa -f diff --git a/anda/go/xyproto-textoutput/update.rhai b/anda/langs/go/xyproto-textoutput/update.rhai similarity index 100% rename from anda/go/xyproto-textoutput/update.rhai rename to anda/langs/go/xyproto-textoutput/update.rhai diff --git a/anda/go/xyproto-vt100/anda.hcl b/anda/langs/go/xyproto-vt100/anda.hcl similarity index 100% rename from anda/go/xyproto-vt100/anda.hcl rename to anda/langs/go/xyproto-vt100/anda.hcl diff --git a/anda/go/xyproto-vt100/golang-github-xyproto-vt100.spec b/anda/langs/go/xyproto-vt100/golang-github-xyproto-vt100.spec similarity index 97% rename from anda/go/xyproto-vt100/golang-github-xyproto-vt100.spec rename to anda/langs/go/xyproto-vt100/golang-github-xyproto-vt100.spec index 1a4577ab31..df9b90e00f 100644 --- a/anda/go/xyproto-vt100/golang-github-xyproto-vt100.spec +++ b/anda/langs/go/xyproto-vt100/golang-github-xyproto-vt100.spec @@ -3,7 +3,7 @@ # https://github.com/xyproto/vt100 %global goipath github.com/xyproto/vt100 -Version: 1.12.9 +Version: 1.14.2 %gometa -f diff --git a/anda/go/xyproto-vt100/update.rhai b/anda/langs/go/xyproto-vt100/update.rhai similarity index 100% rename from anda/go/xyproto-vt100/update.rhai rename to anda/langs/go/xyproto-vt100/update.rhai diff --git a/anda/go/yhat-scrape/anda.hcl b/anda/langs/go/yhat-scrape/anda.hcl similarity index 100% rename from anda/go/yhat-scrape/anda.hcl rename to anda/langs/go/yhat-scrape/anda.hcl diff --git a/anda/go/yhat-scrape/golang-github-yhat-scrape.spec b/anda/langs/go/yhat-scrape/golang-github-yhat-scrape.spec similarity index 100% rename from anda/go/yhat-scrape/golang-github-yhat-scrape.spec rename to anda/langs/go/yhat-scrape/golang-github-yhat-scrape.spec diff --git a/anda/groovy/anda.hcl b/anda/langs/groovy/anda.hcl similarity index 100% rename from anda/groovy/anda.hcl rename to anda/langs/groovy/anda.hcl diff --git a/anda/groovy/groovy-docs/anda.hcl b/anda/langs/groovy/groovy-docs/anda.hcl similarity index 100% rename from anda/groovy/groovy-docs/anda.hcl rename to anda/langs/groovy/groovy-docs/anda.hcl diff --git a/anda/groovy/groovy-docs/groovy-docs.spec b/anda/langs/groovy/groovy-docs/groovy-docs.spec similarity index 97% rename from anda/groovy/groovy-docs/groovy-docs.spec rename to anda/langs/groovy/groovy-docs/groovy-docs.spec index b68bf8891d..a6b01ea1e8 100644 --- a/anda/groovy/groovy-docs/groovy-docs.spec +++ b/anda/langs/groovy/groovy-docs/groovy-docs.spec @@ -1,5 +1,5 @@ Name: groovy-docs -Version: 4.0.16 +Version: 4.0.17 Release: 1%{?dist} Summary: Documentation for the Groovy programming language URL: https://groovy-lang.org/ diff --git a/anda/groovy/groovy-docs/update.rhai b/anda/langs/groovy/groovy-docs/update.rhai similarity index 100% rename from anda/groovy/groovy-docs/update.rhai rename to anda/langs/groovy/groovy-docs/update.rhai diff --git a/anda/groovy/groovy.spec b/anda/langs/groovy/groovy.spec similarity index 99% rename from anda/groovy/groovy.spec rename to anda/langs/groovy/groovy.spec index b44584c90d..4d3d8e31df 100644 --- a/anda/groovy/groovy.spec +++ b/anda/langs/groovy/groovy.spec @@ -1,5 +1,5 @@ Name: groovy -Version: 4.0.16 +Version: 4.0.17 Release: 1%{?dist} Summary: A multi-faceted language for the Java platform BuildArch: noarch diff --git a/anda/groovy/update.rhai b/anda/langs/groovy/update.rhai similarity index 100% rename from anda/groovy/update.rhai rename to anda/langs/groovy/update.rhai diff --git a/anda/kotlin/kotlin-native/anda.hcl b/anda/langs/kotlin/kotlin-native/anda.hcl similarity index 100% rename from anda/kotlin/kotlin-native/anda.hcl rename to anda/langs/kotlin/kotlin-native/anda.hcl diff --git a/anda/kotlin/kotlin-native/kotlin-native.spec b/anda/langs/kotlin/kotlin-native/kotlin-native.spec similarity index 99% rename from anda/kotlin/kotlin-native/kotlin-native.spec rename to anda/langs/kotlin/kotlin-native/kotlin-native.spec index 66b2d5a053..dab8e146f8 100644 --- a/anda/kotlin/kotlin-native/kotlin-native.spec +++ b/anda/langs/kotlin/kotlin-native/kotlin-native.spec @@ -2,7 +2,7 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-build Name: kotlin-native -Version: 1.9.21 +Version: 1.9.22 Release: 1%{?dist} Summary: LLVM backend for the Kotlin compiler ExclusiveArch: x86_64 diff --git a/anda/kotlin/kotlin-native/update.rhai b/anda/langs/kotlin/kotlin-native/update.rhai similarity index 100% rename from anda/kotlin/kotlin-native/update.rhai rename to anda/langs/kotlin/kotlin-native/update.rhai diff --git a/anda/kotlin/kotlin/anda.hcl b/anda/langs/kotlin/kotlin/anda.hcl similarity index 100% rename from anda/kotlin/kotlin/anda.hcl rename to anda/langs/kotlin/kotlin/anda.hcl diff --git a/anda/kotlin/kotlin/kotlin.spec b/anda/langs/kotlin/kotlin/kotlin.spec similarity index 99% rename from anda/kotlin/kotlin/kotlin.spec rename to anda/langs/kotlin/kotlin/kotlin.spec index 9d5c612728..92df279e4a 100644 --- a/anda/kotlin/kotlin/kotlin.spec +++ b/anda/langs/kotlin/kotlin/kotlin.spec @@ -1,7 +1,7 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildArch: noarch Name: kotlin -Version: 1.9.21 +Version: 1.9.22 Release: 1%{?dist} Summary: Statically typed programming language diff --git a/anda/kotlin/kotlin/update.rhai b/anda/langs/kotlin/kotlin/update.rhai similarity index 100% rename from anda/kotlin/kotlin/update.rhai rename to anda/langs/kotlin/kotlin/update.rhai diff --git a/anda/nim/choosenim/anda.hcl b/anda/langs/nim/choosenim/anda.hcl similarity index 100% rename from anda/nim/choosenim/anda.hcl rename to anda/langs/nim/choosenim/anda.hcl diff --git a/anda/nim/choosenim/choosenim.spec b/anda/langs/nim/choosenim/choosenim.spec similarity index 100% rename from anda/nim/choosenim/choosenim.spec rename to anda/langs/nim/choosenim/choosenim.spec diff --git a/anda/nim/choosenim/update.rhai b/anda/langs/nim/choosenim/update.rhai similarity index 100% rename from anda/nim/choosenim/update.rhai rename to anda/langs/nim/choosenim/update.rhai diff --git a/anda/nim/nim-nightly/anda.hcl b/anda/langs/nim/nim-nightly/anda.hcl similarity index 100% rename from anda/nim/nim-nightly/anda.hcl rename to anda/langs/nim/nim-nightly/anda.hcl diff --git a/anda/nim/nim-nightly/nim-nightly.spec b/anda/langs/nim/nim-nightly/nim-nightly.spec similarity index 98% rename from anda/nim/nim-nightly/nim-nightly.spec rename to anda/langs/nim/nim-nightly/nim-nightly.spec index 1c4573db5d..d43675c2f3 100644 --- a/anda/nim/nim-nightly/nim-nightly.spec +++ b/anda/langs/nim/nim-nightly/nim-nightly.spec @@ -1,5 +1,5 @@ %global csrc_commit 561b417c65791cd8356b5f73620914ceff845d10 -%global commit 57ffeafda016a9772f6548d462f8d9acdcad33bd +%global commit ade5295fd56f632fc6fbdcfef42b1bb827574be6 %global ver 2.1.1 %global debug_package %nil diff --git a/anda/nim/nim-nightly/nim.1 b/anda/langs/nim/nim-nightly/nim.1 similarity index 100% rename from anda/nim/nim-nightly/nim.1 rename to anda/langs/nim/nim-nightly/nim.1 diff --git a/anda/nim/nim-nightly/nimble.1 b/anda/langs/nim/nim-nightly/nimble.1 similarity index 100% rename from anda/nim/nim-nightly/nimble.1 rename to anda/langs/nim/nim-nightly/nimble.1 diff --git a/anda/nim/nim-nightly/nimgrep.1 b/anda/langs/nim/nim-nightly/nimgrep.1 similarity index 100% rename from anda/nim/nim-nightly/nimgrep.1 rename to anda/langs/nim/nim-nightly/nimgrep.1 diff --git a/anda/nim/nim-nightly/nimsuggest.1 b/anda/langs/nim/nim-nightly/nimsuggest.1 similarity index 100% rename from anda/nim/nim-nightly/nimsuggest.1 rename to anda/langs/nim/nim-nightly/nimsuggest.1 diff --git a/anda/nim/nim-nightly/update.rhai b/anda/langs/nim/nim-nightly/update.rhai similarity index 100% rename from anda/nim/nim-nightly/update.rhai rename to anda/langs/nim/nim-nightly/update.rhai diff --git a/anda/nim/nim/anda.hcl b/anda/langs/nim/nim/anda.hcl similarity index 100% rename from anda/nim/nim/anda.hcl rename to anda/langs/nim/nim/anda.hcl diff --git a/anda/nim/nim/nim.1 b/anda/langs/nim/nim/nim.1 similarity index 100% rename from anda/nim/nim/nim.1 rename to anda/langs/nim/nim/nim.1 diff --git a/anda/nim/nim/nim.spec b/anda/langs/nim/nim/nim.spec similarity index 99% rename from anda/nim/nim/nim.spec rename to anda/langs/nim/nim/nim.spec index 51a97db01c..4240576b43 100644 --- a/anda/nim/nim/nim.spec +++ b/anda/langs/nim/nim/nim.spec @@ -2,7 +2,7 @@ %global debug_package %{nil} Name: nim -Version: 2.0.0 +Version: 2.0.2 Release: 1%{?dist} Summary: Imperative, multi-paradigm, compiled programming language License: MIT and BSD diff --git a/anda/nim/nim/nimble.1 b/anda/langs/nim/nim/nimble.1 similarity index 100% rename from anda/nim/nim/nimble.1 rename to anda/langs/nim/nim/nimble.1 diff --git a/anda/nim/nim/nimgrep.1 b/anda/langs/nim/nim/nimgrep.1 similarity index 100% rename from anda/nim/nim/nimgrep.1 rename to anda/langs/nim/nim/nimgrep.1 diff --git a/anda/nim/nim/nimsuggest.1 b/anda/langs/nim/nim/nimsuggest.1 similarity index 100% rename from anda/nim/nim/nimsuggest.1 rename to anda/langs/nim/nim/nimsuggest.1 diff --git a/anda/nim/nim/update.rhai b/anda/langs/nim/nim/update.rhai similarity index 100% rename from anda/nim/nim/update.rhai rename to anda/langs/nim/nim/update.rhai diff --git a/anda/tools/ffmpeg/anda.hcl b/anda/langs/python/mpv/anda.hcl similarity index 51% rename from anda/tools/ffmpeg/anda.hcl rename to anda/langs/python/mpv/anda.hcl index 59a107e452..78b5dbc445 100644 --- a/anda/tools/ffmpeg/anda.hcl +++ b/anda/langs/python/mpv/anda.hcl @@ -1,5 +1,5 @@ project pkg { rpm { - spec = "ffmpeg.spec" + spec = "python-mpv.spec" } } diff --git a/anda/langs/python/mpv/python-mpv.spec b/anda/langs/python/mpv/python-mpv.spec new file mode 100644 index 0000000000..779d243f44 --- /dev/null +++ b/anda/langs/python/mpv/python-mpv.spec @@ -0,0 +1,40 @@ +%define debug_package %nil + +Name: python3-mpv +Version: 1.0.5 +Release: 1%{?dist} +Summary: Python interface to the awesome mpv media player +License: GPL-2.0+ OR LGPL-2.1+ +URL: https://github.com/jaseg/python-mpv +Source0: https://github.com/jaseg/python-mpv/archive/refs/tags/v%version.tar.gz +Requires: mpv-devel +BuildRequires: python3-devel +BuildRequires: python3dist(setuptools) + +%description +python-mpv is a ctypes-based python interface to the mpv media player. +It gives you more or less full control of all features of the player, just as the lua interface does. + +%prep +%autosetup -n python-mpv-%version +cat< setup.py +from setuptools import setup + +setup() +EOL + +%build +%py3_build + +%install +%py3_install + +%files +%doc README.rst +%license LICENSE.GPL LICENSE.LGPL +%ghost %python3_sitelib/__pycache__/mpv.cpython-*.pyc +%python3_sitelib/mpv-%version-py%python3_version.egg-info/ +%python3_sitelib/mpv.py + +%changelog +%autochangelog diff --git a/anda/langs/python/mpv/update.rhai b/anda/langs/python/mpv/update.rhai new file mode 100644 index 0000000000..838b801614 --- /dev/null +++ b/anda/langs/python/mpv/update.rhai @@ -0,0 +1 @@ +rpm.version(gh_tag("jaseg/python-mpv")); diff --git a/anda/python/protobuf/anda.hcl b/anda/langs/python/protobuf/anda.hcl similarity index 100% rename from anda/python/protobuf/anda.hcl rename to anda/langs/python/protobuf/anda.hcl diff --git a/anda/python/protobuf/python3-protobuf.spec b/anda/langs/python/protobuf/python3-protobuf.spec similarity index 98% rename from anda/python/protobuf/python3-protobuf.spec rename to anda/langs/python/protobuf/python3-protobuf.spec index ab91f11aa0..0753d31cee 100644 --- a/anda/python/protobuf/python3-protobuf.spec +++ b/anda/langs/python/protobuf/python3-protobuf.spec @@ -2,7 +2,7 @@ %global pypi_name protobuf Name: python-%{pypi_name} -Version: 4.25.1 +Version: 4.25.2 Release: 1%{?dist} Summary: Protocol Buffers diff --git a/anda/python/protobuf/update.rhai b/anda/langs/python/protobuf/update.rhai similarity index 100% rename from anda/python/protobuf/update.rhai rename to anda/langs/python/protobuf/update.rhai diff --git a/anda/python/ruff/anda.hcl b/anda/langs/python/ruff/anda.hcl similarity index 100% rename from anda/python/ruff/anda.hcl rename to anda/langs/python/ruff/anda.hcl diff --git a/anda/python/ruff/python3-ruff.spec b/anda/langs/python/ruff/python3-ruff.spec similarity index 66% rename from anda/python/ruff/python3-ruff.spec rename to anda/langs/python/ruff/python3-ruff.spec index bc736af83d..44dc3a2bc6 100644 --- a/anda/python/ruff/python3-ruff.spec +++ b/anda/langs/python/ruff/python3-ruff.spec @@ -1,13 +1,13 @@ %define debug_package %{nil} Name: python3-ruff -Version: 0.1.7 +Version: 0.1.13 Release: 1%{?dist} Summary: An extremely fast Python linter, written in Rust License: MIT URL: https://beta.ruff.rs/ Source0: https://github.com/astral-sh/ruff/archive/refs/tags/v%{version}.tar.gz -BuildRequires: python3-installer python3.11 python3-pip maturin cargo +BuildRequires: python3-installer python3-pip maturin cargo Provides: python3.11dist(ruff) = %{version} %description @@ -18,10 +18,10 @@ integrating more functionality behind a single, common interface. %autosetup -n ruff-%{version} %build -maturin build --release --strip --locked --all-features +maturin build --release --strip --all-features # --locked %install -python3.11 -m installer --destdir="%{buildroot}" target/wheels/*.whl +pip3 install --root=%{buildroot} target/wheels/*.whl rm -rf %{python3_sitelib}/ruff/__pycache__ %files @@ -30,12 +30,14 @@ rm -rf %{python3_sitelib}/ruff/__pycache__ /usr/lib64/python*/site-packages/ruff-%{version}.dist-info/METADATA /usr/lib64/python*/site-packages/ruff-%{version}.dist-info/RECORD /usr/lib64/python*/site-packages/ruff-%{version}.dist-info/WHEEL -/usr/lib64/python*/site-packages/ruff/__pycache__/__init__.cpython-*.pyc +/usr/lib64/python*/site-packages/ruff-%{version}.dist-info/INSTALLER +/usr/lib64/python*/site-packages/ruff-%{version}.dist-info/REQUESTED +/usr/lib64/python*/site-packages/ruff-%{version}.dist-info/direct_url.json /usr/lib64/python*/site-packages/ruff-%{version}.dist-info/license_files/LICENSE /usr/lib64/python*/site-packages/ruff/__init__.py /usr/lib64/python*/site-packages/ruff/__main__.py -/usr/lib64/python*/site-packages/ruff/__pycache__/__main__.cpython-*.opt-1.pyc -/usr/lib64/python*/site-packages/ruff/__pycache__/__main__.cpython-*.pyc +/usr/lib64/python*/site-packages/ruff/__pycache__/*.cpython-*.opt-1.pyc +/usr/lib64/python*/site-packages/ruff/__pycache__/*.cpython-*.pyc /usr/bin/ruff %changelog diff --git a/anda/python/ruff/update.rhai b/anda/langs/python/ruff/update.rhai similarity index 100% rename from anda/python/ruff/update.rhai rename to anda/langs/python/ruff/update.rhai diff --git a/anda/rust/bandwhich/anda.hcl b/anda/langs/rust/bandwhich/anda.hcl similarity index 100% rename from anda/rust/bandwhich/anda.hcl rename to anda/langs/rust/bandwhich/anda.hcl diff --git a/anda/rust/bandwhich/bandwhich-fix-metadata-auto.diff b/anda/langs/rust/bandwhich/bandwhich-fix-metadata-auto.diff similarity index 100% rename from anda/rust/bandwhich/bandwhich-fix-metadata-auto.diff rename to anda/langs/rust/bandwhich/bandwhich-fix-metadata-auto.diff diff --git a/anda/rust/bandwhich/rust-bandwhich.spec b/anda/langs/rust/bandwhich/rust-bandwhich.spec similarity index 100% rename from anda/rust/bandwhich/rust-bandwhich.spec rename to anda/langs/rust/bandwhich/rust-bandwhich.spec diff --git a/anda/rust/bandwhich/update.rhai b/anda/langs/rust/bandwhich/update.rhai similarity index 100% rename from anda/rust/bandwhich/update.rhai rename to anda/langs/rust/bandwhich/update.rhai diff --git a/anda/rust/bat-extras/anda.hcl b/anda/langs/rust/bat-extras/anda.hcl similarity index 100% rename from anda/rust/bat-extras/anda.hcl rename to anda/langs/rust/bat-extras/anda.hcl diff --git a/anda/rust/bat-extras/bat-extras.spec b/anda/langs/rust/bat-extras/bat-extras.spec similarity index 100% rename from anda/rust/bat-extras/bat-extras.spec rename to anda/langs/rust/bat-extras/bat-extras.spec diff --git a/anda/rust/bat-extras/update.rhai b/anda/langs/rust/bat-extras/update.rhai similarity index 100% rename from anda/rust/bat-extras/update.rhai rename to anda/langs/rust/bat-extras/update.rhai diff --git a/anda/rust/felix/anda.hcl b/anda/langs/rust/felix/anda.hcl similarity index 100% rename from anda/rust/felix/anda.hcl rename to anda/langs/rust/felix/anda.hcl diff --git a/anda/rust/felix/rust-felix.spec b/anda/langs/rust/felix/rust-felix.spec similarity index 97% rename from anda/rust/felix/rust-felix.spec rename to anda/langs/rust/felix/rust-felix.spec index 7716b41b68..8185cdd65d 100644 --- a/anda/rust/felix/rust-felix.spec +++ b/anda/langs/rust/felix/rust-felix.spec @@ -2,7 +2,7 @@ %global crate felix Name: rust-felix -Version: 2.10.1 +Version: 2.11.1 Release: 1%{?dist} Summary: Tui file manager with vim-like key mapping diff --git a/anda/rust/felix/update.rhai b/anda/langs/rust/felix/update.rhai similarity index 100% rename from anda/rust/felix/update.rhai rename to anda/langs/rust/felix/update.rhai diff --git a/anda/rust/gitoxide/anda.hcl b/anda/langs/rust/gitoxide/anda.hcl similarity index 100% rename from anda/rust/gitoxide/anda.hcl rename to anda/langs/rust/gitoxide/anda.hcl diff --git a/anda/rust/gitoxide/rust-gitoxide.spec b/anda/langs/rust/gitoxide/rust-gitoxide.spec similarity index 99% rename from anda/rust/gitoxide/rust-gitoxide.spec rename to anda/langs/rust/gitoxide/rust-gitoxide.spec index b9f1eed12f..7be592cc1f 100644 --- a/anda/rust/gitoxide/rust-gitoxide.spec +++ b/anda/langs/rust/gitoxide/rust-gitoxide.spec @@ -4,7 +4,7 @@ %global crate gitoxide Name: rust-gitoxide -Version: 0.32.0 +Version: 0.33.0 Release: 1%{?dist} Summary: Command-line application for interacting with git repositories @@ -27,7 +27,6 @@ Summary: %{summary} %files -n %{crate} %license LICENSE-APACHE %license LICENSE-MIT -%doc CHANGELOG.md %doc README.md %{_bindir}/ein %{_bindir}/gix @@ -44,7 +43,6 @@ use the "%{crate}" crate. %files devel %license %{crate_instdir}/LICENSE-APACHE %license %{crate_instdir}/LICENSE-MIT -%doc %{crate_instdir}/CHANGELOG.md %doc %{crate_instdir}/README.md %{crate_instdir}/ diff --git a/anda/rust/gitoxide/update.rhai b/anda/langs/rust/gitoxide/update.rhai similarity index 100% rename from anda/rust/gitoxide/update.rhai rename to anda/langs/rust/gitoxide/update.rhai diff --git a/anda/rust/gping/anda.hcl b/anda/langs/rust/gping/anda.hcl similarity index 100% rename from anda/rust/gping/anda.hcl rename to anda/langs/rust/gping/anda.hcl diff --git a/anda/rust/gping/rust-gping.spec b/anda/langs/rust/gping/rust-gping.spec similarity index 100% rename from anda/rust/gping/rust-gping.spec rename to anda/langs/rust/gping/rust-gping.spec diff --git a/anda/rust/gping/update.rhai b/anda/langs/rust/gping/update.rhai similarity index 100% rename from anda/rust/gping/update.rhai rename to anda/langs/rust/gping/update.rhai diff --git a/anda/rust/joshuto/anda.hcl b/anda/langs/rust/joshuto/anda.hcl similarity index 100% rename from anda/rust/joshuto/anda.hcl rename to anda/langs/rust/joshuto/anda.hcl diff --git a/anda/rust/joshuto/rust-joshuto.spec b/anda/langs/rust/joshuto/rust-joshuto.spec similarity index 100% rename from anda/rust/joshuto/rust-joshuto.spec rename to anda/langs/rust/joshuto/rust-joshuto.spec diff --git a/anda/rust/joshuto/update.rhai b/anda/langs/rust/joshuto/update.rhai similarity index 100% rename from anda/rust/joshuto/update.rhai rename to anda/langs/rust/joshuto/update.rhai diff --git a/anda/rust/kondo-ui/anda.hcl b/anda/langs/rust/kondo-ui/anda.hcl similarity index 100% rename from anda/rust/kondo-ui/anda.hcl rename to anda/langs/rust/kondo-ui/anda.hcl diff --git a/anda/rust/kondo-ui/rust-kondo-ui.spec b/anda/langs/rust/kondo-ui/rust-kondo-ui.spec similarity index 98% rename from anda/rust/kondo-ui/rust-kondo-ui.spec rename to anda/langs/rust/kondo-ui/rust-kondo-ui.spec index 07fbbd84cf..e96222e791 100644 --- a/anda/rust/kondo-ui/rust-kondo-ui.spec +++ b/anda/langs/rust/kondo-ui/rust-kondo-ui.spec @@ -2,7 +2,7 @@ %global crate kondo-ui Name: rust-kondo-ui -Version: 0.7.0 +Version: 0.8.0 Release: 1%{?dist} Summary: Filesystem cleaning tool that recursively searches directories for known project structures and allows you to clean them of unnecessary files like build artifacts diff --git a/anda/rust/kondo-ui/update.rhai b/anda/langs/rust/kondo-ui/update.rhai similarity index 100% rename from anda/rust/kondo-ui/update.rhai rename to anda/langs/rust/kondo-ui/update.rhai diff --git a/anda/rust/kondo/anda.hcl b/anda/langs/rust/kondo/anda.hcl similarity index 100% rename from anda/rust/kondo/anda.hcl rename to anda/langs/rust/kondo/anda.hcl diff --git a/anda/rust/kondo/rust-kondo.spec b/anda/langs/rust/kondo/rust-kondo.spec similarity index 98% rename from anda/rust/kondo/rust-kondo.spec rename to anda/langs/rust/kondo/rust-kondo.spec index 427e4fb3f8..ede9507850 100644 --- a/anda/rust/kondo/rust-kondo.spec +++ b/anda/langs/rust/kondo/rust-kondo.spec @@ -4,7 +4,7 @@ %global crate kondo Name: rust-kondo -Version: 0.7 +Version: 0.8 Release: 1%{?dist} Summary: Filesystem cleaning tool for projects diff --git a/anda/rust/kondo/update.rhai b/anda/langs/rust/kondo/update.rhai similarity index 100% rename from anda/rust/kondo/update.rhai rename to anda/langs/rust/kondo/update.rhai diff --git a/anda/rust/maturin/anda.hcl b/anda/langs/rust/maturin/anda.hcl similarity index 100% rename from anda/rust/maturin/anda.hcl rename to anda/langs/rust/maturin/anda.hcl diff --git a/anda/rust/maturin/rust-terra-maturin.spec b/anda/langs/rust/maturin/rust-terra-maturin.spec similarity index 100% rename from anda/rust/maturin/rust-terra-maturin.spec rename to anda/langs/rust/maturin/rust-terra-maturin.spec diff --git a/anda/rust/maturin/update.rhai b/anda/langs/rust/maturin/update.rhai similarity index 100% rename from anda/rust/maturin/update.rhai rename to anda/langs/rust/maturin/update.rhai diff --git a/anda/rust/nushell/anda.hcl b/anda/langs/rust/nushell/anda.hcl similarity index 100% rename from anda/rust/nushell/anda.hcl rename to anda/langs/rust/nushell/anda.hcl diff --git a/anda/rust/nushell/nushell.spec b/anda/langs/rust/nushell/nushell.spec similarity index 94% rename from anda/rust/nushell/nushell.spec rename to anda/langs/rust/nushell/nushell.spec index 6f7d66f7aa..d530f5a188 100644 --- a/anda/rust/nushell/nushell.spec +++ b/anda/langs/rust/nushell/nushell.spec @@ -1,12 +1,12 @@ Name: nushell -Version: 0.86.0 +Version: 0.89.0 Release: 1%{?dist} Summary: A new type of shell License: MIT URL: https://www.nushell.sh/ Source0: https://github.com/nushell/nushell/archive/refs/tags/%version.tar.gz BuildRequires: anda-srpm-macros rust-packaging openssl-devel -Requires: glibc gcc-libs openssl zlib +Requires: glibc openssl zlib %description %summary. @@ -30,6 +30,7 @@ if [ "$1" = 1 ]; then else grep -q "^%{_bindir}/nu$" %{_sysconfdir}/shells || echo "%{_bindir}/nu" >> %{_sysconfdir}/shells grep -q "^/bin/nu$" %{_sysconfdir}/shells || echo "/bin/nu" >> %{_sysconfdir}/shells + fi fi %postun diff --git a/anda/rust/nushell/update.rhai b/anda/langs/rust/nushell/update.rhai similarity index 100% rename from anda/rust/nushell/update.rhai rename to anda/langs/rust/nushell/update.rhai diff --git a/anda/rust/ouch/anda.hcl b/anda/langs/rust/ouch/anda.hcl similarity index 100% rename from anda/rust/ouch/anda.hcl rename to anda/langs/rust/ouch/anda.hcl diff --git a/anda/langs/rust/ouch/ouch-fix-metadata-auto.diff b/anda/langs/rust/ouch/ouch-fix-metadata-auto.diff new file mode 100644 index 0000000000..4b23e58e2d --- /dev/null +++ b/anda/langs/rust/ouch/ouch-fix-metadata-auto.diff @@ -0,0 +1,8 @@ +--- ouch-0.5.1/Cargo.toml 1970-01-01T00:00:01+00:00 ++++ ouch-0.5.1/Cargo.toml 2023-12-10T09:36:31.446957+00:00 +@@ -176,5 +176,3 @@ + ] + use_zstd_thin = ["zstd/thin"] + +-[target."cfg(not(unix))".dependencies.is_executable] +-version = "1.0.1" diff --git a/anda/rust/ouch/rust-ouch.spec b/anda/langs/rust/ouch/rust-ouch.spec similarity index 79% rename from anda/rust/ouch/rust-ouch.spec rename to anda/langs/rust/ouch/rust-ouch.spec index 9e72ae86cc..b745ec90d9 100644 --- a/anda/rust/ouch/rust-ouch.spec +++ b/anda/langs/rust/ouch/rust-ouch.spec @@ -1,4 +1,4 @@ -# Generated by rust2rpm 24 +# Generated by rust2rpm 25 %bcond_without check %global crate ouch @@ -11,10 +11,11 @@ Summary: Command-line utility for easily compressing and decompressing fi License: MIT URL: https://crates.io/crates/ouch Source: %{crates_source} -# Automatically generated patch to strip foreign dependencies +# Automatically generated patch to strip dependencies and normalize metadata Patch: ouch-fix-metadata-auto.diff -BuildRequires: anda-srpm-macros rust-packaging >= 21 +BuildRequires: anda-srpm-macros cargo-rpm-macros >= 24 +BuildRequires: gcc-c++ %global _description %{expand: A command-line utility for easily compressing and decompressing files @@ -35,7 +36,7 @@ Summary: %{summary} %{_bindir}/ouch %prep -%autosetup -n %{crate}-%{version_no_tilde} -p1 +%autosetup -n %{crate}-%{version} -p1 %cargo_prep_online %build diff --git a/anda/rust/ouch/update.rhai b/anda/langs/rust/ouch/update.rhai similarity index 100% rename from anda/rust/ouch/update.rhai rename to anda/langs/rust/ouch/update.rhai diff --git a/anda/rust/oxipng/anda.hcl b/anda/langs/rust/oxipng/anda.hcl similarity index 100% rename from anda/rust/oxipng/anda.hcl rename to anda/langs/rust/oxipng/anda.hcl diff --git a/anda/rust/oxipng/oxipng-fix-metadata-auto.diff b/anda/langs/rust/oxipng/oxipng-fix-metadata-auto.diff similarity index 100% rename from anda/rust/oxipng/oxipng-fix-metadata-auto.diff rename to anda/langs/rust/oxipng/oxipng-fix-metadata-auto.diff diff --git a/anda/rust/oxipng/rust-oxipng.spec b/anda/langs/rust/oxipng/rust-oxipng.spec similarity index 100% rename from anda/rust/oxipng/rust-oxipng.spec rename to anda/langs/rust/oxipng/rust-oxipng.spec diff --git a/anda/rust/oxipng/update.rhai b/anda/langs/rust/oxipng/update.rhai similarity index 100% rename from anda/rust/oxipng/update.rhai rename to anda/langs/rust/oxipng/update.rhai diff --git a/anda/rust/pop-launcher/.gitignore b/anda/langs/rust/pop-launcher/.gitignore similarity index 100% rename from anda/rust/pop-launcher/.gitignore rename to anda/langs/rust/pop-launcher/.gitignore diff --git a/anda/rust/pop-launcher/0001-Copy-instead-of-symlink.patch b/anda/langs/rust/pop-launcher/0001-Copy-instead-of-symlink.patch similarity index 100% rename from anda/rust/pop-launcher/0001-Copy-instead-of-symlink.patch rename to anda/langs/rust/pop-launcher/0001-Copy-instead-of-symlink.patch diff --git a/anda/rust/pop-launcher/0001-Remove-frozen-lock.patch b/anda/langs/rust/pop-launcher/0001-Remove-frozen-lock.patch similarity index 100% rename from anda/rust/pop-launcher/0001-Remove-frozen-lock.patch rename to anda/langs/rust/pop-launcher/0001-Remove-frozen-lock.patch diff --git a/anda/rust/pop-launcher/anda.hcl b/anda/langs/rust/pop-launcher/anda.hcl similarity index 100% rename from anda/rust/pop-launcher/anda.hcl rename to anda/langs/rust/pop-launcher/anda.hcl diff --git a/anda/rust/pop-launcher/pop-launcher.spec b/anda/langs/rust/pop-launcher/pop-launcher.spec similarity index 100% rename from anda/rust/pop-launcher/pop-launcher.spec rename to anda/langs/rust/pop-launcher/pop-launcher.spec diff --git a/anda/rust/pop-launcher/prepare.sh b/anda/langs/rust/pop-launcher/prepare.sh similarity index 100% rename from anda/rust/pop-launcher/prepare.sh rename to anda/langs/rust/pop-launcher/prepare.sh diff --git a/anda/rust/pop-launcher/umpkg.cfg b/anda/langs/rust/pop-launcher/umpkg.cfg similarity index 100% rename from anda/rust/pop-launcher/umpkg.cfg rename to anda/langs/rust/pop-launcher/umpkg.cfg diff --git a/anda/rust/pop-launcher/umpkg.toml b/anda/langs/rust/pop-launcher/umpkg.toml similarity index 100% rename from anda/rust/pop-launcher/umpkg.toml rename to anda/langs/rust/pop-launcher/umpkg.toml diff --git a/anda/rust/pop-launcher/update.rhai b/anda/langs/rust/pop-launcher/update.rhai similarity index 100% rename from anda/rust/pop-launcher/update.rhai rename to anda/langs/rust/pop-launcher/update.rhai diff --git a/anda/rust/rnote/anda.hcl b/anda/langs/rust/rnote/anda.hcl similarity index 100% rename from anda/rust/rnote/anda.hcl rename to anda/langs/rust/rnote/anda.hcl diff --git a/anda/rust/rnote/rnote.spec b/anda/langs/rust/rnote/rnote.spec similarity index 98% rename from anda/rust/rnote/rnote.spec rename to anda/langs/rust/rnote/rnote.spec index 223625f1ef..1dbd2b29a5 100644 --- a/anda/rust/rnote/rnote.spec +++ b/anda/langs/rust/rnote/rnote.spec @@ -1,5 +1,5 @@ Name: rnote -Version: 0.9.3 +Version: 0.9.4 Release: 1%{?dist} Summary: Sketch and take handwritten notes. License: GPL-3.0 diff --git a/anda/rust/rnote/update.rhai b/anda/langs/rust/rnote/update.rhai similarity index 100% rename from anda/rust/rnote/update.rhai rename to anda/langs/rust/rnote/update.rhai diff --git a/anda/rust/starship/anda.hcl b/anda/langs/rust/starship/anda.hcl similarity index 100% rename from anda/rust/starship/anda.hcl rename to anda/langs/rust/starship/anda.hcl diff --git a/anda/rust/starship/rust-starship.spec b/anda/langs/rust/starship/rust-starship.spec similarity index 99% rename from anda/rust/starship/rust-starship.spec rename to anda/langs/rust/starship/rust-starship.spec index d8ed88bcaa..43afbec1ef 100644 --- a/anda/rust/starship/rust-starship.spec +++ b/anda/langs/rust/starship/rust-starship.spec @@ -5,7 +5,7 @@ %global crate starship Name: rust-starship -Version: 1.16.0 +Version: 1.17.1 Release: 1%{?dist} Summary: Minimal, blazing-fast, and infinitely customizable prompt for any shell! ☄🌌️ diff --git a/anda/rust/starship/starship-fix-metadata-auto.diff b/anda/langs/rust/starship/starship-fix-metadata-auto.diff similarity index 100% rename from anda/rust/starship/starship-fix-metadata-auto.diff rename to anda/langs/rust/starship/starship-fix-metadata-auto.diff diff --git a/anda/rust/starship/update.rhai b/anda/langs/rust/starship/update.rhai similarity index 100% rename from anda/rust/starship/update.rhai rename to anda/langs/rust/starship/update.rhai diff --git a/anda/rust/tectonic/anda.hcl b/anda/langs/rust/tectonic/anda.hcl similarity index 100% rename from anda/rust/tectonic/anda.hcl rename to anda/langs/rust/tectonic/anda.hcl diff --git a/anda/rust/tectonic/rust-tectonic.spec b/anda/langs/rust/tectonic/rust-tectonic.spec similarity index 100% rename from anda/rust/tectonic/rust-tectonic.spec rename to anda/langs/rust/tectonic/rust-tectonic.spec diff --git a/anda/rust/tectonic/update.rhai b/anda/langs/rust/tectonic/update.rhai similarity index 100% rename from anda/rust/tectonic/update.rhai rename to anda/langs/rust/tectonic/update.rhai diff --git a/anda/rust/youki/anda.hcl b/anda/langs/rust/youki/anda.hcl similarity index 100% rename from anda/rust/youki/anda.hcl rename to anda/langs/rust/youki/anda.hcl diff --git a/anda/rust/youki/dep-protobuf.diff b/anda/langs/rust/youki/dep-protobuf.diff similarity index 100% rename from anda/rust/youki/dep-protobuf.diff rename to anda/langs/rust/youki/dep-protobuf.diff diff --git a/anda/langs/rust/youki/rust-youki.spec b/anda/langs/rust/youki/rust-youki.spec new file mode 100644 index 0000000000..03ddf728ec --- /dev/null +++ b/anda/langs/rust/youki/rust-youki.spec @@ -0,0 +1,58 @@ +# Generated by rust2rpm 25 +#bcond_without check + +%global crate youki + +Name: rust-youki +Version: 0.3.0 +Release: %autorelease +Summary: Container runtime written in Rust + +License: None +URL: https://crates.io/crates/youki +Source: %{crates_source} + +BuildRequires: anda-srpm-macros cargo-rpm-macros >= 24 +BuildRequires: pkg-config +BuildRequires: systemd-devel +BuildRequires: dbus-devel +BuildRequires: libseccomp-devel +BuildRequires: elfutils-libelf-devel +BuildRequires: binutils + +%global _description %{expand: +A container runtime written in Rust.} + +%description %{_description} + +%package -n %{crate} +Summary: %{summary} +License: Apache-2.0 + +%description -n %{crate} %{_description} + +%files -n %{crate} +%license LICENSE +%license LICENSE.dependencies +%doc README.md +%{_bindir}/youki + +%prep +%autosetup -n %{crate}-%{version} -p1 +%cargo_prep_online + +%build +%cargo_build +%{cargo_license_summary} +%{cargo_license} > LICENSE.dependencies + +%install +%cargo_install + +%if %{with check} +%check +%cargo_test +%endif + +%changelog +%autochangelog diff --git a/anda/rust/youki/update.rhai b/anda/langs/rust/youki/update.rhai similarity index 100% rename from anda/rust/youki/update.rhai rename to anda/langs/rust/youki/update.rhai diff --git a/anda/rust/youki/youki.spec b/anda/langs/rust/youki/youki.spec similarity index 87% rename from anda/rust/youki/youki.spec rename to anda/langs/rust/youki/youki.spec index b8ab7999f3..1bc9773b13 100644 --- a/anda/rust/youki/youki.spec +++ b/anda/langs/rust/youki/youki.spec @@ -1,12 +1,11 @@ Name: youki -Version: 0.3.0 +Version: 0.3.1 Release: 1%{?dist} Summary: A container runtime written in Rust License: Apache-2.0 URL: https://github.com/containers/youki Source0: https://github.com/containers/youki/archive/refs/tags/v%{version}.tar.gz -Patch0: dep-protobuf.diff BuildRequires: pkg-config BuildRequires: rust-packaging @@ -38,13 +37,12 @@ git checkout v%{version} # mkdir -p ~/.ssh # ssh-keyscan github.com >> ~/.ssh/known_hosts -git submodule set-url integration_tests/oci-runtime-tests https://github.com/opencontainers/runtime-tools -git submodule sync +#git submodule set-url integration_tests/oci-runtime-tests https://github.com/opencontainers/runtime-tools +#git submodule sync # download git submodules git submodule update --init --recursive -%patch 0 -p1 %cargo_prep_online diff --git a/anda/rust/zellij/.gitignore b/anda/langs/rust/zellij/.gitignore similarity index 100% rename from anda/rust/zellij/.gitignore rename to anda/langs/rust/zellij/.gitignore diff --git a/anda/rust/zellij/anda.hcl b/anda/langs/rust/zellij/anda.hcl similarity index 100% rename from anda/rust/zellij/anda.hcl rename to anda/langs/rust/zellij/anda.hcl diff --git a/anda/rust/zellij/rust-zellij.spec b/anda/langs/rust/zellij/rust-zellij.spec similarity index 95% rename from anda/rust/zellij/rust-zellij.spec rename to anda/langs/rust/zellij/rust-zellij.spec index 193288b67f..af75cf782e 100644 --- a/anda/rust/zellij/rust-zellij.spec +++ b/anda/langs/rust/zellij/rust-zellij.spec @@ -18,6 +18,8 @@ ExclusiveArch: %{rust_arches} BuildRequires: anda-srpm-macros BuildRequires: rust-packaging BuildRequires: openssl-devel +BuildRequires: gcc +BuildRequires: perl #BuildRequires: external:crate:sccache diff --git a/anda/rust/zellij/umpkg.toml b/anda/langs/rust/zellij/umpkg.toml similarity index 100% rename from anda/rust/zellij/umpkg.toml rename to anda/langs/rust/zellij/umpkg.toml diff --git a/anda/rust/zellij/update.rhai b/anda/langs/rust/zellij/update.rhai similarity index 100% rename from anda/rust/zellij/update.rhai rename to anda/langs/rust/zellij/update.rhai diff --git a/anda/vala/vala-language-server-nightly/anda.hcl b/anda/langs/vala/vala-language-server-nightly/anda.hcl similarity index 100% rename from anda/vala/vala-language-server-nightly/anda.hcl rename to anda/langs/vala/vala-language-server-nightly/anda.hcl diff --git a/anda/vala/vala-language-server-nightly/update.rhai b/anda/langs/vala/vala-language-server-nightly/update.rhai similarity index 100% rename from anda/vala/vala-language-server-nightly/update.rhai rename to anda/langs/vala/vala-language-server-nightly/update.rhai diff --git a/anda/vala/vala-language-server-nightly/vala-language-server-nightly.spec b/anda/langs/vala/vala-language-server-nightly/vala-language-server-nightly.spec similarity index 100% rename from anda/vala/vala-language-server-nightly/vala-language-server-nightly.spec rename to anda/langs/vala/vala-language-server-nightly/vala-language-server-nightly.spec diff --git a/anda/vala/vala-lint-nightly/anda.hcl b/anda/langs/vala/vala-lint-nightly/anda.hcl similarity index 100% rename from anda/vala/vala-lint-nightly/anda.hcl rename to anda/langs/vala/vala-lint-nightly/anda.hcl diff --git a/anda/vala/vala-lint-nightly/update.rhai b/anda/langs/vala/vala-lint-nightly/update.rhai similarity index 100% rename from anda/vala/vala-lint-nightly/update.rhai rename to anda/langs/vala/vala-lint-nightly/update.rhai diff --git a/anda/vala/vala-lint-nightly/vala-lint-nightly.spec b/anda/langs/vala/vala-lint-nightly/vala-lint-nightly.spec similarity index 90% rename from anda/vala/vala-lint-nightly/vala-lint-nightly.spec rename to anda/langs/vala/vala-lint-nightly/vala-lint-nightly.spec index c3fe93dd99..7c9ed5b917 100644 --- a/anda/vala/vala-lint-nightly/vala-lint-nightly.spec +++ b/anda/langs/vala/vala-lint-nightly/vala-lint-nightly.spec @@ -1,6 +1,6 @@ %global real_name vala-lint -%global commit 95cf9e61a73fe4a0f69fd8c275c9548703f79838 +%global commit 8ae2bb65fe66458263d94711ae4ddd978faece00 %global shortcommit %(c=%{commit}; echo ${c:0:7}) %global commit_date %(date '+%Y%m%d') @@ -19,8 +19,9 @@ BuildRequires: cmake BuildRequires: gcc BuildRequires: meson BuildRequires: ninja-build -BuildRequires: vala = 0.56.4 -BuildRequires: vala-devel = 0.56.4 +BuildRequires: vala >= 0.56.4 +BuildRequires: vala-devel >= 0.56.4 +BuildRequires: pkgconfig(json-glib-1.0) %description Small command line tool and library for checking Vala code files for code-style diff --git a/anda/vala/vala-nightly/anda.hcl b/anda/langs/vala/vala-nightly/anda.hcl similarity index 100% rename from anda/vala/vala-nightly/anda.hcl rename to anda/langs/vala/vala-nightly/anda.hcl diff --git a/anda/vala/vala-nightly/update.rhai b/anda/langs/vala/vala-nightly/update.rhai similarity index 100% rename from anda/vala/vala-nightly/update.rhai rename to anda/langs/vala/vala-nightly/update.rhai diff --git a/anda/vala/vala-nightly/vala-nightly.spec b/anda/langs/vala/vala-nightly/vala-nightly.spec similarity index 86% rename from anda/vala/vala-nightly/vala-nightly.spec rename to anda/langs/vala/vala-nightly/vala-nightly.spec index 72b9d7791a..3f1882fcd1 100644 --- a/anda/vala/vala-nightly/vala-nightly.spec +++ b/anda/langs/vala/vala-nightly/vala-nightly.spec @@ -3,7 +3,7 @@ %global priority 90 %global real_name vala -%global commit f25dc811e83dc539add58ee35ab2b164868f0959 +%global commit 729d2993dc1844f7120b7123de8f41c4be0111cd %global shortcommit %(c=%{commit}; echo ${c:0:7}) %global repo https://gitlab.gnome.org/GNOME/%{real_name}.git @@ -86,22 +86,24 @@ applications and libraries written in C. This package contains development files for libvala. This is not necessary for using the %{name} compiler. +# TODO: currently the docs aren't included in the default build (they were before, even with sphinx installed) +# I think this is because they recently changed to using sphinx, which they're still working on +# I'll try to get this working again, but for now I'll just disable it until they're ready +# %package doc +# Summary: Documentation for %{name} +# BuildArch: noarch +# Requires: %{name} = %{version}-%{release} +# Requires: devhelp -%package doc -Summary: Documentation for %{name} -BuildArch: noarch -Requires: %{name} = %{version}-%{release} -Requires: devhelp +# Conflicts: vala-doc -Conflicts: vala-doc +# %description doc +# Vala is a new programming language that aims to bring modern programming +# language features to GNOME developers without imposing any additional +# runtime requirements and without using a different ABI compared to +# applications and libraries written in C. -%description doc -Vala is a new programming language that aims to bring modern programming -language features to GNOME developers without imposing any additional -runtime requirements and without using a different ABI compared to -applications and libraries written in C. - -This package contains documentation in a devhelp HTML book. +# This package contains documentation in a devhelp HTML book. %package -n valadoc-nightly @@ -200,8 +202,8 @@ export -n VALAFLAGS %{_libdir}/libvala-%{api_ver}.so %{_libdir}/pkgconfig/libvala-%{api_ver}.pc -%files doc -%doc %{_libdir}/valadoc-%{api_ver}/doclets/devhelp +# %files doc +# %doc %{_datadir}/devhelp/books/vala-%{api_ver} %files -n valadoc-nightly %{_bindir}/valadoc diff --git a/anda/apps/vala-panel-appmenu/anda.hcl b/anda/langs/vala/vala-panel-appmenu/anda.hcl similarity index 100% rename from anda/apps/vala-panel-appmenu/anda.hcl rename to anda/langs/vala/vala-panel-appmenu/anda.hcl diff --git a/anda/apps/vala-panel-appmenu/update.rhai b/anda/langs/vala/vala-panel-appmenu/update.rhai similarity index 100% rename from anda/apps/vala-panel-appmenu/update.rhai rename to anda/langs/vala/vala-panel-appmenu/update.rhai diff --git a/anda/apps/vala-panel-appmenu/vala-panel-appmenu.spec b/anda/langs/vala/vala-panel-appmenu/vala-panel-appmenu.spec similarity index 98% rename from anda/apps/vala-panel-appmenu/vala-panel-appmenu.spec rename to anda/langs/vala/vala-panel-appmenu/vala-panel-appmenu.spec index aee519f693..23a8278a7c 100644 --- a/anda/apps/vala-panel-appmenu/vala-panel-appmenu.spec +++ b/anda/langs/vala/vala-panel-appmenu/vala-panel-appmenu.spec @@ -1,5 +1,5 @@ %global forgeurl https://gitlab.com/vala-panel-project/vala-panel-appmenu -%global commit 76442be6195385193cb5931d0004122310d40c95 +%global commit 7abc96e774fb7bc00318d834ad988dd229655c34 %forgemeta Name: vala-panel-appmenu @@ -7,6 +7,7 @@ Version: 0.7.6 Release: 2%?dist License: LGPL-3.0-or-later Summary: Application Menu plugin for vala-panel +Group: System/GUI/Other URL: %{forgeurl} Source: %{forgesource} diff --git a/anda/apps/vala-panel/anda.hcl b/anda/langs/vala/vala-panel/anda.hcl similarity index 100% rename from anda/apps/vala-panel/anda.hcl rename to anda/langs/vala/vala-panel/anda.hcl diff --git a/anda/apps/vala-panel/vala-panel.spec b/anda/langs/vala/vala-panel/vala-panel.spec similarity index 98% rename from anda/apps/vala-panel/vala-panel.spec rename to anda/langs/vala/vala-panel/vala-panel.spec index 5f403e84fd..43e5868d87 100644 --- a/anda/apps/vala-panel/vala-panel.spec +++ b/anda/langs/vala/vala-panel/vala-panel.spec @@ -1,6 +1,5 @@ %global forgeurl https://gitlab.com/vala-panel-project/vala-panel %global commit ead4e7a36b0e4b0a2ac43c5d9ca17eb753461afe - %forgemeta Name: vala-panel @@ -8,6 +7,7 @@ Version: 0.5.0 Release: 2%?dist License: LGPL-3.0-or-later Summary: This package provides Application Menu plugin for vala-panel +Group: System/GUI/Other URL: %{forgeurl} Source: %{forgesource} diff --git a/anda/lib/libayatana-common/libayatana-common.spec b/anda/lib/libayatana-common/libayatana-common.spec index 3063b480ca..e2c1367b5c 100644 --- a/anda/lib/libayatana-common/libayatana-common.spec +++ b/anda/lib/libayatana-common/libayatana-common.spec @@ -1,6 +1,6 @@ Name: libayatana-common Summary: Common functions for Ayatana System Indicators -Version: 0.9.9 +Version: 0.9.10 Release: 1%{?dist} License: GPL-3.0 URL: https://github.com/AyatanaIndicators/libayatana-common diff --git a/anda/lib/libhelium/libhelium.spec b/anda/lib/libhelium/libhelium.spec index e5bdfc40d8..cce7e6b7a9 100644 --- a/anda/lib/libhelium/libhelium.spec +++ b/anda/lib/libhelium/libhelium.spec @@ -1,6 +1,6 @@ Summary: The Application Framework for tauOS apps Name: libhelium -Version: 1.8.1 +Version: 1.8.2 Release: 1%{?dist} License: GPL-3.0 URL: https://github.com/tau-OS/libhelium diff --git a/anda/lib/openh264/openh264.spec b/anda/lib/openh264/openh264.spec index c2c742282b..a755ceeb11 100644 --- a/anda/lib/openh264/openh264.spec +++ b/anda/lib/openh264/openh264.spec @@ -2,8 +2,8 @@ %global commit1 e7d30b921df736a1121a0c8e0cf3ab1ce5b8a4b7 %global shortcommit1 %(c=%{commit1}; echo ${c:0:7}) -%global openh264_version 2.3.1 -%global gst_version 1.22.7 +%global openh264_version 2.4.0 +%global gst_version 1.22.8 Name: openh264 Version: %{openh264_version} diff --git a/anda/lib/placebo/anda.hcl b/anda/lib/placebo/anda.hcl new file mode 100644 index 0000000000..43b027d77c --- /dev/null +++ b/anda/lib/placebo/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "terra-libplacebo.spec" + } +} diff --git a/anda/lib/placebo/terra-libplacebo.spec b/anda/lib/placebo/terra-libplacebo.spec new file mode 100644 index 0000000000..4a83b812c2 --- /dev/null +++ b/anda/lib/placebo/terra-libplacebo.spec @@ -0,0 +1,80 @@ +Name: terra-libplacebo +Version: 6.338.1 +Release: %autorelease +Summary: Reusable library for GPU-accelerated video/image rendering primitives + +License: LGPLv2+ +URL: https://github.com/haasn/libplacebo +Source0: %{url}/archive/v%{version}%{?prerelease}/libplacebo-%{version}%{?prerelease}.tar.gz + +BuildRequires: gcc +BuildRequires: gcc-c++ +BuildRequires: meson +BuildRequires: glad2 >= 2.0.0 +BuildRequires: lcms2-devel +BuildRequires: libdovi-devel +BuildRequires: libepoxy-devel +BuildRequires: libunwind-devel +BuildRequires: libshaderc-devel >= 2018.0-1 +BuildRequires: python3-mako +BuildRequires: spirv-tools-devel +BuildRequires: vulkan-devel +BuildRequires: glslang-devel +BuildRequires: xxhash-devel + + +%description +libplacebo is essentially the core rendering algorithms and ideas of +mpv turned into a library. This grew out of an interest to accomplish +the following goals: + +- Clean up mpv's internal API and make it reusable for other projects. +- Provide a standard library of useful GPU-accelerated image processing + primitives based on GLSL, so projects like VLC or Firefox can use them + without incurring a heavy dependency on `libmpv`. +- Rewrite core parts of mpv's GPU-accelerated video renderer on top of + redesigned abstractions. (Basically, I wanted to eliminate code smell + like `shader_cache.c` and totally redesign `gpu/video.c`) + + +%package devel +Summary: Development files for %{name} +Requires: %{name}%{?_isa} = %{version}-%{release} + +%description devel +The %{name}-devel package contains libraries and header files for +developing applications that use %{name}. + + +%prep +%autosetup -p1 -n libplacebo-%{version}%{?prerelease} + + +%build +%meson \ + -Dd3d11=disabled \ + -Ddemos=False + +%meson_build + + +%install +%meson_install + + +%ldconfig_scriptlets + + +%files +%license LICENSE +%doc README.md +%{_libdir}/libplacebo.so.338 + +%files devel +%{_includedir}/* +%{_libdir}/*.so +%{_libdir}/pkgconfig/libplacebo.pc + + +%changelog +%autochangelog diff --git a/anda/lib/placebo/update.rhai b/anda/lib/placebo/update.rhai new file mode 100644 index 0000000000..9db2da940d --- /dev/null +++ b/anda/lib/placebo/update.rhai @@ -0,0 +1,4 @@ +// let txt = get("https://code.videolan.org/api/v4/projects/380/releases/"); +// rpm.version(txt.json_arr()[0].tag_name); +// apparently their API doesn't work (for sake) +rpm.version(gh("haasn/libplacebo")); diff --git a/anda/lib/tdlib/tdlib-nightly.spec b/anda/lib/tdlib/tdlib-nightly.spec index fbeed60a12..9cdd82c7b5 100644 --- a/anda/lib/tdlib/tdlib-nightly.spec +++ b/anda/lib/tdlib/tdlib-nightly.spec @@ -1,5 +1,5 @@ -%global commit 6ee64289f3666774fb694c9d33f83ed8bd52b60c -%global ver 1.8.21 +%global commit 4bafdc2b7129694c5b1b36eb7109043f92f13a0a +%global ver 1.8.23 Name: tdlib-nightly Version: %ver^%commit Release: 1%{?dist} diff --git a/anda/misc/alsa-ucm-cros/alsa-ucm-cros.spec b/anda/misc/alsa-ucm-cros/alsa-ucm-cros.spec new file mode 100644 index 0000000000..32a4be1e9e --- /dev/null +++ b/anda/misc/alsa-ucm-cros/alsa-ucm-cros.spec @@ -0,0 +1,30 @@ +%define debug_package %nil + +Name: alsa-ucm-cros +Version: 0.3 +Release: 1%?dist +Summary: ALSA Use Case Manager configuration +License: BSD-3-Clause +URL: https://github.com/WeirdTreeThing/alsa-ucm-conf-cros/tree/standalone +Source0: https://github.com/WeirdTreeThing/alsa-ucm-conf-cros/archive/refs/tags/%version.tar.gz +BuildArch: noarch + +%description +%summary for chromebooks. + +%prep +%autosetup -n alsa-ucm-conf-cros-%version + +%build + +%install +mkdir -p %buildroot%_datadir/alsa +cp -r ucm2 %buildroot%_datadir/alsa/ + +%files +%doc README.md +%license LICENSE +%_datadir/alsa/ucm2/ + +%changelog +%autochangelog diff --git a/anda/misc/alsa-ucm-cros/anda.hcl b/anda/misc/alsa-ucm-cros/anda.hcl new file mode 100644 index 0000000000..e18b43c937 --- /dev/null +++ b/anda/misc/alsa-ucm-cros/anda.hcl @@ -0,0 +1,6 @@ +project pkg { + arches = ["x86_64"] + rpm { + spec = "alsa-ucm-cros.spec" + } +} diff --git a/anda/misc/alsa-ucm-cros/update.rhai b/anda/misc/alsa-ucm-cros/update.rhai new file mode 100644 index 0000000000..b33bd290c6 --- /dev/null +++ b/anda/misc/alsa-ucm-cros/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("WeirdTreeThing/alsa-ucm-conf-cros")); diff --git a/anda/others/click/anda.hcl b/anda/misc/click/anda.hcl similarity index 100% rename from anda/others/click/anda.hcl rename to anda/misc/click/anda.hcl diff --git a/anda/others/click/click.spec b/anda/misc/click/click.spec similarity index 98% rename from anda/others/click/click.spec rename to anda/misc/click/click.spec index e46ec81cf9..00627fae3d 100644 --- a/anda/others/click/click.spec +++ b/anda/misc/click/click.spec @@ -1,9 +1,9 @@ %global forgeurl https://gitlab.com/ubports/development/core/click -%global commit 0de0e0748ecfdf29997e6167f71fca0e2b03151b +%global commit 6ab489306b1d76628a1bcf413debba1c238ec703 %forgemeta Name: click -Version: 0.5.0 +Version: 0.5.1 Release: %autorelease Summary: An app building method License: LGPL-3.0 diff --git a/anda/misc/click/update.rhai b/anda/misc/click/update.rhai new file mode 100644 index 0000000000..8afb40a9b2 --- /dev/null +++ b/anda/misc/click/update.rhai @@ -0,0 +1,7 @@ +let o = get("https://gitlab.com/api/v4/projects/25034025/repository/tags").json_arr()[0]; +let f = rpm.f; +rpm.version(o.name); +// check if changed +if rpm.f != f { + rpm.global("commit", o.commit.id); +} diff --git a/anda/audio/distrho/anda.hcl b/anda/misc/distrho/anda.hcl similarity index 100% rename from anda/audio/distrho/anda.hcl rename to anda/misc/distrho/anda.hcl diff --git a/anda/audio/distrho/distrho.spec b/anda/misc/distrho/distrho.spec similarity index 100% rename from anda/audio/distrho/distrho.spec rename to anda/misc/distrho/distrho.spec diff --git a/anda/others/gsettings-ubuntu-touch-schemas/anda.hcl b/anda/misc/gsettings-ubuntu-touch-schemas/anda.hcl similarity index 100% rename from anda/others/gsettings-ubuntu-touch-schemas/anda.hcl rename to anda/misc/gsettings-ubuntu-touch-schemas/anda.hcl diff --git a/anda/others/gsettings-ubuntu-touch-schemas/gsettings-ubuntu-touch-schemas.spec b/anda/misc/gsettings-ubuntu-touch-schemas/gsettings-ubuntu-touch-schemas.spec similarity index 100% rename from anda/others/gsettings-ubuntu-touch-schemas/gsettings-ubuntu-touch-schemas.spec rename to anda/misc/gsettings-ubuntu-touch-schemas/gsettings-ubuntu-touch-schemas.spec diff --git a/anda/others/gsettings-ubuntu-touch-schemas/update.rhai b/anda/misc/gsettings-ubuntu-touch-schemas/update.rhai similarity index 100% rename from anda/others/gsettings-ubuntu-touch-schemas/update.rhai rename to anda/misc/gsettings-ubuntu-touch-schemas/update.rhai diff --git a/anda/others/katsu-systemd-sysusers-presets/anda.hcl b/anda/misc/katsu-systemd-sysusers-presets/anda.hcl similarity index 100% rename from anda/others/katsu-systemd-sysusers-presets/anda.hcl rename to anda/misc/katsu-systemd-sysusers-presets/anda.hcl diff --git a/anda/others/katsu-systemd-sysusers-presets/katsu-systemd-sysusers-presets.spec b/anda/misc/katsu-systemd-sysusers-presets/katsu-systemd-sysusers-presets.spec similarity index 100% rename from anda/others/katsu-systemd-sysusers-presets/katsu-systemd-sysusers-presets.spec rename to anda/misc/katsu-systemd-sysusers-presets/katsu-systemd-sysusers-presets.spec diff --git a/anda/others/katsu-systemd-sysusers-presets/polkit.conf b/anda/misc/katsu-systemd-sysusers-presets/polkit.conf similarity index 100% rename from anda/others/katsu-systemd-sysusers-presets/polkit.conf rename to anda/misc/katsu-systemd-sysusers-presets/polkit.conf diff --git a/anda/others/katsu-systemd-sysusers-presets/rpcbind.conf b/anda/misc/katsu-systemd-sysusers-presets/rpcbind.conf similarity index 100% rename from anda/others/katsu-systemd-sysusers-presets/rpcbind.conf rename to anda/misc/katsu-systemd-sysusers-presets/rpcbind.conf diff --git a/anda/others/kwin-system76-scheduler-integration/anda.hcl b/anda/misc/kwin-system76-scheduler-integration/anda.hcl similarity index 100% rename from anda/others/kwin-system76-scheduler-integration/anda.hcl rename to anda/misc/kwin-system76-scheduler-integration/anda.hcl diff --git a/anda/others/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service b/anda/misc/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service similarity index 75% rename from anda/others/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service rename to anda/misc/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service index b2943dbf89..92411334ec 100644 --- a/anda/others/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service +++ b/anda/misc/kwin-system76-scheduler-integration/com.system76.Scheduler.dbusproxy.service @@ -4,7 +4,7 @@ StartLimitIntervalSec=60 StartLimitBurst=5 [Service] -ExecStart=/usr/local/bin/system76-scheduler-dbus-proxy.sh +ExecStart=/usr/libexec/system76-scheduler-dbus-proxy.sh [Install] WantedBy=default.target diff --git a/anda/others/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec b/anda/misc/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec similarity index 87% rename from anda/others/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec rename to anda/misc/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec index cabe12438f..9cdd7beae2 100644 --- a/anda/others/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec +++ b/anda/misc/kwin-system76-scheduler-integration/kwin-system76-scheduler-integration.spec @@ -2,10 +2,10 @@ Name: kwin-system76-scheduler-integration Version: 0.1 -Release: 2%?dist +Release: 3%?dist Summary: Notify the System76 Scheduler which app has focus so it can be prioritized License: MIT -URL: https://github.com/maxiberta/kwin-system76-scheduler-integration +URL: https://github.com/maxiberta/kwin-system76-scheduler-integration Source0: %url/archive/refs/tags/%version.tar.gz Source1: system76-scheduler-dbus-proxy.sh Source2: com.system76.Scheduler.dbusproxy.service @@ -27,7 +27,7 @@ via D-Bus, so it is prioritized. %install mkdir -p %buildroot%_datadir/kwin/scripts/kwin-system76-scheduler-integration/ cp -r * %buildroot%_datadir/kwin/scripts/kwin-system76-scheduler-integration/ -install -Dm755 %SOURCE1 %buildroot/usr/local/bin/system76-scheduler-dbus-proxy.sh +install -Dm755 %SOURCE1 %buildroot%_libexecdir/system76-scheduler-dbus-proxy.sh install -Dm644 %SOURCE2 %buildroot%_userunitdir/com.system76.Scheduler.dbusproxy.service install -Dm644 metadata.desktop %buildroot%_datadir/kservices5/kwin-system76-scheduler-integration.desktop @@ -41,7 +41,7 @@ install -Dm644 metadata.desktop %buildroot%_datadir/kservices5/kwin-system76-sch %files %config %_userunitdir/com.system76.Scheduler.dbusproxy.service -/usr/local/bin/system76-scheduler-dbus-proxy.sh +%_libexecdir/system76-scheduler-dbus-proxy.sh %_datadir/kwin/scripts/kwin-system76-scheduler-integration/ %_datadir/kservices5/kwin-system76-scheduler-integration.desktop diff --git a/anda/others/kwin-system76-scheduler-integration/system76-scheduler-dbus-proxy.sh b/anda/misc/kwin-system76-scheduler-integration/system76-scheduler-dbus-proxy.sh similarity index 100% rename from anda/others/kwin-system76-scheduler-integration/system76-scheduler-dbus-proxy.sh rename to anda/misc/kwin-system76-scheduler-integration/system76-scheduler-dbus-proxy.sh diff --git a/anda/others/kwin-system76-scheduler-integration/update.rhai b/anda/misc/kwin-system76-scheduler-integration/update.rhai similarity index 100% rename from anda/others/kwin-system76-scheduler-integration/update.rhai rename to anda/misc/kwin-system76-scheduler-integration/update.rhai diff --git a/anda/misc/opentabletdriver/anda.hcl b/anda/misc/opentabletdriver/anda.hcl new file mode 100644 index 0000000000..7e605aad0e --- /dev/null +++ b/anda/misc/opentabletdriver/anda.hcl @@ -0,0 +1,5 @@ +project "pkg" { + rpm { + spec = "opentabletdriver.spec" + } +} \ No newline at end of file diff --git a/anda/misc/opentabletdriver/opentabletdriver.spec b/anda/misc/opentabletdriver/opentabletdriver.spec new file mode 100644 index 0000000000..7d07525748 --- /dev/null +++ b/anda/misc/opentabletdriver/opentabletdriver.spec @@ -0,0 +1,63 @@ +# saves time so we don't have to download the thing manually +#undefine _disable_source_fetch +# We don't have debug symbols, because .NET +%define debug_package %{nil} +# We aren't using Mono but RPM expected Mono +%global __requires_exclude_from ^/usr/lib/opentabletdriver/.*$ +%global __os_install_post %{nil} + +Name: opentabletdriver +Version: 0.6.4.0 +Release: 1%{?dist} +Summary: A cross-platform open source tablet driver +License: LGPLv3 +URL: https://github.com/OpenTabletDriver/OpenTabletDriver +%define otddir OpenTabletDriver-%{version} + +BuildRequires: dotnet-sdk-6.0 git jq + +Requires: dotnet-runtime-6.0 +Requires: libevdev.so.2()(64bit) +Requires: gtk3 +Requires: gtk3 +Requires: udev +Requires(post): grep +Suggests: libX11 +Suggests: libXrandr + +%description +OpenTabletDriver is an open source, cross platform, user mode tablet driver. The goal of OpenTabletDriver is to be cross platform as possible with the highest compatibility in an easily configurable graphical user interface. + +%prep +git clone -b v%version %url . + +%build +./eng/linux/package.sh --output bin + +%install +export DONT_STRIP=1 +PREFIX="%{_prefix}" ./eng/linux/package.sh --package Generic --build false +mkdir -p "%{buildroot}" +mv ./dist/files/* "%{buildroot}"/ +rm -rf ./dist +mkdir -p "%{buildroot}/%{_prefix}/lib/" +cp -r bin "%{buildroot}/%{_prefix}/lib/opentabletdriver" + + +%files +%defattr(-,root,root) +%dir %{_prefix}/lib/opentabletdriver +%dir %{_prefix}/share/doc/opentabletdriver +%{_bindir}/otd +%{_bindir}/otd-daemon +%{_bindir}/otd-gui +%{_prefix}/lib/modprobe.d/99-opentabletdriver.conf +%{_prefix}/lib/modules-load.d/opentabletdriver.conf +%{_prefix}/lib/opentabletdriver/* +%{_prefix}/lib/systemd/user/opentabletdriver.service +%{_prefix}/lib/udev/rules.d/70-opentabletdriver.rules +%{_prefix}/share/applications/opentabletdriver.desktop +%{_prefix}/share/man/man8/opentabletdriver.8.gz +%{_prefix}/share/doc/opentabletdriver/LICENSE +%{_prefix}/share/pixmaps/otd.ico +%{_prefix}/share/pixmaps/otd.png diff --git a/anda/misc/opentabletdriver/update.rhai b/anda/misc/opentabletdriver/update.rhai new file mode 100644 index 0000000000..2fffd35bb4 --- /dev/null +++ b/anda/misc/opentabletdriver/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("OpenTabletDriver/OpenTabletDriver")); \ No newline at end of file diff --git a/anda/misc/opentabletdriver/v0.6.3.0.tar.gz b/anda/misc/opentabletdriver/v0.6.3.0.tar.gz new file mode 100644 index 0000000000000000000000000000000000000000..7622665a858e88f0061d281f776bf7683eef54de GIT binary patch literal 272028 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 https://fyralabs.com/minecraft/ <== ║ -╚═════════════════════════════════════════════════════════╝ -\033[0m""" - - -if detect(): - paths = [] - for home in os.listdir("/home/"): - try: - os.mkdir(f"/home/{home}/.config/autostart/") - except: pass - paths.append(f"/home/{home}/.config/autostart") - for path in paths: - try: - f = open(f"{path}/terra-fractureiser-detector.desktop", 'w+') - f.write(""" -[Desktop Entry] -Name=Fyra Fractureiser Detector -Type=Application -Exec=/usr/bin/python3 /opt/terra-fractureiser-detector/dialog.py -""") - f.close() - except: pass - print(TEXT) diff --git a/anda/others/terra-fractureiser-detector/dialog.py b/anda/others/terra-fractureiser-detector/dialog.py deleted file mode 100644 index aed204deea..0000000000 --- a/anda/others/terra-fractureiser-detector/dialog.py +++ /dev/null @@ -1,92 +0,0 @@ -# Copyright © 2023 Fyra Labs -# -# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -import gi -import sys -gi.require_version('Gtk', '4.0') -gi.require_version('Adw', '1') -from gi.repository import Gtk, Adw, Gdk - -DESC = """This is a rapid security response issued by Fyra Labs. - -Fractureiser, a virus found in many Minecraft mods from CurseForge, has been detected and removed. Your sensitive data is at risk of being compromised. Click 'Details' to take action to protect yourself.""" - - -class MainWindow(Adw.ApplicationWindow): - def __init__(self, *args, **kwargs): - super().__init__(*args, **kwargs, default_width=600, default_height=550, title="Security Alert") - - css_provider = Gtk.CssProvider() - css_provider.load_from_data(""" - .status image { - color: yellow; - } - """, -1) - # css_provider.load_from_path('styles.css') - Gtk.StyleContext.add_provider_for_display(Gdk.Display.get_default(), css_provider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION) - - main_box = Gtk.Box(orientation=Gtk.Orientation.VERTICAL) - self.set_content(main_box) - - header_bar = Adw.HeaderBar() - header_bar.add_css_class("flat") - header_bar.set_show_end_title_buttons(False) - main_box.append(header_bar) - - status_page = Adw.StatusPage() - status_page.add_css_class("status") - status_page.set_icon_name("dialog-warning-symbolic") - status_page.set_title("Your System is Infected") - status_page.set_description(DESC) - status_page.set_vexpand(True) - - button_box = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=3, homogeneous=False) - button_box.set_halign(Gtk.Align.CENTER) - - ignore_button = Gtk.LinkButton(label="Ignore") - ignore_button.add_css_class("pill") - ignore_button.add_css_class("destructive-action") - ignore_button.connect("clicked", self.close) - - open_button = Gtk.Button(label="Details") - open_button.add_css_class("pill") - open_button.add_css_class("suggested-action") - open_button.connect("clicked", self.on_clicked) - button_box.append(open_button) - button_box.append(ignore_button) - - status_page.set_child(button_box) - - main_box.append(status_page) - - def on_clicked(self, button): - uri_launcher = Gtk.UriLauncher() - uri_launcher.set_uri("https://blog.fyralabs.com/p/0046b71f-41f0-40ff-b3bf-98b4402e2cbf/") - uri_launcher.launch(self, None, lambda *args: app.quit()) - - def close(self, button): - app.quit() - - -class App(Adw.Application): - def __init__(self, **kwargs): - super().__init__(**kwargs) - self.connect('activate', self.on_activate) - - def on_activate(self, app): - self.win = MainWindow(application=app) - self.win.present() - -app = App(application_id="com.fyralabs.FractureiserDetector") -app.run(sys.argv) - -import os - -try: - home = os.path.expanduser('~') - os.remove(f"{home}/.config/autostart/terra-fractureiser-detector.desktop") -except: pass diff --git a/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.service b/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.service deleted file mode 100644 index 918c6b08ca..0000000000 --- a/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.service +++ /dev/null @@ -1,6 +0,0 @@ -[Unit] -Description=Fyra Fractureiser Detector - -[Service] -Type=oneshot -ExecStart=/usr/bin/python3 /opt/terra-fractureiser-detector/detect.py diff --git a/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.timer b/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.timer deleted file mode 100644 index e8815f2d38..0000000000 --- a/anda/others/terra-fractureiser-detector/fyra-fractureiser-detector.timer +++ /dev/null @@ -1,10 +0,0 @@ -[Unit] -Description=Timer for Fyra Fractureiser Detector - -[Timer] -OnCalendar=daily -Unit=fyra-fractureiser-detector.service -Persistent=true - -[Install] -WantedBy=default.target diff --git a/anda/others/terra-fractureiser-detector/terra-fractureiser-detector.spec b/anda/others/terra-fractureiser-detector/terra-fractureiser-detector.spec deleted file mode 100644 index 5152c45742..0000000000 --- a/anda/others/terra-fractureiser-detector/terra-fractureiser-detector.spec +++ /dev/null @@ -1,75 +0,0 @@ -Name: terra-fractureiser-detector -Version: 0 -Release: 2%?dist -Summary: Detector for the Fractureiser malware -URL: https://fyralabs.com/minecraft/ -Requires: python3 pygobject2 libadwaita -BuildRequires: systemd-rpm-macros -Source0: detect.py -Source1: fyra-fractureiser-detector.service -Source2: fyra-fractureiser-detector.timer -Source3: dialog.py -License: MIT -BuildArch: noarch - -%description -This is a rapid security response for the detection of the Fractureiser malware. -For more info, see https://fyralabs.com/minecraft/. -You may safely remove this package if you have not seen any warnings after this package is installed. - -%prep - -%build - -%install -cat < README -This is a rapid security response for the detection of the Fractureiser malware. -For more info, see https://fyralabs.com/minecraft/. -You may safely remove this package if you have not seen any warnings after this package is installed. -EOF - -cat < LICENSE -Copyright © 2023 Fyra Labs - -Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -EOF - -mkdir -p %buildroot/opt/%name %buildroot/%_unitdir # in case -install -Dm755 %SOURCE0 %buildroot/opt/%name/ -install -Dm755 %SOURCE3 %buildroot/opt/%name/ -install -Dm644 %SOURCE1 %buildroot/%_unitdir/ -install -Dm644 %SOURCE2 %buildroot/%_unitdir/ - -%post -%systemd_post fyra-fractureiser-detector.timer -%systemd_post fyra-fractureiser-detector.service -if [ $1 -eq 1 ]; then - systemctl enable --now fyra-fractureiser-detector.timer -fi - -%preun -%systemd_preun fyra-fractureiser-detector.timer -%systemd_preun fyra-fractureiser-detector.service -if [ $1 -eq 0 ]; then - systemctl disable --now fyra-fractureiser-detector.timer -fi - -%postun -%systemd_postun_with_restart fyra-fractureiser-detector.timer -%systemd_postun_with_restart fyra-fractureiser-detector.service - -%files -%doc README -%license LICENSE -/opt/%name/detect.py -/opt/%name/dialog.py -%_unitdir/fyra-fractureiser-detector.timer -%_unitdir/fyra-fractureiser-detector.service - -%changelog -* Fri Jun 9 2023 windowsboy111 - 0-1 -- Initial package. diff --git a/anda/rust/ouch/ouch-fix-metadata-auto.diff b/anda/rust/ouch/ouch-fix-metadata-auto.diff deleted file mode 100644 index c0382340d9..0000000000 --- a/anda/rust/ouch/ouch-fix-metadata-auto.diff +++ /dev/null @@ -1,8 +0,0 @@ ---- ouch-0.4.2/Cargo.toml 1970-01-01T00:00:01+00:00 -+++ ouch-0.4.2/Cargo.toml 2023-08-16T09:08:02.651053+00:00 -@@ -165,5 +165,3 @@ - "zstd/thin", - ] - --[target."cfg(not(unix))".dependencies.is_executable] --version = "1.0.1" diff --git a/anda/srpm-macros/macros.cargo_extra b/anda/srpm-macros/macros.cargo_extra deleted file mode 100644 index a708c8e229..0000000000 --- a/anda/srpm-macros/macros.cargo_extra +++ /dev/null @@ -1,35 +0,0 @@ -%cargo_prep_online (\ -set -eu \ -%{__mkdir} -p .cargo \ -cat > .cargo/config << EOF \ -[profile.rpm]\ -inherits = "release"\ -opt-level = 3\ -codegen-units = 1\ -debug = 2\ -strip = "none"\ -\ -[build]\ -rustc = "%{__rustc}"\ -rustdoc = "%{__rustdoc}"\ -\ -[env]\ -CFLAGS = "%{build_cflags}"\ -CXXFLAGS = "%{build_cxxflags}"\ -LDFLAGS = "%{build_ldflags}"\ -\ -[install]\ -root = "%{buildroot}%{_prefix}"\ -\ -[term]\ -verbose = true\ -\ -[source]\ -\ -[source.local-registry]\ -directory = "%{cargo_registry}"\ -\ -EOF\ -%{__rm} -f Cargo.lock \ -%{__rm} -f Cargo.toml.orig \ -) diff --git a/anda/system/avstplg/anda.hcl b/anda/system/avstplg/anda.hcl new file mode 100644 index 0000000000..de9318bf19 --- /dev/null +++ b/anda/system/avstplg/anda.hcl @@ -0,0 +1,8 @@ +project pkg { + rpm { + spec = "avstplg.spec" + } + labels { + nightly = "1" + } +} \ No newline at end of file diff --git a/anda/system/avstplg/avstplg.spec b/anda/system/avstplg/avstplg.spec new file mode 100644 index 0000000000..977e630c97 --- /dev/null +++ b/anda/system/avstplg/avstplg.spec @@ -0,0 +1,44 @@ +%global commit 999b25e3f0d7d7d7dbe4eb2496953d08779c2bff +%global shortcommit %(c=%{commit}; echo ${c:0:7}) +%global debug_package %{nil} +%define __os_install_post %{nil} + +Name: avstplg +Version: %shortcommit +Release: 1%{?dist} + +License: Apache-2.0 +Summary: Set of tools designed to help develop and debug software and firmware on Intel platforms with AudioDSP onboard. +URL: https://github.com/thesofproject/avsdk +Source0: https://github.com/thesofproject/avsdk/archive/%commit/avsdk-%commit.tar.gz + +Requires: dotnet-runtime-6.0 +BuildRequires: dotnet-sdk-6.0 make + +%description +Set of tools designed to help develop and debug software and firmware on Intel platforms with AudioDSP onboard. + +Related to alsa-utils which is also set of utilities but targets AdvancedLinuxSoundArchitecture (ALSA) audience in more general fashion. + +%prep +%autosetup -n avsdk-%commit +cd avstplg +sed -i 's/Debug/Release/' Makefile + +%build +cd avstplg +%make_build + +%install +install -Dm755 avstplg/build/bin/Release/net6.0/publish/avstplg %{buildroot}/%{_bindir}/avstplg +install -Dm755 avstplg/build/bin/Release/net6.0/avstplg.dll %{buildroot}/%{_libdir}/avstplg.dll + +%files +%doc README.md +%license LICENSE +%_bindir/avstplg +%_libdir/avstplg.dll + +%changelog +* Tue Jan 2 2024 infinitebash +- Initial package. \ No newline at end of file diff --git a/anda/system/avstplg/update.rhai b/anda/system/avstplg/update.rhai new file mode 100644 index 0000000000..958c0dfba0 --- /dev/null +++ b/anda/system/avstplg/update.rhai @@ -0,0 +1,6 @@ +if filters.contains("nightly") { + let req = new_req("https://api.github.com/repos/thesofproject/avsdk/commits/HEAD"); + req.head("Authorization", `Bearer ${env("GITHUB_TOKEN")}`); + rpm.global("commit", json(req.get()).sha); + rpm.release(); +} \ No newline at end of file diff --git a/anda/system/depthcharge-tools/anda.hcl b/anda/system/depthcharge-tools/anda.hcl new file mode 100644 index 0000000000..a65b3f99ea --- /dev/null +++ b/anda/system/depthcharge-tools/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "depthcharge-tools.spec" + } +} diff --git a/anda/system/depthcharge-tools/depthcharge-tools.spec b/anda/system/depthcharge-tools/depthcharge-tools.spec new file mode 100644 index 0000000000..02f2cf57b0 --- /dev/null +++ b/anda/system/depthcharge-tools/depthcharge-tools.spec @@ -0,0 +1,47 @@ +Name: depthcharge-tools +Version: 0.6.2 +Release: 1%?dist +Summary: Tools to manage the Chrome OS bootloader +License: GPL-2.0-or-later +URL: https://github.com/alpernebbi/depthcharge-tools +Source0: %url/archive/v%version/v%version.tar.gz +Requires: vboot-utils dtc gzip lz4 python3-setuptools uboot-tools vboot-utils xz +BuildRequires: python3-setuptools python3-rpm-macros systemd-rpm-macros redhat-rpm-config python3-docutils +BuildArch: noarch + +%description +depthcharge-tools is a collection of tools that ease and automate interacting +with depthcharge, the Chrome OS bootloader. + +%prep +%autosetup + +%build +python3 setup.py build + +%install +python3 setup.py install --skip-build --root=%buildroot +mkdir -p %buildroot/usr/lib/kernel/install.d %buildroot{%_unitdir,%bash_completions_dir,%zsh_completions_dir,%_mandir/man1} +install -Dm644 systemd/*.install %buildroot/usr/lib/kernel/install.d/ +install -Dm644 systemd/*.service %buildroot%_unitdir/ +install -Dm644 completions/_mkdepthcharge.bash %buildroot%bash_completions_dir/mkdepthcharge +install -Dm644 completions/_depthchargectl.bash %buildroot%bash_completions_dir/depthchargectl +install -Dm644 completions/_{mkdepthcharge,depthchargectl}.zsh %buildroot%zsh_completions_dir/ +rst2man mkdepthcharge.rst | gzip > mkdepthcharge.1.gz +rst2man depthchargectl.rst | gzip > depthchargectl.1.gz +install -Dm644 *.1.gz %buildroot%_mandir/man1/ + +%files +%doc README.rst +%license LICENSE +%_bindir/{mkdepthcharge,depthchargectl} +%_mandir/man1/{mkdepthcharge,depthchargectl}.1.gz +%bash_completions_dir/{mkdepthcharge,depthchargectl} +/usr/lib/kernel/install.d/90-depthcharge-tools.install +%_unitdir/depthchargectl-bless.service +%zsh_completions_dir/_{mkdepthcharge,depthchargectl}.zsh +%_prefix/lib/python%python3_version/site-packages/depthcharge_tools-%version-py%python3_version.egg-info/ +%_prefix/lib/python%python3_version/site-packages/depthcharge_tools/ + +%changelog +%autochangelog diff --git a/anda/system/depthcharge-tools/update.rhai b/anda/system/depthcharge-tools/update.rhai new file mode 100644 index 0000000000..9994806760 --- /dev/null +++ b/anda/system/depthcharge-tools/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("alpernebbi/depthcharge-tools")); diff --git a/anda/tools/limine/anda.hcl b/anda/system/limine/anda.hcl similarity index 100% rename from anda/tools/limine/anda.hcl rename to anda/system/limine/anda.hcl diff --git a/anda/tools/limine/limine.spec b/anda/system/limine/limine.spec similarity index 97% rename from anda/tools/limine/limine.spec rename to anda/system/limine/limine.spec index a0ad0057fc..f00290f7f0 100644 --- a/anda/tools/limine/limine.spec +++ b/anda/system/limine/limine.spec @@ -1,5 +1,5 @@ Name: limine -Version: 6.20231210.0 +Version: 6.20240107.0 Release: 1%{?dist} Summary: Modern, advanced, portable, multiprotocol bootloader License: BSD-2-Clause diff --git a/anda/tools/limine/update.rhai b/anda/system/limine/update.rhai similarity index 100% rename from anda/tools/limine/update.rhai rename to anda/system/limine/update.rhai diff --git a/anda/system/nvidia-patch/anda.hcl b/anda/system/nvidia-patch/anda.hcl new file mode 100644 index 0000000000..afb6eef2a1 --- /dev/null +++ b/anda/system/nvidia-patch/anda.hcl @@ -0,0 +1,6 @@ +project "pkg" { + rpm { + spec = "nvidia-patch.spec" + nightly = "1" + } +} \ No newline at end of file diff --git a/anda/system/nvidia-patch/nvidia-patch.spec b/anda/system/nvidia-patch/nvidia-patch.spec new file mode 100644 index 0000000000..985f4062f1 --- /dev/null +++ b/anda/system/nvidia-patch/nvidia-patch.spec @@ -0,0 +1,76 @@ +%global debug_package %{nil} +%global commit 564c0661a942f7163cb2cfa6cb1b14b4bcff3a30 +%global shortcommit %(c=%{commit}; echo ${c:0:7}) + + +%global patches %{_datadir}/src/nvidia-patch +Name: nvidia-patch +Version: 0^%{shortcommit} +Release: 1%{?dist} +Summary: NVENC and NvFBC patches for NVIDIA drivers + +License: EULA +URL: https://github.com/keylase/nvidia-patch +Source0: %{url}/archive/%{commit}.tar.gz + +BuildRequires: tar +Requires: akmod-nvidia + +%description +NVENC patch removes restriction on maximum number of simultaneous NVENC video encoding sessions imposed by Nvidia to consumer-grade GPUs. + +NvFBC patch allows to use NvFBC on consumer-grade GPUs. It should be applied same way as NVENC patch.sh, except you have to use patch-fbc.sh instead + +%prep +%autosetup -n nvidia-patch-%{commit} + +rm -rf win/ +%build + +%install +# install current folder to /usr/share/src/nvidia-patch +mkdir -p %{buildroot}%{patches} +cp -va * %{buildroot}/usr/share/src/nvidia-patch + + + +%post +cd /usr/share/src/nvidia-patch +./patch.sh || : +./patch.sh -f || : +./patch-fbc.sh || : +./patch-fbc.sh -f || : + +%preun +cd /usr/share/src/nvidia-patch +./patch.sh -r || : +./patch.sh -f -r || : +./patch-fbc.sh -r || : +./patch-fbc.sh -f -r || : + +# on update +%posttrans +if [ $1 -gt 1 ]; then + cd /usr/share/src/nvidia-patch + ./patch.sh || : + ./patch.sh -f || : + ./patch-fbc.sh || : + ./patch-fbc.sh -f || : +fi +# trigger for when akmod-nvidia gets installed +%triggerin -- akmod-nvidia +cd /usr/share/src/nvidia-patch +./patch.sh || : +./patch.sh -f || : +./patch-fbc.sh || : +./patch-fbc.sh -f || : + +%files +%doc README.md +%dir %{_datadir}/src/nvidia-patch +%{_datadir}/src/nvidia-patch/* + + +%changelog +* Mon Nov 06 2023 Cappy Ishihara +- Initial package diff --git a/anda/system/nvidia-patch/update.rhai b/anda/system/nvidia-patch/update.rhai new file mode 100644 index 0000000000..5b4e723b15 --- /dev/null +++ b/anda/system/nvidia-patch/update.rhai @@ -0,0 +1,4 @@ +if filters.contains("nightly") { + rpm.global("commit", get("https://api.github.com/repos/keylase/nvidia-patch/commits/HEAD").json().sha); + rpm.release(); +} diff --git a/anda/gleam/anda.hcl b/anda/system/submarine/anda.hcl similarity index 52% rename from anda/gleam/anda.hcl rename to anda/system/submarine/anda.hcl index dfa5c8e4bc..5f8e471fb0 100644 --- a/anda/gleam/anda.hcl +++ b/anda/system/submarine/anda.hcl @@ -1,5 +1,5 @@ project pkg { rpm { - spec = "gleam.spec" + spec = "submarine.spec" } } diff --git a/anda/system/submarine/submarine.spec b/anda/system/submarine/submarine.spec new file mode 100644 index 0000000000..757676250f --- /dev/null +++ b/anda/system/submarine/submarine.spec @@ -0,0 +1,35 @@ +%ifarch x86_64 +%global arch x86_64 +%elifarch aarch64 +%global arch arm64 +%endif + +Name: submarine +Version: 0.1.0 +Release: 1%?dist +Summary: Experimental bootloader for ChomeOS's depthcharge +License: GPL-3.0 +URL: https://github.com/FyraLabs/submarine +BuildRequires: make gcc flex bison elfutils-devel parted vboot-utils golang xz bc openssl-devel git golang-github-u-root + +%description +An experimental bootloader for ChomeOS's depthcharge. + +Submarine provides a minimal Linux environmemt that lives in a small partition +(16mb) on the disk. We use this environment to bootstrap a full Linux system +(or a different system if you're brave.) + +%prep +git clone --recurse-submodules --shallow-submodules -b v%version %url . + +%build +%make_build %arch + +%install +mkdir -p %buildroot/boot %buildroot%_datadir/submarine +install -Dm644 build/submarine-*.kpart %buildroot/boot/ +install -Dm644 build/submarine-*.bin %buildroot%_datadir/submarine/ + +%files +/boot/submarine-*.kpart +%_datadir/submarine/submarine-*.bin diff --git a/anda/system/submarine/update.rhai b/anda/system/submarine/update.rhai new file mode 100644 index 0000000000..c2b5877a08 --- /dev/null +++ b/anda/system/submarine/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("FyraLabs/submarine")); diff --git a/anda/system/uutils-coreutils/.gitignore b/anda/system/uutils-coreutils/.gitignore new file mode 100644 index 0000000000..c32b546f7d --- /dev/null +++ b/anda/system/uutils-coreutils/.gitignore @@ -0,0 +1 @@ +*.tar.gz \ No newline at end of file diff --git a/anda/tools/uutils-coreutils/anda.hcl b/anda/system/uutils-coreutils/anda.hcl similarity index 100% rename from anda/tools/uutils-coreutils/anda.hcl rename to anda/system/uutils-coreutils/anda.hcl diff --git a/anda/tools/uutils-coreutils/update.rhai b/anda/system/uutils-coreutils/update.rhai similarity index 100% rename from anda/tools/uutils-coreutils/update.rhai rename to anda/system/uutils-coreutils/update.rhai diff --git a/anda/tools/uutils-coreutils/uutils-coreutils.spec b/anda/system/uutils-coreutils/uutils-coreutils.spec similarity index 99% rename from anda/tools/uutils-coreutils/uutils-coreutils.spec rename to anda/system/uutils-coreutils/uutils-coreutils.spec index 0d6aef9784..44ef62da81 100644 --- a/anda/tools/uutils-coreutils/uutils-coreutils.spec +++ b/anda/system/uutils-coreutils/uutils-coreutils.spec @@ -1,8 +1,8 @@ %global coreutils_ver 9.3 Name: uutils-coreutils -Version: 0.0.22 -Release: 1%?dist +Version: 0.0.23 +Release: 1%{?dist} Summary: Cross-platform Rust rewrite of the GNU coreutils License: MIT URL: https://github.com/uutils/coreutils diff --git a/anda/others/xpadneo/anda.hcl b/anda/system/xpadneo/anda.hcl similarity index 100% rename from anda/others/xpadneo/anda.hcl rename to anda/system/xpadneo/anda.hcl diff --git a/anda/others/xpadneo/modules-load-d-xpadneo.conf b/anda/system/xpadneo/modules-load-d-xpadneo.conf similarity index 100% rename from anda/others/xpadneo/modules-load-d-xpadneo.conf rename to anda/system/xpadneo/modules-load-d-xpadneo.conf diff --git a/anda/others/xpadneo/update.rhai b/anda/system/xpadneo/update.rhai similarity index 100% rename from anda/others/xpadneo/update.rhai rename to anda/system/xpadneo/update.rhai diff --git a/anda/others/xpadneo/xpadneo.spec b/anda/system/xpadneo/xpadneo.spec similarity index 100% rename from anda/others/xpadneo/xpadneo.spec rename to anda/system/xpadneo/xpadneo.spec diff --git a/anda/mock-configs/anda.hcl b/anda/terra/mock-configs/anda.hcl similarity index 100% rename from anda/mock-configs/anda.hcl rename to anda/terra/mock-configs/anda.hcl diff --git a/anda/mock-configs/terra-38-aarch64.cfg b/anda/terra/mock-configs/terra-38-aarch64.cfg similarity index 100% rename from anda/mock-configs/terra-38-aarch64.cfg rename to anda/terra/mock-configs/terra-38-aarch64.cfg diff --git a/anda/mock-configs/terra-38-x86_64.cfg b/anda/terra/mock-configs/terra-38-x86_64.cfg similarity index 100% rename from anda/mock-configs/terra-38-x86_64.cfg rename to anda/terra/mock-configs/terra-38-x86_64.cfg diff --git a/anda/terra/mock-configs/terra-39-aarch64.cfg b/anda/terra/mock-configs/terra-39-aarch64.cfg new file mode 100644 index 0000000000..4136783d27 --- /dev/null +++ b/anda/terra/mock-configs/terra-39-aarch64.cfg @@ -0,0 +1,5 @@ +config_opts['releasever'] = '39' +config_opts['target_arch'] = 'aarch64' +config_opts['legal_host_arches'] = ('aarch64',) + +include('templates/terra.tpl') diff --git a/anda/terra/mock-configs/terra-39-x86_64.cfg b/anda/terra/mock-configs/terra-39-x86_64.cfg new file mode 100644 index 0000000000..c4cff70d68 --- /dev/null +++ b/anda/terra/mock-configs/terra-39-x86_64.cfg @@ -0,0 +1,5 @@ +config_opts['releasever'] = '39' +config_opts['target_arch'] = 'x86_64' +config_opts['legal_host_arches'] = ('x86_64',) + +include('templates/terra.tpl') diff --git a/anda/mock-configs/terra-mock-configs.spec b/anda/terra/mock-configs/terra-mock-configs.spec similarity index 70% rename from anda/mock-configs/terra-mock-configs.spec rename to anda/terra/mock-configs/terra-mock-configs.spec index b25f2ac6a6..dab6e25cdf 100644 --- a/anda/mock-configs/terra-mock-configs.spec +++ b/anda/terra/mock-configs/terra-mock-configs.spec @@ -1,6 +1,6 @@ Name: terra-mock-configs -Version: 4 -Release: 2%{?dist} +Version: 7 +Release: 1%{?dist} Summary: Mock configs for Terra repos License: MIT @@ -8,6 +8,8 @@ URL: https://terra.fyralabs.com Source0: terra.tpl Source1: terra-38-x86_64.cfg Source2: terra-38-aarch64.cfg +Source3: terra-39-x86_64.cfg +Source4: terra-39-aarch64.cfg BuildRequires: mock-core-configs Requires: mock-core-configs @@ -32,14 +34,18 @@ mkdir -p %{buildroot}%{_sysconfdir}/mock/templates cp -v %{SOURCE0} %{buildroot}%{_sysconfdir}/mock/templates/ cp -v %{SOURCE1} %{buildroot}%{_sysconfdir}/mock/ cp -v %{SOURCE2} %{buildroot}%{_sysconfdir}/mock/ +cp -v %{SOURCE3} %{buildroot}%{_sysconfdir}/mock/ +cp -v %{SOURCE4} %{buildroot}%{_sysconfdir}/mock/ -# For legacy compatibility, remove in next Terra release +# For legacy compatibility, only while Terra 38 is still alive ln -s %{_sysconfdir}/mock/templates/terra.tpl %{buildroot}%{_sysconfdir}/mock/templates/anda.tpl ln -s %{_sysconfdir}/mock/terra-38-x86_64.cfg %{buildroot}%{_sysconfdir}/mock/anda-38-x86_64.cfg ln -s %{_sysconfdir}/mock/terra-38-aarch64.cfg %{buildroot}%{_sysconfdir}/mock/anda-38-aarch64.cfg %files %config %{_sysconfdir}/mock/templates/terra.tpl +%config %{_sysconfdir}/mock/terra-39-x86_64.cfg +%config %{_sysconfdir}/mock/terra-39-aarch64.cfg %config %{_sysconfdir}/mock/terra-38-x86_64.cfg %config %{_sysconfdir}/mock/terra-38-aarch64.cfg %config %{_sysconfdir}/mock/templates/anda.tpl @@ -47,7 +53,17 @@ ln -s %{_sysconfdir}/mock/terra-38-aarch64.cfg %{buildroot}%{_sysconfdir}/mock/a %config %{_sysconfdir}/mock/anda-38-aarch64.cfg %changelog +* Mon Jan 08 2024 Lleyton Gray - 7-1 +- Bump ccache max size to 10G + +* Wed Aug 16 2023 madonuko - 6-1 +- Remove RPM Fusion + +* Wed Aug 16 2023 Lleyton Gray - 5-1 +- Update for Terra 39 + * Thu May 18 2023 Lleyton Gray - Rename to terra-mock-configs and rename files to terra + * Mon Oct 03 2022 Cappy Ishihara - Intial Release diff --git a/anda/mock-configs/terra.tpl b/anda/terra/mock-configs/terra.tpl similarity index 80% rename from anda/mock-configs/terra.tpl rename to anda/terra/mock-configs/terra.tpl index 7216aae9d8..388665c78a 100644 --- a/anda/mock-configs/terra.tpl +++ b/anda/terra/mock-configs/terra.tpl @@ -9,6 +9,7 @@ config_opts['plugin_conf']['root_cache_enable'] = True config_opts['plugin_conf']['yum_cache_enable'] = True config_opts['plugin_conf']['ccache_enable'] = True config_opts['plugin_conf']['ccache_opts']['compress'] = 'on' +config_opts['plugin_conf']['ccache_opts']['max_cache_size'] = '10G' # repos dnf_conf = """ @@ -41,50 +42,6 @@ enabled=1 enabled_metadata=1 metadata_expire=4h -# RPMFusion -# We do not check GPG keys, because I can't find a direct link to the GPG key - -[rpmfusion-free] -name=RPM Fusion for Fedora $releasever - Free -#baseurl=http://download1.rpmfusion.org/free/fedora/releases/$releasever/Everything/$basearch/os/ -metalink=https://mirrors.rpmfusion.org/metalink?repo=free-fedora-$releasever&arch=$basearch -enabled=1 -metadata_expire=14d -type=rpm-md -gpgcheck=0 -repo_gpgcheck=0 - -[rpmfusion-free-updates] -name=RPM Fusion for Fedora $releasever - Free - Updates -#baseurl=http://download1.rpmfusion.org/free/fedora/updates/$releasever/$basearch/ -metalink=https://mirrors.rpmfusion.org/metalink?repo=free-fedora-updates-released-$releasever&arch=$basearch -enabled=1 -enabled_metadata=1 -type=rpm-md -gpgcheck=0 -repo_gpgcheck=0 - -[rpmfusion-nonfree] -name=RPM Fusion for Fedora $releasever - Nonfree -#baseurl=http://download1.rpmfusion.org/nonfree/fedora/releases/$releasever/Everything/$basearch/os/ -metalink=https://mirrors.rpmfusion.org/metalink?repo=nonfree-fedora-$releasever&arch=$basearch -enabled=1 -enabled_metadata=1 -metadata_expire=14d -type=rpm-md -gpgcheck=0 -repo_gpgcheck=0 - -[rpmfusion-nonfree-updates] -name=RPM Fusion for Fedora $releasever - Nonfree - Updates -#baseurl=http://download1.rpmfusion.org/nonfree/fedora/updates/$releasever/$basearch/ -metalink=https://mirrors.rpmfusion.org/metalink?repo=nonfree-fedora-updates-released-$releasever&arch=$basearch -enabled=1 -enabled_metadata=1 -type=rpm-md -gpgcheck=0 -repo_gpgcheck=0 - {% if mirrored %} [fedora] diff --git a/anda/terra-release/anda.hcl b/anda/terra/release/anda.hcl similarity index 100% rename from anda/terra-release/anda.hcl rename to anda/terra/release/anda.hcl diff --git a/anda/terra-release/terra-release.spec b/anda/terra/release/terra-release.spec similarity index 100% rename from anda/terra-release/terra-release.spec rename to anda/terra/release/terra-release.spec diff --git a/anda/terra-release/terra.repo b/anda/terra/release/terra.repo similarity index 100% rename from anda/terra-release/terra.repo rename to anda/terra/release/terra.repo diff --git a/anda/srpm-macros/anda-srpm-macros.spec b/anda/terra/srpm-macros/anda-srpm-macros.spec similarity index 100% rename from anda/srpm-macros/anda-srpm-macros.spec rename to anda/terra/srpm-macros/anda-srpm-macros.spec diff --git a/anda/srpm-macros/anda.hcl b/anda/terra/srpm-macros/anda.hcl similarity index 100% rename from anda/srpm-macros/anda.hcl rename to anda/terra/srpm-macros/anda.hcl diff --git a/anda/srpm-macros/macros.anda b/anda/terra/srpm-macros/macros.anda similarity index 100% rename from anda/srpm-macros/macros.anda rename to anda/terra/srpm-macros/macros.anda diff --git a/anda/srpm-macros/macros.caching b/anda/terra/srpm-macros/macros.caching similarity index 92% rename from anda/srpm-macros/macros.caching rename to anda/terra/srpm-macros/macros.caching index 21262592a5..2b9bbbd375 100644 --- a/anda/srpm-macros/macros.caching +++ b/anda/terra/srpm-macros/macros.caching @@ -3,8 +3,8 @@ %_sccache %{_bindir}/sccache %sccache_prep (\ -export CC="%{_sccache} gcc" \ -export CXX="%{_sccache} g++" \ +export CC="%{_sccache} $CC" \ +export CXX="%{_sccache} $CXX" \ export RUSTC_WRAPPER="sccache" \ \ export SCCACHE_BUCKET=%{?sccache_bucket}\ diff --git a/anda/terra/srpm-macros/macros.cargo_extra b/anda/terra/srpm-macros/macros.cargo_extra new file mode 100644 index 0000000000..c2ca56f1ef --- /dev/null +++ b/anda/terra/srpm-macros/macros.cargo_extra @@ -0,0 +1,116 @@ +%cargo_prep_online (\ +set -eu \ +%{__mkdir} -p .cargo \ +cat > .cargo/config << EOF \ +[profile.rpm]\ +inherits = "release"\ +opt-level = 3\ +codegen-units = 1\ +debug = 2\ +strip = "none"\ +\ +[build]\ +rustc = "%{__rustc}"\ +rustdoc = "%{__rustdoc}"\ +\ +[env]\ +CFLAGS = "%{build_cflags}"\ +CXXFLAGS = "%{build_cxxflags}"\ +LDFLAGS = "%{build_ldflags}"\ +\ +[install]\ +root = "%{buildroot}%{_prefix}"\ +\ +[term]\ +verbose = true\ +\ +[source]\ +\ +[source.local-registry]\ +directory = "%{cargo_registry}"\ +\ +EOF\ +%{__rm} -f Cargo.lock \ +%{__rm} -f Cargo.toml.orig \ +) + + + +# cargo_license: print license information for all crate dependencies +# +# The "no-build,no-dev,no-proc-macro" argument results in only crates which are +# linked into the final binary to be considered. +# +# Additionally, deprecated SPDX syntax ("/" instead of "OR") is normalized +# before sorting the results to ensure reproducible output of this macro. +# +# This macro must be called with the same feature flags as other cargo macros, +# in particular, "cargo_build", otherwise its output will be incomplete. +# +# The "cargo tree" command called by this macro will fail if there are missing +# (optional) dependencies. +%cargo_license_online(naf:)\ +(\ +set -euo pipefail\ +%{shrink: \ + %{__cargo} tree \ + -Z avoid-dev-deps \ + --workspace \ + --edges no-build,no-dev,no-proc-macro \ + --no-dedupe \ + --target all \ + %{__cargo_parse_opts %{-n} %{-a} %{-f:-f%{-f*}}} \ + --prefix none \ + --format "{l}: {p}" \ + | sed -e "s: ($(pwd)[^)]*)::g" -e "s: / :/:g" -e "s:/: OR :g" \ + | sort -u \ +}\ +) + +# cargo_license_summary: print license summary for all crate dependencies +# +# This macro works in the same way as cargo_license, except that it only prints +# a list of licenses, and not the complete license information for every crate +# in the dependency tree. This is useful for determining the correct License +# tag for packages that contain compiled Rust binaries. +%cargo_license_summary_online(naf:)\ +(\ +set -euo pipefail\ +%{shrink: \ + %{__cargo} tree \ + -Z avoid-dev-deps \ + --workspace \ + --edges no-build,no-dev,no-proc-macro \ + --no-dedupe \ + --target all \ + %{__cargo_parse_opts %{-n} %{-a} %{-f:-f%{-f*}}} \ + --prefix none \ + --format "# {l}" \ + | sed -e "s: / :/:g" -e "s:/: OR :g" \ + | sort -u \ +}\ +) + +# cargo_vendor_manifest: write list of vendored crates and their versions +# +# The arguments for the internal "cargo tree" call emulate the logic +# that determines which crates are included when running "cargo vendor". +# The results are written to "cargo-vendor.txt". +%cargo_vendor_manifest_online()\ +(\ +set -euo pipefail\ +%{shrink: \ + %{__cargo} tree \ + --workspace \ + --edges normal,build,dev \ + --no-dedupe \ + --target all \ + --all-features \ + --prefix none \ + --format "{p}" \ + | grep -v "$(pwd)" \ + | sed -e "s: (proc-macro)::" \ + | sort -u \ + > cargo-vendor.txt \ +}\ +) diff --git a/anda/srpm-macros/macros.go_extra b/anda/terra/srpm-macros/macros.go_extra similarity index 100% rename from anda/srpm-macros/macros.go_extra rename to anda/terra/srpm-macros/macros.go_extra diff --git a/anda/srpm-macros/umpkg.toml b/anda/terra/srpm-macros/umpkg.toml similarity index 100% rename from anda/srpm-macros/umpkg.toml rename to anda/terra/srpm-macros/umpkg.toml diff --git a/anda/others/tau-helium/anda.hcl b/anda/themes/tau-helium/anda.hcl similarity index 100% rename from anda/others/tau-helium/anda.hcl rename to anda/themes/tau-helium/anda.hcl diff --git a/anda/others/tau-helium/tau-helium.spec b/anda/themes/tau-helium/tau-helium.spec similarity index 100% rename from anda/others/tau-helium/tau-helium.spec rename to anda/themes/tau-helium/tau-helium.spec diff --git a/anda/others/tau-helium/update.rhai b/anda/themes/tau-helium/update.rhai similarity index 100% rename from anda/others/tau-helium/update.rhai rename to anda/themes/tau-helium/update.rhai diff --git a/anda/others/tau-hydrogen/anda.hcl b/anda/themes/tau-hydrogen/anda.hcl similarity index 100% rename from anda/others/tau-hydrogen/anda.hcl rename to anda/themes/tau-hydrogen/anda.hcl diff --git a/anda/others/tau-hydrogen/tau-hydrogen.spec b/anda/themes/tau-hydrogen/tau-hydrogen.spec similarity index 100% rename from anda/others/tau-hydrogen/tau-hydrogen.spec rename to anda/themes/tau-hydrogen/tau-hydrogen.spec diff --git a/anda/others/tau-hydrogen/update.rhai b/anda/themes/tau-hydrogen/update.rhai similarity index 100% rename from anda/others/tau-hydrogen/update.rhai rename to anda/themes/tau-hydrogen/update.rhai diff --git a/anda/tools/amdctl/0001-RPM-makefile-Remove-unused-Makefile-variables.patch b/anda/tools/amdctl/0001-RPM-makefile-Remove-unused-Makefile-variables.patch new file mode 100644 index 0000000000..e0e225078b --- /dev/null +++ b/anda/tools/amdctl/0001-RPM-makefile-Remove-unused-Makefile-variables.patch @@ -0,0 +1,22 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Paskal Sitepu +Date: Sat, 4 Nov 2023 09:54:38 +0700 +Subject: [PATCH] (RPM) makefile: Remove unused Makefile variables + +Signed-off-by: Paskal Sitepu +--- + makefile | 2 -- + 1 file changed, 2 deletions(-) + +diff --git a/makefile b/makefile +index 5ca6bab..0091429 100644 +--- a/makefile ++++ b/makefile +@@ -1,5 +1,3 @@ +-CC=gcc +-CFLAGS=-Wall -pedantic -Wextra -std=c99 -O2 + all: amdctl + %.o: %.c + $(CC) -c -o $@ $< $(CFLAGS) +-- +2.41.0 diff --git a/anda/tools/amdctl/amdctl.spec b/anda/tools/amdctl/amdctl.spec new file mode 100644 index 0000000000..c0a18e54d3 --- /dev/null +++ b/anda/tools/amdctl/amdctl.spec @@ -0,0 +1,79 @@ +Name: amdctl +Summary: Set P-State voltages and clock speeds on recent AMD CPUs on Linux +License: GPLv3 +URL: https://github.com/kevinlekiller/%{name} + +Version: 0.11 +Release: 2%{?dist} +Source0: https://github.com/kevinlekiller/%{name}/archive/refs/tags/v%{version}.tar.gz +# Remove hardcoded CFLAGS and CC +Patch0: 0001-RPM-makefile-Remove-unused-Makefile-variables.patch + +# `msr` is a builtin kernel module +Requires: kernel-core systemd-udev coreutils +BuildRequires: make gcc kernel-headers glibc-headers + +%description +Tool for changing voltages and clock speeds for AMD processors with +control over every power state and CPU core. + +%prep +%setup -qn %{name}-%{version} +patch -p1 -i %{PATCH0} + +%build +%set_build_flags +%make_build + +%install +# install the 'amdctl' binary +mkdir -p %{buildroot}/%{_bindir} +install -m 0755 ./%{name} %{buildroot}/%{_bindir}/ + +# add modules.load.d entry +mkdir -p %{buildroot}/%{_modulesloaddir}/ +echo 'msr' > %{buildroot}/%{_modulesloaddir}/%{name}.conf + +# write the udev helper script +mkdir -p %{buildroot}/%{_libexecdir}/%{name}/ +cat << 'EOF' > %{buildroot}/%{_libexecdir}/%{name}/udev-helper.sh +#!/bin/sh +echo 'on' > /sys/module/msr/parameters/allow_writes +EOF +chmod 0755 %{buildroot}/%{_libexecdir}/%{name}/udev-helper.sh + +# add udev rules to enable msr writes +mkdir -p %{buildroot}/%{_udevrulesdir}/ +cat << 'EOF' > %{buildroot}/%{_udevrulesdir}/99-%{name}.rules +DRIVER=="msr", RUN+="%{_libexecdir}/%{name}/udev-helper.sh" +EOF + +%files +%license LICENSE +%doc README.md +/%{_bindir}/%{name} +/%{_libexecdir}/%{name} +/%{_modulesloaddir}/%{name}.conf +/%{_udevrulesdir}/99-%{name}.rules + +%changelog +* Sat Nov 4 2023 - 0.11-1 +- Track upstream to 0.11 + +* Fri Mar 18 2022 - 0.8-2 +- Clean up RPM spec file + +* Fri Mar 18 2022 - 0.8-1 +- Track upstream to 0.8 + +* Mon Sep 13 2021 rmnscnce - 0.6.1-3 +- Wrap %%description + +* Mon Sep 13 2021 rmnscnce - 0.6.1-2 +- Fix missing executable bit for udev-helper.sh + +* Mon Sep 13 2021 rmnscnce - 0.6.1-1 +- Track upstream to 0.6.1 + +* Mon May 24 2021 rmnscnce - 0.2-2.git+gb0ffbad +- Initial packaging \ No newline at end of file diff --git a/anda/tools/amdctl/anda.hcl b/anda/tools/amdctl/anda.hcl new file mode 100644 index 0000000000..9390a58e2e --- /dev/null +++ b/anda/tools/amdctl/anda.hcl @@ -0,0 +1,6 @@ +project pkg { + arches = ["x86_64"] // Because of course + rpm { + spec = "amdctl.spec" + } +} diff --git a/anda/tools/amdctl/update.rhai b/anda/tools/amdctl/update.rhai new file mode 100644 index 0000000000..84e5aefdab --- /dev/null +++ b/anda/tools/amdctl/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("kevinlekiller/amdctl")); \ No newline at end of file diff --git a/anda/tools/anda/anda.hcl b/anda/tools/buildsys/anda/anda.hcl similarity index 100% rename from anda/tools/anda/anda.hcl rename to anda/tools/buildsys/anda/anda.hcl diff --git a/anda/tools/anda/rust-anda.spec b/anda/tools/buildsys/anda/rust-anda.spec similarity index 100% rename from anda/tools/anda/rust-anda.spec rename to anda/tools/buildsys/anda/rust-anda.spec diff --git a/anda/tools/anda/update.rhai b/anda/tools/buildsys/anda/update.rhai similarity index 100% rename from anda/tools/anda/update.rhai rename to anda/tools/buildsys/anda/update.rhai diff --git a/anda/tools/gradle/anda.hcl b/anda/tools/buildsys/gradle/anda.hcl similarity index 100% rename from anda/tools/gradle/anda.hcl rename to anda/tools/buildsys/gradle/anda.hcl diff --git a/anda/tools/gradle/gradle.spec b/anda/tools/buildsys/gradle/gradle.spec similarity index 100% rename from anda/tools/gradle/gradle.spec rename to anda/tools/buildsys/gradle/gradle.spec diff --git a/anda/tools/gradle/update.rhai b/anda/tools/buildsys/gradle/update.rhai similarity index 100% rename from anda/tools/gradle/update.rhai rename to anda/tools/buildsys/gradle/update.rhai diff --git a/anda/tools/katsu/anda.hcl b/anda/tools/buildsys/katsu/anda.hcl similarity index 100% rename from anda/tools/katsu/anda.hcl rename to anda/tools/buildsys/katsu/anda.hcl diff --git a/anda/tools/katsu/katsu.spec b/anda/tools/buildsys/katsu/katsu.spec similarity index 95% rename from anda/tools/katsu/katsu.spec rename to anda/tools/buildsys/katsu/katsu.spec index 8449b4ff4c..9187321272 100644 --- a/anda/tools/katsu/katsu.spec +++ b/anda/tools/buildsys/katsu/katsu.spec @@ -6,7 +6,7 @@ Release: 1%{?dist} Summary: The vicious image builder License: MIT URL: https://github.com/FyraLabs/katsu -Source0: %url/archive/refs/tags/%version.tar.gz +Source0: %url/archive/refs/tags/v%version.tar.gz Requires: xorriso dracut limine grub2 systemd-devel squashfs-tools Requires: dracut-live dracut-config-generic dracut-config-rescue grub2-tools-extra dracut-squash BuildRequires: cargo rust-packaging pkgconfig(libudev) clang-devel diff --git a/anda/tools/katsu/update.rhai b/anda/tools/buildsys/katsu/update.rhai similarity index 100% rename from anda/tools/katsu/update.rhai rename to anda/tools/buildsys/katsu/update.rhai diff --git a/anda/tools/muon/anda.hcl b/anda/tools/buildsys/muon/anda.hcl similarity index 100% rename from anda/tools/muon/anda.hcl rename to anda/tools/buildsys/muon/anda.hcl diff --git a/anda/tools/muon/muon.spec b/anda/tools/buildsys/muon/muon.spec similarity index 100% rename from anda/tools/muon/muon.spec rename to anda/tools/buildsys/muon/muon.spec diff --git a/anda/tools/ops2deb/anda.hcl b/anda/tools/buildsys/ops2deb/anda.hcl similarity index 100% rename from anda/tools/ops2deb/anda.hcl rename to anda/tools/buildsys/ops2deb/anda.hcl diff --git a/anda/tools/ops2deb/ops2deb.spec b/anda/tools/buildsys/ops2deb/ops2deb.spec similarity index 96% rename from anda/tools/ops2deb/ops2deb.spec rename to anda/tools/buildsys/ops2deb/ops2deb.spec index 218399f7b0..6e89648ae4 100644 --- a/anda/tools/ops2deb/ops2deb.spec +++ b/anda/tools/buildsys/ops2deb/ops2deb.spec @@ -2,8 +2,8 @@ %define _python_dist_allow_version_zero # upstream issue? Name: python3-ops2deb -Version: 2.4.1 -Release: 1%?dist +Version: 2.5.0 +Release: 1%{?dist} Summary: Generate Debian packages for common devops tools License: MIT URL: https://github.com/upciti/ops2deb diff --git a/anda/tools/ops2deb/update.rhai b/anda/tools/buildsys/ops2deb/update.rhai similarity index 100% rename from anda/tools/ops2deb/update.rhai rename to anda/tools/buildsys/ops2deb/update.rhai diff --git a/anda/tools/subatomic/anda.hcl b/anda/tools/buildsys/subatomic/anda.hcl similarity index 100% rename from anda/tools/subatomic/anda.hcl rename to anda/tools/buildsys/subatomic/anda.hcl diff --git a/anda/tools/subatomic/subatomic.spec b/anda/tools/buildsys/subatomic/subatomic.spec similarity index 100% rename from anda/tools/subatomic/subatomic.spec rename to anda/tools/buildsys/subatomic/subatomic.spec diff --git a/anda/tools/subatomic/update.rhai b/anda/tools/buildsys/subatomic/update.rhai similarity index 100% rename from anda/tools/subatomic/update.rhai rename to anda/tools/buildsys/subatomic/update.rhai diff --git a/anda/tools/chromium-ectool/anda.hcl b/anda/tools/chromium-ectool/anda.hcl new file mode 100644 index 0000000000..52c95d7d50 --- /dev/null +++ b/anda/tools/chromium-ectool/anda.hcl @@ -0,0 +1,5 @@ +project pkg { + rpm { + spec = "chromium-ectool.spec" + } +} \ No newline at end of file diff --git a/anda/tools/chromium-ectool/chromium-ectool.spec b/anda/tools/chromium-ectool/chromium-ectool.spec new file mode 100644 index 0000000000..d9388298e0 --- /dev/null +++ b/anda/tools/chromium-ectool/chromium-ectool.spec @@ -0,0 +1,35 @@ +%global commit 55680f70d2a1e61c193fc78ff1d51c7437803683 +%global shortcommit %(c=%{commit}; echo ${c:0:7}) + +Name: chromium-ectool +Summary: Query and send commands to ChromiumOS EC from userspace. +License: BSD-3-Clause +URL: https://chromium.googlesource.com/chromiumos/platform/ec/ + +Version: %shortcommit +Release: 14526.B%{?dist} +Source0: https://github.com/coreboot/chrome-ec/archive/refs/heads/release-R100-14526.B-main.tar.gz +Provides: ectool + +BuildRequires: make gcc libftdi-devel libusb1-devel hostname + +%description +A tool to query and send commands to ChromiumOS EC from userspace. + +%prep +%autosetup -n chrome-ec-release-R100-14526.B-main + +%build +BOARD=host %make_build utils-host + +%install +install -Dm755 build/host/util/ectool %{buildroot}%{_bindir}/ectool + +%files +%license LICENSE +%doc README.md +%{_bindir}/ectool + +%changelog +* Tue Jan 2 2024 infinitebash +- Initial package. \ No newline at end of file diff --git a/anda/tools/electron/electron.spec b/anda/tools/electron/electron.spec index 746295a4b2..5bceb6c1ae 100644 --- a/anda/tools/electron/electron.spec +++ b/anda/tools/electron/electron.spec @@ -12,7 +12,7 @@ %global __provides_exclude_from %{_libdir}/%{name}/.*\\.so Name: electron -Version: 28.0.0 +Version: 28.1.3 Release: 1%{?dist} Summary: Build cross platform desktop apps with web technologies License: MIT diff --git a/anda/tools/ffmpeg/0001-avcodec-x86-mathops-clip-constants-used-with-shift-i.patch b/anda/tools/ffmpeg/0001-avcodec-x86-mathops-clip-constants-used-with-shift-i.patch deleted file mode 100644 index f47e82732c..0000000000 --- a/anda/tools/ffmpeg/0001-avcodec-x86-mathops-clip-constants-used-with-shift-i.patch +++ /dev/null @@ -1,76 +0,0 @@ -From effadce6c756247ea8bae32dc13bb3e6f464f0eb Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?R=C3=A9mi=20Denis-Courmont?= -Date: Sun, 16 Jul 2023 18:18:02 +0300 -Subject: [PATCH] avcodec/x86/mathops: clip constants used with shift - instructions within inline assembly - -Fixes assembling with binutil as >= 2.41 - -Signed-off-by: James Almer ---- - libavcodec/x86/mathops.h | 26 +++++++++++++++++++++++--- - 1 file changed, 23 insertions(+), 3 deletions(-) - -diff --git a/libavcodec/x86/mathops.h b/libavcodec/x86/mathops.h -index 6298f5ed19..ca7e2dffc1 100644 ---- a/libavcodec/x86/mathops.h -+++ b/libavcodec/x86/mathops.h -@@ -35,12 +35,20 @@ - static av_always_inline av_const int MULL(int a, int b, unsigned shift) - { - int rt, dummy; -+ if (__builtin_constant_p(shift)) - __asm__ ( - "imull %3 \n\t" - "shrdl %4, %%edx, %%eax \n\t" - :"=a"(rt), "=d"(dummy) -- :"a"(a), "rm"(b), "ci"((uint8_t)shift) -+ :"a"(a), "rm"(b), "i"(shift & 0x1F) - ); -+ else -+ __asm__ ( -+ "imull %3 \n\t" -+ "shrdl %4, %%edx, %%eax \n\t" -+ :"=a"(rt), "=d"(dummy) -+ :"a"(a), "rm"(b), "c"((uint8_t)shift) -+ ); - return rt; - } - -@@ -113,19 +121,31 @@ __asm__ volatile(\ - // avoid +32 for shift optimization (gcc should do that ...) - #define NEG_SSR32 NEG_SSR32 - static inline int32_t NEG_SSR32( int32_t a, int8_t s){ -+ if (__builtin_constant_p(s)) - __asm__ ("sarl %1, %0\n\t" - : "+r" (a) -- : "ic" ((uint8_t)(-s)) -+ : "i" (-s & 0x1F) - ); -+ else -+ __asm__ ("sarl %1, %0\n\t" -+ : "+r" (a) -+ : "c" ((uint8_t)(-s)) -+ ); - return a; - } - - #define NEG_USR32 NEG_USR32 - static inline uint32_t NEG_USR32(uint32_t a, int8_t s){ -+ if (__builtin_constant_p(s)) - __asm__ ("shrl %1, %0\n\t" - : "+r" (a) -- : "ic" ((uint8_t)(-s)) -+ : "i" (-s & 0x1F) - ); -+ else -+ __asm__ ("shrl %1, %0\n\t" -+ : "+r" (a) -+ : "c" ((uint8_t)(-s)) -+ ); - return a; - } - --- -2.41.0 - diff --git a/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-remove-deprecated-field.patch b/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-remove-deprecated-field.patch deleted file mode 100644 index 0819af4591..0000000000 --- a/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-remove-deprecated-field.patch +++ /dev/null @@ -1,73 +0,0 @@ -From 1231003c3c6d4839a9e838d06f8e16ee7690958f Mon Sep 17 00:00:00 2001 -From: Niklas Haas -Date: Mon, 13 Mar 2023 14:33:16 +0100 -Subject: [PATCH] avfilter/vf_libplacebo: remove deprecated field - -This has not been functional since a year ago, including in our current -minimum dependency of libplacebo (v4.192.0). It also causes build errors -against libplacebo v6, so it needs to be removed from the code. We can -keep the option around for now, but it should also be removed soon. - -Signed-off-by: Niklas Haas -Signed-off-by: James Almer ---- - doc/filters.texi | 3 --- - libavfilter/vf_libplacebo.c | 7 ++++--- - 2 files changed, 4 insertions(+), 6 deletions(-) - -diff --git a/doc/filters.texi b/doc/filters.texi -index 7a7b2ba4e79e..77b594f69cb1 100644 ---- a/doc/filters.texi -+++ b/doc/filters.texi -@@ -16242,9 +16242,6 @@ Disable linear light scaling. - @item disable_builtin - Disable built-in GPU sampling (forces LUT). - --@item force_icc_lut --Force the use of a full ICC 3DLUT for gamut mapping. -- - @item disable_fbos - Forcibly disable FBOs, resulting in loss of almost all functionality, but - offering the maximum possible speed. -diff --git a/libavfilter/vf_libplacebo.c b/libavfilter/vf_libplacebo.c -index d75723289069..757dc519e9ad 100644 ---- a/libavfilter/vf_libplacebo.c -+++ b/libavfilter/vf_libplacebo.c -@@ -97,7 +97,6 @@ typedef struct LibplaceboContext { - float polar_cutoff; - int disable_linear; - int disable_builtin; -- int force_icc_lut; - int force_dither; - int disable_fbos; - -@@ -139,6 +138,7 @@ typedef struct LibplaceboContext { - float desat_exp; - int gamut_warning; - int gamut_clipping; -+ int force_icc_lut; - #endif - - /* pl_dither_params */ -@@ -463,7 +463,6 @@ static int process_frames(AVFilterContext *avctx, AVFrame *out, AVFrame *in) - .polar_cutoff = s->polar_cutoff, - .disable_linear_scaling = s->disable_linear, - .disable_builtin_scalers = s->disable_builtin, -- .force_icc_lut = s->force_icc_lut, - .force_dither = s->force_dither, - .disable_fbos = s->disable_fbos, - }; -@@ -855,7 +854,9 @@ static const AVOption libplacebo_options[] = { - { "polar_cutoff", "Polar LUT cutoff", OFFSET(polar_cutoff), AV_OPT_TYPE_FLOAT, {.dbl = 0}, 0.0, 1.0, DYNAMIC }, - { "disable_linear", "Disable linear scaling", OFFSET(disable_linear), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, - { "disable_builtin", "Disable built-in scalers", OFFSET(disable_builtin), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, -- { "force_icc_lut", "Force the use of a full ICC 3DLUT for color mapping", OFFSET(force_icc_lut), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, -+#if FF_API_LIBPLACEBO_OPTS -+ { "force_icc_lut", "Deprecated, does nothing", OFFSET(force_icc_lut), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC | AV_OPT_FLAG_DEPRECATED }, -+#endif - { "force_dither", "Force dithering", OFFSET(force_dither), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, - { "disable_fbos", "Force-disable FBOs", OFFSET(disable_fbos), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, - { NULL }, --- -2.39.2 - diff --git a/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-wrap-deprecated-opts-in-FF_AP.patch b/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-wrap-deprecated-opts-in-FF_AP.patch deleted file mode 100644 index 2d2a939b84..0000000000 --- a/anda/tools/ffmpeg/0001-avfilter-vf_libplacebo-wrap-deprecated-opts-in-FF_AP.patch +++ /dev/null @@ -1,76 +0,0 @@ -From 11eca6018c40f5ebe6af93cbc4b4dce447d8b3bc Mon Sep 17 00:00:00 2001 -From: Niklas Haas -Date: Mon, 13 Mar 2023 15:10:26 +0100 -Subject: [PATCH] avfilter/vf_libplacebo: wrap deprecated opts in FF_API define - -Signed-off-by: Niklas Haas -Signed-off-by: James Almer ---- - libavfilter/version_major.h | 2 ++ - libavfilter/vf_libplacebo.c | 8 ++++++++ - 2 files changed, 10 insertions(+) - -diff --git a/libavfilter/version_major.h b/libavfilter/version_major.h -index 899dfdb27dba..1decc4012ee0 100644 ---- a/libavfilter/version_major.h -+++ b/libavfilter/version_major.h -@@ -35,4 +35,6 @@ - * the public API and may change, break or disappear at any time. - */ - -+#define FF_API_LIBPLACEBO_OPTS (LIBAVFILTER_VERSION_MAJOR < 10) -+ - #endif /* AVFILTER_VERSION_MAJOR_H */ -diff --git a/libavfilter/vf_libplacebo.c b/libavfilter/vf_libplacebo.c -index 7cd495de2619..d75723289069 100644 ---- a/libavfilter/vf_libplacebo.c -+++ b/libavfilter/vf_libplacebo.c -@@ -132,11 +132,14 @@ typedef struct LibplaceboContext { - int inverse_tonemapping; - float crosstalk; - int tonemapping_lut_size; -+ -+#if FF_API_LIBPLACEBO_OPTS - /* for backwards compatibility */ - float desat_str; - float desat_exp; - int gamut_warning; - int gamut_clipping; -+#endif - - /* pl_dither_params */ - int dithering; -@@ -380,6 +383,7 @@ static int process_frames(AVFilterContext *avctx, AVFrame *out, AVFrame *in) - pl_rect2df_aspect_set(&target.crop, aspect, s->pad_crop_ratio); - } - -+#if FF_API_LIBPLACEBO_OPTS - /* backwards compatibility with older API */ - if (!tonemapping_mode && (s->desat_str >= 0.0f || s->desat_exp >= 0.0f)) { - float str = s->desat_str < 0.0f ? 0.9f : s->desat_str; -@@ -397,6 +401,7 @@ static int process_frames(AVFilterContext *avctx, AVFrame *out, AVFrame *in) - gamut_mode = PL_GAMUT_WARN; - if (s->gamut_clipping) - gamut_mode = PL_GAMUT_DESATURATE; -+#endif - - /* Update render params */ - params = (struct pl_render_params) { -@@ -818,11 +823,14 @@ static const AVOption libplacebo_options[] = { - { "inverse_tonemapping", "Inverse tone mapping (range expansion)", OFFSET(inverse_tonemapping), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC }, - { "tonemapping_crosstalk", "Crosstalk factor for tone-mapping", OFFSET(crosstalk), AV_OPT_TYPE_FLOAT, {.dbl = 0.04}, 0.0, 0.30, DYNAMIC }, - { "tonemapping_lut_size", "Tone-mapping LUT size", OFFSET(tonemapping_lut_size), AV_OPT_TYPE_INT, {.i64 = 256}, 2, 1024, DYNAMIC }, -+ -+#if FF_API_LIBPLACEBO_OPTS - /* deprecated options for backwards compatibility, defaulting to -1 to not override the new defaults */ - { "desaturation_strength", "Desaturation strength", OFFSET(desat_str), AV_OPT_TYPE_FLOAT, {.dbl = -1.0}, -1.0, 1.0, DYNAMIC | AV_OPT_FLAG_DEPRECATED }, - { "desaturation_exponent", "Desaturation exponent", OFFSET(desat_exp), AV_OPT_TYPE_FLOAT, {.dbl = -1.0}, -1.0, 10.0, DYNAMIC | AV_OPT_FLAG_DEPRECATED }, - { "gamut_warning", "Highlight out-of-gamut colors", OFFSET(gamut_warning), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC | AV_OPT_FLAG_DEPRECATED }, - { "gamut_clipping", "Enable colorimetric gamut clipping", OFFSET(gamut_clipping), AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, DYNAMIC | AV_OPT_FLAG_DEPRECATED }, -+#endif - - { "dithering", "Dither method to use", OFFSET(dithering), AV_OPT_TYPE_INT, {.i64 = PL_DITHER_BLUE_NOISE}, -1, PL_DITHER_METHOD_COUNT - 1, DYNAMIC, "dither" }, - { "none", "Disable dithering", 0, AV_OPT_TYPE_CONST, {.i64 = -1}, 0, 0, STATIC, "dither" }, --- -2.39.2 - diff --git a/anda/tools/ffmpeg/0001-fftools-ffmpeg_filter-initialize-the-o-to-silence-th.patch b/anda/tools/ffmpeg/0001-fftools-ffmpeg_filter-initialize-the-o-to-silence-th.patch deleted file mode 100644 index 85b43a4433..0000000000 --- a/anda/tools/ffmpeg/0001-fftools-ffmpeg_filter-initialize-the-o-to-silence-th.patch +++ /dev/null @@ -1,30 +0,0 @@ -From a0a0a804998da8d1a397479c9bafeb000e6be088 Mon Sep 17 00:00:00 2001 -From: Jun Zhao -Date: Sat, 25 Feb 2023 21:54:00 +0800 -Subject: [PATCH] fftools/ffmpeg_filter: initialize the 'o' to silence the - warning - -silence the warning: variable 'o' is used uninitialized whenever -'&&' condition is false - -Signed-off-by: Jun Zhao ---- - fftools/ffmpeg_filter.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/fftools/ffmpeg_filter.c b/fftools/ffmpeg_filter.c -index 1f5bbf6c4d..3504a3cc0a 100644 ---- a/fftools/ffmpeg_filter.c -+++ b/fftools/ffmpeg_filter.c -@@ -362,7 +362,7 @@ fail: - - static int filter_opt_apply(AVFilterContext *f, const char *key, const char *val) - { -- const AVOption *o; -+ const AVOption *o = NULL; - int ret; - - ret = av_opt_set(f, key, val, AV_OPT_SEARCH_CHILDREN); --- -2.41.0 - diff --git a/anda/tools/ffmpeg/ffmpeg.spec b/anda/tools/ffmpeg/ffmpeg.spec deleted file mode 100644 index a015da2d90..0000000000 --- a/anda/tools/ffmpeg/ffmpeg.spec +++ /dev/null @@ -1,540 +0,0 @@ -# ref: https://github.com/rpmfusion/ffmpeg/blob/master/ffmpeg.spec -# TODO: add make test to %%check section - -#global branch oldabi- -#global date 20230221 -#global commit 691d01989936d4b0681aa226aea8a19f06c04cea -#global rel %(c=%{commit}; echo ${c:0:7}) - -%if 0%{?fedora} >= 37 || 0%{?rhel} >= 9 -%bcond_without libavcodec_freeworld -%else -%bcond_with libavcodec_freeworld -%endif - -%undefine _package_note_file - -%ifarch %{ix86} -# Fails due to asm issue -%global _lto_cflags %{nil} -%endif - -# Cuda and others are only available on some arches -%global cuda_arches x86_64 - -# Disable because of gcc issue -%global _without_lensfun 1 -%ifnarch i686 -%global _with_bs2b 1 -%global _with_chromaprint 1 -%global _with_ilbc 1 -%global _with_openh264 1 -%if 0%{?fedora} -%global _with_placebo 1 -%endif -%global _with_rav1e 1 -%global _with_rubberband 1 -%global _with_smb 1 -%global _with_snappy 1 -%global _with_svtav1 1 -%global _with_tesseract 1 -%global _with_twolame 1 -%global _with_wavpack 1 -%global _with_webp 1 -%global _with_zmq 1 -%else -%global _without_vulkan 1 -%endif -%ifarch x86_64 -%global _with_vpl 1 -%global _with_vapoursynth 1 -%global _with_vmaf 1 -%endif - -# flavor nonfree -%if 0%{?_with_cuda:1} -%global debug_package %{nil} -%global flavor -cuda -%global progs_suffix -cuda -#global build_suffix -lgpl -%ifarch %{cuda_arches} -%global _with_cuvid 1 -%global _with_libnpp 1 -%endif -%global _with_fdk_aac 1 -%global _without_cdio 1 -%global _without_frei0r 1 -%global _without_gpl 1 -%global _without_vidstab 1 -%global _without_x264 1 -%global _without_x265 1 -%global _without_xvid 1 -%undefine _with_smb -%endif - -# Disable nvenc when not relevant -#ifnarch %{cuda_arches} aarch64 -%global _without_nvenc 1 -#endif - -# extras flags -%if 0%{!?_cuda_version:1} -%global _cuda_version 11.2 -%endif -%global _cuda_version_rpm %(echo %{_cuda_version} | sed -e 's/\\./-/') -%global _cuda_bindir %{_cuda_prefix}/bin -%if 0%{?_with_cuda:1} -%global cuda_cflags $(pkg-config --cflags cuda-%{_cuda_version}) -%global cuda_ldflags $(pkg-config --libs cuda-%{_cuda_version}) -%endif - -%if 0%{?_with_libnpp:1} -%global libnpp_cflags $(pkg-config --cflags nppi-%{_cuda_version} nppc-%{_cuda_version}) -%global libnpp_ldlags $(pkg-config --libs-only-L nppi-%{_cuda_version} nppc-%{_cuda_version}) -%endif - -%if 0%{?_with_rpi:1} -%global _with_omx 1 -%global _with_omx_rpi 1 -%global _with_mmal 1 -ExclusiveArch: armv7hnl -%endif - -%if 0%{?_without_gpl} -%global lesser L -%endif - -%if 0%{!?_without_amr} || 0%{?_with_gmp} || 0%{?_with_smb} || 0%{?_with_vmaf} -%global ffmpeg_license %{?lesser}GPLv3+ -%else -%global ffmpeg_license %{?lesser}GPLv2+ -%endif - -Summary: Digital VCR and streaming server -Name: ffmpeg%{?flavor} -Version: 6.0 -Release: 18%{?date:.%{?date}%{?date:git}%{?rel}}%{?dist} -License: %{ffmpeg_license} -URL: https://ffmpeg.org/ -%if 0%{?date} -Source0: ffmpeg-%{?branch}%{date}.tar.bz2 -%else -Source0: https://ffmpeg.org/releases/ffmpeg-%{version}.tar.xz -Source1: https://ffmpeg.org/releases/ffmpeg-%{version}.tar.xz.asc -Source2: https://ffmpeg.org/ffmpeg-devel.asc -%endif -Patch0: 0001-avfilter-vf_libplacebo-wrap-deprecated-opts-in-FF_AP.patch -Patch1: 0001-avfilter-vf_libplacebo-remove-deprecated-field.patch -Patch2: 0001-avcodec-x86-mathops-clip-constants-used-with-shift-i.patch -# Backport fix for segfault when passing non-existent filter option -# See: https://bugzilla.rpmfusion.org/show_bug.cgi?id=6773 -Patch3: 0001-fftools-ffmpeg_filter-initialize-the-o-to-silence-th.patch -Conflicts: %{name}-free -Provides: %{name}-bin = %{version}-%{release} -Requires: %{name}-libs%{?_isa} = %{version}-%{release} -%{?_with_cuda:BuildRequires: cuda-minimal-build-%{_cuda_version_rpm} cuda-drivers-devel} -%{?_with_cuda:%{?!_with_cuda_nvcc:BuildRequires: clang}} -%{?_with_libnpp:BuildRequires: pkgconfig(nppc-%{_cuda_version})} -BuildRequires: alsa-lib-devel -BuildRequires: AMF-devel -BuildRequires: bzip2-devel -%{?_with_faac:BuildRequires: faac-devel} -%{?_with_fdk_aac:BuildRequires: fdk-aac-devel} -%{?_with_flite:BuildRequires: flite-devel} -BuildRequires: fontconfig-devel -BuildRequires: freetype-devel -BuildRequires: fribidi-devel -%{!?_without_frei0r:BuildRequires: frei0r-devel} -%{?_with_gme:BuildRequires: game-music-emu-devel} -BuildRequires: gnupg2 -BuildRequires: gnutls-devel -BuildRequires: gsm-devel -%{?_with_ilbc:BuildRequires: ilbc-devel} -BuildRequires: lame-devel >= 3.98.3 -%{!?_without_jack:BuildRequires: jack-audio-connection-kit-devel} -%{!?_without_jxl:BuildRequires: libjxl-devel} -%{!?_without_ladspa:BuildRequires: ladspa-devel} -%{!?_without_aom:BuildRequires: libaom-devel} -%{!?_without_dav1d:BuildRequires: libdav1d-devel} -%{!?_without_ass:BuildRequires: libass-devel} -%{!?_without_bluray:BuildRequires: libbluray-devel} -%{?_with_bs2b:BuildRequires: libbs2b-devel} -%{?_with_caca:BuildRequires: libcaca-devel} -%{!?_without_cdio:BuildRequires: libcdio-paranoia-devel} -%{?_with_chromaprint:BuildRequires: libchromaprint-devel} -%{?_with_crystalhd:BuildRequires: libcrystalhd-devel} -%{!?_without_lensfun:BuildRequires: lensfun-devel} -%if 0%{?_with_ieee1394} -BuildRequires: libavc1394-devel -BuildRequires: libdc1394-devel -BuildRequires: libiec61883-devel -%endif -BuildRequires: libdrm-devel -BuildRequires: libgcrypt-devel -BuildRequires: libGL-devel -BuildRequires: libmodplug-devel -BuildRequires: libmysofa-devel -%{?_with_openh264:BuildRequires: openh264-devel} -BuildRequires: libopenmpt-devel -%{?_with_placebo:BuildRequires: libplacebo-devel >= 4.192.0} -BuildRequires: librsvg2-devel -# Disable rtmp because of rfbz: 6441 & 2399 -%{?_with_rtmp:BuildRequires: librtmp-devel} -%{?_with_smb:BuildRequires: libsmbclient-devel} -BuildRequires: libssh-devel -BuildRequires: libtheora-devel -BuildRequires: libv4l-devel -%{?!_without_vaapi:BuildRequires: libva-devel >= 0.31.0} -BuildRequires: libvdpau-devel -BuildRequires: libvorbis-devel -%{?_with_vapoursynth:BuildRequires: vapoursynth-devel} -%{?!_without_vpx:BuildRequires: libvpx-devel >= 1.4.0} -%{?_with_mfx:BuildRequires: pkgconfig(libmfx) >= 1.23-1} -%ifarch %{ix86} x86_64 -BuildRequires: nasm -%endif -%{?_with_webp:BuildRequires: libwebp-devel} -%{?_with_netcdf:BuildRequires: netcdf-devel} -%{?_with_rpi:BuildRequires: raspberrypi-vc-devel} -%{!?_without_nvenc:BuildRequires: nv-codec-headers} -%{!?_without_amr:BuildRequires: opencore-amr-devel vo-amrwbenc-devel} -%{?_with_omx:BuildRequires: libomxil-bellagio-devel} -BuildRequires: libxcb-devel -BuildRequires: libxml2-devel -%{!?_without_lv2:BuildRequires: lilv-devel lv2-devel} -%{!?_without_openal:BuildRequires: openal-soft-devel} -%if 0%{!?_without_opencl:1} -BuildRequires: opencl-headers ocl-icd-devel -%{?fedora:Recommends: opencl-icd} -%endif -%{?_with_opencv:BuildRequires: opencv-devel} -BuildRequires: openjpeg2-devel -%{!?_without_opus:BuildRequires: opus-devel >= 1.1.3} -%{!?_without_pulse:BuildRequires: pulseaudio-libs-devel} -BuildRequires: perl(Pod::Man) -%{?_with_rav1e:BuildRequires: pkgconfig(rav1e)} -%{?_with_rubberband:BuildRequires: rubberband-devel} -%{!?_without_tools:BuildRequires: SDL2-devel} -%{?_with_snappy:BuildRequires: snappy-devel} -BuildRequires: soxr-devel -BuildRequires: speex-devel -BuildRequires: pkgconfig(srt) -%{?_with_svtav1:BuildRequires: svt-av1-devel >= 0.9.0} -%{?_with_tesseract:BuildRequires: tesseract-devel} -#BuildRequires: texi2html -BuildRequires: texinfo -%{?_with_twolame:BuildRequires: twolame-devel} -%{?_with_vmaf:BuildRequires: libvmaf-devel >= 1.5.2} -%{?_with_vpl:BuildRequires: pkgconfig(vpl) >= 2.6} -%{?_with_wavpack:BuildRequires: wavpack-devel} -%{!?_without_vidstab:BuildRequires: vid.stab-devel} -%{!?_without_vulkan:BuildRequires: vulkan-loader-devel pkgconfig(shaderc)} -%{!?_without_x264:BuildRequires: x264-devel >= 0.0.0-0.31} -%{!?_without_x265:BuildRequires: x265-devel} -%{!?_without_xvid:BuildRequires: xvidcore-devel} -%{!?_without_zimg:BuildRequires: zimg-devel >= 2.7.0} -BuildRequires: zlib-devel -%{?_with_zmq:BuildRequires: zeromq-devel} -%{!?_without_zvbi:BuildRequires: zvbi-devel} - -%description -FFmpeg is a complete and free Internet live audio and video -broadcasting solution for Linux/Unix. It also includes a digital -VCR. It can encode in real time in many formats including MPEG1 audio -and video, MPEG4, h263, ac3, asf, avi, real, mjpeg, and flash. - -%package libs -Summary: Libraries for %{name} -Conflicts: libavcodec-free -Conflicts: libavfilter-free -Conflicts: libavformat-free -Conflicts: libavutil-free -Conflicts: libpostproc-free -Conflicts: libswresample-free -Conflicts: libswscale-free -%{?_with_vmaf:Recommends: vmaf-models} - -%description libs -FFmpeg is a complete and free Internet live audio and video -broadcasting solution for Linux/Unix. It also includes a digital -VCR. It can encode in real time in many formats including MPEG1 audio -and video, MPEG4, h263, ac3, asf, avi, real, mjpeg, and flash. -This package contains the libraries for %{name} - -%package -n libavdevice%{?flavor} -Summary: Special devices muxing/demuxing library -Conflicts: libavdevice-free -Requires: %{name}-libs%{_isa} = %{version}-%{release} - -%description -n libavdevice%{?flavor} -Libavdevice is a complementary library to libavf "libavformat". It provides -various "special" platform-specific muxers and demuxers, e.g. for grabbing -devices, audio capture and playback etc. - -%package devel -Summary: Development package for %{name} -Conflicts: %{name}-free-devel -Requires: %{name}-libs%{_isa} = %{version}-%{release} -Requires: libavdevice%{?flavor}%{_isa} = %{version}-%{release} -Requires: pkgconfig - -%description devel -FFmpeg is a complete and free Internet live audio and video -broadcasting solution for Linux/Unix. It also includes a digital -VCR. It can encode in real time in many formats including MPEG1 audio -and video, MPEG4, h263, ac3, asf, avi, real, mjpeg, and flash. -This package contains development files for %{name} - -%if %{with libavcodec_freeworld} -%package -n libavcodec-freeworld -Summary: Freeworld libavcodec to complement the distro counterparts -# Supplements doesn't work well yet - we can rely on comps for now -#Supplements: libavcodec-free >= %%{version} - -%description -n libavcodec-freeworld -Freeworld libavcodec to complement the distro counterparts -%endif - - -# Don't use the %%configure macro as this is not an autotool script -%global ff_configure \ -./configure \\\ - --prefix=%{_prefix} \\\ - --bindir=%{_bindir} \\\ - --datadir=%{_datadir}/%{name} \\\ - --docdir=%{_docdir}/%{name} \\\ - --incdir=%{_includedir}/%{name} \\\ - --libdir=%{_libdir} \\\ - --mandir=%{_mandir} \\\ - --arch=%{_target_cpu} \\\ - --optflags="%{optflags}" \\\ - --extra-ldflags="%{?__global_ldflags} %{?cuda_ldflags} %{?libnpp_ldlags}" \\\ - --extra-cflags="%{?cuda_cflags} %{?libnpp_cflags} -I%{_includedir}/rav1e" \\\ - %{?flavor:--disable-manpages} \\\ - %{?progs_suffix:--progs-suffix=%{progs_suffix}} \\\ - %{?build_suffix:--build-suffix=%{build_suffix}} \\\ - %{!?_without_amr:--enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libvo-amrwbenc --enable-version3} \\\ - --enable-bzlib \\\ - %{?_with_chromaprint:--enable-chromaprint} \\\ - %{!?_with_crystalhd:--disable-crystalhd} \\\ - --enable-fontconfig \\\ - %{!?_without_frei0r:--enable-frei0r} \\\ - --enable-gcrypt \\\ - %{?_with_gmp:--enable-gmp --enable-version3} \\\ - --enable-gnutls \\\ - %{!?_without_ladspa:--enable-ladspa} \\\ - %{!?_without_aom:--enable-libaom} \\\ - %{!?_without_dav1d:--enable-libdav1d} \\\ - %{!?_without_ass:--enable-libass} \\\ - %{!?_without_bluray:--enable-libbluray} \\\ - %{?_with_bs2b:--enable-libbs2b} \\\ - %{?_with_caca:--enable-libcaca} \\\ - %{?_with_cuda_nvcc:--enable-cuda-nvcc --enable-nonfree} \\\ - %{?_with_cuvid:--enable-cuvid --enable-nonfree} \\\ - %{!?_without_cdio:--enable-libcdio} \\\ - %{?_with_ieee1394:--enable-libdc1394 --enable-libiec61883} \\\ - --enable-libdrm \\\ - %{?_with_faac:--enable-libfaac --enable-nonfree} \\\ - %{?_with_fdk_aac:--enable-libfdk-aac --enable-nonfree} \\\ - %{?_with_flite:--enable-libflite} \\\ - %{!?_without_jack:--enable-libjack} \\\ - %{!?_without_jxl:--enable-libjxl} \\\ - --enable-libfreetype \\\ - %{!?_without_fribidi:--enable-libfribidi} \\\ - %{?_with_gme:--enable-libgme} \\\ - --enable-libgsm \\\ - %{?_with_ilbc:--enable-libilbc} \\\ - %{!?_without_lensfun:--enable-liblensfun} \\\ - %{?_with_libnpp:--enable-libnpp --enable-nonfree} \\\ - --enable-libmp3lame \\\ - --enable-libmysofa \\\ - %{?_with_netcdf:--enable-netcdf} \\\ - %{?_with_mmal:--enable-mmal} \\\ - %{!?_without_nvenc:--enable-nvenc} \\\ - %{?_with_omx:--enable-omx} \\\ - %{?_with_omx_rpi:--enable-omx-rpi} \\\ - %{!?_without_openal:--enable-openal} \\\ - %{!?_without_opencl:--enable-opencl} \\\ - %{?_with_opencv:--enable-libopencv} \\\ - %{!?_without_opengl:--enable-opengl} \\\ - %{?_with_openh264:--enable-libopenh264} \\\ - --enable-libopenjpeg \\\ - --enable-libopenmpt \\\ - %{!?_without_opus:--enable-libopus} \\\ - %{!?_without_pulse:--enable-libpulse} \\\ - %{?_with_placebo:--enable-libplacebo} \\\ - --enable-librsvg \\\ - %{?_with_rav1e:--enable-librav1e} \\\ - %{?_with_rtmp:--enable-librtmp} \\\ - %{?_with_rubberband:--enable-librubberband} \\\ - %{?_with_smb:--enable-libsmbclient --enable-version3} \\\ - %{?_with_snappy:--enable-libsnappy} \\\ - --enable-libsoxr \\\ - --enable-libspeex \\\ - --enable-libsrt \\\ - --enable-libssh \\\ - %{?_with_svtav1:--enable-libsvtav1} \\\ - %{?_with_tesseract:--enable-libtesseract} \\\ - --enable-libtheora \\\ - %{?_with_twolame:--enable-libtwolame} \\\ - --enable-libvorbis \\\ - --enable-libv4l2 \\\ - %{!?_without_vidstab:--enable-libvidstab} \\\ - %{?_with_vmaf:--enable-libvmaf --enable-version3} \\\ - %{?_with_vapoursynth:--enable-vapoursynth} \\\ - %{!?_without_vpx:--enable-libvpx} \\\ - %{!?_without_vulkan:--enable-vulkan --enable-libshaderc} \\\ - %{?_with_webp:--enable-libwebp} \\\ - %{!?_without_x264:--enable-libx264} \\\ - %{!?_without_x265:--enable-libx265} \\\ - %{!?_without_xvid:--enable-libxvid} \\\ - --enable-libxml2 \\\ - %{!?_without_zimg:--enable-libzimg} \\\ - %{?_with_zmq:--enable-libzmq} \\\ - %{!?_without_zvbi:--enable-libzvbi} \\\ - %{!?_without_lv2:--enable-lv2} \\\ - --enable-avfilter \\\ - --enable-libmodplug \\\ - --enable-postproc \\\ - --enable-pthreads \\\ - --disable-static \\\ - --enable-shared \\\ - %{!?_without_gpl:--enable-gpl} \\\ - --disable-debug \\\ - --disable-stripping - - -%prep -%if 0%{?date} -%autosetup -p1 -n ffmpeg-%{?branch}%{date} -echo "git-snapshot-%{?branch}%{date}-rpmfusion" > VERSION -%else -%{gpgverify} --keyring='%{SOURCE2}' --signature='%{SOURCE1}' --data='%{SOURCE0}' -%autosetup -p1 -n ffmpeg-%{version} -%endif -# fix -O3 -g in host_cflags -sed -i "s|check_host_cflags -O3|check_host_cflags %{optflags}|" configure -mkdir -p _doc/examples -cp -pr doc/examples/{*.c,Makefile,README} _doc/examples/ - -%build -%{?_with_cuda:export PATH=${PATH}:%{_cuda_bindir}} -%{ff_configure}\ - --shlibdir=%{_libdir} \ -%if 0%{?_without_tools:1} - --disable-doc \ - --disable-ffmpeg --disable-ffplay --disable-ffprobe \ -%endif -%ifnarch %{ix86} - --enable-lto \ -%endif -%ifarch %{ix86} - --cpu=%{_target_cpu} \ -%endif - %{?_with_mfx:--enable-libmfx} \ - %{?_with_vpl:--enable-libvpl} \ -%ifarch %{ix86} x86_64 %{power64} - --enable-runtime-cpudetect \ -%endif -%ifarch %{power64} -%ifarch ppc64 - --cpu=g5 \ -%endif -%ifarch ppc64p7 - --cpu=power7 \ -%endif -%ifarch ppc64le - --cpu=power8 \ -%endif - --enable-pic \ -%endif -%ifarch %{arm} - --disable-runtime-cpudetect --arch=arm \ -%ifarch armv6hl - --cpu=armv6 \ -%endif -%ifarch armv7hl armv7hnl - --cpu=armv7-a \ - --enable-vfpv3 \ - --enable-thumb \ -%endif -%ifarch armv7hl - --disable-neon \ -%endif -%ifarch armv7hnl - --enable-neon \ -%endif -%endif - || cat ffbuild/config.log - -%make_build V=1 -make documentation V=1 -make alltools V=1 - -%install -%make_install V=1 -%if 0%{!?flavor:1} -rm -r %{buildroot}%{_datadir}/%{name}/examples -%endif -%if 0%{!?progs_suffix:1} -install -pm755 tools/qt-faststart %{buildroot}%{_bindir} -%endif - -%if %{with libavcodec_freeworld} -# Install the libavcodec freeworld counterpart -mkdir -p %{buildroot}%{_sysconfdir}/ld.so.conf.d/ -mkdir -p %{buildroot}%{_libdir}/%{name} -echo -e "%{_libdir}/%{name}\n" > %{buildroot}%{_sysconfdir}/ld.so.conf.d/%{name}-%{_lib}.conf -cp -pa %{buildroot}%{_libdir}/libavcodec.so.* \ - %{buildroot}%{_libdir}/%{name} -# Strip to prevent debuginfo duplication -strip %{buildroot}%{_libdir}/%{name}/libavcodec.so.* -%endif - -%ldconfig_scriptlets libs -%ldconfig_scriptlets -n libavdevice%{?flavor} - -%if 0%{!?_without_tools:1} -%files -%{_bindir}/ffmpeg%{?progs_suffix} -%{_bindir}/ffplay%{?progs_suffix} -%{_bindir}/ffprobe%{?progs_suffix} -%{!?progs_suffix:%{_bindir}/qt-faststart} -%{!?flavor: -%{_mandir}/man1/ffmpeg*.1* -%{_mandir}/man1/ffplay*.1* -%{_mandir}/man1/ffprobe*.1* -} -%{_datadir}/%{name} -%endif - -%files libs -%doc CREDITS README.md -%license COPYING.* -%{_libdir}/lib*.so.* -%exclude %{_libdir}/libavdevice%{?build_suffix}.so.* -%{!?flavor:%{_mandir}/man3/lib*.3.* -%exclude %{_mandir}/man3/libavdevice.3* -} - -%files -n libavdevice%{?flavor} -%{_libdir}/libavdevice%{?build_suffix}.so.* -%{!?flavor:%{_mandir}/man3/libavdevice.3*} - -%files devel -%doc MAINTAINERS doc/APIchanges doc/*.txt -%doc _doc/examples -%doc %{_docdir}/%{name}/*.{css,html} -%{_includedir}/%{name} -%{_libdir}/pkgconfig/lib*.pc -%{_libdir}/lib*.so - -%if %{with libavcodec_freeworld} -%files -n libavcodec-freeworld -%{_sysconfdir}/ld.so.conf.d/%{name}-%{_lib}.conf -%{_libdir}/%{name}/libavcodec.so.* -%endif - - -%changelog -%autochangelog diff --git a/anda/tools/graalvm/graalvm.spec b/anda/tools/graalvm/graalvm.spec index 521cb1afab..c9f46a6bf5 100644 --- a/anda/tools/graalvm/graalvm.spec +++ b/anda/tools/graalvm/graalvm.spec @@ -10,8 +10,8 @@ execution of applications written in Java and other JVM languages along with support for JavaScript, Ruby, Python, and a number of other popular languages.} Name: graalvm -Version: 22.3.2 -Release: 2%{?dist} +Version: 22.3.3 +Release: 1%{?dist} URL: https://www.graalvm.org/ Summary: %{gsummary} License: GPL-2.0 diff --git a/anda/tools/keyd/keyd.spec b/anda/tools/keyd/keyd.spec index 2f249dae93..b96cc7faed 100644 --- a/anda/tools/keyd/keyd.spec +++ b/anda/tools/keyd/keyd.spec @@ -1,12 +1,12 @@ Name: keyd Version: 2.4.3 -Release: 2%?dist +Release: 3%?dist Summary: Key remapping daemon for linux URL: https://github.com/rvaiya/keyd License: MIT Source0: %url/archive/refs/tags/v%version.tar.gz Suggests: python3 python3-xlib -BuildRequires: gcc mold make kernel-headers +BuildRequires: gcc mold make kernel-headers systemd-rpm-macros %description keyd provides a flexible system wide daemon which remaps keys using kernel @@ -20,16 +20,27 @@ level input primitives (evdev, uinput). %install %make_install +install -Dm644 keyd.service %buildroot%_unitdir/keyd.service + +%post +%systemd_post keyd.service + +%preun +%systemd_preun keyd.service + +%postun +%systemd_postun_with_restart keyd.service %files %doc README.md %license LICENSE -/usr/bin/keyd -/usr/bin/keyd-application-mapper -/usr/share/doc/keyd/ -/usr/share/keyd -/usr/share/man/man1/keyd-application-mapper.1.gz -/usr/share/man/man1/keyd.1.gz +%_unitdir/keyd.service +%_bindir/keyd +%_bindir/keyd-application-mapper +%_datadir/keyd +%_datadir/doc/keyd/ +%_mandir/man1/keyd-application-mapper.1.gz +%_mandir/man1/keyd.1.gz %changelog * Tue May 23 2023 windowsboy111 - 2.4.3-1 diff --git a/anda/tools/umstellar/.gitignore b/anda/tools/umstellar/.gitignore new file mode 100644 index 0000000000..c32b546f7d --- /dev/null +++ b/anda/tools/umstellar/.gitignore @@ -0,0 +1 @@ +*.tar.gz \ No newline at end of file diff --git a/anda/tools/umstellar/anda.hcl b/anda/tools/umstellar/anda.hcl new file mode 100644 index 0000000000..aa51dee858 --- /dev/null +++ b/anda/tools/umstellar/anda.hcl @@ -0,0 +1,5 @@ +project "pkg" { + rpm { + spec = "umstellar.spec" + } +} \ No newline at end of file diff --git a/anda/tools/umstellar/umstellar.spec b/anda/tools/umstellar/umstellar.spec new file mode 100644 index 0000000000..3deca4b2f5 --- /dev/null +++ b/anda/tools/umstellar/umstellar.spec @@ -0,0 +1,63 @@ +# Created by pyp2rpm-3.3.10 +%global pypi_name umstellar +%global pypi_version 0.0.3 + +Name: python-%{pypi_name} +Version: 0.0.3 +Provides: python3-%{pypi_name} = %{version}-%{release} +Provides: %{pypi_name} = %{version}-%{release} +Release: 1%{?dist} +Summary: Ultramarine Quickstart Tool + +License: None +URL: https://github.com/Ultramarine-Linux/stellar +Source0: %{url}/archive/v%{version}.tar.gz +BuildArch: noarch + +BuildRequires: python3-devel +BuildRequires: python3dist(setuptools) + +%description + Stellar (Stellar)Stellar is a quick-and-dirty GUI post-install menu for +Ultramarine Linux. It's written in Python and uses libadwaita for the UI.We +hacked this together in a few days, just in time for Ultramarine Linux 39 which +happened to get delayed due to some major GNOME 45 porting issues. It's meant +to only be used for Ultramarine Linux 39's Anaconda post-install menu. +Why?So,... + +%package -n python3-%{pypi_name} +Summary: %{summary} +%{?python_provide:%python_provide python3-%{pypi_name}} + +Requires: python3dist(requests) +Requires: python3dist(setuptools) +Requires: python3dist(setuptools) = 67.7.2 +Requires: anaconda-core +%description -n python3-%{pypi_name} + +Stellar is a quick-and-dirty GUI post-install menu for +Ultramarine Linux + + +%prep +%autosetup -n stellar-%{pypi_version} + +%build +%py3_build + +%install +%py3_install + +# install kickstart file +install -D -m 644 example.ks %{buildroot}%{_datadir}/anaconda/post-scripts/stellar.ks + +%files -n python3-%{pypi_name} +%license LICENSE +%doc README.md +%{python3_sitelib}/umstellar +%{python3_sitelib}/%{pypi_name}-%{pypi_version}-py%{python3_version}.egg-info +%{_datadir}/anaconda/post-scripts/stellar.ks + +%changelog +* Fri Nov 10 2023 Cappy Ishihara - 0.0.1-1 +- Initial package. \ No newline at end of file diff --git a/anda/tools/umstellar/update.rhai b/anda/tools/umstellar/update.rhai new file mode 100644 index 0000000000..c929de9bef --- /dev/null +++ b/anda/tools/umstellar/update.rhai @@ -0,0 +1 @@ +rpm.version(gh("Ultramarine-Linux/stellar"));