1. 15 Oct, 2013 1 commit
  2. 08 Oct, 2013 1 commit
    • Adrien Destugues's avatar
      Haiku: Several fixes to platform module · 7ebc1cb2
      Adrien Destugues authored
      * Do not define BEOS anymore (this includes workarounds which we don't
        need most of the time in Haiku, so we prefer opt-in IF(HAIKU) in the
        cmake files instead).
      * On the other hand, do define UNIX (we are trying to be compliant) and
        HAIKU (there is still a number of things we don't do like the
        average UNIX clone)
      * Do not use UnixPaths, as our filesystem hierarchy isn't anything like
        what it expects.
      * Do not use -nostart, which the compiler doesn't know about anymore.
        This used to be an Haiku extension to gcc, and is equivalent to
        -shared which is the default gcc option.
      * While "dl" functions are provided in libroot, this is always
        implicitly linked so there is no need to tell cmake about it.
      * Forcing position-independent code is not needed, so remove it.
      * On the other hand, include appropriate linker options for executables
        and shared libraries.
      * Support for the two available compilers in Haiku (gcc2 and gcc4) and
        pick the right headers and libraries according to the currently
        selected one.
      * With the adoption of the package manager, the directory layout was
        changed. Tell cmake where to look for header files and libraries.
      * As we don't define BEOS anymore, enable the workaround we still need
        for HAIKU as well. This is the lack of a libm (it is part of the
        implicitly linked in libroot)
      Applied-by: Rolf Eike Beer's avatarRolf Eike Beer <eike@sf-mail.de>
      7ebc1cb2
  3. 07 Jan, 2013 1 commit
  4. 04 Dec, 2012 1 commit
  5. 14 Aug, 2012 2 commits
    • Rolf Eike Beer's avatar
      use PATH_SUFFIXES to simplify find_* calls · cfe4ac4b
      Rolf Eike Beer authored
      Especially remove "lib64" when the given paths are all Unix ones and "lib" is
      also explicitely given. In that case CMake will search "lib64" anyway for
      platforms where it is known to make sense.
      cfe4ac4b
    • Rolf Eike Beer's avatar
      use the find_* functions ENV parameter · b04650e1
      Rolf Eike Beer authored
      Instead of directly passing $ENV{SOMEVAR} to a find_* call pass in ENV SOMEVAR.
      This will make sure the paths will get correctly handled through different
      platforms, especially on Windows.
      
      Also fixes one place where paths with windows delimiters (\) were hardcoded to
      use forward slashes.
      b04650e1
  6. 13 Aug, 2012 3 commits
    • Kitware Robot's avatar
      Remove CMake-language block-end command arguments · 9db31162
      Kitware Robot authored
      Ancient versions of CMake required else(), endif(), and similar block
      termination commands to have arguments matching the command starting the
      block.  This is no longer the preferred style.
      
      Run the following shell code:
      
      for c in else endif endforeach endfunction endmacro endwhile; do
          echo 's/\b'"$c"'\(\s*\)(.\+)/'"$c"'\1()/'
      done >convert.sed &&
      git ls-files -z -- bootstrap '*.cmake' '*.cmake.in' '*CMakeLists.txt' |
      egrep -z -v '^(Utilities/cm|Source/kwsys/)' |
      egrep -z -v 'Tests/CMakeTests/While-Endwhile-' |
      xargs -0 sed -i -f convert.sed &&
      rm convert.sed
      9db31162
    • Kitware Robot's avatar
      Convert CMake-language commands to lower case · 77543bde
      Kitware Robot authored
      Ancient CMake versions required upper-case commands.  Later command
      names became case-insensitive.  Now the preferred style is lower-case.
      
      Run the following shell code:
      
      cmake --help-command-list |
      grep -v "cmake version" |
      while read c; do
          echo 's/\b'"$(echo $c | tr '[:lower:]' '[:upper:]')"'\(\s*\)(/'"$c"'\1(/g'
      done >convert.sed &&
      git ls-files -z -- bootstrap '*.cmake' '*.cmake.in' '*CMakeLists.txt' |
      egrep -z -v '^(Utilities/cm|Source/kwsys/)' |
      xargs -0 sed -i -f convert.sed &&
      rm convert.sed
      77543bde
    • Kitware Robot's avatar
      Remove trailing whitespace from most CMake and C/C++ code · 7bbaa428
      Kitware Robot authored
      Our Git commit hooks disallow modification or addition of lines with
      trailing whitespace.  Wipe out all remnants of trailing whitespace
      everywhere except third-party code.
      
      Run the following shell code:
      
      git ls-files -z -- \
       bootstrap doxygen.config '*.readme' \
       '*.c' '*.cmake' '*.cpp' '*.cxx' \
       '*.el' '*.f' '*.f90' '*.h' '*.in' '*.in.l' '*.java' \
       '*.mm' '*.pike' '*.py' '*.txt' '*.vim' |
      egrep -z -v '^(Utilities/cm|Source/(kwsys|CursesDialog/form)/)' |
      egrep -z -v '^(Modules/CPack\..*\.in)' |
      xargs -0 sed -i 's/ \+$//'
      7bbaa428
  7. 19 Jun, 2012 1 commit
  8. 26 Jan, 2012 1 commit
  9. 20 Jan, 2011 1 commit
    • Brad King's avatar
      Modules: Include builtin FindPackageHandleStandardArgs directly · c4275592
      Brad King authored
      The FindPackageHandleStandardArgs module was originally created outside
      of CMake.  It was added for CMake 2.6.0 by commit e118a627 (add a macro
      FIND_PACKAGE_HANDLE_STANDARD_ARGS..., 2007-07-18).  However, it also
      proliferated into a number of other projects that at the time required
      only CMake 2.4 and thus could not depend on CMake to provide the module.
      CMake's own find modules started using the module in commit b5f656e0
      (use the new FIND_PACKAGE_HANDLE_STANDARD_ARGS in some of the FindXXX
      modules..., 2007-07-18).
      
      Then commit d358cf5c (add 2nd, more powerful mode to
      find_package_handle_standard_args, 2010-07-29) added a new feature to
      the interface of the module that was fully optional and backward
      compatible with all existing users of the module.  Later commit 5f183caa
      (FindZLIB: use the FPHSA version mode, 2010-08-04) and others shortly
      thereafter started using the new interface in CMake's own find modules.
      This change was also backward compatible because it was only an
      implementation detail within each module.
      
      Unforutnately these changes introduced a problem for projects that still
      have an old copy of FindPackageHandleStandardArgs in CMAKE_MODULE_PATH.
      When any such project uses one of CMake's builtin find modules the line
      
        include(FindPackageHandleStandardArgs)
      
      loads the copy from the project which does not have the new interface!
      Then the including find module tries to use the new interface with the
      old module and fails.
      
      Whether this breakage can be considered a backward incompatible change
      in CMake is debatable.  The situation is analagous to copying a standard
      library header from one version of a compiler into a project and then
      observing problems when the next version of the compiler reports errors
      in its other headers that depend on its new version of the original
      header.  Nevertheless it is a change to CMake that causes problems for
      projects that worked with previous versions.
      
      This problem was discovered during the 2.8.3 release candidate cycle.
      It is an instance of a more general problem with projects that provide
      their own versions of CMake modules when other CMake modules depend on
      them.  At the time we resolved this instance of the problem with commit
      b0118402 (Use absolute path to FindPackageHandleStandardArgs.cmake
      everywhere, 2010-09-28) for the 2.8.3 release.
      
      In order to address the more general problem we introduced policy
      CMP0017 in commit db44848f (Prefer files from CMAKE_ROOT when including
      from CMAKE_ROOT, 2010-11-17).  That change was followed by commit
      ce28737c (Remove usage of CMAKE_CURRENT_LIST_DIR now that we have
      CMP0017, 2010-12-20) which reverted the original workaround in favor of
      using the policy.  However, existing project releases do not set the
      policy behavior to NEW and therefore still exhibit the problem.
      
      We introduced in commit a364daf1 (Allow users to specify defaults for
      unset policies, 2011-01-03) an option for users to build existing
      projects by adding -DCMAKE_POLICY_DEFAULT_CMP0017=NEW to the command
      line.  Unfortunately this solution still does not allow such projects to
      build out of the box, and there is no good way to suggest the use of the
      new option.
      
      The only remaining solution to keep existing projects that exhibit this
      problem building is to restore the change originally made in commit
      b0118402 (Use absolute path to FindPackageHandleStandardArgs.cmake
      everywhere, 2010-09-28).  This also avoids policy CMP0017 warnings for
      this particular instance of the problem the policy addresses.
      c4275592
  10. 04 Jan, 2011 1 commit
  11. 28 Sep, 2010 1 commit
  12. 09 Aug, 2010 1 commit
  13. 01 Oct, 2009 1 commit
  14. 28 Sep, 2009 1 commit
    • Brad King's avatar
      Convert CMake find-modules to BSD License · c4bb9c9d
      Brad King authored
      This adds copyright/license notification blocks CMake's find-modules.
      Many of the modules had no notices at all.  Some had notices referring
      to the BSD license already.  This commit normalizes existing notices and
      adds missing notices.
      c4bb9c9d
  15. 30 Jan, 2009 1 commit
  16. 14 Aug, 2008 1 commit
  17. 09 Jun, 2008 1 commit
    • Brad King's avatar
      ENH: Cleanup Find* modules with new HINTS feature · e2ec3b67
      Brad King authored
        - The find_* commands now provide a HINTS option.
        - The option specifies paths to be preferred over the system paths.
        - Many Find* modules were using two find calls with NO_DEFAULT_PATH
          to approximate the behavior, but that blocked users from overriding
          things with CMAKE_PREFIX_PATH.
        - This commit uses the HINTS feature to get desired behavior in
          only one find command call.
      e2ec3b67
  18. 02 Jun, 2008 1 commit
  19. 10 Mar, 2008 1 commit
  20. 15 Jan, 2008 1 commit
  21. 20 Dec, 2007 1 commit
    • Eric Wing's avatar
      BUG: Fixed modules to set FOO_FOUND when both headers and libraries are found. · a5b3ab4e
      Eric Wing authored
      BUG: FindSDL now has flag it responds to so it will not find/link against SDLmain. This is required to build libraries instead of applications since they don't have main().
      ENH: All modules have a predictable search order, where environmental variables are searched before system paths. This is designed to make automation easier for those that need to automatically build projects without intervention but may be using alternative install locations for isolated testing.
      ENH: New modules for OpenSceneGraph, Freetype, GDAL, Lua, QuickTime, GIFLIB, Producer, OpenThreads.
      STYLE: Added documentation explaining peculuar SDL_LIBRARY_TEMP variable in SDL
        module when library find is incomplete.
      a5b3ab4e