Hi all,

I've been wanting to make some changes to this eclass for a while since I've
been putting on some bandages to make things work.  This is a rather major
overhaul.  Basically packaging upstream got a lot more regulated since obz and
I wrote the original eclass [1], so we can simplify many things.  This results
in trivial ebuilds, ease of maintaining, quicker installs, and (I think) a
better user interface.

Anyways, a diff would be useless so I've attached the proposed eclass [2].

My plan for updating the tree is as follows:
 1) Wait until at least 25 January 2010, discussing on the gentoo-dev ml
 2) As long as there are no pending items for review, I will test with all
current x11-plugins/desklet-* ebuilds, diffing the "old" and "new" directories
 3) Commit the new eclass
 4) Tweak the x11-plugins/desklet-* ebuilds to remove unneeded variables

Please let me know what you think.

Thanks,
Joe

--
[1]
http://sources.gentoo.org/viewcvs.py/gentoo-x86/eclass/gdesklets.eclass?view=markup
[2] http://dev.gentoo.org/~nixphoeni/gdesklets/eclass/gdesklets-20091101.eclass
# Copyright 2004-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License, v2 or later
# $Header: $

# @ECLASS: gdesklets.eclass
# @MAINTAINER:
# gdeskl...@gentoo.org
# @BLURB: Installation functions for Desklets and Controls supported
# by gDesklets
# @DESCRIPTION:
# The gdesklets eclass provides a simple way to create ebuilds for
# globally installing desktop applets ("Desklets") and supporting code
# ("Controls") used in the gDesklets framework (provided by
# gnome-extra/gdesklets-core)
#
# This eclass assumes a package following the instructions at
# http://gdesklets.de/index.php?q=node/2 .  Specifically, the package
# should be a Desklet or Control ONLY (and *not* a Sensor).  You
# technically could have an ebuild that works around this limitation,
# but no new packages should be added to the tree that do this (mainly
# for ease of maintenance).
#
# Original authors:     Joe Sapp <nixpho...@gentoo.org>
#                       Mike Gardiner <o...@gentoo.org>

# @ECLASS_VARIABLE: DESKLET_NAME
# @DESCRIPTION:
# *Optional*  The name of the Desklet, if the package is one. The
# default is to assume a Desklet with the name being ${PN} without the
# "desklet-" prefix.

# @ECLASS_VARIABLE: CONTROL_NAME
# @DESCRIPTION:
# *Optional*  The name of the Control, if the package is one.

# @ECLASS_VARIABLE: DOCS
# @DESCRIPTION:
# Anything (like a README) that should be dodoc'd.

# @ECLASS_VARIABLE: SLOT
# @DESCRIPTION:
# Set only if the package is a Control and it provides a different
# interface (i.e. expands to a different install directory) than a
# previous version.

inherit eutils multilib python

if [[ -n "${CONTROL_NAME}" ]]; then
        debug-print "Looking for a Control named \"${CONTROL_NAME}\""
        MY_PN="${CONTROL_NAME}"
        
SRC_URI="http://gdesklets.de/files/controls/${MY_PN}/${MY_PN}-${PV}.tar.gz";
        unset DESKLET_NAME
else # [[ -n "${DESKLET_NAME}" ]]; then
        # Assume an unset DESKLET_NAME means the name is ${PN} without
        # the "desklet-" prefix
        [[ -z "${DESKLET_NAME}" ]] && DESKLET_NAME="${PN#desklet-}"
        debug-print "Looking for a Desklet named \"${DESKLET_NAME}\""
        MY_PN="${DESKLET_NAME}"
        
SRC_URI="http://gdesklets.de/files/desklets/${MY_PN}/${MY_PN}-${PV}.tar.gz";
fi

MY_P="${MY_PN}-${PV}"
S="${WORKDIR}/${MY_PN}"

SLOT="0"
# Ebuild writer shouldn't need to touch these (except maybe RDEPEND)
IUSE=""
RDEPEND=">=gnome-extra/gdesklets-core-0.36.1-r3"

GDESKLETS_INST_DIR="${ROOT:-/}usr/$(get_libdir)/gdesklets"

# @FUNCTION: gdesklets_src_install
# @DESCRIPTION:
# Installs a Desklet or Control depending on which is set of
# CONTROL_NAME or DESKLET_NAME
gdesklets_src_install() {

        debug-print-function $FUNCNAME $*

        # Disable compilation of included python modules (for Controls)
        python_disable_pyc

        # Avoid sandbox violations caused by misbehaving packages (bug #128289)
        addwrite "${ROOT}/root/.gnome2"

        # Both Displays and Controls only need to be readable
        insopts -m0744

        # Check to see if DISPLAY is set for the
        # gdesklets-control-getid script to run without error
        [ -z "${DISPLAY}" ] && DISPLAY=""
        export DISPLAY

        debug-print-section docs_install

        # Install some docs if so requested (and then delete them so they
        # don't get copied into the installation directory)
        [[ -n "${DOCS}" ]] && dodoc ${DOCS} && \
                rm -f ${DOCS} \
                debug-print "Installed and deleted ${DOCS}"
        # LICENSE doesn't need to get installed if it exists
        find . -name LICENSE -delete

        if [[ -n "${DESKLET_NAME}" ]]; then

                debug-print-section display_install

                # Base installation directory for displays from this desklet
                INSDIR="${GDESKLETS_INST_DIR}/Displays/${DESKLET_NAME}"

                debug-print "Installing into ${INSDIR}"
                debug-print "Exiting Display-specific installation code"

        elif [[ -n "${CONTROL_NAME}" ]]; then

                debug-print-section control_install

                # Unique name for this Control and its interface
                CTRL_DIRNAME=$( "${GDESKLETS_INST_DIR}/gdesklets-control-getid" 
`pwd` )
                einfo "Installing Control ${CTRL_DIRNAME}"

                # Base installation directory for this Control
                INSDIR="${GDESKLETS_INST_DIR}/Controls/${CTRL_DIRNAME}"
                debug-print "Installing into ${INSDIR}"

                # Mercilessly delete all existing compiled code
                find . -iname '*.py[co]' -delete

                debug-print "Exiting Control-specific installation code"

        else
                die "nothing to install, is the ebuild written correctly?"
        fi

        debug-print-section common_install

        # Create the proper subdirectory in the global Controls or
        # Displays directory
        dodir "${INSDIR}"
        insinto "${INSDIR}"
        doins -r *

}

# @FUNCTION: gdesklets_pkg_postinst
# @DESCRIPTION:
# Marks the Control for rebuilding on Python version change and
# compiles the Python code or display a useful message to the user,
# depending on which of CONTROL_NAME or DESKLET_NAME is set.
gdesklets_pkg_postinst() {

        # The only time compilation of python modules should occur is
        # for Controls, since Displays are run from inside the sandbox
        # (and therefore can't be compiled).
        if [[ -n "${CONTROL_NAME}" ]]; then

                CTRL_DIRNAME=$( "${GDESKLETS_INST_DIR}/gdesklets-control-getid" 
`pwd` )
                python_need_rebuild
                python_mod_optimize 
"${GDESKLETS_INST_DIR}/Controls/${CTRL_DIRNAME}"

        else

                einfo "Each user can now add this desklet to their desktop 
through the"
                einfo "gDesklets shell or the command line (.display files can 
be"
                einfo "found in 
${GDESKLETS_INST_DIR}/Displays/${DESKLET_NAME})."

        fi

}

EXPORT_FUNCTIONS src_install pkg_postinst

Attachment: signature.asc
Description: OpenPGP digital signature

Reply via email to