From: "Gilles Dartiguelongue" <eva@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:gnome-xdg-eclasses commit in: eclass/
Date: Tue, 24 Nov 2015 18:50:07 +0000 (UTC) [thread overview]
Message-ID: <1448390977.0913bfc8d9650ad4eb542ec9a1a30736013224f2.eva@gentoo> (raw)
commit: 0913bfc8d9650ad4eb542ec9a1a30736013224f2
Author: Gilles Dartiguelongue <eva <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 24 17:42:27 2015 +0000
Commit: Gilles Dartiguelongue <eva <AT> gentoo <DOT> org>
CommitDate: Tue Nov 24 18:49:37 2015 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0913bfc8
xdg*.eclass: move phase related logic to xdg.eclass
eclass/xdg-utils.eclass | 32 --------------------------------
eclass/xdg.eclass | 34 +++++++++++++++++++++++++++-------
2 files changed, 27 insertions(+), 39 deletions(-)
diff --git a/eclass/xdg-utils.eclass b/eclass/xdg-utils.eclass
index d140283..3dc9e8e 100644
--- a/eclass/xdg-utils.eclass
+++ b/eclass/xdg-utils.eclass
@@ -62,17 +62,6 @@ xdg_environment_reset() {
unset DBUS_SESSION_BUS_ADDRESS
}
-# @FUNCTION: xdg_desktopfiles_savelist
-# @DESCRIPTION:
-# Find the .desktop files about to be installed and save their location
-# in the XDG_ECLASS_DESKTOPFILES environment variable.
-# This function should be called from pkg_preinst.
-xdg_desktopfiles_savelist() {
- pushd "${D}" > /dev/null || die
- export XDG_ECLASS_DESKTOPFILES=$(find 'usr/share/applications' -type f 2> /dev/null)
- popd > /dev/null || die
-}
-
# @FUNCTION: fdo-xdg_desktop_database_update
# @DESCRIPTION:
# Updates the .desktop files database.
@@ -85,27 +74,11 @@ xdg_desktop_database_update() {
return
fi
- if [[ -z "${XDG_ECLASS_DESKTOPFILES}" ]]; then
- debug-print "No .desktop files to add to database"
- return
- fi
-
ebegin "Updating .desktop files database ..."
"${updater}" -q "${EROOT}${DESKTOP_DATABASE_DIR}"
eend $?
}
-# @FUNCTION: xdg_mimeinfo_savelist
-# @DESCRIPTION:
-# Find the mime information files about to be installed and save their location
-# in the XDG_ECLASS_MIMEINFOFILES environment variable.
-# This function should be called from pkg_preinst.
-xdg_mimeinfo_savelist() {
- pushd "${D}" > /dev/null || die
- export XDG_ECLASS_MIMEINFOFILES=$(find 'usr/share/mime' -type f 2> /dev/null)
- popd > /dev/null || die
-}
-
# @FUNCTION: xdg_mimeinfo_database_update
# @DESCRIPTION:
# Update the mime database.
@@ -118,11 +91,6 @@ xdg_mimeinfo_database_update() {
return
fi
- if [[ -z "${XDG_ECLASS_MIMEINFOFILES}" ]]; then
- debug-print "No mime info files to add to database"
- return
- fi
-
ebegin "Updating shared mime info database ..."
"${updater}" "${EROOT}${MIMEINFO_DATABASE_DIR}"
eend $?
diff --git a/eclass/xdg.eclass b/eclass/xdg.eclass
index 799d6a2..1813858 100644
--- a/eclass/xdg.eclass
+++ b/eclass/xdg.eclass
@@ -37,25 +37,45 @@ xdg_src_prepare() {
# @FUNCTION: xdg_pkg_preinst
# @DESCRIPTION:
-# Finds .desktop and mime info files for later handling in pkg_postinst
+# Finds .desktop and mime info files for later handling in pkg_postinst.
+# Locations are stored in XDG_ECLASS_DESKTOPFILES and XDG_ECLASS_MIMEINFOFILES
+# respectively.
xdg_pkg_preinst() {
- xdg_desktopfiles_savelist
- xdg_mimeinfo_savelist
+ export XDG_ECLASS_DESKTOPFILES=( $(cd "${D}" && find 'usr/share/applications' -type f -print0 2> /dev/null) )
+ export XDG_ECLASS_MIMEINFOFILES=( $(cd "${D}" && find 'usr/share/mime' -type f -print0 2> /dev/null) )
}
# @FUNCTION: xdg_pkg_postinst
# @DESCRIPTION:
# Handle desktop and mime info database updates.
xdg_pkg_postinst() {
- xdg_desktop_database_update
- xdg_mimeinfo_database_update
+ if [[ -n "${XDG_ECLASS_DESKTOPFILES}" ]]; then
+ xdg_desktop_database_update
+ else
+ debug-print "No .desktop files to add to database"
+ fi
+
+ if [[ -n "${XDG_ECLASS_MIMEINFOFILES}" ]]; then
+ xdg_mimeinfo_database_update
+ else
+ debug-print "No mime info files to add to database"
+ fi
}
# @FUNCTION: xdg_pkg_postrm
# @DESCRIPTION:
# Handle desktop and mime info database updates.
xdg_pkg_postrm() {
- xdg_desktop_database_update
- xdg_mimeinfo_database_update
+ if [[ -n "${XDG_ECLASS_DESKTOPFILES}" ]]; then
+ xdg_desktop_database_update
+ else
+ debug-print "No .desktop files to add to database"
+ fi
+
+ if [[ -n "${XDG_ECLASS_MIMEINFOFILES}" ]]; then
+ xdg_mimeinfo_database_update
+ else
+ debug-print "No mime info files to add to database"
+ fi
}
next reply other threads:[~2015-11-24 18:50 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-11-24 18:50 Gilles Dartiguelongue [this message]
-- strict thread matches above, loose matches on Subject: below --
2015-11-24 19:08 [gentoo-commits] repo/gentoo:gnome-xdg-eclasses commit in: eclass/ Gilles Dartiguelongue
2015-11-24 18:50 Gilles Dartiguelongue
2015-11-24 18:50 Gilles Dartiguelongue
2015-11-24 18:50 Gilles Dartiguelongue
2015-11-24 18:50 Gilles Dartiguelongue
2015-11-24 18:50 Gilles Dartiguelongue
2015-11-23 14:38 Gilles Dartiguelongue
2015-11-23 14:38 Gilles Dartiguelongue
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1448390977.0913bfc8d9650ad4eb542ec9a1a30736013224f2.eva@gentoo \
--to=eva@gentoo.org \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox