commit:     fbb4c3e23a636402c56c0158d715328d64f1d172
Author:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  2 20:20:10 2021 +0000
Commit:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
CommitDate: Sat Jan  2 20:24:39 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fbb4c3e2

sys-apps/smartmontools: Bump to version 7.2

- Renamed "update_drivedb" USE flag to "update-drivedb" (#695108)
- Enabled "update-drivedb" USE flag by default (#684160)
- USE="static" fails with USE="systemd" - exclude each other (#683328)

Bug: https://bugs.gentoo.org/695108
Closes: https://bugs.gentoo.org/684160
Closes: https://bugs.gentoo.org/683328
Package-Manager: Portage-3.0.12, Repoman-3.0.2
Signed-off-by: Lars Wendler <polynomial-c <AT> gentoo.org>

 sys-apps/smartmontools/Manifest                 |   1 +
 sys-apps/smartmontools/metadata.xml             |   1 +
 sys-apps/smartmontools/smartmontools-7.2.ebuild | 151 ++++++++++++++++++++++++
 3 files changed, 153 insertions(+)

diff --git a/sys-apps/smartmontools/Manifest b/sys-apps/smartmontools/Manifest
index cba124633a6..5bf7834d177 100644
--- a/sys-apps/smartmontools/Manifest
+++ b/sys-apps/smartmontools/Manifest
@@ -1 +1,2 @@
 DIST smartmontools-7.1.tar.gz 971468 BLAKE2B 
de3e1b10997903cb9bf6107f1bd1be9587b66af08a94e368dc9ed3aa6d69ba93d6b41d1ba60076275603702d9d0b47b26e376d3c9f020eb18fde5af4b686485b
 SHA512 
440b2a957da10d240a8ef0008bd3358b83adb9eaca0f8d3e049b25d56a139c61dcd0bb4b27898faef6f189a27e159bdca3331e52e445c0eebf35e5d930f9e295
+DIST smartmontools-7.2.tar.gz 992256 BLAKE2B 
9f671656e610404b0ab8b6ec51421b4046c64d16331cff821a8d9dbf34dd6c4be4fa63d3a2eaffe2aa869b09acf5f18b9c9750f76e33423710ef9166212e3a92
 SHA512 
d7e724295b5d53797b5e4136eea5f5cc278db81e4016ba65142438b8c68c54f85a32c582c147a1590b9bc8f74a58952bcb57b9923dd69d34582530a0985799ea

diff --git a/sys-apps/smartmontools/metadata.xml 
b/sys-apps/smartmontools/metadata.xml
index cb72f5108e4..9ac33efa0d5 100644
--- a/sys-apps/smartmontools/metadata.xml
+++ b/sys-apps/smartmontools/metadata.xml
@@ -9,6 +9,7 @@
        <flag name="caps">Build against <pkg>sys-libs/libcap-ng</pkg> to allow 
smartd to drop its privileges.</flag>
        <flag name="daemon">Install the monitoring daemon (smartd) and 
associated scripts.</flag>
        <flag name="update_drivedb">Install a script to update the drivedb 
file.</flag>
+       <flag name="update-drivedb">Install a script to update the drivedb 
file.</flag>
 </use>
 <upstream>
        <remote-id type="sourceforge">smartmontools</remote-id>

diff --git a/sys-apps/smartmontools/smartmontools-7.2.ebuild 
b/sys-apps/smartmontools/smartmontools-7.2.ebuild
new file mode 100644
index 00000000000..bcbd184c16d
--- /dev/null
+++ b/sys-apps/smartmontools/smartmontools-7.2.ebuild
@@ -0,0 +1,151 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="6"
+
+inherit autotools flag-o-matic systemd
+if [[ ${PV} == "9999" ]] ; then
+       
ESVN_REPO_URI="https://svn.code.sf.net/p/smartmontools/code/trunk/smartmontools";
+       ESVN_PROJECT="smartmontools"
+       inherit subversion
+else
+       SRC_URI="mirror://sourceforge/${PN}/${P}.tar.gz"
+       KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 
~sparc ~x86 ~amd64-linux ~x86-linux ~x64-macos"
+fi
+
+DESCRIPTION="Tools to monitor storage systems to provide advanced warning of 
disk degradation"
+HOMEPAGE="https://www.smartmontools.org";
+
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="caps +daemon selinux static systemd +update-drivedb"
+
+DEPEND="
+       caps? (
+               static? ( sys-libs/libcap-ng[static-libs] )
+               !static? ( sys-libs/libcap-ng )
+       )
+       selinux? (
+               sys-libs/libselinux
+       )"
+RDEPEND="${DEPEND}
+       daemon? ( virtual/mailx )
+       selinux? ( sec-policy/selinux-smartmon )
+       systemd? ( sys-apps/systemd )
+       update-drivedb? (
+               app-crypt/gnupg
+               || (
+                       net-misc/curl
+                       net-misc/wget
+                       www-client/lynx
+                       dev-vcs/subversion
+               )
+       )
+"
+
+REQUIRED_USE="(
+       caps? ( daemon )
+       static? ( !systemd )
+)"
+
+src_prepare() {
+       default
+       eautoreconf
+}
+
+src_configure() {
+       use static && append-ldflags -static
+       # The build installs /etc/init.d/smartd, but we clobber it
+       # in our src_install, so no need to manually delete it.
+       myeconfargs=(
+               --with-drivedbdir="${EPREFIX}/var/db/${PN}" #575292
+               --with-initscriptdir="${EPREFIX}/etc/init.d"
+               #--with-smartdscriptdir="${EPREFIX}/usr/share/${PN}"
+               $(use_with caps libcap-ng)
+               $(use_with selinux)
+               $(use_with systemd libsystemd)
+               $(use_with update-drivedb gnupg)
+               $(use_with update-drivedb update-smart-drivedb)
+               $(usex systemd 
"--with-systemdsystemunitdir=$(systemd_get_systemunitdir)" '')
+       )
+       econf "${myeconfargs[@]}"
+}
+
+src_install() {
+       local db_path="/var/db/${PN}"
+       insopts -m0644 -p # preserve timestamps
+
+       if use daemon; then
+               default
+
+               newinitd "${FILESDIR}"/smartd-r1.rc smartd
+               newconfd "${FILESDIR}"/smartd.confd smartd
+       else
+               dosbin smartctl
+               doman smartctl.8
+
+               local DOCS=( AUTHORS ChangeL* COPYING INSTALL NEWS README TODO )
+               einstalldocs
+       fi
+
+       if use update-drivedb ; then
+               if ! use daemon; then
+                       dosbin "${S}"/update-smart-drivedb
+               fi
+
+               exeinto /etc/cron.monthly
+               doexe "${FILESDIR}/${PN}-update-drivedb"
+       fi
+
+       if use daemon || use update-drivedb; then
+               keepdir "${db_path}"
+
+               # Install a copy of the initial drivedb.h to /usr/share/${PN}
+               # so that we can access that file later in pkg_postinst
+               # even when dealing with binary packages (bug #575292)
+               insinto /usr/share/${PN}
+               doins "${S}"/drivedb.h
+       fi
+
+       # Make sure we never install drivedb.h into the db location
+       # of the acutal image so we don't record hashes because user
+       # can modify that file
+       rm -f "${ED%/}${db_path}/drivedb.h" || die
+
+       # Bug #622072
+       find "${ED%/}"/usr/share/doc -type f -exec chmod a-x '{}' \; || die
+}
+
+pkg_postinst() {
+       if use daemon || use update-drivedb; then
+               local initial_db_file="${EROOT}/usr/share/${PN}/drivedb.h"
+               local db_path="${EROOT}/var/db/${PN}"
+
+               if [[ ! -f "${db_path}/drivedb.h" ]] ; then
+                       # No initial database found
+                       cp "${initial_db_file}" "${db_path}" || die
+                       einfo "Default drive database which was shipped with 
this release of ${PN}"
+                       einfo "has been installed to '${db_path}'."
+               else
+                       ewarn "WARNING: There's already a drive database in 
'${db_path}'!"
+                       ewarn "Because we cannot determine if this database is 
untouched"
+                       ewarn "or was modified by the user you have to manually 
update the"
+                       ewarn "drive database:"
+                       ewarn ""
+                       ewarn "a) Replace '${db_path}/drivedb.h' by the 
database shipped with this"
+                       ewarn "   release which can be found in 
'${initial_db_file}', i.e."
+                       ewarn ""
+                       ewarn "     cp \"${initial_db_file}\" \"${db_path}\""
+                       ewarn ""
+                       ewarn "b) Run the following command as root:"
+                       ewarn ""
+                       ewarn "     /usr/sbin/update-smart-drivedb"
+
+                       if ! use update-drivedb ; then
+                               ewarn ""
+                               ewarn "However, 'update-smart-drivedb' requires 
that you re-emerge ${PN}"
+                               ewarn "with USE='update-drivedb'."
+                       fi
+               fi
+       fi
+}

Reply via email to