pkgsrc-Changes archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

CVS commit: pkgsrc/mk



Module Name:    pkgsrc
Committed By:   jlam
Date:           Thu Aug 10 05:41:07 UTC 2017

Modified Files:
        pkgsrc/mk/pkgformat/pkg/templates: header
        pkgsrc/mk/pkgtasks: bsd.pkgtasks.mk
        pkgsrc/mk/pkgtasks/tests: Kyuafile
Added Files:
        pkgsrc/mk/pkgtasks: icon_themes.mk
        pkgsrc/mk/pkgtasks/tests: icon_themes_test

Log Message:
mk/pkgtasks: Add infrastructure to use "icon_themes" package task.

Add definitions for the gtk-update-icon-cache(1) command to the
script header template, and a makefile fragment that creates the
data file for the "icon_themes" package task if ${ICON_THEMES} is
"yes" in the package Makefile.

Also bump pkgtasks dependency to version 1.12 for the "icon_themes"
package task and compatibility with pkgsrc/mk/pkginstall.


To generate a diff of this commit:
cvs rdiff -u -r1.4 -r1.5 pkgsrc/mk/pkgformat/pkg/templates/header
cvs rdiff -u -r1.4 -r1.5 pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk
cvs rdiff -u -r0 -r1.1 pkgsrc/mk/pkgtasks/icon_themes.mk
cvs rdiff -u -r1.1 -r1.2 pkgsrc/mk/pkgtasks/tests/Kyuafile
cvs rdiff -u -r0 -r1.1 pkgsrc/mk/pkgtasks/tests/icon_themes_test

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: pkgsrc/mk/pkgformat/pkg/templates/header
diff -u pkgsrc/mk/pkgformat/pkg/templates/header:1.4 pkgsrc/mk/pkgformat/pkg/templates/header:1.5
--- pkgsrc/mk/pkgformat/pkg/templates/header:1.4        Thu Aug 10 05:38:00 2017
+++ pkgsrc/mk/pkgformat/pkg/templates/header    Thu Aug 10 05:41:07 2017
@@ -29,7 +29,7 @@
 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 # POSSIBILITY OF SUCH DAMAGE.
 #
-# $NetBSD: header,v 1.4 2017/08/10 05:38:00 jlam Exp $
+# $NetBSD: header,v 1.5 2017/08/10 05:41:07 jlam Exp $
 
 # Package task loader.
 : ${TASK_MODULE_DIR:=@LOCALBASE@/share/pkgtasks-1}
@@ -67,6 +67,8 @@ CHMOD="@CHMOD@"
 CHOWN="@CHOWN@"
 CP="@CP@"
 DATE="@DATE@"
+GTK2_UPDATE_ICON_CACHE="@GTK2_UPDATE_ICON_CACHE@"
+GTK3_UPDATE_ICON_CACHE="@GTK2_UPDATE_ICON_CACHE@"
 FIND="@FIND@"
 ID="@ID@"
 INSTALL_INFO="@INSTALL_INFO@"

Index: pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk
diff -u pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk:1.4 pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk:1.5
--- pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk:1.4      Sun Jun  4 00:03:43 2017
+++ pkgsrc/mk/pkgtasks/bsd.pkgtasks.mk  Thu Aug 10 05:41:07 2017
@@ -1,4 +1,4 @@
-# $NetBSD: bsd.pkgtasks.mk,v 1.4 2017/06/04 00:03:43 jlam Exp $
+# $NetBSD: bsd.pkgtasks.mk,v 1.5 2017/08/10 05:41:07 jlam Exp $
 #
 # Copyright (c) 2017 The NetBSD Foundation, Inc.
 # All rights reserved.
@@ -134,6 +134,7 @@ USE_PKGTASKS=               no
 .include "${PKGSRCDIR}/mk/pkgtasks/directories.mk"
 .include "${PKGSRCDIR}/mk/pkgtasks/files.mk"
 .include "${PKGSRCDIR}/mk/pkgtasks/fonts.mk"
+.include "${PKGSRCDIR}/mk/pkgtasks/icon_themes.mk"
 .include "${PKGSRCDIR}/mk/pkgtasks/info_files.mk"
 .include "${PKGSRCDIR}/mk/pkgtasks/ocaml_findlib.mk"
 .include "${PKGSRCDIR}/mk/pkgtasks/permissions.mk"
@@ -142,7 +143,7 @@ USE_PKGTASKS=               no
 .include "${PKGSRCDIR}/mk/pkgtasks/usergroup.mk"
 
 # Add a dependency on pkgtasks if package tasks are needed.
-_PKGTASKS_DEPENDS=     pkgtasks-1>=1.10:../../pkgtools/pkgtasks
+_PKGTASKS_DEPENDS=     pkgtasks-1>=1.12:../../pkgtools/pkgtasks
 DEPENDS+=              ${"${USE_PKGTASKS:tl}" == "yes":?${_PKGTASKS_DEPENDS}:}
 TASK_MODULE_DIR?=      ${LOCALBASE}/share/pkgtasks-1
 

Index: pkgsrc/mk/pkgtasks/tests/Kyuafile
diff -u pkgsrc/mk/pkgtasks/tests/Kyuafile:1.1 pkgsrc/mk/pkgtasks/tests/Kyuafile:1.2
--- pkgsrc/mk/pkgtasks/tests/Kyuafile:1.1       Thu Jun  1 02:06:05 2017
+++ pkgsrc/mk/pkgtasks/tests/Kyuafile   Thu Aug 10 05:41:07 2017
@@ -1,4 +1,4 @@
--- $NetBSD: Kyuafile,v 1.1 2017/06/01 02:06:05 jlam Exp $
+-- $NetBSD: Kyuafile,v 1.2 2017/08/10 05:41:07 jlam Exp $
 --[[-----------------------------------------------------------------------
 Copyright (c) 2017 The NetBSD Foundation, Inc.
 All rights reserved.
@@ -52,6 +52,7 @@ atf_test_program { name = "directories_t
 atf_test_program { name = "files_test" }
 atf_test_program { name = "fonts_test" }
 atf_test_program { name = "groups_test" }
+atf_test_program { name = "icon_themes_test" }
 atf_test_program { name = "info_files_test" }
 atf_test_program { name = "ocaml_findlib_test" }
 atf_test_program { name = "permissions_test" }

Added files:

Index: pkgsrc/mk/pkgtasks/icon_themes.mk
diff -u /dev/null pkgsrc/mk/pkgtasks/icon_themes.mk:1.1
--- /dev/null   Thu Aug 10 05:41:07 2017
+++ pkgsrc/mk/pkgtasks/icon_themes.mk   Thu Aug 10 05:41:07 2017
@@ -0,0 +1,64 @@
+# $NetBSD: icon_themes.mk,v 1.1 2017/08/10 05:41:07 jlam Exp $
+#
+# Copyright (c) 2017 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# This code is derived from software contributed to The NetBSD Foundation
+# by Johnny C. Lam.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+# 1. Redistributions of source code must retain the above copyright
+#    notice, this list of conditions and the following disclaimer.
+# 2. Redistributions in binary form must reproduce the above copyright
+#    notice, this list of conditions and the following disclaimer in the
+#    documentation and/or other materials provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+
+# Generate the data file for the icon_themes package task.
+
+# ICON_THEMES
+#      Package-settable variable for whether to automatically update
+#      the GTK+ icon theme directory caches.
+#
+#      Possible: yes, no
+#      Default: yes
+#
+_PKG_VARS.pkgtasks+=   ICON_THEMES
+ICON_THEMES?=          no
+
+FILES_SUBST+=  GTK_UPDATE_ICON_CACHE=${LOCALBASE:Q}/bin/gtk-update-icon-cache
+FILES_SUBST+=  GTK2_UPDATE_ICON_CACHE=${LOCALBASE:Q}/bin/gtk2-update-icon-cache
+FILES_SUBST+=  GTK3_UPDATE_ICON_CACHE=${LOCALBASE:Q}/bin/gtk-update-icon-cache
+
+# Trigger pkgtasks dependency if needed.
+.if "${ICON_THEMES:tl}" == "yes"
+USE_PKGTASKS=          yes
+.endif
+
+_PKGTASKS_DATA.icon_themes=    ${_PKGTASKS_DIR}/icon_themes
+_PKGTASKS_DATAFILES+=          ${_PKGTASKS_DATA.icon_themes}
+
+# ${ICON_THEMES_cmd} is defined by the plist module.
+${_PKGTASKS_DATA.icon_themes}:
+       ${RUN}${MKDIR} ${.TARGET:H:Q}
+       ${RUN}exec > ${.TARGET:Q}.tmp
+       ${RUN}${TEST} "${ICON_THEMES:tl}" = "yes" || exit 0;            \
+       cmd=${ICON_THEMES_cmd:Q}"";                                     \
+       ${TEST} -n "$$cmd" || cmd=${TRUE:Q}"";                          \
+       eval $$cmd | while IFS= read themedir; do                       \
+               ${ECHO} "# ICON_THEME: $$themedir";                     \
+       done >> ${.TARGET:Q}.tmp
+       ${RUN}${MV} ${.TARGET:Q}.tmp ${.TARGET:Q}

Index: pkgsrc/mk/pkgtasks/tests/icon_themes_test
diff -u /dev/null pkgsrc/mk/pkgtasks/tests/icon_themes_test:1.1
--- /dev/null   Thu Aug 10 05:41:07 2017
+++ pkgsrc/mk/pkgtasks/tests/icon_themes_test   Thu Aug 10 05:41:07 2017
@@ -0,0 +1,103 @@
+#!/usr/bin/env atf-sh
+#
+# $NetBSD: icon_themes_test,v 1.1 2017/08/10 05:41:07 jlam Exp $
+#
+# Copyright (c) 2017 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# This code is derived from software contributed to The NetBSD Foundation
+# by Johnny C. Lam.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+# 1. Redistributions of source code must retain the above copyright
+#    notice, this list of conditions and the following disclaimer.
+# 2. Redistributions in binary form must reproduce the above copyright
+#    notice, this list of conditions and the following disclaimer in the
+#    documentation and/or other materials provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+
+# ENVIRONMENT
+#      The following variables are used if they are set:
+#
+#      MAKE    The name or path to the BSD make(1) utility.  The default
+#              is "make".
+#
+#      PKGSRCDIR
+#              The location of the pkgsrc source tree.  The default is
+#              "/usr/pkgsrc".
+#
+
+setup()
+{
+       cat > Makefile << 'EOF'
+.include "${PKGSRCDIR}/mk/pkgtasks/tests/test.mk"
+.sinclude "mk.conf"
+.include "${PKGSRCDIR}/mk/pkgtasks/icon_themes.mk"
+
+all: value
+value: ${_PKGTASKS_DATA.icon_themes}
+       ${RUN}${CP} ${.ALLSRC:Q} ${.TARGET:Q}
+EOF
+}
+
+###
+### test1
+###
+
+atf_test_case test1
+
+test1_head()
+{
+       atf_set "descr" "pkgsrc/mk/pkgtasks/icon_themes.mk"
+}
+
+test1_body()
+{
+       : ${MAKE:=make}
+       : ${PKGSRCDIR:=/usr/pkgsrc}
+
+       setup
+
+       cat > mk.conf << 'EOF'
+# Create mock ${ICON_THEMES_cmd}.
+ICON_THEMES=           yes
+ICON_THEMES_cmd=       ( echo "icon_theme1"; echo "icon_theme2" )
+EOF
+       # Expected output is each path stripped of leading "share/icons/"
+       # and inserted into the following template:
+       #
+       #    # ICON_THEMES: <themedir>
+       #
+       cat > expected << 'EOF'
+# ICON_THEME: icon_theme1
+# ICON_THEME: icon_theme2
+EOF
+       echo ">>> expected"
+       cat expected
+
+       ${MAKE} PKGSRCDIR="${PKGSRCDIR}" || atf_fail "make(1) failed"
+
+       echo ">>> value"
+       cat value
+
+       cmp expected value || atf_fail "expected differs from value"
+       atf_pass
+}
+
+atf_init_test_cases()
+{
+       atf_add_test_case test1
+}



Home | Main Index | Thread Index | Old Index