diff options
Diffstat (limited to 'tools/gr-usrptest/cmake')
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/CMakeParseArgumentsCopy.cmake | 138 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/FindCppUnit.cmake | 39 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/FindGnuradioRuntime.cmake | 36 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/GrMiscUtils.cmake | 528 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/GrPlatform.cmake | 54 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/GrPython.cmake | 241 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/GrSwig.cmake | 251 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/GrTest.cmake | 143 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/UseSWIG.cmake | 304 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/Modules/usrptestConfig.cmake | 30 | ||||
| -rw-r--r-- | tools/gr-usrptest/cmake/cmake_uninstall.cmake.in | 32 | 
11 files changed, 1796 insertions, 0 deletions
| diff --git a/tools/gr-usrptest/cmake/Modules/CMakeParseArgumentsCopy.cmake b/tools/gr-usrptest/cmake/Modules/CMakeParseArgumentsCopy.cmake new file mode 100644 index 000000000..7ce4c49ae --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/CMakeParseArgumentsCopy.cmake @@ -0,0 +1,138 @@ +# CMAKE_PARSE_ARGUMENTS(<prefix> <options> <one_value_keywords> <multi_value_keywords> args...) +# +# CMAKE_PARSE_ARGUMENTS() is intended to be used in macros or functions for +# parsing the arguments given to that macro or function. +# It processes the arguments and defines a set of variables which hold the +# values of the respective options. +# +# The <options> argument contains all options for the respective macro, +# i.e. keywords which can be used when calling the macro without any value +# following, like e.g. the OPTIONAL keyword of the install() command. +# +# The <one_value_keywords> argument contains all keywords for this macro +# which are followed by one value, like e.g. DESTINATION keyword of the +# install() command. +# +# The <multi_value_keywords> argument contains all keywords for this macro +# which can be followed by more than one value, like e.g. the TARGETS or +# FILES keywords of the install() command. +# +# When done, CMAKE_PARSE_ARGUMENTS() will have defined for each of the +# keywords listed in <options>, <one_value_keywords> and +# <multi_value_keywords> a variable composed of the given <prefix> +# followed by "_" and the name of the respective keyword. +# These variables will then hold the respective value from the argument list. +# For the <options> keywords this will be TRUE or FALSE. +# +# All remaining arguments are collected in a variable +# <prefix>_UNPARSED_ARGUMENTS, this can be checked afterwards to see whether +# your macro was called with unrecognized parameters. +# +# As an example here a my_install() macro, which takes similar arguments as the +# real install() command: +# +#   function(MY_INSTALL) +#     set(options OPTIONAL FAST) +#     set(oneValueArgs DESTINATION RENAME) +#     set(multiValueArgs TARGETS CONFIGURATIONS) +#     cmake_parse_arguments(MY_INSTALL "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} ) +#     ... +# +# Assume my_install() has been called like this: +#   my_install(TARGETS foo bar DESTINATION bin OPTIONAL blub) +# +# After the cmake_parse_arguments() call the macro will have set the following +# variables: +#   MY_INSTALL_OPTIONAL = TRUE +#   MY_INSTALL_FAST = FALSE (this option was not used when calling my_install() +#   MY_INSTALL_DESTINATION = "bin" +#   MY_INSTALL_RENAME = "" (was not used) +#   MY_INSTALL_TARGETS = "foo;bar" +#   MY_INSTALL_CONFIGURATIONS = "" (was not used) +#   MY_INSTALL_UNPARSED_ARGUMENTS = "blub" (no value expected after "OPTIONAL" +# +# You can the continue and process these variables. +# +# Keywords terminate lists of values, e.g. if directly after a one_value_keyword +# another recognized keyword follows, this is interpreted as the beginning of +# the new option. +# E.g. my_install(TARGETS foo DESTINATION OPTIONAL) would result in +# MY_INSTALL_DESTINATION set to "OPTIONAL", but MY_INSTALL_DESTINATION would +# be empty and MY_INSTALL_OPTIONAL would be set to TRUE therefor. + +#============================================================================= +# Copyright 2010 Alexander Neundorf <neundorf@kde.org> +# +# Distributed under the OSI-approved BSD License (the "License"); +# see accompanying file Copyright.txt for details. +# +# This software is distributed WITHOUT ANY WARRANTY; without even the +# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# See the License for more information. +#============================================================================= +# (To distribute this file outside of CMake, substitute the full +#  License text for the above reference.) + + +if(__CMAKE_PARSE_ARGUMENTS_INCLUDED) +  return() +endif() +set(__CMAKE_PARSE_ARGUMENTS_INCLUDED TRUE) + + +function(CMAKE_PARSE_ARGUMENTS prefix _optionNames _singleArgNames _multiArgNames) +  # first set all result variables to empty/FALSE +  foreach(arg_name ${_singleArgNames} ${_multiArgNames}) +    set(${prefix}_${arg_name}) +  endforeach(arg_name) + +  foreach(option ${_optionNames}) +    set(${prefix}_${option} FALSE) +  endforeach(option) + +  set(${prefix}_UNPARSED_ARGUMENTS) + +  set(insideValues FALSE) +  set(currentArgName) + +  # now iterate over all arguments and fill the result variables +  foreach(currentArg ${ARGN}) +    list(FIND _optionNames "${currentArg}" optionIndex)  # ... then this marks the end of the arguments belonging to this keyword +    list(FIND _singleArgNames "${currentArg}" singleArgIndex)  # ... then this marks the end of the arguments belonging to this keyword +    list(FIND _multiArgNames "${currentArg}" multiArgIndex)  # ... then this marks the end of the arguments belonging to this keyword + +    if(${optionIndex} EQUAL -1  AND  ${singleArgIndex} EQUAL -1  AND  ${multiArgIndex} EQUAL -1) +      if(insideValues) +        if("${insideValues}" STREQUAL "SINGLE") +          set(${prefix}_${currentArgName} ${currentArg}) +          set(insideValues FALSE) +        elseif("${insideValues}" STREQUAL "MULTI") +          list(APPEND ${prefix}_${currentArgName} ${currentArg}) +        endif() +      else(insideValues) +        list(APPEND ${prefix}_UNPARSED_ARGUMENTS ${currentArg}) +      endif(insideValues) +    else() +      if(NOT ${optionIndex} EQUAL -1) +        set(${prefix}_${currentArg} TRUE) +        set(insideValues FALSE) +      elseif(NOT ${singleArgIndex} EQUAL -1) +        set(currentArgName ${currentArg}) +        set(${prefix}_${currentArgName}) +        set(insideValues "SINGLE") +      elseif(NOT ${multiArgIndex} EQUAL -1) +        set(currentArgName ${currentArg}) +        set(${prefix}_${currentArgName}) +        set(insideValues "MULTI") +      endif() +    endif() + +  endforeach(currentArg) + +  # propagate the result variables to the caller: +  foreach(arg_name ${_singleArgNames} ${_multiArgNames} ${_optionNames}) +    set(${prefix}_${arg_name}  ${${prefix}_${arg_name}} PARENT_SCOPE) +  endforeach(arg_name) +  set(${prefix}_UNPARSED_ARGUMENTS ${${prefix}_UNPARSED_ARGUMENTS} PARENT_SCOPE) + +endfunction(CMAKE_PARSE_ARGUMENTS _options _singleArgs _multiArgs) diff --git a/tools/gr-usrptest/cmake/Modules/FindCppUnit.cmake b/tools/gr-usrptest/cmake/Modules/FindCppUnit.cmake new file mode 100644 index 000000000..f93ade341 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/FindCppUnit.cmake @@ -0,0 +1,39 @@ +# http://www.cmake.org/pipermail/cmake/2006-October/011446.html +# Modified to use pkg config and use standard var names + +# +# Find the CppUnit includes and library +# +# This module defines +# CPPUNIT_INCLUDE_DIR, where to find tiff.h, etc. +# CPPUNIT_LIBRARIES, the libraries to link against to use CppUnit. +# CPPUNIT_FOUND, If false, do not try to use CppUnit. + +INCLUDE(FindPkgConfig) +PKG_CHECK_MODULES(PC_CPPUNIT "cppunit") + +FIND_PATH(CPPUNIT_INCLUDE_DIRS +    NAMES cppunit/TestCase.h +    HINTS ${PC_CPPUNIT_INCLUDE_DIR} +    ${CMAKE_INSTALL_PREFIX}/include +    PATHS +    /usr/local/include +    /usr/include +) + +FIND_LIBRARY(CPPUNIT_LIBRARIES +    NAMES cppunit +    HINTS ${PC_CPPUNIT_LIBDIR} +    ${CMAKE_INSTALL_PREFIX}/lib +    ${CMAKE_INSTALL_PREFIX}/lib64 +    PATHS +    ${CPPUNIT_INCLUDE_DIRS}/../lib +    /usr/local/lib +    /usr/lib +) + +LIST(APPEND CPPUNIT_LIBRARIES ${CMAKE_DL_LIBS}) + +INCLUDE(FindPackageHandleStandardArgs) +FIND_PACKAGE_HANDLE_STANDARD_ARGS(CPPUNIT DEFAULT_MSG CPPUNIT_LIBRARIES CPPUNIT_INCLUDE_DIRS) +MARK_AS_ADVANCED(CPPUNIT_LIBRARIES CPPUNIT_INCLUDE_DIRS) diff --git a/tools/gr-usrptest/cmake/Modules/FindGnuradioRuntime.cmake b/tools/gr-usrptest/cmake/Modules/FindGnuradioRuntime.cmake new file mode 100644 index 000000000..afed684a5 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/FindGnuradioRuntime.cmake @@ -0,0 +1,36 @@ +INCLUDE(FindPkgConfig) +PKG_CHECK_MODULES(PC_GNURADIO_RUNTIME gnuradio-runtime) + +if(PC_GNURADIO_RUNTIME_FOUND) +  # look for include files +  FIND_PATH( +    GNURADIO_RUNTIME_INCLUDE_DIRS +    NAMES gnuradio/top_block.h +    HINTS $ENV{GNURADIO_RUNTIME_DIR}/include +          ${PC_GNURADIO_RUNTIME_INCLUDE_DIRS} +          ${CMAKE_INSTALL_PREFIX}/include +    PATHS /usr/local/include +          /usr/include +    ) + +  # look for libs +  FIND_LIBRARY( +    GNURADIO_RUNTIME_LIBRARIES +    NAMES gnuradio-runtime +    HINTS $ENV{GNURADIO_RUNTIME_DIR}/lib +          ${PC_GNURADIO_RUNTIME_LIBDIR} +          ${CMAKE_INSTALL_PREFIX}/lib/ +          ${CMAKE_INSTALL_PREFIX}/lib64/ +    PATHS /usr/local/lib +          /usr/local/lib64 +          /usr/lib +          /usr/lib64 +    ) + +  set(GNURADIO_RUNTIME_FOUND ${PC_GNURADIO_RUNTIME_FOUND}) +endif(PC_GNURADIO_RUNTIME_FOUND) + +INCLUDE(FindPackageHandleStandardArgs) +# do not check GNURADIO_RUNTIME_INCLUDE_DIRS, is not set when default include path us used. +FIND_PACKAGE_HANDLE_STANDARD_ARGS(GNURADIO_RUNTIME DEFAULT_MSG GNURADIO_RUNTIME_LIBRARIES) +MARK_AS_ADVANCED(GNURADIO_RUNTIME_LIBRARIES GNURADIO_RUNTIME_INCLUDE_DIRS) diff --git a/tools/gr-usrptest/cmake/Modules/GrMiscUtils.cmake b/tools/gr-usrptest/cmake/Modules/GrMiscUtils.cmake new file mode 100644 index 000000000..5bad57c51 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/GrMiscUtils.cmake @@ -0,0 +1,528 @@ +# Copyright 2010-2011,2014 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING.  If not, write to +# the Free Software Foundation, Inc., 51 Franklin Street, +# Boston, MA 02110-1301, USA. + +if(DEFINED __INCLUDED_GR_MISC_UTILS_CMAKE) +    return() +endif() +set(__INCLUDED_GR_MISC_UTILS_CMAKE TRUE) + +######################################################################## +# Set global variable macro. +# Used for subdirectories to export settings. +# Example: include and library paths. +######################################################################## +function(GR_SET_GLOBAL var) +    set(${var} ${ARGN} CACHE INTERNAL "" FORCE) +endfunction(GR_SET_GLOBAL) + +######################################################################## +# Set the pre-processor definition if the condition is true. +#  - def the pre-processor definition to set and condition name +######################################################################## +function(GR_ADD_COND_DEF def) +    if(${def}) +        add_definitions(-D${def}) +    endif(${def}) +endfunction(GR_ADD_COND_DEF) + +######################################################################## +# Check for a header and conditionally set a compile define. +#  - hdr the relative path to the header file +#  - def the pre-processor definition to set +######################################################################## +function(GR_CHECK_HDR_N_DEF hdr def) +    include(CheckIncludeFileCXX) +    CHECK_INCLUDE_FILE_CXX(${hdr} ${def}) +    GR_ADD_COND_DEF(${def}) +endfunction(GR_CHECK_HDR_N_DEF) + +######################################################################## +# Include subdirectory macro. +# Sets the CMake directory variables, +# includes the subdirectory CMakeLists.txt, +# resets the CMake directory variables. +# +# This macro includes subdirectories rather than adding them +# so that the subdirectory can affect variables in the level above. +# This provides a work-around for the lack of convenience libraries. +# This way a subdirectory can append to the list of library sources. +######################################################################## +macro(GR_INCLUDE_SUBDIRECTORY subdir) +    #insert the current directories on the front of the list +    list(INSERT _cmake_source_dirs 0 ${CMAKE_CURRENT_SOURCE_DIR}) +    list(INSERT _cmake_binary_dirs 0 ${CMAKE_CURRENT_BINARY_DIR}) + +    #set the current directories to the names of the subdirs +    set(CMAKE_CURRENT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/${subdir}) +    set(CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/${subdir}) + +    #include the subdirectory CMakeLists to run it +    file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}) +    include(${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt) + +    #reset the value of the current directories +    list(GET _cmake_source_dirs 0 CMAKE_CURRENT_SOURCE_DIR) +    list(GET _cmake_binary_dirs 0 CMAKE_CURRENT_BINARY_DIR) + +    #pop the subdir names of the front of the list +    list(REMOVE_AT _cmake_source_dirs 0) +    list(REMOVE_AT _cmake_binary_dirs 0) +endmacro(GR_INCLUDE_SUBDIRECTORY) + +######################################################################## +# Check if a compiler flag works and conditionally set a compile define. +#  - flag the compiler flag to check for +#  - have the variable to set with result +######################################################################## +macro(GR_ADD_CXX_COMPILER_FLAG_IF_AVAILABLE flag have) +    include(CheckCXXCompilerFlag) +    CHECK_CXX_COMPILER_FLAG(${flag} ${have}) +    if(${have}) +      if(${CMAKE_VERSION} VERSION_GREATER "2.8.4") +        STRING(FIND "${CMAKE_CXX_FLAGS}" "${flag}" flag_dup) +        if(${flag_dup} EQUAL -1) +          set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${flag}") +          set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${flag}") +        endif(${flag_dup} EQUAL -1) +      endif(${CMAKE_VERSION} VERSION_GREATER "2.8.4") +    endif(${have}) +endmacro(GR_ADD_CXX_COMPILER_FLAG_IF_AVAILABLE) + +######################################################################## +# Generates the .la libtool file +# This appears to generate libtool files that cannot be used by auto*. +# Usage GR_LIBTOOL(TARGET [target] DESTINATION [dest]) +# Notice: there is not COMPONENT option, these will not get distributed. +######################################################################## +function(GR_LIBTOOL) +    if(NOT DEFINED GENERATE_LIBTOOL) +        set(GENERATE_LIBTOOL OFF) #disabled by default +    endif() + +    if(GENERATE_LIBTOOL) +        include(CMakeParseArgumentsCopy) +        CMAKE_PARSE_ARGUMENTS(GR_LIBTOOL "" "TARGET;DESTINATION" "" ${ARGN}) + +        find_program(LIBTOOL libtool) +        if(LIBTOOL) +            include(CMakeMacroLibtoolFile) +            CREATE_LIBTOOL_FILE(${GR_LIBTOOL_TARGET} /${GR_LIBTOOL_DESTINATION}) +        endif(LIBTOOL) +    endif(GENERATE_LIBTOOL) + +endfunction(GR_LIBTOOL) + +######################################################################## +# Do standard things to the library target +# - set target properties +# - make install rules +# Also handle gnuradio custom naming conventions w/ extras mode. +######################################################################## +function(GR_LIBRARY_FOO target) +    #parse the arguments for component names +    include(CMakeParseArgumentsCopy) +    CMAKE_PARSE_ARGUMENTS(GR_LIBRARY "" "RUNTIME_COMPONENT;DEVEL_COMPONENT" "" ${ARGN}) + +    #set additional target properties +    set_target_properties(${target} PROPERTIES SOVERSION ${LIBVER}) + +    #install the generated files like so... +    install(TARGETS ${target} +        LIBRARY DESTINATION ${GR_LIBRARY_DIR} COMPONENT ${GR_LIBRARY_RUNTIME_COMPONENT} # .so/.dylib file +        ARCHIVE DESTINATION ${GR_LIBRARY_DIR} COMPONENT ${GR_LIBRARY_DEVEL_COMPONENT}   # .lib file +        RUNTIME DESTINATION ${GR_RUNTIME_DIR} COMPONENT ${GR_LIBRARY_RUNTIME_COMPONENT} # .dll file +    ) + +    #extras mode enabled automatically on linux +    if(NOT DEFINED LIBRARY_EXTRAS) +        set(LIBRARY_EXTRAS ${LINUX}) +    endif() + +    #special extras mode to enable alternative naming conventions +    if(LIBRARY_EXTRAS) + +        #create .la file before changing props +        GR_LIBTOOL(TARGET ${target} DESTINATION ${GR_LIBRARY_DIR}) + +        #give the library a special name with ultra-zero soversion +        set_target_properties(${target} PROPERTIES OUTPUT_NAME ${target}-${LIBVER} SOVERSION "0.0.0") +        set(target_name lib${target}-${LIBVER}.so.0.0.0) + +        #custom command to generate symlinks +        add_custom_command( +            TARGET ${target} +            POST_BUILD +            COMMAND ${CMAKE_COMMAND} -E create_symlink ${target_name} ${CMAKE_CURRENT_BINARY_DIR}/lib${target}.so +            COMMAND ${CMAKE_COMMAND} -E create_symlink ${target_name} ${CMAKE_CURRENT_BINARY_DIR}/lib${target}-${LIBVER}.so.0 +            COMMAND ${CMAKE_COMMAND} -E touch ${target_name} #so the symlinks point to something valid so cmake 2.6 will install +        ) + +        #and install the extra symlinks +        install( +            FILES +            ${CMAKE_CURRENT_BINARY_DIR}/lib${target}.so +            ${CMAKE_CURRENT_BINARY_DIR}/lib${target}-${LIBVER}.so.0 +            DESTINATION ${GR_LIBRARY_DIR} COMPONENT ${GR_LIBRARY_RUNTIME_COMPONENT} +        ) + +    endif(LIBRARY_EXTRAS) +endfunction(GR_LIBRARY_FOO) + +######################################################################## +# Create a dummy custom command that depends on other targets. +# Usage: +#   GR_GEN_TARGET_DEPS(unique_name target_deps <target1> <target2> ...) +#   ADD_CUSTOM_COMMAND(<the usual args> ${target_deps}) +# +# Custom command cant depend on targets, but can depend on executables, +# and executables can depend on targets. So this is the process: +######################################################################## +function(GR_GEN_TARGET_DEPS name var) +    file( +        WRITE ${CMAKE_CURRENT_BINARY_DIR}/${name}.cpp.in +        "int main(void){return 0;}\n" +    ) +    execute_process( +        COMMAND ${CMAKE_COMMAND} -E copy_if_different +        ${CMAKE_CURRENT_BINARY_DIR}/${name}.cpp.in +        ${CMAKE_CURRENT_BINARY_DIR}/${name}.cpp +    ) +    add_executable(${name} ${CMAKE_CURRENT_BINARY_DIR}/${name}.cpp) +    if(ARGN) +        add_dependencies(${name} ${ARGN}) +    endif(ARGN) + +    if(CMAKE_CROSSCOMPILING) +        set(${var} "DEPENDS;${name}" PARENT_SCOPE) #cant call command when cross +    else() +        set(${var} "DEPENDS;${name};COMMAND;${name}" PARENT_SCOPE) +    endif() +endfunction(GR_GEN_TARGET_DEPS) + +######################################################################## +# Control use of gr_logger +# Usage: +#   GR_LOGGING() +# +# Will set ENABLE_GR_LOG to 1 by default. +# Can manually set with -DENABLE_GR_LOG=0|1 +######################################################################## +function(GR_LOGGING) +  find_package(Log4cpp) + +  OPTION(ENABLE_GR_LOG "Use gr_logger" ON) +  if(ENABLE_GR_LOG) +    # If gr_logger is enabled, make it usable +    add_definitions( -DENABLE_GR_LOG ) + +    # also test LOG4CPP; if we have it, use this version of the logger +    # otherwise, default to the stdout/stderr model. +    if(LOG4CPP_FOUND) +      SET(HAVE_LOG4CPP True CACHE INTERNAL "" FORCE) +      add_definitions( -DHAVE_LOG4CPP ) +    else(not LOG4CPP_FOUND) +      SET(HAVE_LOG4CPP False CACHE INTERNAL "" FORCE) +      SET(LOG4CPP_INCLUDE_DIRS "" CACHE INTERNAL "" FORCE) +      SET(LOG4CPP_LIBRARY_DIRS "" CACHE INTERNAL "" FORCE) +      SET(LOG4CPP_LIBRARIES "" CACHE INTERNAL "" FORCE) +    endif(LOG4CPP_FOUND) + +    SET(ENABLE_GR_LOG ${ENABLE_GR_LOG} CACHE INTERNAL "" FORCE) + +  else(ENABLE_GR_LOG) +    SET(HAVE_LOG4CPP False CACHE INTERNAL "" FORCE) +    SET(LOG4CPP_INCLUDE_DIRS "" CACHE INTERNAL "" FORCE) +    SET(LOG4CPP_LIBRARY_DIRS "" CACHE INTERNAL "" FORCE) +    SET(LOG4CPP_LIBRARIES "" CACHE INTERNAL "" FORCE) +  endif(ENABLE_GR_LOG) + +  message(STATUS "ENABLE_GR_LOG set to ${ENABLE_GR_LOG}.") +  message(STATUS "HAVE_LOG4CPP set to ${HAVE_LOG4CPP}.") +  message(STATUS "LOG4CPP_LIBRARIES set to ${LOG4CPP_LIBRARIES}.") + +endfunction(GR_LOGGING) + +######################################################################## +# Run GRCC to compile .grc files into .py files. +# +# Usage: GRCC(filename, directory) +#    - filenames: List of file name of .grc file +#    - directory: directory of built .py file - usually in +#                 ${CMAKE_CURRENT_BINARY_DIR} +#    - Sets PYFILES: output converted GRC file names to Python files. +######################################################################## +function(GRCC) +  # Extract directory from list of args, remove it for the list of filenames. +  list(GET ARGV -1 directory) +  list(REMOVE_AT ARGV -1) +  set(filenames ${ARGV}) +  file(MAKE_DIRECTORY ${directory}) + +  SET(GRCC_COMMAND ${CMAKE_SOURCE_DIR}/gr-utils/python/grcc) + +  # GRCC uses some stuff in grc and gnuradio-runtime, so we force +  # the known paths here +  list(APPEND PYTHONPATHS +    ${CMAKE_SOURCE_DIR} +    ${CMAKE_SOURCE_DIR}/gnuradio-runtime/python +    ${CMAKE_SOURCE_DIR}/gnuradio-runtime/lib/swig +    ${CMAKE_BINARY_DIR}/gnuradio-runtime/lib/swig +    ) + +  if(WIN32) +    #SWIG generates the python library files into a subdirectory. +    #Therefore, we must append this subdirectory into PYTHONPATH. +    #Only do this for the python directories matching the following: +    foreach(pydir ${PYTHONPATHS}) +      get_filename_component(name ${pydir} NAME) +      if(name MATCHES "^(swig|lib|src)$") +        list(APPEND PYTHONPATHS ${pydir}/${CMAKE_BUILD_TYPE}) +      endif() +    endforeach(pydir) +  endif(WIN32) + +  file(TO_NATIVE_PATH "${PYTHONPATHS}" pypath) + +  if(UNIX) +    list(APPEND pypath "$PYTHONPATH") +    string(REPLACE ";" ":" pypath "${pypath}") +    set(ENV{PYTHONPATH} ${pypath}) +  endif(UNIX) + +  if(WIN32) +    list(APPEND pypath "%PYTHONPATH%") +    string(REPLACE ";" "\\;" pypath "${pypath}") +    #list(APPEND environs "PYTHONPATH=${pypath}") +    set(ENV{PYTHONPATH} ${pypath}) +  endif(WIN32) + +  foreach(f ${filenames}) +    execute_process( +      COMMAND ${GRCC_COMMAND} -d ${directory} ${f} +      ) +    string(REPLACE ".grc" ".py" pyfile "${f}") +    string(REPLACE "${CMAKE_CURRENT_SOURCE_DIR}" "${CMAKE_CURRENT_BINARY_DIR}" pyfile "${pyfile}") +    list(APPEND pyfiles ${pyfile}) +  endforeach(f) + +  set(PYFILES ${pyfiles} PARENT_SCOPE) +endfunction(GRCC) + +######################################################################## +# Check if HAVE_PTHREAD_SETSCHEDPARAM and HAVE_SCHED_SETSCHEDULER +#  should be defined +######################################################################## +macro(GR_CHECK_LINUX_SCHED_AVAIL) +set(CMAKE_REQUIRED_LIBRARIES -lpthread) +    CHECK_CXX_SOURCE_COMPILES(" +        #include <pthread.h> +        int main(){ +            pthread_t pthread; +            pthread_setschedparam(pthread,  0, 0); +            return 0; +        } " HAVE_PTHREAD_SETSCHEDPARAM +    ) +    GR_ADD_COND_DEF(HAVE_PTHREAD_SETSCHEDPARAM) + +    CHECK_CXX_SOURCE_COMPILES(" +        #include <sched.h> +        int main(){ +            pid_t pid; +            sched_setscheduler(pid, 0, 0); +            return 0; +        } " HAVE_SCHED_SETSCHEDULER +    ) +    GR_ADD_COND_DEF(HAVE_SCHED_SETSCHEDULER) +endmacro(GR_CHECK_LINUX_SCHED_AVAIL) + +######################################################################## +# Macros to generate source and header files from template +######################################################################## +macro(GR_EXPAND_X_H component root) + +  include(GrPython) + +  file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +"#!${PYTHON_EXECUTABLE} + +import sys, os, re +sys.path.append('${GR_RUNTIME_PYTHONPATH}') +sys.path.append('${CMAKE_SOURCE_DIR}/python') +os.environ['srcdir'] = '${CMAKE_CURRENT_SOURCE_DIR}' +os.chdir('${CMAKE_CURRENT_BINARY_DIR}') + +if __name__ == '__main__': +    import build_utils +    root, inp = sys.argv[1:3] +    for sig in sys.argv[3:]: +        name = re.sub ('X+', sig, root) +        d = build_utils.standard_dict2(name, sig, '${component}') +        build_utils.expand_template(d, inp) +") + +  #make a list of all the generated headers +  unset(expanded_files_h) +  foreach(sig ${ARGN}) +    string(REGEX REPLACE "X+" ${sig} name ${root}) +    list(APPEND expanded_files_h ${CMAKE_CURRENT_BINARY_DIR}/${name}.h) +  endforeach(sig) +  unset(name) + +  #create a command to generate the headers +  add_custom_command( +    OUTPUT ${expanded_files_h} +    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${root}.h.t +    COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +    ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +    ${root} ${root}.h.t ${ARGN} +  ) + +  #install rules for the generated headers +  list(APPEND generated_includes ${expanded_files_h}) + +endmacro(GR_EXPAND_X_H) + +macro(GR_EXPAND_X_CC_H component root) + +  include(GrPython) + +  file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +"#!${PYTHON_EXECUTABLE} + +import sys, os, re +sys.path.append('${GR_RUNTIME_PYTHONPATH}') +sys.path.append('${CMAKE_SOURCE_DIR}/python') +os.environ['srcdir'] = '${CMAKE_CURRENT_SOURCE_DIR}' +os.chdir('${CMAKE_CURRENT_BINARY_DIR}') + +if __name__ == '__main__': +    import build_utils +    root, inp = sys.argv[1:3] +    for sig in sys.argv[3:]: +        name = re.sub ('X+', sig, root) +        d = build_utils.standard_impl_dict2(name, sig, '${component}') +        build_utils.expand_template(d, inp) +") + +  #make a list of all the generated files +  unset(expanded_files_cc) +  unset(expanded_files_h) +  foreach(sig ${ARGN}) +    string(REGEX REPLACE "X+" ${sig} name ${root}) +    list(APPEND expanded_files_cc ${CMAKE_CURRENT_BINARY_DIR}/${name}.cc) +    list(APPEND expanded_files_h  ${CMAKE_CURRENT_BINARY_DIR}/${name}.h) +  endforeach(sig) +  unset(name) + +  #create a command to generate the source files +  add_custom_command( +    OUTPUT ${expanded_files_cc} +    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${root}.cc.t +    COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +    ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +    ${root} ${root}.cc.t ${ARGN} +  ) + +  #create a command to generate the header files +  add_custom_command( +    OUTPUT ${expanded_files_h} +    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${root}.h.t +    COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +    ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +    ${root} ${root}.h.t ${ARGN} +  ) + +  #make source files depends on headers to force generation +  set_source_files_properties(${expanded_files_cc} +    PROPERTIES OBJECT_DEPENDS "${expanded_files_h}" +  ) + +  #install rules for the generated files +  list(APPEND generated_sources ${expanded_files_cc}) +  list(APPEND generated_headers ${expanded_files_h}) + +endmacro(GR_EXPAND_X_CC_H) + +macro(GR_EXPAND_X_CC_H_IMPL component root) + +  include(GrPython) + +  file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +"#!${PYTHON_EXECUTABLE} + +import sys, os, re +sys.path.append('${GR_RUNTIME_PYTHONPATH}') +sys.path.append('${CMAKE_SOURCE_DIR}/python') +os.environ['srcdir'] = '${CMAKE_CURRENT_SOURCE_DIR}' +os.chdir('${CMAKE_CURRENT_BINARY_DIR}') + +if __name__ == '__main__': +    import build_utils +    root, inp = sys.argv[1:3] +    for sig in sys.argv[3:]: +        name = re.sub ('X+', sig, root) +        d = build_utils.standard_dict(name, sig, '${component}') +        build_utils.expand_template(d, inp, '_impl') +") + +  #make a list of all the generated files +  unset(expanded_files_cc_impl) +  unset(expanded_files_h_impl) +  unset(expanded_files_h) +  foreach(sig ${ARGN}) +    string(REGEX REPLACE "X+" ${sig} name ${root}) +    list(APPEND expanded_files_cc_impl ${CMAKE_CURRENT_BINARY_DIR}/${name}_impl.cc) +    list(APPEND expanded_files_h_impl ${CMAKE_CURRENT_BINARY_DIR}/${name}_impl.h) +    list(APPEND expanded_files_h ${CMAKE_CURRENT_BINARY_DIR}/../include/gnuradio/${component}/${name}.h) +  endforeach(sig) +  unset(name) + +  #create a command to generate the _impl.cc files +  add_custom_command( +    OUTPUT ${expanded_files_cc_impl} +    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${root}_impl.cc.t +    COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +    ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +    ${root} ${root}_impl.cc.t ${ARGN} +  ) + +  #create a command to generate the _impl.h files +  add_custom_command( +    OUTPUT ${expanded_files_h_impl} +    DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${root}_impl.h.t +    COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +    ${CMAKE_CURRENT_BINARY_DIR}/generate_helper.py +    ${root} ${root}_impl.h.t ${ARGN} +  ) + +  #make _impl.cc source files depend on _impl.h to force generation +  set_source_files_properties(${expanded_files_cc_impl} +    PROPERTIES OBJECT_DEPENDS "${expanded_files_h_impl}" +  ) + +  #make _impl.h source files depend on headers to force generation +  set_source_files_properties(${expanded_files_h_impl} +    PROPERTIES OBJECT_DEPENDS "${expanded_files_h}" +  ) + +  #install rules for the generated files +  list(APPEND generated_sources ${expanded_files_cc_impl}) +  list(APPEND generated_headers ${expanded_files_h_impl}) + +endmacro(GR_EXPAND_X_CC_H_IMPL) diff --git a/tools/gr-usrptest/cmake/Modules/GrPlatform.cmake b/tools/gr-usrptest/cmake/Modules/GrPlatform.cmake new file mode 100644 index 000000000..fbbea5fee --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/GrPlatform.cmake @@ -0,0 +1,54 @@ +# Copyright 2011 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING.  If not, write to +# the Free Software Foundation, Inc., 51 Franklin Street, +# Boston, MA 02110-1301, USA. + +if(DEFINED __INCLUDED_GR_PLATFORM_CMAKE) +    return() +endif() +set(__INCLUDED_GR_PLATFORM_CMAKE TRUE) + +######################################################################## +# Setup additional defines for OS types +######################################################################## +if(CMAKE_SYSTEM_NAME STREQUAL "Linux") +    set(LINUX TRUE) +endif() + +if(NOT CMAKE_CROSSCOMPILING AND LINUX AND EXISTS "/etc/debian_version") +    set(DEBIAN TRUE) +endif() + +if(NOT CMAKE_CROSSCOMPILING AND LINUX AND EXISTS "/etc/redhat-release") +    set(REDHAT TRUE) +endif() + +if(NOT CMAKE_CROSSCOMPILING AND LINUX AND EXISTS "/etc/slackware-version") +    set(SLACKWARE TRUE) +endif() + +######################################################################## +# when the library suffix should be 64 (applies to redhat linux family) +######################################################################## +if (REDHAT OR SLACKWARE) +    set(LIB64_CONVENTION TRUE) +endif() + +if(NOT DEFINED LIB_SUFFIX AND LIB64_CONVENTION AND CMAKE_SYSTEM_PROCESSOR MATCHES "64$") +    set(LIB_SUFFIX 64) +endif() +set(LIB_SUFFIX ${LIB_SUFFIX} CACHE STRING "lib directory suffix") diff --git a/tools/gr-usrptest/cmake/Modules/GrPython.cmake b/tools/gr-usrptest/cmake/Modules/GrPython.cmake new file mode 100644 index 000000000..06e061e21 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/GrPython.cmake @@ -0,0 +1,241 @@ +# Copyright 2010-2011 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING.  If not, write to +# the Free Software Foundation, Inc., 51 Franklin Street, +# Boston, MA 02110-1301, USA. + +if(DEFINED __INCLUDED_GR_PYTHON_CMAKE) +    return() +endif() +set(__INCLUDED_GR_PYTHON_CMAKE TRUE) + +######################################################################## +# Setup the python interpreter: +# This allows the user to specify a specific interpreter, +# or finds the interpreter via the built-in cmake module. +######################################################################## +#this allows the user to override PYTHON_EXECUTABLE +if(PYTHON_EXECUTABLE) + +    set(PYTHONINTERP_FOUND TRUE) + +#otherwise if not set, try to automatically find it +else(PYTHON_EXECUTABLE) + +    #use the built-in find script +    find_package(PythonInterp 2) + +    #and if that fails use the find program routine +    if(NOT PYTHONINTERP_FOUND) +        find_program(PYTHON_EXECUTABLE NAMES python python2 python2.7 python2.6 python2.5) +        if(PYTHON_EXECUTABLE) +            set(PYTHONINTERP_FOUND TRUE) +        endif(PYTHON_EXECUTABLE) +    endif(NOT PYTHONINTERP_FOUND) + +endif(PYTHON_EXECUTABLE) + +if (CMAKE_CROSSCOMPILING) +    set(QA_PYTHON_EXECUTABLE "/usr/bin/python") +else (CMAKE_CROSSCOMPILING) +    set(QA_PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE}) +endif(CMAKE_CROSSCOMPILING) + +#make the path to the executable appear in the cmake gui +set(PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE} CACHE FILEPATH "python interpreter") +set(QA_PYTHON_EXECUTABLE ${QA_PYTHON_EXECUTABLE} CACHE FILEPATH "python interpreter for QA tests") + +#make sure we can use -B with python (introduced in 2.6) +if(PYTHON_EXECUTABLE) +    execute_process( +        COMMAND ${PYTHON_EXECUTABLE} -B -c "" +        OUTPUT_QUIET ERROR_QUIET +        RESULT_VARIABLE PYTHON_HAS_DASH_B_RESULT +    ) +    if(PYTHON_HAS_DASH_B_RESULT EQUAL 0) +        set(PYTHON_DASH_B "-B") +    endif() +endif(PYTHON_EXECUTABLE) + +######################################################################## +# Check for the existence of a python module: +# - desc a string description of the check +# - mod the name of the module to import +# - cmd an additional command to run +# - have the result variable to set +######################################################################## +macro(GR_PYTHON_CHECK_MODULE desc mod cmd have) +    message(STATUS "") +    message(STATUS "Python checking for ${desc}") +    execute_process( +        COMMAND ${PYTHON_EXECUTABLE} -c " +######################################### +try: +    import ${mod} +    assert ${cmd} +except ImportError, AssertionError: exit(-1) +except: pass +#########################################" +        RESULT_VARIABLE ${have} +    ) +    if(${have} EQUAL 0) +        message(STATUS "Python checking for ${desc} - found") +        set(${have} TRUE) +    else(${have} EQUAL 0) +        message(STATUS "Python checking for ${desc} - not found") +        set(${have} FALSE) +    endif(${have} EQUAL 0) +endmacro(GR_PYTHON_CHECK_MODULE) + +######################################################################## +# Sets the python installation directory GR_PYTHON_DIR +######################################################################## +if(NOT DEFINED GR_PYTHON_DIR) +execute_process(COMMAND ${PYTHON_EXECUTABLE} -c " +from distutils import sysconfig +print sysconfig.get_python_lib(plat_specific=True, prefix='') +" OUTPUT_VARIABLE GR_PYTHON_DIR OUTPUT_STRIP_TRAILING_WHITESPACE +) +endif() +file(TO_CMAKE_PATH ${GR_PYTHON_DIR} GR_PYTHON_DIR) + +######################################################################## +# Create an always-built target with a unique name +# Usage: GR_UNIQUE_TARGET(<description> <dependencies list>) +######################################################################## +function(GR_UNIQUE_TARGET desc) +    file(RELATIVE_PATH reldir ${CMAKE_BINARY_DIR} ${CMAKE_CURRENT_BINARY_DIR}) +    execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "import re, hashlib +unique = hashlib.md5('${reldir}${ARGN}').hexdigest()[:5] +print(re.sub('\\W', '_', '${desc} ${reldir} ' + unique))" +    OUTPUT_VARIABLE _target OUTPUT_STRIP_TRAILING_WHITESPACE) +    add_custom_target(${_target} ALL DEPENDS ${ARGN}) +endfunction(GR_UNIQUE_TARGET) + +######################################################################## +# Install python sources (also builds and installs byte-compiled python) +######################################################################## +function(GR_PYTHON_INSTALL) +    include(CMakeParseArgumentsCopy) +    CMAKE_PARSE_ARGUMENTS(GR_PYTHON_INSTALL "" "DESTINATION;COMPONENT" "FILES;PROGRAMS" ${ARGN}) + +    #################################################################### +    if(GR_PYTHON_INSTALL_FILES) +    #################################################################### +        install(${ARGN}) #installs regular python files + +        #create a list of all generated files +        unset(pysrcfiles) +        unset(pycfiles) +        unset(pyofiles) +        foreach(pyfile ${GR_PYTHON_INSTALL_FILES}) +            get_filename_component(pyfile ${pyfile} ABSOLUTE) +            list(APPEND pysrcfiles ${pyfile}) + +            #determine if this file is in the source or binary directory +            file(RELATIVE_PATH source_rel_path ${CMAKE_CURRENT_SOURCE_DIR} ${pyfile}) +            string(LENGTH "${source_rel_path}" source_rel_path_len) +            file(RELATIVE_PATH binary_rel_path ${CMAKE_CURRENT_BINARY_DIR} ${pyfile}) +            string(LENGTH "${binary_rel_path}" binary_rel_path_len) + +            #and set the generated path appropriately +            if(${source_rel_path_len} GREATER ${binary_rel_path_len}) +                set(pygenfile ${CMAKE_CURRENT_BINARY_DIR}/${binary_rel_path}) +            else() +                set(pygenfile ${CMAKE_CURRENT_BINARY_DIR}/${source_rel_path}) +            endif() +            list(APPEND pycfiles ${pygenfile}c) +            list(APPEND pyofiles ${pygenfile}o) + +            #ensure generation path exists +            get_filename_component(pygen_path ${pygenfile} PATH) +            file(MAKE_DIRECTORY ${pygen_path}) + +        endforeach(pyfile) + +        #the command to generate the pyc files +        add_custom_command( +            DEPENDS ${pysrcfiles} OUTPUT ${pycfiles} +            COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_BINARY_DIR}/python_compile_helper.py ${pysrcfiles} ${pycfiles} +        ) + +        #the command to generate the pyo files +        add_custom_command( +            DEPENDS ${pysrcfiles} OUTPUT ${pyofiles} +            COMMAND ${PYTHON_EXECUTABLE} -O ${CMAKE_BINARY_DIR}/python_compile_helper.py ${pysrcfiles} ${pyofiles} +        ) + +        #create install rule and add generated files to target list +        set(python_install_gen_targets ${pycfiles} ${pyofiles}) +        install(FILES ${python_install_gen_targets} +            DESTINATION ${GR_PYTHON_INSTALL_DESTINATION} +            COMPONENT ${GR_PYTHON_INSTALL_COMPONENT} +        ) + +    #################################################################### +    elseif(GR_PYTHON_INSTALL_PROGRAMS) +    #################################################################### +        file(TO_NATIVE_PATH ${PYTHON_EXECUTABLE} pyexe_native) + +        if (CMAKE_CROSSCOMPILING) +           set(pyexe_native "/usr/bin/env python") +        endif() + +        foreach(pyfile ${GR_PYTHON_INSTALL_PROGRAMS}) +            get_filename_component(pyfile_name ${pyfile} NAME) +            get_filename_component(pyfile ${pyfile} ABSOLUTE) +            string(REPLACE "${CMAKE_SOURCE_DIR}" "${CMAKE_BINARY_DIR}" pyexefile "${pyfile}.exe") +            list(APPEND python_install_gen_targets ${pyexefile}) + +            get_filename_component(pyexefile_path ${pyexefile} PATH) +            file(MAKE_DIRECTORY ${pyexefile_path}) + +            add_custom_command( +                OUTPUT ${pyexefile} DEPENDS ${pyfile} +                COMMAND ${PYTHON_EXECUTABLE} -c +                "import re; R=re.compile('^\#!.*$\\n',flags=re.MULTILINE); open('${pyexefile}','w').write('\#!${pyexe_native}\\n'+R.sub('',open('${pyfile}','r').read()))" +                COMMENT "Shebangin ${pyfile_name}" +                VERBATIM +            ) + +            #on windows, python files need an extension to execute +            get_filename_component(pyfile_ext ${pyfile} EXT) +            if(WIN32 AND NOT pyfile_ext) +                set(pyfile_name "${pyfile_name}.py") +            endif() + +            install(PROGRAMS ${pyexefile} RENAME ${pyfile_name} +                DESTINATION ${GR_PYTHON_INSTALL_DESTINATION} +                COMPONENT ${GR_PYTHON_INSTALL_COMPONENT} +            ) +        endforeach(pyfile) + +    endif() + +    GR_UNIQUE_TARGET("pygen" ${python_install_gen_targets}) + +endfunction(GR_PYTHON_INSTALL) + +######################################################################## +# Write the python helper script that generates byte code files +######################################################################## +file(WRITE ${CMAKE_BINARY_DIR}/python_compile_helper.py " +import sys, py_compile +files = sys.argv[1:] +srcs, gens = files[:len(files)/2], files[len(files)/2:] +for src, gen in zip(srcs, gens): +    py_compile.compile(file=src, cfile=gen, doraise=True) +") diff --git a/tools/gr-usrptest/cmake/Modules/GrSwig.cmake b/tools/gr-usrptest/cmake/Modules/GrSwig.cmake new file mode 100644 index 000000000..abf4dc461 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/GrSwig.cmake @@ -0,0 +1,251 @@ +# Copyright 2010-2011 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING.  If not, write to +# the Free Software Foundation, Inc., 51 Franklin Street, +# Boston, MA 02110-1301, USA. + +if(DEFINED __INCLUDED_GR_SWIG_CMAKE) +    return() +endif() +set(__INCLUDED_GR_SWIG_CMAKE TRUE) + +include(GrPython) + +######################################################################## +# Builds a swig documentation file to be generated into python docstrings +# Usage: GR_SWIG_MAKE_DOCS(output_file input_path input_path....) +# +# Set the following variable to specify extra dependent targets: +#   - GR_SWIG_DOCS_SOURCE_DEPS +#   - GR_SWIG_DOCS_TARGET_DEPS +######################################################################## +function(GR_SWIG_MAKE_DOCS output_file) +    if(ENABLE_DOXYGEN) + +        #setup the input files variable list, quote formated +        set(input_files) +        unset(INPUT_PATHS) +        foreach(input_path ${ARGN}) +            if(IS_DIRECTORY ${input_path}) #when input path is a directory +                file(GLOB input_path_h_files ${input_path}/*.h) +            else() #otherwise its just a file, no glob +                set(input_path_h_files ${input_path}) +            endif() +            list(APPEND input_files ${input_path_h_files}) +            set(INPUT_PATHS "${INPUT_PATHS} \"${input_path}\"") +        endforeach(input_path) + +        #determine the output directory +        get_filename_component(name ${output_file} NAME_WE) +        get_filename_component(OUTPUT_DIRECTORY ${output_file} PATH) +        set(OUTPUT_DIRECTORY ${OUTPUT_DIRECTORY}/${name}_swig_docs) +        make_directory(${OUTPUT_DIRECTORY}) + +        #generate the Doxyfile used by doxygen +        configure_file( +            ${CMAKE_SOURCE_DIR}/docs/doxygen/Doxyfile.swig_doc.in +            ${OUTPUT_DIRECTORY}/Doxyfile +        @ONLY) + +        #Create a dummy custom command that depends on other targets +        include(GrMiscUtils) +        GR_GEN_TARGET_DEPS(_${name}_tag tag_deps ${GR_SWIG_DOCS_TARGET_DEPS}) + +        #call doxygen on the Doxyfile + input headers +        add_custom_command( +            OUTPUT ${OUTPUT_DIRECTORY}/xml/index.xml +            DEPENDS ${input_files} ${GR_SWIG_DOCS_SOURCE_DEPS} ${tag_deps} +            COMMAND ${DOXYGEN_EXECUTABLE} ${OUTPUT_DIRECTORY}/Doxyfile +            COMMENT "Generating doxygen xml for ${name} docs" +        ) + +        #call the swig_doc script on the xml files +        add_custom_command( +            OUTPUT ${output_file} +            DEPENDS ${input_files} ${stamp-file} ${OUTPUT_DIRECTORY}/xml/index.xml +            COMMAND ${PYTHON_EXECUTABLE} ${PYTHON_DASH_B} +                ${CMAKE_SOURCE_DIR}/docs/doxygen/swig_doc.py +                ${OUTPUT_DIRECTORY}/xml +                ${output_file} +            COMMENT "Generating python docstrings for ${name}" +            WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/docs/doxygen +        ) + +    else(ENABLE_DOXYGEN) +        file(WRITE ${output_file} "\n") #no doxygen -> empty file +    endif(ENABLE_DOXYGEN) +endfunction(GR_SWIG_MAKE_DOCS) + +######################################################################## +# Build a swig target for the common gnuradio use case. Usage: +# GR_SWIG_MAKE(target ifile ifile ifile...) +# +# Set the following variables before calling: +#   - GR_SWIG_FLAGS +#   - GR_SWIG_INCLUDE_DIRS +#   - GR_SWIG_LIBRARIES +#   - GR_SWIG_SOURCE_DEPS +#   - GR_SWIG_TARGET_DEPS +#   - GR_SWIG_DOC_FILE +#   - GR_SWIG_DOC_DIRS +######################################################################## +macro(GR_SWIG_MAKE name) +    set(ifiles ${ARGN}) + +    # Shimming this in here to take care of a SWIG bug with handling +    # vector<size_t> and vector<unsigned int> (on 32-bit machines) and +    # vector<long unsigned int> (on 64-bit machines). Use this to test +    # the size of size_t, then set SIZE_T_32 if it's a 32-bit machine +    # or not if it's 64-bit. The logic in gr_type.i handles the rest. +    INCLUDE(CheckTypeSize) +    CHECK_TYPE_SIZE("size_t" SIZEOF_SIZE_T) +    CHECK_TYPE_SIZE("unsigned int" SIZEOF_UINT) +    if(${SIZEOF_SIZE_T} EQUAL ${SIZEOF_UINT}) +      list(APPEND GR_SWIG_FLAGS -DSIZE_T_32) +    endif(${SIZEOF_SIZE_T} EQUAL ${SIZEOF_UINT}) + +    #do swig doc generation if specified +    if(GR_SWIG_DOC_FILE) +        set(GR_SWIG_DOCS_SOURCE_DEPS ${GR_SWIG_SOURCE_DEPS}) +        list(APPEND GR_SWIG_DOCS_TARGET_DEPS ${GR_SWIG_TARGET_DEPS}) +        GR_SWIG_MAKE_DOCS(${GR_SWIG_DOC_FILE} ${GR_SWIG_DOC_DIRS}) +        add_custom_target(${name}_swig_doc DEPENDS ${GR_SWIG_DOC_FILE}) +        list(APPEND GR_SWIG_TARGET_DEPS ${name}_swig_doc ${GR_RUNTIME_SWIG_DOC_FILE}) +    endif() + +    #append additional include directories +    find_package(PythonLibs 2) +    list(APPEND GR_SWIG_INCLUDE_DIRS ${PYTHON_INCLUDE_PATH}) #deprecated name (now dirs) +    list(APPEND GR_SWIG_INCLUDE_DIRS ${PYTHON_INCLUDE_DIRS}) + +    #prepend local swig directories +    list(INSERT GR_SWIG_INCLUDE_DIRS 0 ${CMAKE_CURRENT_SOURCE_DIR}) +    list(INSERT GR_SWIG_INCLUDE_DIRS 0 ${CMAKE_CURRENT_BINARY_DIR}) + +    #determine include dependencies for swig file +    execute_process( +        COMMAND ${PYTHON_EXECUTABLE} +            ${CMAKE_BINARY_DIR}/get_swig_deps.py +            "${ifiles}" "${GR_SWIG_INCLUDE_DIRS}" +        OUTPUT_STRIP_TRAILING_WHITESPACE +        OUTPUT_VARIABLE SWIG_MODULE_${name}_EXTRA_DEPS +        WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} +    ) + +    #Create a dummy custom command that depends on other targets +    include(GrMiscUtils) +    GR_GEN_TARGET_DEPS(_${name}_swig_tag tag_deps ${GR_SWIG_TARGET_DEPS}) +    set(tag_file ${CMAKE_CURRENT_BINARY_DIR}/${name}.tag) +    add_custom_command( +        OUTPUT ${tag_file} +        DEPENDS ${GR_SWIG_SOURCE_DEPS} ${tag_deps} +        COMMAND ${CMAKE_COMMAND} -E touch ${tag_file} +    ) + +    #append the specified include directories +    include_directories(${GR_SWIG_INCLUDE_DIRS}) +    list(APPEND SWIG_MODULE_${name}_EXTRA_DEPS ${tag_file}) + +    #setup the swig flags with flags and include directories +    set(CMAKE_SWIG_FLAGS -fvirtual -modern -keyword -w511 -module ${name} ${GR_SWIG_FLAGS}) +    foreach(dir ${GR_SWIG_INCLUDE_DIRS}) +        list(APPEND CMAKE_SWIG_FLAGS "-I${dir}") +    endforeach(dir) + +    #set the C++ property on the swig .i file so it builds +    set_source_files_properties(${ifiles} PROPERTIES CPLUSPLUS ON) + +    #setup the actual swig library target to be built +    include(UseSWIG) +    SWIG_ADD_MODULE(${name} python ${ifiles}) +    SWIG_LINK_LIBRARIES(${name} ${PYTHON_LIBRARIES} ${GR_SWIG_LIBRARIES}) +    if(${name} STREQUAL "runtime_swig") +        SET_TARGET_PROPERTIES(${SWIG_MODULE_runtime_swig_REAL_NAME} PROPERTIES DEFINE_SYMBOL "gnuradio_runtime_EXPORTS") +    endif(${name} STREQUAL "runtime_swig") + +endmacro(GR_SWIG_MAKE) + +######################################################################## +# Install swig targets generated by GR_SWIG_MAKE. Usage: +# GR_SWIG_INSTALL( +#   TARGETS target target target... +#   [DESTINATION destination] +#   [COMPONENT component] +# ) +######################################################################## +macro(GR_SWIG_INSTALL) + +    include(CMakeParseArgumentsCopy) +    CMAKE_PARSE_ARGUMENTS(GR_SWIG_INSTALL "" "DESTINATION;COMPONENT" "TARGETS" ${ARGN}) + +    foreach(name ${GR_SWIG_INSTALL_TARGETS}) +        install(TARGETS ${SWIG_MODULE_${name}_REAL_NAME} +            DESTINATION ${GR_SWIG_INSTALL_DESTINATION} +            COMPONENT ${GR_SWIG_INSTALL_COMPONENT} +        ) + +        include(GrPython) +        GR_PYTHON_INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${name}.py +            DESTINATION ${GR_SWIG_INSTALL_DESTINATION} +            COMPONENT ${GR_SWIG_INSTALL_COMPONENT} +        ) + +        GR_LIBTOOL( +            TARGET ${SWIG_MODULE_${name}_REAL_NAME} +            DESTINATION ${GR_SWIG_INSTALL_DESTINATION} +        ) + +    endforeach(name) + +endmacro(GR_SWIG_INSTALL) + +######################################################################## +# Generate a python file that can determine swig dependencies. +# Used by the make macro above to determine extra dependencies. +# When you build C++, CMake figures out the header dependencies. +# This code essentially performs that logic for swig includes. +######################################################################## +file(WRITE ${CMAKE_BINARY_DIR}/get_swig_deps.py " + +import os, sys, re + +i_include_matcher = re.compile('%(include|import)\\s*[<|\"](.*)[>|\"]') +h_include_matcher = re.compile('#(include)\\s*[<|\"](.*)[>|\"]') +include_dirs = sys.argv[2].split(';') + +def get_swig_incs(file_path): +    if file_path.endswith('.i'): matcher = i_include_matcher +    else: matcher = h_include_matcher +    file_contents = open(file_path, 'r').read() +    return matcher.findall(file_contents, re.MULTILINE) + +def get_swig_deps(file_path, level): +    deps = [file_path] +    if level == 0: return deps +    for keyword, inc_file in get_swig_incs(file_path): +        for inc_dir in include_dirs: +            inc_path = os.path.join(inc_dir, inc_file) +            if not os.path.exists(inc_path): continue +            deps.extend(get_swig_deps(inc_path, level-1)) +            break #found, we dont search in lower prio inc dirs +    return deps + +if __name__ == '__main__': +    ifiles = sys.argv[1].split(';') +    deps = sum([get_swig_deps(ifile, 3) for ifile in ifiles], []) +    #sys.stderr.write(';'.join(set(deps)) + '\\n\\n') +    print(';'.join(set(deps))) +") diff --git a/tools/gr-usrptest/cmake/Modules/GrTest.cmake b/tools/gr-usrptest/cmake/Modules/GrTest.cmake new file mode 100644 index 000000000..62caab4b5 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/GrTest.cmake @@ -0,0 +1,143 @@ +# Copyright 2010-2011 Free Software Foundation, Inc. +# +# This file is part of GNU Radio +# +# GNU Radio is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# GNU Radio is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with GNU Radio; see the file COPYING.  If not, write to +# the Free Software Foundation, Inc., 51 Franklin Street, +# Boston, MA 02110-1301, USA. + +if(DEFINED __INCLUDED_GR_TEST_CMAKE) +    return() +endif() +set(__INCLUDED_GR_TEST_CMAKE TRUE) + +######################################################################## +# Add a unit test and setup the environment for a unit test. +# Takes the same arguments as the ADD_TEST function. +# +# Before calling set the following variables: +# GR_TEST_TARGET_DEPS  - built targets for the library path +# GR_TEST_LIBRARY_DIRS - directories for the library path +# GR_TEST_PYTHON_DIRS  - directories for the python path +# GR_TEST_ENVIRONS  - other environment key/value pairs +######################################################################## +function(GR_ADD_TEST test_name) + +        #Ensure that the build exe also appears in the PATH. +        list(APPEND GR_TEST_TARGET_DEPS ${ARGN}) + +        #In the land of windows, all libraries must be in the PATH. +        #Since the dependent libraries are not yet installed, +        #we must manually set them in the PATH to run tests. +        #The following appends the path of a target dependency. +        foreach(target ${GR_TEST_TARGET_DEPS}) +            get_target_property(location ${target} LOCATION) +            if(location) +                get_filename_component(path ${location} PATH) +                string(REGEX REPLACE "\\$\\(.*\\)" ${CMAKE_BUILD_TYPE} path ${path}) +                list(APPEND GR_TEST_LIBRARY_DIRS ${path}) +            endif(location) +        endforeach(target) + +    if(WIN32) +        #SWIG generates the python library files into a subdirectory. +        #Therefore, we must append this subdirectory into PYTHONPATH. +        #Only do this for the python directories matching the following: +        foreach(pydir ${GR_TEST_PYTHON_DIRS}) +            get_filename_component(name ${pydir} NAME) +            if(name MATCHES "^(swig|lib|src)$") +                list(APPEND GR_TEST_PYTHON_DIRS ${pydir}/${CMAKE_BUILD_TYPE}) +            endif() +        endforeach(pydir) +    endif(WIN32) + +    file(TO_NATIVE_PATH ${CMAKE_CURRENT_SOURCE_DIR} srcdir) +    file(TO_NATIVE_PATH "${GR_TEST_LIBRARY_DIRS}" libpath) #ok to use on dir list? +    file(TO_NATIVE_PATH "${GR_TEST_PYTHON_DIRS}" pypath) #ok to use on dir list? + +    set(environs "VOLK_GENERIC=1" "GR_DONT_LOAD_PREFS=1" "srcdir=${srcdir}") +    list(APPEND environs ${GR_TEST_ENVIRONS}) + +    #http://www.cmake.org/pipermail/cmake/2009-May/029464.html +    #Replaced this add test + set environs code with the shell script generation. +    #Its nicer to be able to manually run the shell script to diagnose problems. +    #ADD_TEST(${ARGV}) +    #SET_TESTS_PROPERTIES(${test_name} PROPERTIES ENVIRONMENT "${environs}") + +    if(UNIX) +        set(LD_PATH_VAR "LD_LIBRARY_PATH") +        if(APPLE) +            set(LD_PATH_VAR "DYLD_LIBRARY_PATH") +        endif() + +        set(binpath "${CMAKE_CURRENT_BINARY_DIR}:$PATH") +        list(APPEND libpath "$${LD_PATH_VAR}") +        list(APPEND pypath "$PYTHONPATH") + +        #replace list separator with the path separator +        string(REPLACE ";" ":" libpath "${libpath}") +        string(REPLACE ";" ":" pypath "${pypath}") +        list(APPEND environs "PATH=${binpath}" "${LD_PATH_VAR}=${libpath}" "PYTHONPATH=${pypath}") + +        #generate a bat file that sets the environment and runs the test +	if (CMAKE_CROSSCOMPILING) +                set(SHELL "/bin/sh") +        else(CMAKE_CROSSCOMPILING) +                find_program(SHELL sh) +        endif(CMAKE_CROSSCOMPILING) +        set(sh_file ${CMAKE_CURRENT_BINARY_DIR}/${test_name}_test.sh) +        file(WRITE ${sh_file} "#!${SHELL}\n") +        #each line sets an environment variable +        foreach(environ ${environs}) +            file(APPEND ${sh_file} "export ${environ}\n") +        endforeach(environ) +        #load the command to run with its arguments +        foreach(arg ${ARGN}) +            file(APPEND ${sh_file} "${arg} ") +        endforeach(arg) +        file(APPEND ${sh_file} "\n") + +        #make the shell file executable +        execute_process(COMMAND chmod +x ${sh_file}) + +        add_test(${test_name} ${SHELL} ${sh_file}) + +    endif(UNIX) + +    if(WIN32) +        list(APPEND libpath ${DLL_PATHS} "%PATH%") +        list(APPEND pypath "%PYTHONPATH%") + +        #replace list separator with the path separator (escaped) +        string(REPLACE ";" "\\;" libpath "${libpath}") +        string(REPLACE ";" "\\;" pypath "${pypath}") +        list(APPEND environs "PATH=${libpath}" "PYTHONPATH=${pypath}") + +        #generate a bat file that sets the environment and runs the test +        set(bat_file ${CMAKE_CURRENT_BINARY_DIR}/${test_name}_test.bat) +        file(WRITE ${bat_file} "@echo off\n") +        #each line sets an environment variable +        foreach(environ ${environs}) +            file(APPEND ${bat_file} "SET ${environ}\n") +        endforeach(environ) +        #load the command to run with its arguments +        foreach(arg ${ARGN}) +            file(APPEND ${bat_file} "${arg} ") +        endforeach(arg) +        file(APPEND ${bat_file} "\n") + +        add_test(${test_name} ${bat_file}) +    endif(WIN32) + +endfunction(GR_ADD_TEST) diff --git a/tools/gr-usrptest/cmake/Modules/UseSWIG.cmake b/tools/gr-usrptest/cmake/Modules/UseSWIG.cmake new file mode 100644 index 000000000..c0f172870 --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/UseSWIG.cmake @@ -0,0 +1,304 @@ +# - SWIG module for CMake +# Defines the following macros: +#   SWIG_ADD_MODULE(name language [ files ]) +#     - Define swig module with given name and specified language +#   SWIG_LINK_LIBRARIES(name [ libraries ]) +#     - Link libraries to swig module +# All other macros are for internal use only. +# To get the actual name of the swig module, +# use: ${SWIG_MODULE_${name}_REAL_NAME}. +# Set Source files properties such as CPLUSPLUS and SWIG_FLAGS to specify +# special behavior of SWIG. Also global CMAKE_SWIG_FLAGS can be used to add +# special flags to all swig calls. +# Another special variable is CMAKE_SWIG_OUTDIR, it allows one to specify +# where to write all the swig generated module (swig -outdir option) +# The name-specific variable SWIG_MODULE_<name>_EXTRA_DEPS may be used +# to specify extra dependencies for the generated modules. +# If the source file generated by swig need some special flag you can use +# set_source_files_properties( ${swig_generated_file_fullname} +#        PROPERTIES COMPILE_FLAGS "-bla") + + +#============================================================================= +# Copyright 2004-2009 Kitware, Inc. +# Copyright 2009 Mathieu Malaterre <mathieu.malaterre@gmail.com> +# +# Distributed under the OSI-approved BSD License (the "License"); +# see accompanying file Copyright.txt for details. +# +# This software is distributed WITHOUT ANY WARRANTY; without even the +# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# See the License for more information. +#============================================================================= +# (To distribute this file outside of CMake, substitute the full +#  License text for the above reference.) + +set(SWIG_CXX_EXTENSION "cxx") +set(SWIG_EXTRA_LIBRARIES "") + +set(SWIG_PYTHON_EXTRA_FILE_EXTENSION "py") + +# +# For given swig module initialize variables associated with it +# +macro(SWIG_MODULE_INITIALIZE name language) +  string(TOUPPER "${language}" swig_uppercase_language) +  string(TOLOWER "${language}" swig_lowercase_language) +  set(SWIG_MODULE_${name}_LANGUAGE "${swig_uppercase_language}") +  set(SWIG_MODULE_${name}_SWIG_LANGUAGE_FLAG "${swig_lowercase_language}") + +  set(SWIG_MODULE_${name}_REAL_NAME "${name}") +  if("${SWIG_MODULE_${name}_LANGUAGE}" STREQUAL "UNKNOWN") +    message(FATAL_ERROR "SWIG Error: Language \"${language}\" not found") +  elseif("${SWIG_MODULE_${name}_LANGUAGE}" STREQUAL "PYTHON") +    # when swig is used without the -interface it will produce in the module.py +    # a 'import _modulename' statement, which implies having a corresponding +    # _modulename.so (*NIX), _modulename.pyd (Win32). +    set(SWIG_MODULE_${name}_REAL_NAME "_${name}") +  elseif("${SWIG_MODULE_${name}_LANGUAGE}" STREQUAL "PERL") +    set(SWIG_MODULE_${name}_EXTRA_FLAGS "-shadow") +  endif() +endmacro() + +# +# For a given language, input file, and output file, determine extra files that +# will be generated. This is internal swig macro. +# + +macro(SWIG_GET_EXTRA_OUTPUT_FILES language outfiles generatedpath infile) +  set(${outfiles} "") +  get_source_file_property(SWIG_GET_EXTRA_OUTPUT_FILES_module_basename +    ${infile} SWIG_MODULE_NAME) +  if(SWIG_GET_EXTRA_OUTPUT_FILES_module_basename STREQUAL "NOTFOUND") +    get_filename_component(SWIG_GET_EXTRA_OUTPUT_FILES_module_basename "${infile}" NAME_WE) +  endif() +  foreach(it ${SWIG_${language}_EXTRA_FILE_EXTENSION}) +    set(${outfiles} ${${outfiles}} +      "${generatedpath}/${SWIG_GET_EXTRA_OUTPUT_FILES_module_basename}.${it}") +  endforeach() +endmacro() + +# +# Take swig (*.i) file and add proper custom commands for it +# +macro(SWIG_ADD_SOURCE_TO_MODULE name outfiles infile) +  set(swig_full_infile ${infile}) +  get_filename_component(swig_source_file_path "${infile}" PATH) +  get_filename_component(swig_source_file_name_we "${infile}" NAME_WE) +  get_source_file_property(swig_source_file_generated ${infile} GENERATED) +  get_source_file_property(swig_source_file_cplusplus ${infile} CPLUSPLUS) +  get_source_file_property(swig_source_file_flags ${infile} SWIG_FLAGS) +  if("${swig_source_file_flags}" STREQUAL "NOTFOUND") +    set(swig_source_file_flags "") +  endif() +  set(swig_source_file_fullname "${infile}") +  if(${swig_source_file_path} MATCHES "^${CMAKE_CURRENT_SOURCE_DIR}") +    string(REGEX REPLACE +      "^${CMAKE_CURRENT_SOURCE_DIR}" "" +      swig_source_file_relative_path +      "${swig_source_file_path}") +  else() +    if(${swig_source_file_path} MATCHES "^${CMAKE_CURRENT_BINARY_DIR}") +      string(REGEX REPLACE +        "^${CMAKE_CURRENT_BINARY_DIR}" "" +        swig_source_file_relative_path +        "${swig_source_file_path}") +      set(swig_source_file_generated 1) +    else() +      set(swig_source_file_relative_path "${swig_source_file_path}") +      if(swig_source_file_generated) +        set(swig_source_file_fullname "${CMAKE_CURRENT_BINARY_DIR}/${infile}") +      else() +        set(swig_source_file_fullname "${CMAKE_CURRENT_SOURCE_DIR}/${infile}") +      endif() +    endif() +  endif() + +  set(swig_generated_file_fullname +    "${CMAKE_CURRENT_BINARY_DIR}") +  if(swig_source_file_relative_path) +    set(swig_generated_file_fullname +      "${swig_generated_file_fullname}/${swig_source_file_relative_path}") +  endif() +  # If CMAKE_SWIG_OUTDIR was specified then pass it to -outdir +  if(CMAKE_SWIG_OUTDIR) +    set(swig_outdir ${CMAKE_SWIG_OUTDIR}) +  else() +    set(swig_outdir ${CMAKE_CURRENT_BINARY_DIR}) +  endif() +  SWIG_GET_EXTRA_OUTPUT_FILES(${SWIG_MODULE_${name}_LANGUAGE} +    swig_extra_generated_files +    "${swig_outdir}" +    "${infile}") +  set(swig_generated_file_fullname +    "${swig_generated_file_fullname}/${swig_source_file_name_we}") +  # add the language into the name of the file (i.e. TCL_wrap) +  # this allows for the same .i file to be wrapped into different languages +  set(swig_generated_file_fullname +    "${swig_generated_file_fullname}${SWIG_MODULE_${name}_LANGUAGE}_wrap") + +  if(swig_source_file_cplusplus) +    set(swig_generated_file_fullname +      "${swig_generated_file_fullname}.${SWIG_CXX_EXTENSION}") +  else() +    set(swig_generated_file_fullname +      "${swig_generated_file_fullname}.c") +  endif() + +  # Shut up some warnings from poor SWIG code generation that we +  # can do nothing about, when this flag is available +  include(CheckCXXCompilerFlag) +  check_cxx_compiler_flag("-Wno-unused-but-set-variable" HAVE_WNO_UNUSED_BUT_SET_VARIABLE) +  if(HAVE_WNO_UNUSED_BUT_SET_VARIABLE) +    set_source_files_properties(${swig_generated_file_fullname} +      PROPERTIES COMPILE_FLAGS "-Wno-unused-but-set-variable") +  endif(HAVE_WNO_UNUSED_BUT_SET_VARIABLE) + +  get_directory_property(cmake_include_directories INCLUDE_DIRECTORIES) +  set(swig_include_dirs) +  foreach(it ${cmake_include_directories}) +    set(swig_include_dirs ${swig_include_dirs} "-I${it}") +  endforeach() + +  set(swig_special_flags) +  # default is c, so add c++ flag if it is c++ +  if(swig_source_file_cplusplus) +    set(swig_special_flags ${swig_special_flags} "-c++") +  endif() +  set(swig_extra_flags) +  if(SWIG_MODULE_${name}_EXTRA_FLAGS) +    set(swig_extra_flags ${swig_extra_flags} ${SWIG_MODULE_${name}_EXTRA_FLAGS}) +  endif() + +  # hack to work around CMake bug in add_custom_command with multiple OUTPUT files + +  file(RELATIVE_PATH reldir ${CMAKE_BINARY_DIR} ${CMAKE_CURRENT_BINARY_DIR}) +  execute_process( +    COMMAND ${PYTHON_EXECUTABLE} -c "import re, hashlib +unique = hashlib.md5('${reldir}${ARGN}').hexdigest()[:5] +print(re.sub('\\W', '_', '${name} ${reldir} ' + unique))" +    OUTPUT_VARIABLE _target OUTPUT_STRIP_TRAILING_WHITESPACE +  ) + +  file( +    WRITE ${CMAKE_CURRENT_BINARY_DIR}/${_target}.cpp.in +   "int main(void){return 0;}\n" +  ) + +  # create dummy dependencies +  add_custom_command( +    OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${_target}.cpp +    COMMAND ${CMAKE_COMMAND} -E copy +        ${CMAKE_CURRENT_BINARY_DIR}/${_target}.cpp.in +        ${CMAKE_CURRENT_BINARY_DIR}/${_target}.cpp +    DEPENDS "${swig_source_file_fullname}" ${SWIG_MODULE_${name}_EXTRA_DEPS} +    COMMENT "" +  ) + +  # create the dummy target +  add_executable(${_target} ${CMAKE_CURRENT_BINARY_DIR}/${_target}.cpp) + +  # add a custom command to the dummy target +  add_custom_command( +    TARGET ${_target} +    # Let's create the ${swig_outdir} at execution time, in case dir contains $(OutDir) +    COMMAND ${CMAKE_COMMAND} -E make_directory ${swig_outdir} +    COMMAND "${SWIG_EXECUTABLE}" +    ARGS "-${SWIG_MODULE_${name}_SWIG_LANGUAGE_FLAG}" +    ${swig_source_file_flags} +    ${CMAKE_SWIG_FLAGS} +    -outdir ${swig_outdir} +    ${swig_special_flags} +    ${swig_extra_flags} +    ${swig_include_dirs} +    -o "${swig_generated_file_fullname}" +    "${swig_source_file_fullname}" +    COMMENT "Swig source" +  ) + +  #add dummy independent dependencies from the _target to each file +  #that will be generated by the SWIG command above + +  set(${outfiles} "${swig_generated_file_fullname}" ${swig_extra_generated_files}) + +  foreach(swig_gen_file ${${outfiles}}) +    add_custom_command( +      OUTPUT ${swig_gen_file} +      COMMAND "" +      DEPENDS ${_target} +      COMMENT "" +    ) +  endforeach() + +  set_source_files_properties( +    ${outfiles} PROPERTIES GENERATED 1 +  ) + +endmacro() + +# +# Create Swig module +# +macro(SWIG_ADD_MODULE name language) +  SWIG_MODULE_INITIALIZE(${name} ${language}) +  set(swig_dot_i_sources) +  set(swig_other_sources) +  foreach(it ${ARGN}) +    if(${it} MATCHES ".*\\.i$") +      set(swig_dot_i_sources ${swig_dot_i_sources} "${it}") +    else() +      set(swig_other_sources ${swig_other_sources} "${it}") +    endif() +  endforeach() + +  set(swig_generated_sources) +  foreach(it ${swig_dot_i_sources}) +    SWIG_ADD_SOURCE_TO_MODULE(${name} swig_generated_source ${it}) +    set(swig_generated_sources ${swig_generated_sources} "${swig_generated_source}") +  endforeach() +  get_directory_property(swig_extra_clean_files ADDITIONAL_MAKE_CLEAN_FILES) +  set_directory_properties(PROPERTIES +    ADDITIONAL_MAKE_CLEAN_FILES "${swig_extra_clean_files};${swig_generated_sources}") +  add_library(${SWIG_MODULE_${name}_REAL_NAME} +    MODULE +    ${swig_generated_sources} +    ${swig_other_sources}) +  string(TOLOWER "${language}" swig_lowercase_language) +  if ("${swig_lowercase_language}" STREQUAL "java") +    if (APPLE) +        # In java you want: +        #      System.loadLibrary("LIBRARY"); +        # then JNI will look for a library whose name is platform dependent, namely +        #   MacOS  : libLIBRARY.jnilib +        #   Windows: LIBRARY.dll +        #   Linux  : libLIBRARY.so +        set_target_properties (${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES SUFFIX ".jnilib") +      endif () +  endif () +  if ("${swig_lowercase_language}" STREQUAL "python") +    # this is only needed for the python case where a _modulename.so is generated +    set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES PREFIX "") +    # Python extension modules on Windows must have the extension ".pyd" +    # instead of ".dll" as of Python 2.5.  Older python versions do support +    # this suffix. +    # http://docs.python.org/whatsnew/ports.html#SECTION0001510000000000000000 +    # <quote> +    # Windows: .dll is no longer supported as a filename extension for extension modules. +    # .pyd is now the only filename extension that will be searched for. +    # </quote> +    if(WIN32 AND NOT CYGWIN) +      set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES SUFFIX ".pyd") +    endif() +  endif () +endmacro() + +# +# Like TARGET_LINK_LIBRARIES but for swig modules +# +macro(SWIG_LINK_LIBRARIES name) +  if(SWIG_MODULE_${name}_REAL_NAME) +    target_link_libraries(${SWIG_MODULE_${name}_REAL_NAME} ${ARGN}) +  else() +    message(SEND_ERROR "Cannot find Swig library \"${name}\".") +  endif() +endmacro() diff --git a/tools/gr-usrptest/cmake/Modules/usrptestConfig.cmake b/tools/gr-usrptest/cmake/Modules/usrptestConfig.cmake new file mode 100644 index 000000000..5244d466e --- /dev/null +++ b/tools/gr-usrptest/cmake/Modules/usrptestConfig.cmake @@ -0,0 +1,30 @@ +INCLUDE(FindPkgConfig) +PKG_CHECK_MODULES(PC_USRPTEST usrptest) + +FIND_PATH( +    USRPTEST_INCLUDE_DIRS +    NAMES usrptest/api.h +    HINTS $ENV{USRPTEST_DIR}/include +        ${PC_USRPTEST_INCLUDEDIR} +    PATHS ${CMAKE_INSTALL_PREFIX}/include +          /usr/local/include +          /usr/include +) + +FIND_LIBRARY( +    USRPTEST_LIBRARIES +    NAMES gnuradio-usrptest +    HINTS $ENV{USRPTEST_DIR}/lib +        ${PC_USRPTEST_LIBDIR} +    PATHS ${CMAKE_INSTALL_PREFIX}/lib +          ${CMAKE_INSTALL_PREFIX}/lib64 +          /usr/local/lib +          /usr/local/lib64 +          /usr/lib +          /usr/lib64 +) + +INCLUDE(FindPackageHandleStandardArgs) +FIND_PACKAGE_HANDLE_STANDARD_ARGS(USRPTEST DEFAULT_MSG USRPTEST_LIBRARIES USRPTEST_INCLUDE_DIRS) +MARK_AS_ADVANCED(USRPTEST_LIBRARIES USRPTEST_INCLUDE_DIRS) + diff --git a/tools/gr-usrptest/cmake/cmake_uninstall.cmake.in b/tools/gr-usrptest/cmake/cmake_uninstall.cmake.in new file mode 100644 index 000000000..9ae1ae4bd --- /dev/null +++ b/tools/gr-usrptest/cmake/cmake_uninstall.cmake.in @@ -0,0 +1,32 @@ +# http://www.vtk.org/Wiki/CMake_FAQ#Can_I_do_.22make_uninstall.22_with_CMake.3F + +IF(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt") +  MESSAGE(FATAL_ERROR "Cannot find install manifest: \"@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt\"") +ENDIF(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt") + +FILE(READ "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt" files) +STRING(REGEX REPLACE "\n" ";" files "${files}") +FOREACH(file ${files}) +  MESSAGE(STATUS "Uninstalling \"$ENV{DESTDIR}${file}\"") +  IF(EXISTS "$ENV{DESTDIR}${file}") +    EXEC_PROGRAM( +      "@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\"" +      OUTPUT_VARIABLE rm_out +      RETURN_VALUE rm_retval +      ) +    IF(NOT "${rm_retval}" STREQUAL 0) +      MESSAGE(FATAL_ERROR "Problem when removing \"$ENV{DESTDIR}${file}\"") +    ENDIF(NOT "${rm_retval}" STREQUAL 0) +  ELSEIF(IS_SYMLINK "$ENV{DESTDIR}${file}") +    EXEC_PROGRAM( +      "@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\"" +      OUTPUT_VARIABLE rm_out +      RETURN_VALUE rm_retval +      ) +    IF(NOT "${rm_retval}" STREQUAL 0) +      MESSAGE(FATAL_ERROR "Problem when removing \"$ENV{DESTDIR}${file}\"") +    ENDIF(NOT "${rm_retval}" STREQUAL 0) +  ELSE(EXISTS "$ENV{DESTDIR}${file}") +    MESSAGE(STATUS "File \"$ENV{DESTDIR}${file}\" does not exist.") +  ENDIF(EXISTS "$ENV{DESTDIR}${file}") +ENDFOREACH(file) | 
