diff options
| author | Alex Merry <alex.merry@kde.org> | 2014-04-17 09:55:33 +0100 | 
|---|---|---|
| committer | Alex Merry <alex.merry@kde.org> | 2014-04-25 10:37:28 +0100 | 
| commit | 50b164a7ce83cdaec18209c7c2226d2fdb9cf29e (patch) | |
| tree | 4f18f6a10f00265f30ef3e2428648d8ad72de4a1 /modules | |
| parent | 23829defe0455cf57518ee29fee2988054ed51b7 (diff) | |
| download | extra-cmake-modules-50b164a7ce83cdaec18209c7c2226d2fdb9cf29e.tar.gz extra-cmake-modules-50b164a7ce83cdaec18209c7c2226d2fdb9cf29e.tar.bz2 | |
New syntax for ecm_install_icons()
This requires the icon files to be specified (which is better than
globbing, because the build system will then be able to tell when files
are added or removed and re-run CMake).
It also removes the theme name from the filename pattern: the old code
used a shorthand theme name for a small number of themes, and didn't
allow any other themes. Extending this to arbitrary themes could cause
problems with themes that have numbers or hyphens (or whatever other
delimiter character was used) in their names. Most users are likely to
just want to install to a single theme anyway (based on a random
sampling of users of kde4_install_icons), so that is what the new syntax
requires.
The old syntax still works and behaves as before.
ecm_update_iconcache is renamed to _ecm_update_iconcache - it was never
documented as public API anyway.
REVIEW: 117617
Diffstat (limited to 'modules')
| -rw-r--r-- | modules/ECMInstallIcons.cmake | 157 | 
1 files changed, 119 insertions, 38 deletions
| diff --git a/modules/ECMInstallIcons.cmake b/modules/ECMInstallIcons.cmake index d83003ba..4255d98b 100644 --- a/modules/ECMInstallIcons.cmake +++ b/modules/ECMInstallIcons.cmake @@ -7,18 +7,46 @@  #  # ::  # -#   ecm_install_icons(<icon_install_dir> [<l10n_code>]) +#   ecm_install_icons(ICONS <icon> [<icon> [...]] +#                     DESTINATION <icon_install_dir> +#                     [LANG <l10n_code>] +#                     [THEME <theme>]) +# +# The given icons, whose names must match the pattern:: +# +#   <size>-<group>-<name>.<ext> +# +# will be installed to the appropriate subdirectory of DESTINATION according to +# the FreeDesktop.org icon naming scheme. By default, they are installed to the +# "hicolor" theme, but this can be changed using the THEME argument.  If the +# icons are localized, the LANG argument can be used to install them in a +# locale-specific directory. +# +# ``<size>`` is a numeric pixel size (typically 16, 22, 32, 48, 64, 128 or 256) +# or ``sc`` for scalable (SVG) files, ``<group>`` is one of the standard +# FreeDesktop.org icon groups (actions, animations, apps, categories, devices, +# emblems, emotes, intl, mimetypes, places, status) and ``<ext>`` is one of +# ``.png``, ``.mng`` or ``.svgz``.  # -# Installs all icons found in ``CMAKE_CURRENT_SOURCE_DIR`` to the correct -# subdirectory of ``<icon_install_dir>``.  ``<icon_install_dir>`` should -# typically be something like ``share/icons``, although users of the -# :kde-module:`KDEInstallDirs` module would normally do +# The typical installation directory is ``share/icons``.  #  # .. code-block:: cmake  # -#   ecm_install_icons(${ICON_INSTALL_DIR}) +#   ecm_install_icons(ICONS 22-actions-menu_new.png +#                     DESTINATION share/icons) +# +# The above code will install the file ``22-actions-menu_new.png`` as +# ``${CMAKE_INSTALL_PREFIX}/share/icons/<theme>/22x22/actions/menu_new.png`` +# +# Users of the :kde-module:`KDEInstallDirs` module would normally use +# ``${ICON_INSTALL_DIR}`` as the DESTINATION, while users of the GNUInstallDirs +# module should use ``${CMAKE_INSTALL_DATAROOTDIR}/icons``.  # -# The icons must be named in the form:: +# An old form of arguments will also be accepted:: +# +#   ecm_install_icons(<icon_install_dir> [<l10n_code>]) +# +# This matches files named like::  #  #   <theme><size>-<group>-<name>.<ext>  # @@ -28,16 +56,11 @@  # * ``cr`` for the Crystal icon theme  # * ``ox`` for the Oxygen icon theme  # -# ``<size>`` is a numeric pixel size (typically 16, 22, 32, 48, 64, 128 or 256) -# or ``sc`` for scalable (SVG) files, ``<group>`` is one of the standard -# FreeDesktop.org icon groups (actions, animations, apps, categories, devices, -# emblems, emotes, intl, mimetypes, places, status) and ``<ext>`` is one of -# ``.png``, ``.mng`` or ``.svgz``. -# -# For example the file ``hi22-action-menu_new.png`` would be installed into -# ``<icon_install_dir>/hicolor/22x22/actions/menu_new.png`` +# With this syntax, the file ``hi22-actions-menu_new.png`` would be installed +# into ``<icon_install_dir>/hicolor/22x22/actions/menu_new.png``  #============================================================================= +# Copyright 2014 Alex Merry <alex.merry@kde.org>  # Copyright 2013 David Edmundson <kde@davidedmundson.co.uk>  # Copyright 2008 Chusslove Illich <caslav.ilic@gmx.net>  # Copyright 2006 Alex Neundorf <neundorf@kde.org> @@ -52,10 +75,10 @@  # (To distribute this file outside of extra-cmake-modules, substitute the full  #  License text for the above reference.) +include(CMakeParseArguments) -# a "map" of short type names to the directories -# unknown names should give empty results -# xdg icon naming specification compatibility +# A "map" of short type names to the directories. +# Unknown names produce a warning.  set(_ECM_ICON_GROUP_mimetypes  "mimetypes")  set(_ECM_ICON_GROUP_places     "places")  set(_ECM_ICON_GROUP_devices    "devices") @@ -68,16 +91,14 @@ set(_ECM_ICON_GROUP_emotes     "emotes")  set(_ECM_ICON_GROUP_animations "animations")  set(_ECM_ICON_GROUP_intl       "intl") -# FIXME: this is too KDE-specific; we should keep this map for compatibility, -#        but get users to specify the full theme name -# a "map" of short theme names to the theme directory +# For the "compatibility" syntax: a "map" of short theme names to the theme +# directory  set(_ECM_ICON_THEME_ox "oxygen")  set(_ECM_ICON_THEME_cr "crystalsvg")  set(_ECM_ICON_THEME_lo "locolor")  set(_ECM_ICON_THEME_hi "hicolor") -macro (ECM_INSTALL_ICONS _defaultpath ) - +macro(_ecm_install_icons_v1 _defaultpath)     # the l10n-subdir if language given as second argument (localized icon)     set(_lang ${ARGV1})     if(_lang) @@ -96,7 +117,6 @@ macro (ECM_INSTALL_ICONS _defaultpath )        set(_group "${CMAKE_MATCH_3}")        set(_name  "${CMAKE_MATCH_4}") -      # FIXME: don't use map        set(_theme_GROUP ${_ECM_ICON_THEME_${_type}})        if( _theme_GROUP)           _ECM_ADD_ICON_INSTALL_RULE(${CMAKE_CURRENT_BINARY_DIR}/install_icons.cmake @@ -140,35 +160,96 @@ macro (ECM_INSTALL_ICONS _defaultpath )        endif( _theme_GROUP)     endforeach (_current_ICON) -   ecm_update_iconcache() +   _ecm_update_iconcache("${_defaultpath}" hicolor) -endmacro (ECM_INSTALL_ICONS) +endmacro() -# only used internally by ECM_INSTALL_ICONS -macro (_ECM_ADD_ICON_INSTALL_RULE _install_SCRIPT _install_PATH _group _orig_NAME _install_NAME _l10n_SUBDIR) +# only used internally by _ecm_install_icons_v1 +macro(_ecm_add_icon_install_rule _install_SCRIPT _install_PATH _group _orig_NAME _install_NAME _l10n_SUBDIR)     # if the string doesn't match the pattern, the result is the full string, so all three have the same content     if (NOT ${_group} STREQUAL ${_install_NAME} )        set(_icon_GROUP  ${_ECM_ICON_GROUP_${_group}})        if(NOT _icon_GROUP) -         # FIXME: print warning if not in map (and not "actions")           set(_icon_GROUP "actions")        endif(NOT _icon_GROUP)  #      message(STATUS "icon: ${_current_ICON} size: ${_size} group: ${_group} name: ${_name} l10n: ${_l10n_SUBDIR}")        install(FILES ${_orig_NAME} DESTINATION ${_install_PATH}/${_icon_GROUP}/${_l10n_SUBDIR}/ RENAME ${_install_NAME} )     endif (NOT ${_group} STREQUAL ${_install_NAME} ) -endmacro (_ECM_ADD_ICON_INSTALL_RULE) +endmacro() -macro (ECM_UPDATE_ICONCACHE) -    # Update mtime of hicolor icon theme dir. -    # We don't always have touch command (e.g. on Windows), so instead create -    #  and delete a temporary file in the theme dir. -   install(CODE " +# Updates the mtime of the icon theme directory, so caches that +# watch for changes to the directory will know to update. +function(_ecm_update_iconcache installdir theme) +    # We don't always have touch command (e.g. on Windows), so instead +    # create and delete a temporary file in the theme dir. +    install(CODE "      set(DESTDIR_VALUE \"\$ENV{DESTDIR}\")      if (NOT DESTDIR_VALUE) -        file(WRITE \"${ICON_INSTALL_DIR}/hicolor/temp.txt\" \"update\") -        file(REMOVE \"${ICON_INSTALL_DIR}/hicolor/temp.txt\") +        file(WRITE \"${installdir}/${theme}/temp.txt\" \"update\") +        file(REMOVE \"${installdir}/${theme}/temp.txt\")      endif (NOT DESTDIR_VALUE)      ") -endmacro (ECM_UPDATE_ICONCACHE) +endfunction() + +function(ecm_install_icons) +    set(options) +    set(oneValueArgs DESTINATION LANG THEME) +    set(multiValueArgs ICONS) +    cmake_parse_arguments(ARG "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN}) + +    if(NOT ARG_ICONS AND NOT ARG_DESTINATION) +        message(AUTHOR_WARNING "ecm_install_icons() with no ICONS argument is deprecated") +        _ecm_install_icons_v1(${ARGN}) +        return() +    endif() +    if(ARG_UNPARSED_ARGUMENTS) +        message(FATAL_ERROR "Unexpected arguments to ecm_install_icons: ${ARG_UNPARSED_ARGUMENTS}") +    endif() +    if(NOT ARG_DESTINATION) +        message(FATAL_ERROR "No DESTINATION argument given to ecm_install_icons") +    endif() +    if(NOT ARG_THEME) +        set(ARG_THEME "hicolor") +    endif() +    if(ARG_LANG) +        set(l10n_subdir "l10n/${ARG_LANG}/") +    endif() + +    foreach(icon ${ARG_ICONS}) +        string(REGEX MATCH "([0-9sc]+)\\-([a-z]+)\\-([^/]+)\\.([a-z]+)$" +                           _dummy "${icon}") +        set(size  "${CMAKE_MATCH_1}") +        set(group "${CMAKE_MATCH_2}") +        set(name  "${CMAKE_MATCH_3}") +        set(ext   "${CMAKE_MATCH_4}") +        if(NOT size OR NOT group OR NOT name OR NOT ext) +            message(WARNING "${icon} is not named correctly for ecm_install_icons - ignoring") +        elseif(NOT size STREQUAL "sc" AND NOT size GREATER 0) +            message(WARNING "${icon} size (${size}) is invalid - ignoring") +        else() +            if(NOT _ECM_ICON_GROUP_${group}) +                message(WARNING "${icon} group (${group}) is not recognized") +            endif() +            if(size STREQUAL "sc") +                if(NOT ext STREQUAL "svg" AND NOT ext STREQUAL "svgz") +                    message(WARNING "Scalable icon ${icon} is not SVG or SVGZ") +                endif() +                set(size_dir "scalable") +            else() +                if(NOT ext STREQUAL "png" AND NOT ext STREQUAL "mng") +                    message(WARNING "Fixed-size icon ${icon} is not PNG or MNG") +                endif() +                set(size_dir "${size}x${size}") +            endif() +            install( +                FILES "${icon}" +                DESTINATION "${ARG_DESTINATION}/${ARG_THEME}/${size_dir}/${group}/${l10n_subdir}" +                RENAME "${name}.${ext}" +            ) +        endif() +    endforeach() +    _ecm_update_iconcache("${ARG_DESTINATION}" "${ARG_THEME}") +endfunction() + | 
