From bdc87a5f83eb3787ac0f07846291133f8a9bcb61 Mon Sep 17 00:00:00 2001 From: hgy59 Date: Sun, 19 Jan 2025 00:54:46 +0100 Subject: [PATCH] Redesign dependency-list creation for github prepare action (#6255) * redesign dependency-list creation for github prepare action - add script to evaluate the dependencies - use new script in global Makefile for the dependency-list target - use global Makefile to create dependency-list in prepare.sh - avoid variables in DEPENDS definitions - make dependency-list.sh executable * stockfish-webgui: fix digests * dependency-list: add python and ffmpeg dependency based on include file * revert changes in sabnzbd - avoid conflicting changes with #6366 * revert changes in vim - avoid conflicting changes with #6398 * revert changes in java-11-openjdk - avoid conflicting changes with #6394 --- .github/actions/prepare.sh | 8 +- Makefile | 7 +- cross/python2/Makefile | 2 +- cross/python38/Makefile | 2 +- cross/stockfish-webgui/digests | 6 +- cross/vim/Makefile | 4 +- diyspk/bandwhich/Makefile | 2 +- diyspk/bottom/Makefile | 2 +- diyspk/cpulimit/Makefile | 2 +- diyspk/duf/Makefile | 2 +- diyspk/dutree/Makefile | 2 +- diyspk/etherwake/Makefile | 2 +- diyspk/fritzctl/Makefile | 4 +- diyspk/jupp/Makefile | 2 +- diyspk/mtr/Makefile | 2 +- diyspk/procs/Makefile | 2 +- diyspk/tdu/Makefile | 2 +- diyspk/testdisk/Makefile | 2 +- mk/dependency-list.sh | 129 ++++++++++++++++++++++++++++++++ spk/adminer/Makefile | 2 +- spk/curaengine/Makefile | 2 +- spk/dante-sockd/Makefile | 2 +- spk/darkstat/Makefile | 2 +- spk/dnscrypt-proxy/Makefile | 2 +- spk/gateone/Makefile | 2 +- spk/haproxy/Makefile | 2 +- spk/he853/Makefile | 2 +- spk/icecast/Makefile | 2 +- spk/jappix/Makefile | 2 +- spk/lirc/Makefile | 8 +- spk/mediainfo/Makefile | 2 +- spk/monitoring-plugins/Makefile | 2 +- spk/mtproxy/Makefile | 2 +- spk/node-exporter/Makefile | 2 +- spk/pyload/Makefile | 2 +- spk/roundcube/Makefile | 2 +- spk/shairport-sync/Makefile | 2 +- spk/stockfish/Makefile | 2 +- spk/stunnel/Makefile | 2 +- spk/tt-rss/Makefile | 2 +- spk/umurmur/Makefile | 2 +- spk/zsh-static/Makefile | 3 + 42 files changed, 180 insertions(+), 57 deletions(-) create mode 100755 mk/dependency-list.sh diff --git a/.github/actions/prepare.sh b/.github/actions/prepare.sh index 696e3c63fe0..f87f9277462 100755 --- a/.github/actions/prepare.sh +++ b/.github/actions/prepare.sh @@ -25,13 +25,7 @@ SPK_TO_BUILD="${USER_SPK_TO_BUILD} ${GH_SPK_PACKAGES} " # get dependency list # dependencies in this list include the cross or native folder (i.e. native/python cross/glib) echo "Building dependency list..." -DEPENDENCY_LIST= -for package in $(find spk/ -maxdepth 1 -type d | cut -c 5- | sort) -do - if [ ! -f "./spk/${package}/BROKEN" ]; then - DEPENDENCY_LIST+=$(DEPENDENCY_WALK=1 make -s -C spk/${package} dependency-list 2> /dev/null)$'\n' - fi -done +DEPENDENCY_LIST=$(make dependency-list 2> /dev/null) # search for dependent spk packages for package in ${GH_DEPENDENCY_FOLDERS} diff --git a/Makefile b/Makefile index e133440960b..327562b2e7e 100644 --- a/Makefile +++ b/Makefile @@ -79,12 +79,9 @@ dependency-tree: done # build dependency list for all packages -# - exclude broken packages +# - broken packages are excluded dependency-list: - @for spk in $(filter-out $(dir $(wildcard spk/*/BROKEN)),$(dir $(wildcard spk/*/Makefile))) ; \ - do \ - $(MAKE) -s -C $${spk} dependency-list ; \ - done + @mk/dependency-list.sh # define a template that instantiates a 'python3-avoton-6.1' -style target for # every ($2) arch, every ($1) spk diff --git a/cross/python2/Makefile b/cross/python2/Makefile index 49793ec2b79..9ed60905d3a 100644 --- a/cross/python2/Makefile +++ b/cross/python2/Makefile @@ -7,7 +7,7 @@ PKG_DIST_SITE = https://www.python.org/ftp/python/$(PKG_VERS) PKG_DIR = Python-$(PKG_VERS) DEPENDS = cross/zlib cross/openssl cross/sqlite cross/readline cross/ncursesw cross/bzip2 -DEPENDS += cross/berkeleydb-5.3 native/$(PKG_NAME) +DEPENDS += cross/berkeleydb-5.3 native/python2 HOMEPAGE = http://www.python.org COMMENT = Python Programming Language diff --git a/cross/python38/Makefile b/cross/python38/Makefile index 9d3c47bfc3e..10017345787 100644 --- a/cross/python38/Makefile +++ b/cross/python38/Makefile @@ -6,7 +6,7 @@ PKG_DIST_NAME = Python-$(PKG_VERS).$(PKG_EXT) PKG_DIST_SITE = https://www.python.org/ftp/python/$(PKG_VERS) PKG_DIR = Python-$(PKG_VERS) -BUILD_DEPENDS = native/$(PKG_NAME) +BUILD_DEPENDS = native/python38 DEPENDS = cross/zlib cross/sqlite cross/readline cross/ncursesw cross/bzip2 cross/xz # required for uuid module diff --git a/cross/stockfish-webgui/digests b/cross/stockfish-webgui/digests index 99fb75761b9..3276519f5fd 100644 --- a/cross/stockfish-webgui/digests +++ b/cross/stockfish-webgui/digests @@ -1,3 +1,3 @@ -stockfish-webgui-gite474343.tar.gz SHA1 50fa54b5d6fbebe817fa0438619bcc5a74224f95 -stockfish-webgui-gite474343.tar.gz SHA256 f2abdc0f2bd29804f7473d87e84d3d105775f4b242c7be879c5459975f0e7399 -stockfish-webgui-gite474343.tar.gz MD5 5293d2fb00b57335e6d05e587b59e081 +stockfish-webgui-gite474343.tar.gz SHA1 cf17da9801ae61e20b04c7a794bbf128d7bcf507 +stockfish-webgui-gite474343.tar.gz SHA256 a9e240b642773e6faae59ab3fc851054ff7743bb436953190d9b0dd8ab4509f7 +stockfish-webgui-gite474343.tar.gz MD5 d8cdcb7ecd833e858e2e852a07419273 diff --git a/cross/vim/Makefile b/cross/vim/Makefile index 7ead7ee477b..eb65266a92d 100644 --- a/cross/vim/Makefile +++ b/cross/vim/Makefile @@ -10,7 +10,7 @@ ifeq ($(strip $(PYTHON_PACKAGE)),) PYTHON_PACKAGE = python311 endif -OPTIONAL_DEPENDS = cross/$(PYTHON_PACKAGE) +OPTIONAL_DEPENDS = cross/python311 DEPENDS = cross/ncursesw HOMEPAGE = https://www.vim.org/ @@ -26,7 +26,7 @@ CONFIGURE_ARGS += vim_cv_getcwd_broken=yes vim_cv_stat_ignores_slash=yes vim_cv_ include ../../mk/spksrc.archs.mk ifneq ($(findstring $(ARCH),$(ARMv5_ARCHS) $(OLD_PPC_ARCHS)),$(ARCH)) -BUILD_DEPENDS = cross/$(PYTHON_PACKAGE) +BUILD_DEPENDS = cross/python311 CONFIGURE_ARGS += --enable-python3interp=dynamic --with-python3-command=$(HOSTPYTHON) CONFIGURE_ARGS += vi_cv_path_python3_conf=$(PYTHON_CFG_PATH) CONFIGURE_ARGS += vi_cv_path_python3_pfx=$(PYTHON_PREFIX) diff --git a/diyspk/bandwhich/Makefile b/diyspk/bandwhich/Makefile index 95ac4f855d4..dd924ffb71f 100644 --- a/diyspk/bandwhich/Makefile +++ b/diyspk/bandwhich/Makefile @@ -2,7 +2,7 @@ SPK_NAME = bandwhich SPK_VERS = 0.20.0 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/bandwhich # unknown relocation type 95 ... UNSUPPORTED_ARCHS = $(OLD_PPC_ARCHS) diff --git a/diyspk/bottom/Makefile b/diyspk/bottom/Makefile index 292fde5e914..8a0d955b309 100644 --- a/diyspk/bottom/Makefile +++ b/diyspk/bottom/Makefile @@ -2,7 +2,7 @@ SPK_NAME = bottom SPK_VERS = 0.6.8 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/bottom UNSUPPORTED_ARCHS = $(OLD_PPC_ARCHS) diff --git a/diyspk/cpulimit/Makefile b/diyspk/cpulimit/Makefile index d8a268ad776..65aeca7a7b1 100644 --- a/diyspk/cpulimit/Makefile +++ b/diyspk/cpulimit/Makefile @@ -2,7 +2,7 @@ SPK_NAME = cpulimit SPK_VERS = 0.2 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/cpulimit MAINTAINER = SynoCommunity DESCRIPTION = CPU usage limiter for Linux. diff --git a/diyspk/duf/Makefile b/diyspk/duf/Makefile index 79a331cc66d..982470f042d 100644 --- a/diyspk/duf/Makefile +++ b/diyspk/duf/Makefile @@ -2,7 +2,7 @@ SPK_NAME = duf SPK_VERS = 0.8.1 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/duf UNSUPPORTED_ARCHS = $(PPC_ARCHS) diff --git a/diyspk/dutree/Makefile b/diyspk/dutree/Makefile index a7c526a0e78..61d16479811 100644 --- a/diyspk/dutree/Makefile +++ b/diyspk/dutree/Makefile @@ -2,7 +2,7 @@ SPK_NAME = dutree SPK_VERS = 0.2.18 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/dutree UNSUPPORTED_ARCHS = $(OLD_PPC_ARCHS) diff --git a/diyspk/etherwake/Makefile b/diyspk/etherwake/Makefile index 9a7087fe97e..ffcc2115f75 100644 --- a/diyspk/etherwake/Makefile +++ b/diyspk/etherwake/Makefile @@ -2,7 +2,7 @@ SPK_NAME = etherwake SPK_VERS = 1.09 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/etherwake MAINTAINER = SynoCommunity DESCRIPTION = Generate and transmit a Wake-On-LAN (WOL) Magic Packet diff --git a/diyspk/fritzctl/Makefile b/diyspk/fritzctl/Makefile index 88860e6adea..c480ce4f37b 100644 --- a/diyspk/fritzctl/Makefile +++ b/diyspk/fritzctl/Makefile @@ -1,9 +1,9 @@ SPK_NAME = fritzctl SPK_VERS = 1.4.23 SPK_REV = 1 -SPK_ICON = src/$(SPK_NAME).png +SPK_ICON = src/fritzctl.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/fritzctl MAINTAINER = bpicode DESCRIPTION = A lightweight, easy to use console client for the AVM FRITZ!Box Home Automation. diff --git a/diyspk/jupp/Makefile b/diyspk/jupp/Makefile index c731ae7e39b..974c8129f91 100755 --- a/diyspk/jupp/Makefile +++ b/diyspk/jupp/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 40 SPK_REV = 2 SPK_ICON = src/jupp.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/jupp MAINTAINER = SynoCommunity DESCRIPTION = text editor jupp comes with the editor flavours known from joe, specifically, jmacs, joe, jpico, jstar, and rjoe. diff --git a/diyspk/mtr/Makefile b/diyspk/mtr/Makefile index c7af408c198..4eb6ef64aa9 100644 --- a/diyspk/mtr/Makefile +++ b/diyspk/mtr/Makefile @@ -2,7 +2,7 @@ SPK_NAME = mtr SPK_VERS = 0.95 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/mtr MAINTAINER = SynoCommunity DESCRIPTION = mtr \(My traceroute\) combines the functionality of the 'traceroute' and 'ping' programs in a single network diagnostic tool. diff --git a/diyspk/procs/Makefile b/diyspk/procs/Makefile index 2324ffa8a66..344d514edbf 100644 --- a/diyspk/procs/Makefile +++ b/diyspk/procs/Makefile @@ -2,7 +2,7 @@ SPK_NAME = procs SPK_VERS = 0.12.3 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/procs UNSUPPORTED_ARCHS = $(OLD_PPC_ARCHS) diff --git a/diyspk/tdu/Makefile b/diyspk/tdu/Makefile index d13f30646f3..bc9802a8c44 100644 --- a/diyspk/tdu/Makefile +++ b/diyspk/tdu/Makefile @@ -2,7 +2,7 @@ SPK_NAME = tdu SPK_VERS = 1.36 SPK_REV = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/tdu UNSUPPORTED_ARCHS = $(PPC_ARCHS) diff --git a/diyspk/testdisk/Makefile b/diyspk/testdisk/Makefile index cd44a363103..13f2f997b25 100644 --- a/diyspk/testdisk/Makefile +++ b/diyspk/testdisk/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 7.1 SPK_REV = 4 SPK_ICON = src/testdisk.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/testdisk MAINTAINER = hgy59 DESCRIPTION = "TestDisk is powerful free data recovery software." diff --git a/mk/dependency-list.sh b/mk/dependency-list.sh new file mode 100755 index 00000000000..2d2e11f32b4 --- /dev/null +++ b/mk/dependency-list.sh @@ -0,0 +1,129 @@ +#!/bin/bash + +# Build dependency list +# +# list dependencies for all spk packages +# - used by github prepare action to evaluate packages to build, regarding the modified files +# - broken packages are excluded +# This script must be called in the top folder (spksrc) of the repository +# It is called by the dependency-list target of the toplevel Makefile +# +# This script has benefits over iterating all spk folders and call "make dependency-list" +# - it is much faster (typ. 15 s instead of 180 s) +# - it does not require "OPTIONAL_DEPENDS" defitions anymore +# caveats +# - makefile variables like $(SPK_NAME) are not allowed in dependency definitions anymore +# - definition of dependencies in included make files are not evaluated. +# Those are +# - native/cmake, native/cmake-legacy, native/nasm for cmake/rust packages (^1) +# - cross/$(PYTHON_PACKAGE) for packages reusing prebuilt python (^2) +# - cross/$(FFMPEG_PACKAGE) for packages reusing prebuilt ffmpeg (^2) +# ^1: We could introduce a new OPTIONAL_DEPENDS (ADDITIONAL_DEPENDS) variable to fix this +# But it will hardly happen, that nasm or cmake changes (and are deprecated since those are installed to dev environment) +# ^2: The missing dependencies with packages using prebuilt ffmpeg/python where not +# evaluated in the former solution too. +# So far we did not want to trigger the build of all related packages when only the prebuilt package had changes +# Otherwise we could introduce a new OPTIONAL_DEPENDS (ADDITIONAL_DEPENDS) variable for this + +# get SPK_NAME of a package +# since the spk name might be different to the (spk/){package} folder +# we need to parse the variable in the Makefile +# param1: package folder +function get_spk_name () +{ + if [ -f ${1}/Makefile ]; then + grep "^SPK_NAME" ${1}/Makefile | cut -d= -f2 | xargs + fi +} + +# evaluate python dependency in an spk Makefile +# param1: spk package folder (like spk/{name}) +function get_python_dependency () +{ + if [ -f ${1}/Makefile -a "$(grep ^include.*\/spksrc\.python\.mk ${1}/Makefile)" ]; then + local dep=$(grep "PYTHON_PACKAGE\s*=" ${1}/Makefile | cut -d= -f2 | xargs) + echo "cross/${dep} " + fi +} + +# evaluate ffmpeg dependency in an spk Makefile +# param1: spk package folder (like spk/{name}) +function get_ffmpeg_dependency () +{ + if [ -f ${1}/Makefile -a "$(grep ^include.*\/spksrc\.ffmpeg\.mk ${1}/Makefile)" ]; then + local dep=$(grep "FFMPEG_PACKAGE\s*=" ${1}/Makefile | cut -d= -f2 | xargs) + echo "cross/${dep} " + fi +} + + +# evaluates all dependencies in a single Makefile +# param1: folder (like spk/{name}, cross/{name}, native/{name}) +function get_file_dependencies () +{ + if [ -f ${1}/Makefile ]; then + if [ "$(dirname ${1})" = "spk" ]; then + get_python_dependency ${1} + get_ffmpeg_dependency ${1} + fi + grep "^DEPENDS\|^NATIVE_DEPENDS\|^BUILD_DEPENDS" ${1}/Makefile | cut -d= -f2 | sort -u | tr '\n' ' ' + fi +} + +# search for substring in a list of strings +# param1 list of space separated strings +# param2 substring +function contains () +{ + if [ -z "${1}" -o -z "${2}" ]; then + echo "false"; + else + if [ "$(echo ${1} | tr ' ' '\n' | grep -w ${2})" = "${2}" ]; then + echo "true" + else + echo "false" + fi + fi +} + +# get direct package dependencies +# param1: list of folders containing Makefile to parse +function get_dependencies () +{ + local dependencies= + for dep in "${1}"; do + dependencies+="${dep} " + dependencies+="$(get_file_dependencies ${dep}) " + done + echo ${dependencies} | tr ' ' '\n' | sort -u | tr '\n' ' ' +} + +# get all dependencies of a package +# param1: list of toplevel dependencies +function get_spk_dependencies () +{ + local dependencies=$(get_dependencies "${1}") + local cumulated_dependencies=$(get_dependencies "${dependencies}") + while [ "${cumulated_dependencies}" != "${dependencies}" ]; do + dependencies=${cumulated_dependencies} + cumulated_dependencies=$(get_dependencies "${dependencies}") + done + echo ${cumulated_dependencies} | tr ' ' '\n' | sort -u | tr '\n' ' ' +} + +# get the dependency list for a package +# param1: spk package folder (like spk/{name}) +function get_dependency_list () +{ + local spk_name=$(get_spk_name ${1}) + local toplevel_dependencies=$(get_file_dependencies ${1}) + local spk_dependencies=$(get_spk_dependencies "${toplevel_dependencies}") + echo "${spk_name}: ${spk_dependencies}" +} + +# iterate all packages +for package in $(find spk/ -maxdepth 1 -type d | cut -c 5- | sort); do + if [ ! -f spk/${package}/BROKEN ]; then + get_dependency_list spk/${package} + fi +done diff --git a/spk/adminer/Makefile b/spk/adminer/Makefile index 0a7a47626df..c9ea8f0ef65 100644 --- a/spk/adminer/Makefile +++ b/spk/adminer/Makefile @@ -4,7 +4,7 @@ SPK_REV = 5 SPK_ICON = src/adminer.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/adminer MAINTAINER = piwi82 DESCRIPTION = Adminer is a full-featured database management tool available for MySQL, PostgreSQL, SQLite, MS SQL, Oracle, Firebird, SimpleDB, Elasticsearch and MongoDB. diff --git a/spk/curaengine/Makefile b/spk/curaengine/Makefile index 3da365e3c20..1a3399ee8a5 100644 --- a/spk/curaengine/Makefile +++ b/spk/curaengine/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 2.1.3 SPK_REV = 2 SPK_ICON = src/curaengine.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/curaengine # c++11 compiler required UNSUPPORTED_ARCHS = $(OLD_PPC_ARCHS) $(ARMv5_ARCHS) diff --git a/spk/dante-sockd/Makefile b/spk/dante-sockd/Makefile index 2c01d00a551..edb622a145d 100644 --- a/spk/dante-sockd/Makefile +++ b/spk/dante-sockd/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 1.4.3 SPK_REV = 1 SPK_ICON = src/dante.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/dante-sockd MAINTAINER = Anonym-tsk # From Inferno Nettverk A/S diff --git a/spk/darkstat/Makefile b/spk/darkstat/Makefile index bd18201abb2..eee648ade73 100644 --- a/spk/darkstat/Makefile +++ b/spk/darkstat/Makefile @@ -4,7 +4,7 @@ SPK_REV = 5 SPK_ICON = src/darkstat.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/darkstat # DSM 7 does not allow to run package as root # error: pcap_open_live(): ovs_eth0: You don't have permission to capture on that device (socket: Operation not permitted) diff --git a/spk/dnscrypt-proxy/Makefile b/spk/dnscrypt-proxy/Makefile index 3de9b70a7ed..35e95694e2c 100644 --- a/spk/dnscrypt-proxy/Makefile +++ b/spk/dnscrypt-proxy/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 2.0.44 SPK_REV = 5 SPK_ICON = src/dnscrypt-proxy.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/dnscrypt-proxy SPK_CONFLICT = DNSServer UNSUPPORTED_ARCHS = $(PPC_ARCHS) diff --git a/spk/gateone/Makefile b/spk/gateone/Makefile index a93c412aade..49ba5292d4d 100644 --- a/spk/gateone/Makefile +++ b/spk/gateone/Makefile @@ -4,7 +4,7 @@ SPK_REV = 9 SPK_ICON = src/gateone.png DSM_UI_DIR = app -DEPENDS = cross/busybox cross/dtach cross/$(SPK_NAME) +DEPENDS = cross/busybox cross/dtach cross/gateone WHEELS = src/requirements.txt SPK_DEPENDS = "python>=2.7.11-15" diff --git a/spk/haproxy/Makefile b/spk/haproxy/Makefile index 69d31f8448b..da4d8105c48 100644 --- a/spk/haproxy/Makefile +++ b/spk/haproxy/Makefile @@ -5,7 +5,7 @@ SPK_ICON = src/haproxy.png DSM_UI_DIR = app DSM_APP_NAME = SYNOCOMMUNITY.HAProxy.AppInstance -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/haproxy WHEELS = src/requirements.txt SPK_DEPENDS = "python>2.7.18-25" diff --git a/spk/he853/Makefile b/spk/he853/Makefile index ca67c390653..d36dc121ae7 100755 --- a/spk/he853/Makefile +++ b/spk/he853/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 1.0.3 SPK_REV = 2 SPK_ICON = src/HE853.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/he853 REQUIRED_MIN_DSM = 5.0 MAINTAINER = ymartin59 diff --git a/spk/icecast/Makefile b/spk/icecast/Makefile index 80e6e1b5421..70965fadeb4 100644 --- a/spk/icecast/Makefile +++ b/spk/icecast/Makefile @@ -4,7 +4,7 @@ SPK_REV = 7 SPK_ICON = src/icecast.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/icecast MAINTAINER = SynoCommunity DESCRIPTION = Icecast is a streaming media server which currently supports Ogg \(Vorbis and Theora\), Opus, WebM and MP3 audio streams. It can be used to create an Internet radio station or a privately running jukebox and many things in between. It is very versatile in that new formats can be added relatively easily and supports open standards for communication and interaction. This package includes Ezstream, a command line source client for Icecast media streaming servers. diff --git a/spk/jappix/Makefile b/spk/jappix/Makefile index a69916c0697..1738321b7c9 100644 --- a/spk/jappix/Makefile +++ b/spk/jappix/Makefile @@ -4,7 +4,7 @@ SPK_REV = 2 SPK_ICON = src/jappix.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/jappix MAINTAINER = SynoCommunity DESCRIPTION = Jappix, a full-featured XMPP web-client \(Jappix Desktop, Jappix Mobile \& Jappix Mini\). Jappix is a fresh new open social platform which enables you to create your own cloud, wherever you want to. People must be able to get in touch with all their friends on a free decentralized network! diff --git a/spk/lirc/Makefile b/spk/lirc/Makefile index 8d808b399b2..c1aa2a84ce8 100644 --- a/spk/lirc/Makefile +++ b/spk/lirc/Makefile @@ -13,14 +13,14 @@ UNSUPPORTED_ARCHS = $(PPC_ARCHS) include ../../mk/spksrc.archs.mk # Use older LIRC build for ARCHs with kernel < 2.6.36 -ifneq ($(findstring $(ARCH),$(ARMv5_ARCHS) $(PPC_ARCHS)),) +ifeq ($(findstring $(ARCH),$(ARMv5_ARCHS) $(PPC_ARCHS)),$(ARCH)) SPK_VERS = 0.8.7 +DEPENDS = cross/lirc-0.8.7 LIRC_SUPPORTED_DRIVERS = mceusb uirt uirt2 +else +DEPENDS = cross/lirc-0.9.0 endif -DEPENDS = cross/$(SPK_NAME)-$(SPK_VERS) -OPTIONAL_DEPENDS = cross/lirc-0.8.7 - MAINTAINER = bru7us DESCRIPTION = LIRC daemon decodes infrared signals and provides them on a Unix domain socket DISPLAY_NAME = LIRC diff --git a/spk/mediainfo/Makefile b/spk/mediainfo/Makefile index 0a5174bafd1..3784180a5f8 100644 --- a/spk/mediainfo/Makefile +++ b/spk/mediainfo/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 21.09 SPK_REV = 13 SPK_ICON = src/mediainfo.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/mediainfo MAINTAINER = ymartin59 DESCRIPTION = "MediaInfo is a convenient unified display of the most relevant technical and tag data for video and audio files." diff --git a/spk/monitoring-plugins/Makefile b/spk/monitoring-plugins/Makefile index e5e423b6002..3d14a6c58d3 100644 --- a/spk/monitoring-plugins/Makefile +++ b/spk/monitoring-plugins/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 2.3.1 SPK_REV = 2 SPK_ICON = src/monitoring-plugins.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/monitoring-plugins SPK_DEPENDS = Perl diff --git a/spk/mtproxy/Makefile b/spk/mtproxy/Makefile index d4991954744..900d8a6c36e 100644 --- a/spk/mtproxy/Makefile +++ b/spk/mtproxy/Makefile @@ -6,7 +6,7 @@ SPK_ICON = src/${SPK_NAME}.jpg REQUIRED_MIN_DSM = 5.2 BETA = 1 -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/mtproxy MAINTAINER = Anonym-tsk # From TelegramMessenger/MTProxy diff --git a/spk/node-exporter/Makefile b/spk/node-exporter/Makefile index 0c741d07721..1cde18fe6ab 100644 --- a/spk/node-exporter/Makefile +++ b/spk/node-exporter/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 1.8.2 SPK_REV = 5 SPK_ICON = src/node-exporter.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/node-exporter UNSUPPORTED_ARCHS = $(PPC_ARCHS) diff --git a/spk/pyload/Makefile b/spk/pyload/Makefile index 6547c1f8a5e..672c3bb241c 100644 --- a/spk/pyload/Makefile +++ b/spk/pyload/Makefile @@ -4,7 +4,7 @@ SPK_REV = 4 SPK_ICON = src/pyload.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/pyload SPK_DEPENDS = "python>2.7.3-3" MAINTAINER = SynoCommunity diff --git a/spk/roundcube/Makefile b/spk/roundcube/Makefile index e51b741814b..187aeab67df 100644 --- a/spk/roundcube/Makefile +++ b/spk/roundcube/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 1.6.9 SPK_REV = 5 SPK_ICON = src/roundcube.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/roundcube # Pure PHP package, make sure ARCH is noarch override ARCH=noarch diff --git a/spk/shairport-sync/Makefile b/spk/shairport-sync/Makefile index 8c1c8b56460..ce599f89f74 100644 --- a/spk/shairport-sync/Makefile +++ b/spk/shairport-sync/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 2.3.11 SPK_REV = 2 SPK_ICON = src/shairport-sync.png -DEPENDS = cross/busybox cross/$(SPK_NAME) +DEPENDS = cross/busybox cross/shairport-sync MAINTAINER = SynoCommunity DESCRIPTION = Use Synology NAS as an AirPlay receiver. Requires USB soundcard or speakers. diff --git a/spk/stockfish/Makefile b/spk/stockfish/Makefile index 06b6027e0a6..c45fdd6a10f 100644 --- a/spk/stockfish/Makefile +++ b/spk/stockfish/Makefile @@ -4,7 +4,7 @@ SPK_REV = 3 SPK_ICON= src/stockfish.png DSM_UI_DIR = app -DEPENDS = cross/$(SPK_NAME) cross/stockfish-webgui +DEPENDS = cross/stockfish cross/stockfish-webgui MAINTAINER = mayweed DESCRIPTION = Strong open source chess engine. Stockfish is one of the strongest chess engines in the world. It is also much stronger than the best human chess grandmasters. diff --git a/spk/stunnel/Makefile b/spk/stunnel/Makefile index c328d5f95c9..ad02688b830 100644 --- a/spk/stunnel/Makefile +++ b/spk/stunnel/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 5.60 SPK_REV = 2 SPK_ICON = src/stunnel.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/stunnel BETA = 1 diff --git a/spk/tt-rss/Makefile b/spk/tt-rss/Makefile index be31d81ce2d..dacfa8cbba5 100644 --- a/spk/tt-rss/Makefile +++ b/spk/tt-rss/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 20230828 SPK_REV = 18 SPK_ICON = src/tt-rss.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/tt-rss # Pure PHP package, make sure ARCH is noarch override ARCH=noarch diff --git a/spk/umurmur/Makefile b/spk/umurmur/Makefile index 5ca2cfb77fe..93f699a7309 100644 --- a/spk/umurmur/Makefile +++ b/spk/umurmur/Makefile @@ -3,7 +3,7 @@ SPK_VERS = 0.2.20 SPK_REV = 8 SPK_ICON = src/umurmur.png -DEPENDS = cross/$(SPK_NAME) +DEPENDS = cross/umurmur MAINTAINER = Diaoul DESCRIPTION = uMurmur is a minimalistic VoIP server based on the open source software Mumble. It allows simultaneous communications between multiple users. Its low latency makes it especially suitable for communications during online gaming. The Mumble client is available at https://dl.mumble.info/stable/ \(Windows, Mac, Linux and iOS\). diff --git a/spk/zsh-static/Makefile b/spk/zsh-static/Makefile index f263fc8ed10..39aca77a8a0 100644 --- a/spk/zsh-static/Makefile +++ b/spk/zsh-static/Makefile @@ -4,6 +4,9 @@ SPK_REV = 10 export ZSH_STATIC_MODULES=true +# need to define dependencies for dependency-list creation by script +DEPENDS = cross/zsh + # Reuse targets from zsh. include ../zsh/Makefile