summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWouter Deconinck <wdconinc@gmail.com>2024-10-02 08:48:04 -0500
committerGitHub <noreply@github.com>2024-10-02 15:48:04 +0200
commitb1707c2e3c07130d892951a3c92ec57327848dab (patch)
tree0f3f76aa4887e7644204636e8c926f2bb4af9858
parent0093dd74e365502b5595bd5d286829ae480f09ce (diff)
downloadspack-b1707c2e3c07130d892951a3c92ec57327848dab.tar.gz
spack-b1707c2e3c07130d892951a3c92ec57327848dab.tar.bz2
spack-b1707c2e3c07130d892951a3c92ec57327848dab.tar.xz
spack-b1707c2e3c07130d892951a3c92ec57327848dab.zip
dbus: fix url; add v1.14.10, v1.15.10 (meson); fix CVEs (#46625)
-rw-r--r--var/spack/repos/builtin/packages/dbus/package.py53
1 files changed, 41 insertions, 12 deletions
diff --git a/var/spack/repos/builtin/packages/dbus/package.py b/var/spack/repos/builtin/packages/dbus/package.py
index 7c59223d99..4b54a5fce8 100644
--- a/var/spack/repos/builtin/packages/dbus/package.py
+++ b/var/spack/repos/builtin/packages/dbus/package.py
@@ -6,7 +6,7 @@
from spack.package import *
-class Dbus(AutotoolsPackage):
+class Dbus(AutotoolsPackage, MesonPackage):
"""D-Bus is a message bus system, a simple way for applications to
talk to one another. D-Bus supplies both a system daemon (for
events such new hardware device printer queue ) and a
@@ -17,10 +17,24 @@ class Dbus(AutotoolsPackage):
through the message bus daemon)."""
homepage = "https://dbus.freedesktop.org/"
- url = "https://dbus.freedesktop.org/releases/dbus/dbus-1.8.8.tar.gz"
+ url = "https://dbus.freedesktop.org/releases/dbus/dbus-1.14.10.tar.xz"
+ git = "https://gitlab.freedesktop.org/dbus/dbus"
- license("AFL-2.1 OR GPL-2.0-or-later")
+ license("AFL-2.1 OR GPL-2.0-or-later", checked_by="wdconinc")
+ build_system(
+ conditional("autotools", when="@:1.15.8"),
+ conditional("meson", when="@1.15:"),
+ default="meson",
+ )
+
+ # Note: odd minor versions are unstable, keep last stable version preferred
+ version("1.15.10", sha256="f700f2f1d0473f11e52f3f3e179f577f31b85419f9ae1972af8c3db0bcfde178")
+ version(
+ "1.14.10",
+ sha256="ba1f21d2bd9d339da2d4aa8780c09df32fea87998b73da24f49ab9df1e36a50f",
+ preferred=True,
+ )
version("1.13.6", sha256="b533693232d36d608a09f70c15440c1816319bac3055433300d88019166c1ae4")
version("1.12.8", sha256="e2dc99e7338303393b6663a98320aba6a63421bcdaaf571c8022f815e5896eb3")
version("1.11.2", sha256="5abc4c57686fa82669ad0039830788f9b03fdc4fff487f0ccf6c9d56ba2645c9")
@@ -30,12 +44,11 @@ class Dbus(AutotoolsPackage):
version("1.8.4", sha256="3ef63dc8d0111042071ee7f7bafa0650c6ce2d7be957ef0b7ec269495a651ff8")
version("1.8.2", sha256="5689f7411165adc953f37974e276a3028db94447c76e8dd92efe910c6d3bae08")
- depends_on("c", type="build") # generated
- depends_on("cxx", type="build") # generated
-
variant("xml_docs", default=False, description="Build XML documentation")
variant("system-socket", default="default", description="Location for the DBus system socket")
+ depends_on("c", type="build")
+ depends_on("cxx", type="build", when="platform=windows")
depends_on("pkgconfig", type="build")
depends_on("docbook-xml", type="build")
depends_on("docbook-xsl", type="build")
@@ -44,16 +57,32 @@ class Dbus(AutotoolsPackage):
depends_on("libsm")
depends_on("xmlto", when="+xml_docs", type="build")
+ def url_for_version(self, version):
+ ext = "gz" if version < Version("1.15") else "xz"
+ return f"https://dbus.freedesktop.org/releases/dbus/dbus-{version}.tar.{ext}"
+
+ @run_after("install")
+ def generate_uuid(self):
+ # dbus needs a machine id generated after install
+ dbus_uuidgen = Executable(self.prefix.bin.join("dbus-uuidgen"))
+ dbus_uuidgen("--ensure")
+
+
+class AutotoolsBuilder(spack.build_systems.autotools.AutotoolsBuilder):
def configure_args(self):
- args = ["--disable-systemd", "--disable-launchd"]
+ args = ["--disable-systemd", "--disable-launchd", "--disable-qt-help"]
args += self.enable_or_disable("xml-docs", variant="xml_docs")
socket = self.spec.variants["system-socket"].value
if socket != "default":
args += ["--with-system-socket={0}".format(socket)]
return args
- @run_after("install")
- def generate_uuid(self):
- # dbus needs a machine id generated after install
- dbus_uuidgen = Executable(self.prefix.bin.join("dbus-uuidgen"))
- dbus_uuidgen("--ensure")
+
+class MesonBuilder(spack.build_systems.meson.MesonBuilder):
+ def meson_args(self):
+ args = ["-Dsystemd=disabled", "-Dlaunchd=disabled", "-Dqt_help=disabled"]
+ args += [f"-Dxml_docs={'enabled' if self.spec.satisfies('+xml_docs') else 'disabled'}"]
+ socket = self.spec.variants["system-socket"].value
+ if socket != "default":
+ args += [f"-Dsystem_socket={socket}"]
+ return args