/usr/lib/xbmc/xbmc-addon-helpers.cmake is in xbmc-bin 2:13.2+dfsg1-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 | # Workaround for the fact that cpack's filenames are not customizable.
# Each add-on is added as a separate component to facilitate zip/tgz packaging.
# The filenames are always of the form basename-component, which is
# incompatible with the addonid-version scheme we want. This hack renames
# the files from the file names generated by the 'package' target.
# Sadly we cannot extend the 'package' target, as it is a builtin target, see
# http://public.kitware.com/Bug/view.php?id=8438
# Thus, we have to add an 'addon-package' target.
add_custom_target(addon-package
COMMAND cmake --build ${CMAKE_BINARY_DIR} --target package)
macro(add_cpack_workaround target version ext)
add_custom_command(TARGET addon-package PRE_BUILD
COMMAND cmake -E rename addon-${target}-${version}.${ext} ${target}-${version}.${ext})
endmacro()
# Grab the version from a given add-on's addon.xml
macro (addon_version dir prefix)
FILE(READ ${dir}/addon.xml ADDONXML)
STRING(REGEX MATCH "<addon[^>]*version.?=.?.[0-9\\.]+" VERSION_STRING ${ADDONXML})
STRING(REGEX REPLACE ".*version=.([0-9\\.]+).*" "\\1" ${prefix}_VERSION ${VERSION_STRING})
message(STATUS ${prefix}_VERSION=${${prefix}_VERSION})
endmacro()
# Build, link and optionally package an add-on
macro (build_addon target prefix libs)
ADD_LIBRARY(${target} ${${prefix}_SOURCES})
TARGET_LINK_LIBRARIES(${target} ${${libs}})
addon_version(${target} ${prefix})
SET_TARGET_PROPERTIES(${target} PROPERTIES VERSION ${${prefix}_VERSION}
SOVERSION 13.0
PREFIX "")
IF(OS STREQUAL "android")
SET_TARGET_PROPERTIES(${target} PROPERTIES PREFIX "lib")
ENDIF(OS STREQUAL "android")
# set zip as default if addon-package is called without PACKAGE_XXX
SET(CPACK_GENERATOR "ZIP")
SET(ext "zip")
IF(PACKAGE_ZIP OR PACKAGE_TGZ)
IF(PACKAGE_TGZ)
SET(CPACK_GENERATOR "TGZ")
SET(ext "tar.gz")
ENDIF(PACKAGE_TGZ)
SET(CPACK_INCLUDE_TOPLEVEL_DIRECTORY OFF)
set(CPACK_PACKAGE_FILE_NAME addon)
IF(CMAKE_BUILD_TYPE STREQUAL "Release")
SET(CPACK_STRIP_FILES TRUE)
ENDIF(CMAKE_BUILD_TYPE STREQUAL "Release")
set(CPACK_ARCHIVE_COMPONENT_INSTALL ON)
set(CPACK_COMPONENTS_IGNORE_GROUPS 1)
list(APPEND CPACK_COMPONENTS_ALL ${target}-${${prefix}_VERSION})
# Pack files together to create an archive
INSTALL(DIRECTORY ${target} DESTINATION ./ COMPONENT ${target}-${${prefix}_VERSION})
IF(WIN32)
INSTALL(PROGRAMS ${CMAKE_BINARY_DIR}/${target}.dll
DESTINATION ${target}
COMPONENT ${target}-${${prefix}_VERSION})
ELSE(WIN32)
INSTALL(TARGETS ${target} DESTINATION ${target}
COMPONENT ${target}-${${prefix}_VERSION})
ENDIF(WIN32)
add_cpack_workaround(${target} ${${prefix}_VERSION} ${ext})
ELSE(PACKAGE_ZIP OR PACKAGE_TGZ)
INSTALL(TARGETS ${target} DESTINATION lib/xbmc/addons/${target})
INSTALL(DIRECTORY ${target} DESTINATION share/xbmc/addons)
ENDIF(PACKAGE_ZIP OR PACKAGE_TGZ)
endmacro()
# finds a path to a given file (recursive)
function (xbmc_find_path var_name filename search_path strip_file)
file(GLOB_RECURSE PATH_TO_FILE ${search_path} ${filename})
if(strip_file)
string(REPLACE ${filename} "" PATH_TO_FILE ${PATH_TO_FILE})
endif(strip_file)
set (${var_name} ${PATH_TO_FILE} PARENT_SCOPE)
endfunction()
# Cmake build options
include(AddOptions)
include(TestCXXAcceptsFlag)
OPTION(PACKAGE_ZIP "Package Zip file?" OFF)
OPTION(PACKAGE_TGZ "Package TGZ file?" OFF)
# LTO support?
CHECK_CXX_ACCEPTS_FLAG("-flto" HAVE_LTO)
IF(HAVE_LTO)
OPTION(USE_LTO "use link time optimization" OFF)
IF(USE_LTO)
add_options(ALL_LANGUAGES ALL_BUILDS "-flto")
ENDIF(USE_LTO)
ENDIF(HAVE_LTO)
|