diff options
| author | Oz Linden <oz@lindenlab.com> | 2011-04-01 09:52:37 -0400 | 
|---|---|---|
| committer | Oz Linden <oz@lindenlab.com> | 2011-04-01 09:52:37 -0400 | 
| commit | d0ba2bc847b5addf16cf90cea34de5194cd61511 (patch) | |
| tree | a7f80f0c8bb60f497fee8b49b75faa40e0b0ab52 /indra/cmake | |
| parent | e23eeb7ed20055e1a95ea87e0014ba141f4ab0bb (diff) | |
| parent | 5e617d77f34f17f7a8f3677270f2738f857a60b8 (diff) | |
pull latest changes from viewer-development
Diffstat (limited to 'indra/cmake')
34 files changed, 349 insertions, 242 deletions
| diff --git a/indra/cmake/00-Common.cmake b/indra/cmake/00-Common.cmake index dbe0cf5cd0..15b827b217 100644 --- a/indra/cmake/00-Common.cmake +++ b/indra/cmake/00-Common.cmake @@ -7,10 +7,10 @@ include(Variables)  # Portable compilation flags.  set(CMAKE_CXX_FLAGS_DEBUG "-D_DEBUG -DLL_DEBUG=1")  set(CMAKE_CXX_FLAGS_RELEASE -    "-DLL_RELEASE=1 -DLL_RELEASE_FOR_DOWNLOAD=1 -D_SECURE_SCL=0 -DNDEBUG")  +    "-DLL_RELEASE=1 -DLL_RELEASE_FOR_DOWNLOAD=1 -DNDEBUG")   set(CMAKE_CXX_FLAGS_RELWITHDEBINFO  -    "-DLL_RELEASE=1 -D_SECURE_SCL=0 -DNDEBUG -DLL_RELEASE_WITH_DEBUG_INFO=1") +    "-DLL_RELEASE=1 -DNDEBUG -DLL_RELEASE_WITH_DEBUG_INFO=1")  # Configure crash reporting  set(RELEASE_CRASH_REPORTING OFF CACHE BOOL "Enable use of crash reporting in release builds") @@ -36,13 +36,13 @@ if (WINDOWS)    # Don't build DLLs.    set(BUILD_SHARED_LIBS OFF) -  set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /Od /Zi /MDd /MP" +  set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /Od /Zi /MDd /MP -D_SCL_SECURE_NO_WARNINGS=1"        CACHE STRING "C++ compiler debug options" FORCE)    set(CMAKE_CXX_FLAGS_RELWITHDEBINFO  -      "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /Od /Zi /MD /MP /Ob2" +      "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /Od /Zi /MD /MP /Ob2 -D_SECURE_STL=0"        CACHE STRING "C++ compiler release-with-debug options" FORCE)    set(CMAKE_CXX_FLAGS_RELEASE -      "${CMAKE_CXX_FLAGS_RELEASE} ${LL_CXX_FLAGS} /O2 /Zi /MD /MP /Ob2" +      "${CMAKE_CXX_FLAGS_RELEASE} ${LL_CXX_FLAGS} /O2 /Zi /MD /MP /Ob2 -D_SECURE_STL=0 -D_HAS_ITERATOR_DEBUGGING=0"        CACHE STRING "C++ compiler release options" FORCE)    set(CMAKE_CXX_STANDARD_LIBRARIES "") @@ -59,18 +59,9 @@ if (WINDOWS)        /Zc:forScope        /nologo        /Oy- -      ) -      -  if(MSVC80 OR MSVC90) -    set(CMAKE_CXX_FLAGS_RELEASE -      "${CMAKE_CXX_FLAGS_RELEASE} -D_SECURE_STL=0 -D_HAS_ITERATOR_DEBUGGING=0" -      CACHE STRING "C++ compiler release options" FORCE) -    -    add_definitions(        /Zc:wchar_t-        ) -  endif (MSVC80 OR MSVC90) -   +         # Are we using the crummy Visual Studio KDU build workaround?    if (NOT VS_DISABLE_FATAL_WARNINGS)      add_definitions(/WX) diff --git a/indra/cmake/APR.cmake b/indra/cmake/APR.cmake index 180504d286..daafa00fe2 100644 --- a/indra/cmake/APR.cmake +++ b/indra/cmake/APR.cmake @@ -32,27 +32,21 @@ else (STANDALONE)        )    elseif (DARWIN)      if (LLCOMMON_LINK_SHARED) -      set(APR_selector     "0.3.7.dylib") -      set(APRUTIL_selector "0.3.8.dylib") +      set(APR_selector     "0.dylib") +      set(APRUTIL_selector "0.dylib")      else (LLCOMMON_LINK_SHARED)        set(APR_selector     "a")        set(APRUTIL_selector "a")      endif (LLCOMMON_LINK_SHARED) -    set(APR_LIBRARIES  -      debug ${ARCH_PREBUILT_DIRS_DEBUG}/libapr-1.${APR_selector} -      optimized ${ARCH_PREBUILT_DIRS_RELEASE}/libapr-1.${APR_selector} -      ) -    set(APRUTIL_LIBRARIES  -      debug ${ARCH_PREBUILT_DIRS_DEBUG}/libaprutil-1.${APRUTIL_selector} -      optimized ${ARCH_PREBUILT_DIRS_RELEASE}/libaprutil-1.${APRUTIL_selector} -      ) +    set(APR_LIBRARIES libapr-1.${APR_selector}) +    set(APRUTIL_LIBRARIES libaprutil-1.${APRUTIL_selector})      set(APRICONV_LIBRARIES iconv)    else (WINDOWS)      set(APR_LIBRARIES apr-1)      set(APRUTIL_LIBRARIES aprutil-1)      set(APRICONV_LIBRARIES iconv)    endif (WINDOWS) -  set(APR_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/apr-1) +  set(APR_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include/apr-1)    if (LINUX)      if (VIEWER) diff --git a/indra/cmake/BerkeleyDB.cmake b/indra/cmake/BerkeleyDB.cmake index e3ca0fd77d..57b53f46ff 100644 --- a/indra/cmake/BerkeleyDB.cmake +++ b/indra/cmake/BerkeleyDB.cmake @@ -8,7 +8,8 @@ if (STANDALONE)  else (STANDALONE)    if (LINUX)      # Need to add dependency pthread explicitely to support ld.gold. -    set(DB_LIBRARIES db-4.2 pthread) +    use_prebuilt_binary(db) +    set(DB_LIBRARIES db-5.1 pthread)    else (LINUX)      set(DB_LIBRARIES db-4.2)    endif (LINUX) diff --git a/indra/cmake/Boost.cmake b/indra/cmake/Boost.cmake index 7ce57a5572..2135f0584c 100644 --- a/indra/cmake/Boost.cmake +++ b/indra/cmake/Boost.cmake @@ -10,23 +10,15 @@ if (STANDALONE)    set(BOOST_PROGRAM_OPTIONS_LIBRARY boost_program_options-mt)    set(BOOST_REGEX_LIBRARY boost_regex-mt)    set(BOOST_SIGNALS_LIBRARY boost_signals-mt) +  set(BOOST_SYSTEM_LIBRARY boost_system-mt) +  set(BOOST_FILESYSTEM_LIBRARY boost_filesystem-mt)  else (STANDALONE)    use_prebuilt_binary(boost)    set(Boost_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include)    if (WINDOWS) -    set(BOOST_VERSION 1_39) -    if (MSVC71) -      set(BOOST_PROGRAM_OPTIONS_LIBRARY  -          optimized libboost_program_options-vc71-mt-s-${BOOST_VERSION} -          debug libboost_program_options-vc71-mt-sgd-${BOOST_VERSION}) -      set(BOOST_REGEX_LIBRARY -          optimized libboost_regex-vc71-mt-s-${BOOST_VERSION} -          debug libboost_regex-vc71-mt-sgd-${BOOST_VERSION}) -      set(BOOST_SIGNALS_LIBRARY  -          optimized libboost_signals-vc71-mt-s-${BOOST_VERSION} -          debug libboost_signals-vc71-mt-sgd-${BOOST_VERSION}) -    else (MSVC71) +    set(BOOST_VERSION 1_45) +    if(MSVC80)        set(BOOST_PROGRAM_OPTIONS_LIBRARY             optimized libboost_program_options-vc80-mt-${BOOST_VERSION}            debug libboost_program_options-vc80-mt-gd-${BOOST_VERSION}) @@ -36,14 +28,31 @@ else (STANDALONE)        set(BOOST_SIGNALS_LIBRARY             optimized libboost_signals-vc80-mt-${BOOST_VERSION}            debug libboost_signals-vc80-mt-gd-${BOOST_VERSION}) -    endif (MSVC71) -  elseif (DARWIN) -    set(BOOST_PROGRAM_OPTIONS_LIBRARY boost_program_options-xgcc40-mt) -    set(BOOST_REGEX_LIBRARY boost_regex-xgcc40-mt) -    set(BOOST_SIGNALS_LIBRARY boost_signals-xgcc40-mt) -  elseif (LINUX) -    set(BOOST_PROGRAM_OPTIONS_LIBRARY boost_program_options-gcc41-mt) -    set(BOOST_REGEX_LIBRARY boost_regex-gcc41-mt) -    set(BOOST_SIGNALS_LIBRARY boost_signals-gcc41-mt) +      set(BOOST_SYSTEM_LIBRARY  +          optimized libboost_system-vc80-mt-${BOOST_VERSION} +          debug libboost_system-vc80-mt-gd-${BOOST_VERSION}) +      set(BOOST_FILESYSTEM_LIBRARY  +          optimized libboost_filesystem-vc80-mt-${BOOST_VERSION} +          debug libboost_filesystem-vc80-mt-gd-${BOOST_VERSION}) +    else(MSVC80) +      # MSVC 10.0 config +      set(BOOST_PROGRAM_OPTIONS_LIBRARY  +          optimized libboost_program_options-vc100-mt-${BOOST_VERSION} +          debug libboost_program_options-vc100-mt-gd-${BOOST_VERSION}) +      set(BOOST_REGEX_LIBRARY +          optimized libboost_regex-vc100-mt-${BOOST_VERSION} +          debug libboost_regex-vc100-mt-gd-${BOOST_VERSION}) +      set(BOOST_SYSTEM_LIBRARY  +          optimized libboost_system-vc100-mt-${BOOST_VERSION} +          debug libboost_system-vc100-mt-gd-${BOOST_VERSION}) +      set(BOOST_FILESYSTEM_LIBRARY  +          optimized libboost_filesystem-vc100-mt-${BOOST_VERSION} +          debug libboost_filesystem-vc100-mt-gd-${BOOST_VERSION})     +    endif (MSVC80) +  elseif (DARWIN OR LINUX) +    set(BOOST_PROGRAM_OPTIONS_LIBRARY boost_program_options) +    set(BOOST_REGEX_LIBRARY boost_regex) +    set(BOOST_SYSTEM_LIBRARY boost_system) +    set(BOOST_FILESYSTEM_LIBRARY boost_filesystem)    endif (WINDOWS)  endif (STANDALONE) diff --git a/indra/cmake/CARes.cmake b/indra/cmake/CARes.cmake index 1850b706ac..b0dac5b12f 100644 --- a/indra/cmake/CARes.cmake +++ b/indra/cmake/CARes.cmake @@ -13,10 +13,7 @@ else (STANDALONE)      if (WINDOWS)          set(CARES_LIBRARIES areslib)      elseif (DARWIN) -        set(CARES_LIBRARIES -          optimized ${ARCH_PREBUILT_DIRS_RELEASE}/libcares.a -          debug ${ARCH_PREBUILT_DIRS_DEBUG}/libcares.a -          ) +       set(CARES_LIBRARIES cares)      else (WINDOWS)          set(CARES_LIBRARIES cares)      endif (WINDOWS) diff --git a/indra/cmake/CMakeLists.txt b/indra/cmake/CMakeLists.txt index 3f421b270b..89c1c3691a 100644 --- a/indra/cmake/CMakeLists.txt +++ b/indra/cmake/CMakeLists.txt @@ -20,7 +20,6 @@ set(cmake_SOURCE_FILES      CSharpMacros.cmake      DBusGlib.cmake      DirectX.cmake -    ELFIO.cmake      EXPAT.cmake      FindAPR.cmake      FindBerkeleyDB.cmake @@ -29,7 +28,6 @@ set(cmake_SOURCE_FILES      FindFMOD.cmake      FindGooglePerfTools.cmake      FindMono.cmake -    FindMT.cmake      FindMySQL.cmake      FindOpenJPEG.cmake      FindXmlRpcEpi.cmake @@ -85,7 +83,6 @@ source_group("Shared Rules" FILES ${cmake_SOURCE_FILES})  set(master_SOURCE_FILES      ../CMakeLists.txt -    ../develop.py      )  if (SERVER) diff --git a/indra/cmake/Copy3rdPartyLibs.cmake b/indra/cmake/Copy3rdPartyLibs.cmake index 1b08c3fd2e..4698116022 100644 --- a/indra/cmake/Copy3rdPartyLibs.cmake +++ b/indra/cmake/Copy3rdPartyLibs.cmake @@ -5,6 +5,7 @@  # VisualStudio.  include(CMakeCopyIfDifferent) +include(Linking)  ###################################################################  # set up platform specific lists of files that need to be copied @@ -16,7 +17,7 @@ if(WINDOWS)      #*******************************      # VIVOX - *NOTE: no debug version -    set(vivox_src_dir "${CMAKE_SOURCE_DIR}/newview/vivox-runtime/i686-win32") +    set(vivox_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      set(vivox_files          SLVoice.exe          libsndfile-1.dll @@ -30,24 +31,24 @@ if(WINDOWS)      #*******************************      # Misc shared libs  -    # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables -    # or ARCH_PREBUILT_DIRS -    set(debug_src_dir "${CMAKE_SOURCE_DIR}/../libraries/i686-win32/lib/debug") +    set(debug_src_dir "${ARCH_PREBUILT_DIRS_DEBUG}")      set(debug_files          openjpegd.dll          libapr-1.dll          libaprutil-1.dll          libapriconv-1.dll +        ssleay32.dll +        libeay32.dll          ) -    # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables -    # or ARCH_PREBUILT_DIRS -    set(release_src_dir "${CMAKE_SOURCE_DIR}/../libraries/i686-win32/lib/release") +    set(release_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      set(release_files          openjpeg.dll          libapr-1.dll          libaprutil-1.dll          libapriconv-1.dll +        ssleay32.dll +        libeay32.dll          )      if(USE_GOOGLE_PERFTOOLS) @@ -121,6 +122,62 @@ if (MSVC80)          set(third_party_targets ${third_party_targets} ${out_targets})      endif (EXISTS ${release_msvc8_redist_path}) +elseif (MSVC_VERSION EQUAL 1600) # VisualStudio 2010 +    FIND_PATH(debug_msvc10_redist_path msvcr100d.dll +        PATHS +        ${MSVC_DEBUG_REDIST_PATH} +         [HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\VisualStudio\\10.0\\Setup\\VC;ProductDir]/redist/Debug_NonRedist/x86/Microsoft.VC100.DebugCRT +        NO_DEFAULT_PATH +        NO_DEFAULT_PATH +        ) + +    if(EXISTS ${debug_msvc10_redist_path}) +        set(debug_msvc10_files +            msvcr100d.dll +            msvcp100d.dll +            ) + +        copy_if_different( +            ${debug_msvc10_redist_path} +            "${SHARED_LIB_STAGING_DIR_DEBUG}" +            out_targets +            ${debug_msvc10_files} +            ) +        set(third_party_targets ${third_party_targets} ${out_targets}) + +    endif () + +    FIND_PATH(release_msvc10_redist_path msvcr100.dll +        PATHS +        ${MSVC_REDIST_PATH} +         [HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\VisualStudio\\10.0\\Setup\\VC;ProductDir]/redist/x86/Microsoft.VC100.CRT +        NO_DEFAULT_PATH +        NO_DEFAULT_PATH +        ) + +    if(EXISTS ${release_msvc10_redist_path}) +        set(release_msvc10_files +            msvcr100.dll +            msvcp100.dll +            ) + +        copy_if_different( +            ${release_msvc10_redist_path} +            "${SHARED_LIB_STAGING_DIR_RELEASE}" +            out_targets +            ${release_msvc10_files} +            ) +        set(third_party_targets ${third_party_targets} ${out_targets}) + +        copy_if_different( +            ${release_msvc10_redist_path} +            "${SHARED_LIB_STAGING_DIR_RELWITHDEBINFO}" +            out_targets +            ${release_msvc10_files} +            ) +        set(third_party_targets ${third_party_targets} ${out_targets}) +           +    endif ()  endif (MSVC80)  elseif(DARWIN) @@ -128,7 +185,7 @@ elseif(DARWIN)      set(SHARED_LIB_STAGING_DIR_RELWITHDEBINFO   "${SHARED_LIB_STAGING_DIR}/RelWithDebInfo/Resources")      set(SHARED_LIB_STAGING_DIR_RELEASE          "${SHARED_LIB_STAGING_DIR}/Release/Resources") -    set(vivox_src_dir "${CMAKE_SOURCE_DIR}/newview/vivox-runtime/universal-darwin") +    set(vivox_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      set(vivox_files          SLVoice          libsndfile.dylib @@ -137,20 +194,16 @@ elseif(DARWIN)          libvivoxplatform.dylib          libvivoxsdk.dylib         ) -    # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables -    # or ARCH_PREBUILT_DIRS -    set(debug_src_dir "${CMAKE_SOURCE_DIR}/../libraries/universal-darwin/lib_debug") +    set(debug_src_dir "${ARCH_PREBUILT_DIRS_DEBUG}")      set(debug_files         ) -    # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables -    # or ARCH_PREBUILT_DIRS -    set(release_src_dir "${CMAKE_SOURCE_DIR}/../libraries/universal-darwin/lib_release") +    set(release_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      set(release_files -        libapr-1.0.3.7.dylib +        libapr-1.0.dylib          libapr-1.dylib -        libaprutil-1.0.3.8.dylib +        libaprutil-1.0.dylib          libaprutil-1.dylib -        libexpat.0.5.0.dylib +        libexpat.1.5.2.dylib          libexpat.dylib          libllqtwebkit.dylib          libndofdev.dylib @@ -167,7 +220,7 @@ elseif(LINUX)      set(SHARED_LIB_STAGING_DIR_RELWITHDEBINFO   "${SHARED_LIB_STAGING_DIR}")      set(SHARED_LIB_STAGING_DIR_RELEASE          "${SHARED_LIB_STAGING_DIR}") -    set(vivox_src_dir "${CMAKE_SOURCE_DIR}/newview/vivox-runtime/i686-linux") +    set(vivox_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      set(vivox_files          libsndfile.so.1          libortp.so @@ -178,20 +231,20 @@ elseif(LINUX)         )      # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables      # or ARCH_PREBUILT_DIRS -    set(debug_src_dir "${CMAKE_SOURCE_DIR}/../libraries/i686-linux/lib_debug") +    set(debug_src_dir "${ARCH_PREBUILT_DIRS_DEBUG}")      set(debug_files         )      # *TODO - update this to use LIBS_PREBUILT_DIR and LL_ARCH_DIR variables      # or ARCH_PREBUILT_DIRS -    set(release_src_dir "${CMAKE_SOURCE_DIR}/../libraries/i686-linux/lib_release_client") +    set(release_src_dir "${ARCH_PREBUILT_DIRS_RELEASE}")      # *FIX - figure out what to do with duplicate libalut.so here -brad      set(release_files          libapr-1.so.0          libaprutil-1.so.0          libatk-1.0.so          libbreakpad_client.so.0 -        libcrypto.so.0.9.7 -        libdb-4.2.so +        libcrypto.so.0.9.8 +        libdb-5.1.so          libexpat.so          libexpat.so.1          libgmock_main.so @@ -203,10 +256,11 @@ elseif(LINUX)          libopenal.so          libopenjpeg.so          libssl.so -        libstacktrace.so          libtcmalloc.so -        libuuid.so.1 -        libssl.so.0.9.7 +        libuuid.so.16 +        libuuid.so.16.0.22 +        libssl.so.0.9.8 +        libfontconfig.so.1.4.4         )      if (FMOD) diff --git a/indra/cmake/DBusGlib.cmake b/indra/cmake/DBusGlib.cmake index cfc4ccd404..83c08d3350 100644 --- a/indra/cmake/DBusGlib.cmake +++ b/indra/cmake/DBusGlib.cmake @@ -10,7 +10,7 @@ elseif (LINUX)    use_prebuilt_binary(dbusglib)    set(DBUSGLIB_FOUND ON FORCE BOOL)    set(DBUSGLIB_INCLUDE_DIRS -      ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/glib-2.0 +      ${LIBS_PREBUILT_DIR}/include/dbus        )    # We don't need to explicitly link against dbus-glib itself, because    # the viewer probes for the system's copy at runtime. diff --git a/indra/cmake/DirectX.cmake b/indra/cmake/DirectX.cmake index 29724ee2fc..b2a18805d4 100644 --- a/indra/cmake/DirectX.cmake +++ b/indra/cmake/DirectX.cmake @@ -3,6 +3,7 @@  if (VIEWER AND WINDOWS)    find_path(DIRECTX_INCLUDE_DIR dxdiag.h              "$ENV{DXSDK_DIR}/Include" +            "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (August 2009)/Include"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (March 2009)/Include"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (August 2008)/Include"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (June 2008)/Include" @@ -24,6 +25,7 @@ if (VIEWER AND WINDOWS)    find_path(DIRECTX_LIBRARY_DIR dxguid.lib              "$ENV{DXSDK_DIR}/Lib/x86" +            "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (August 2009)/Lib/x86"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (March 2009)/Lib/x86"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (August 2008)/Lib/x86"              "$ENV{PROGRAMFILES}/Microsoft DirectX SDK (June 2008)/Lib/x86" diff --git a/indra/cmake/ELFIO.cmake b/indra/cmake/ELFIO.cmake deleted file mode 100644 index e51993b0f7..0000000000 --- a/indra/cmake/ELFIO.cmake +++ /dev/null @@ -1,19 +0,0 @@ -# -*- cmake -*- -include(Prebuilt) - -set(ELFIO_FIND_QUIETLY ON) - -if (STANDALONE) -  include(FindELFIO) -elseif (LINUX) -  use_prebuilt_binary(elfio) -  set(ELFIO_LIBRARIES ELFIO) -  set(ELFIO_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include) -  set(ELFIO_FOUND "YES") -endif (STANDALONE) - -if (ELFIO_FOUND) -  add_definitions(-DLL_ELFBIN=1) -else (ELFIO_FOUND) -  set(ELFIO_INCLUDE_DIR "") -endif (ELFIO_FOUND) diff --git a/indra/cmake/FMOD.cmake b/indra/cmake/FMOD.cmake index dcf44cd642..cb5124812d 100644..100755 --- a/indra/cmake/FMOD.cmake +++ b/indra/cmake/FMOD.cmake @@ -1,26 +1,39 @@  # -*- cmake -*- -set(FMOD ON CACHE BOOL "Use FMOD sound library.") +# FMOD can be set when launching the make using the argument -DFMOD:BOOL=ON +# When building using proprietary binaries though (i.e. having access to LL private servers), +# we always build with FMOD. +# Open source devs should use the -DFMOD:BOOL=ON then if they want to build with FMOD, whether +# they are using STANDALONE or not. +if (INSTALL_PROPRIETARY) +  set(FMOD ON CACHE BOOL "Use FMOD sound library.") +endif (INSTALL_PROPRIETARY)  if (FMOD)    if (STANDALONE) +    # In that case, we use the version of the library installed on the system      set(FMOD_FIND_REQUIRED ON)      include(FindFMOD)    else (STANDALONE) -    if (INSTALL_PROPRIETARY) -      include(Prebuilt) -      use_prebuilt_binary(fmod) -    endif (INSTALL_PROPRIETARY) -     -    if (WINDOWS) -      set(FMOD_LIBRARY fmod) -    elseif (DARWIN) -      set(FMOD_LIBRARY fmod) -    elseif (LINUX) -      set(FMOD_LIBRARY fmod-3.75) -    endif (WINDOWS) - -    SET(FMOD_LIBRARIES ${FMOD_LIBRARY}) -    set(FMOD_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include) +    if (FMOD_LIBRARY AND FMOD_INCLUDE_DIR) +	  # If the path have been specified in the arguments, use that +      set(FMOD_LIBRARIES ${FMOD_LIBRARY}) +	  MESSAGE(STATUS "Using FMOD path: ${FMOD_LIBRARIES}, ${FMOD_INCLUDE_DIR}") +    else (FMOD_LIBRARY AND FMOD_INCLUDE_DIR) +	  # If not, we're going to try to get the package listed in autobuild.xml +	  # Note: if you're not using INSTALL_PROPRIETARY, the package URL should be local (file:/// URL)  +	  # as accessing the private LL location will fail if you don't have the credential +	  include(Prebuilt) +	  use_prebuilt_binary(fmod)     +      if (WINDOWS) +        set(FMOD_LIBRARY fmod) +      elseif (DARWIN) +        set(FMOD_LIBRARY fmod) +      elseif (LINUX) +        set(FMOD_LIBRARY fmod-3.75) +      endif (WINDOWS) +      set(FMOD_LIBRARIES ${FMOD_LIBRARY}) +      set(FMOD_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include) +    endif (FMOD_LIBRARY AND FMOD_INCLUDE_DIR)    endif (STANDALONE)  endif (FMOD) diff --git a/indra/cmake/FindAutobuild.cmake b/indra/cmake/FindAutobuild.cmake new file mode 100644 index 0000000000..45db2b6ed0 --- /dev/null +++ b/indra/cmake/FindAutobuild.cmake @@ -0,0 +1,41 @@ +# -*- cmake -*- +# +# Find the autobuild tool +# +# Output variables: +# +#   AUTOBUILD_EXECUTABLE - path to autobuild or pautobuild executable + +# *TODO - if cmake was executed by autobuild, autobuild will have set the AUTOBUILD env var +# update this to check for that case + +IF (NOT AUTOBUILD_EXECUTABLE) +    IF(WIN32) +      SET(AUTOBUILD_EXE_NAMES autobuild.cmd autobuild.exe) +    ELSE(WIN32) +      SET(AUTOBUILD_EXE_NAMES autobuild) +    ENDIF(WIN32) + +    SET(AUTOBUILD_EXECUTABLE) +    FIND_PROGRAM( +      AUTOBUILD_EXECUTABLE  +      NAMES ${AUTOBUILD_EXE_NAMES} +      PATHS  +	ENV PATH +	${CMAKE_SOURCE_DIR}/..  +	${CMAKE_SOURCE_DIR}/../.. +	${CMAKE_SOURCE_DIR}/../../.. +      PATH_SUFFIXES "/autobuild/bin/" +    ) + +    IF (AUTOBUILD_EXECUTABLE) +      GET_FILENAME_COMPONENT(_autobuild_name ${AUTOBUILD_EXECUTABLE} NAME_WE) +      MESSAGE(STATUS "Using autobuild at: ${AUTOBUILD_EXECUTABLE}") +    ELSE (AUTOBUILD_EXECUTABLE) +      IF (AUTOBUILD_FIND_REQUIRED) +	MESSAGE(FATAL_ERROR "Could not find autobuild executable") +      ENDIF (AUTOBUILD_FIND_REQUIRED) +    ENDIF (AUTOBUILD_EXECUTABLE) + +    MARK_AS_ADVANCED(AUTOBUILD_EXECUTABLE) +ENDIF (NOT AUTOBUILD_EXECUTABLE) diff --git a/indra/cmake/FindFMOD.cmake b/indra/cmake/FindFMOD.cmake index e60b386027..1ebbc8c96e 100644 --- a/indra/cmake/FindFMOD.cmake +++ b/indra/cmake/FindFMOD.cmake @@ -11,7 +11,7 @@  FIND_PATH(FMOD_INCLUDE_DIR fmod.h PATH_SUFFIXES fmod) -SET(FMOD_NAMES ${FMOD_NAMES} fmod fmodvc fmod-3.75) +SET(FMOD_NAMES ${FMOD_NAMES} fmod fmodvc fmodex fmod-3.75)  FIND_LIBRARY(FMOD_LIBRARY    NAMES ${FMOD_NAMES}    PATH_SUFFIXES fmod diff --git a/indra/cmake/FreeType.cmake b/indra/cmake/FreeType.cmake index 5f1aa26e89..43a9d282d0 100644 --- a/indra/cmake/FreeType.cmake +++ b/indra/cmake/FreeType.cmake @@ -9,7 +9,7 @@ else (STANDALONE)    use_prebuilt_binary(freetype)    if (LINUX)      set(FREETYPE_INCLUDE_DIRS -        ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +        ${LIBS_PREBUILT_DIR}/include)    else (LINUX)      set(FREETYPE_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include)    endif (LINUX) diff --git a/indra/cmake/GStreamer010Plugin.cmake b/indra/cmake/GStreamer010Plugin.cmake index 0ca432da18..d2d0699bcd 100644 --- a/indra/cmake/GStreamer010Plugin.cmake +++ b/indra/cmake/GStreamer010Plugin.cmake @@ -13,9 +13,9 @@ elseif (LINUX)    set(GSTREAMER010_FOUND ON FORCE BOOL)    set(GSTREAMER010_PLUGINS_BASE_FOUND ON FORCE BOOL)    set(GSTREAMER010_INCLUDE_DIRS -      ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/gstreamer-0.10 -      ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/glib-2.0 -      ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/libxml2 +      ${LIBS_PREBUILT_DIR}/include/gstreamer-0.10 +      ${LIBS_PREBUILT_DIR}/include/glib-2.0 +      ${LIBS_PREBUILT_DIR}/include/libxml2        )    # We don't need to explicitly link against gstreamer itself, because    # LLMediaImplGStreamer probes for the system's copy at runtime. diff --git a/indra/cmake/GooglePerfTools.cmake b/indra/cmake/GooglePerfTools.cmake index 946fc6b375..6c784a3a76 100644 --- a/indra/cmake/GooglePerfTools.cmake +++ b/indra/cmake/GooglePerfTools.cmake @@ -4,7 +4,6 @@ include(Prebuilt)  if (STANDALONE)    include(FindGooglePerfTools)  else (STANDALONE) -  use_prebuilt_binary(google)    if (WINDOWS)      use_prebuilt_binary(google-perftools)      set(TCMALLOC_LIBRARIES  @@ -13,11 +12,11 @@ else (STANDALONE)      set(GOOGLE_PERFTOOLS_FOUND "YES")    endif (WINDOWS)    if (LINUX) +    use_prebuilt_binary(google-perftools)      set(TCMALLOC_LIBRARIES tcmalloc) -    set(STACKTRACE_LIBRARIES stacktrace)      set(PROFILER_LIBRARIES profiler)      set(GOOGLE_PERFTOOLS_INCLUDE_DIR -        ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +        ${LIBS_PREBUILT_DIR}/include)      set(GOOGLE_PERFTOOLS_FOUND "YES")    endif (LINUX)  endif (STANDALONE) diff --git a/indra/cmake/JPEG.cmake b/indra/cmake/JPEG.cmake index 9514d59f64..4f99efd602 100644 --- a/indra/cmake/JPEG.cmake +++ b/indra/cmake/JPEG.cmake @@ -12,10 +12,7 @@ else (STANDALONE)    if (LINUX)      set(JPEG_LIBRARIES jpeg)    elseif (DARWIN) -    set(JPEG_LIBRARIES -      optimized ${ARCH_PREBUILT_DIRS_RELEASE}/liblljpeg.a -      debug ${ARCH_PREBUILT_DIRS_DEBUG}/liblljpeg.a -      ) +    set(JPEG_LIBRARIES jpeg)    elseif (WINDOWS)      set(JPEG_LIBRARIES jpeglib)    endif (LINUX) diff --git a/indra/cmake/JsonCpp.cmake b/indra/cmake/JsonCpp.cmake index 7dd565be7c..499b00fb44 100644 --- a/indra/cmake/JsonCpp.cmake +++ b/indra/cmake/JsonCpp.cmake @@ -11,12 +11,12 @@ else (STANDALONE)    use_prebuilt_binary(jsoncpp)    if (WINDOWS)      set(JSONCPP_LIBRARIES  -      debug json_vc80d -      optimized json_vc80) +      debug json_vc100debug_libmt.lib +      optimized json_vc100_libmt)    elseif (DARWIN) -    set(JSONCPP_LIBRARIES json_mac-universal-gcc_libmt) +    set(JSONCPP_LIBRARIES libjson_linux-gcc-4.0.1_libmt.a)    elseif (LINUX) -    set(JSONCPP_LIBRARIES jsoncpp) +    set(JSONCPP_LIBRARIES libjson_linux-gcc-4.1.3_libmt.a)    endif (WINDOWS) -  set(JSONCPP_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/jsoncpp) +  set(JSONCPP_INCLUDE_DIRS "${LIBS_PREBUILT_DIR}/include/jsoncpp" "${LIBS_PREBUILT_DIR}/include/json")  endif (STANDALONE) diff --git a/indra/cmake/LLKDU.cmake b/indra/cmake/LLKDU.cmake index f5cbad03a6..e478b01f84 100644 --- a/indra/cmake/LLKDU.cmake +++ b/indra/cmake/LLKDU.cmake @@ -1,20 +1,21 @@  # -*- cmake -*- -include(Prebuilt) -# USE_KDU can be set when launching cmake or develop.py as an option using the argument -DUSE_KDU:BOOL=ON -# When building using proprietary binaries though (i.e. having access to LL private servers), we always build with KDU -if (INSTALL_PROPRIETARY AND NOT STANDALONE) -  set(USE_KDU ON) -endif (INSTALL_PROPRIETARY AND NOT STANDALONE) +# USE_KDU can be set when launching cmake as an option using the argument -DUSE_KDU:BOOL=ON +# When building using proprietary binaries though (i.e. having access to LL private servers),  +# we always build with KDU +if (INSTALL_PROPRIETARY) +  set(USE_KDU ON CACHE BOOL "Use Kakadu library.") +endif (INSTALL_PROPRIETARY)  if (USE_KDU) +  include(Prebuilt)    use_prebuilt_binary(kdu)    if (WINDOWS)      set(KDU_LIBRARY kdu.lib)    else (WINDOWS)      set(KDU_LIBRARY libkdu.a)    endif (WINDOWS) -  set(KDU_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include/kdu) +  set(KDU_INCLUDE_DIR ${AUTOBUILD_INSTALL_DIR}/include/kdu)    set(LLKDU_INCLUDE_DIRS ${LIBS_OPEN_DIR}/llkdu)    set(LLKDU_LIBRARIES llkdu)  endif (USE_KDU) diff --git a/indra/cmake/LLWindow.cmake b/indra/cmake/LLWindow.cmake index a5b9cf47a4..b4bb9a078a 100644 --- a/indra/cmake/LLWindow.cmake +++ b/indra/cmake/LLWindow.cmake @@ -18,7 +18,7 @@ else (STANDALONE)      use_prebuilt_binary(SDL)      set (SDL_FOUND TRUE)      set (SDL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/i686-linux) -    set (SDL_LIBRARY SDL) +    set (SDL_LIBRARY SDL directfb fusion direct)    endif (LINUX AND VIEWER)  endif (STANDALONE) diff --git a/indra/cmake/Linking.cmake b/indra/cmake/Linking.cmake index bca99caf2a..07db6ab257 100644 --- a/indra/cmake/Linking.cmake +++ b/indra/cmake/Linking.cmake @@ -1,32 +1,43 @@  # -*- cmake -*- +include(Variables) + +  if (NOT STANDALONE) +  set(ARCH_PREBUILT_DIRS ${AUTOBUILD_INSTALL_DIR}/lib) +  set(ARCH_PREBUILT_DIRS_RELEASE ${AUTOBUILD_INSTALL_DIR}/lib/release) +  set(ARCH_PREBUILT_DIRS_DEBUG ${AUTOBUILD_INSTALL_DIR}/lib/debug)    if (WINDOWS) -    set(ARCH_PREBUILT_DIRS ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib) -    set(ARCH_PREBUILT_DIRS_RELEASE ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib/release) -    set(ARCH_PREBUILT_DIRS_DEBUG ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib/debug) -    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs CACHE FILEPATH "Location of staged DLLs") -    set(EXE_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs CACHE FILEPATH "Location of staged executables") +    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs) +    set(EXE_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs)    elseif (LINUX) -    if (VIEWER) -      set(ARCH_PREBUILT_DIRS ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib_release_client) -    else (VIEWER) -      set(ARCH_PREBUILT_DIRS ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib_release) -    endif (VIEWER) -    set(ARCH_PREBUILT_DIRS_RELEASE ${ARCH_PREBUILT_DIRS}) -    set(ARCH_PREBUILT_DIRS_DEBUG ${ARCH_PREBUILT_DIRS}) -    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs/lib CACHE FILEPATH "Location of staged .sos") -    set(EXE_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs/bin CACHE FILEPATH "Location of staged executables") +    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs/lib) +    set(EXE_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs/bin)    elseif (DARWIN) -    set(ARCH_PREBUILT_DIRS_RELEASE ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/lib_release) -    set(ARCH_PREBUILT_DIRS ${ARCH_PREBUILT_DIRS_RELEASE}) -    set(ARCH_PREBUILT_DIRS_DEBUG ${ARCH_PREBUILT_DIRS_RELEASE}) -    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs CACHE FILEPATH "Location of staged DLLs") -    set(EXE_STAGING_DIR "${CMAKE_BINARY_DIR}/sharedlibs/\$(CONFIGURATION)" CACHE FILEPATH "Location of staged executables") +    set(SHARED_LIB_STAGING_DIR ${CMAKE_BINARY_DIR}/sharedlibs) +    set(EXE_STAGING_DIR "${CMAKE_BINARY_DIR}/sharedlibs/\$(CONFIGURATION)")    endif (WINDOWS)  endif (NOT STANDALONE) -link_directories(${ARCH_PREBUILT_DIRS}) +# Autobuild packages must provide 'release' versions of libraries, but may provide versions for +# specific build types.  AUTOBUILD_LIBS_INSTALL_DIRS lists first the build type directory and then +# the 'release' directory (as a default fallback). +# *NOTE - we have to take special care to use CMAKE_CFG_INTDIR on IDE generators (like mac and +# windows) and CMAKE_BUILD_TYPE on Makefile based generators (like linux).  The reason for this is +# that CMAKE_BUILD_TYPE is essentially meaningless at configuration time for IDE generators and +# CMAKE_CFG_INTDIR is meaningless at build time for Makefile generators +if(WINDOWS OR DARWIN) +  # the cmake xcode and VS generators implicitly append ${CMAKE_CFG_INTDIR} to the library paths for us +  # fortunately both windows and darwin are case insensitive filesystems so this works. +  set(AUTOBUILD_LIBS_INSTALL_DIRS "${AUTOBUILD_INSTALL_DIR}/lib/") +else(WINDOWS OR DARWIN) +  # else block is for linux and any other makefile based generators +  string(TOLOWER ${CMAKE_BUILD_TYPE} CMAKE_BUILD_TYPE_LOWER) +  set(AUTOBUILD_LIBS_INSTALL_DIRS ${AUTOBUILD_INSTALL_DIR}/lib/${CMAKE_BUILD_TYPE_LOWER}) +endif(WINDOWS OR DARWIN) + +list(APPEND AUTOBUILD_LIBS_INSTALL_DIRS ${ARCH_PREBUILT_DIRS_RELEASE}) +link_directories(${AUTOBUILD_LIBS_INSTALL_DIRS})  if (LINUX)    set(DL_LIBRARY dl) diff --git a/indra/cmake/MonoEmbed.cmake b/indra/cmake/MonoEmbed.cmake index 0f1f23309c..30890aed21 100644 --- a/indra/cmake/MonoEmbed.cmake +++ b/indra/cmake/MonoEmbed.cmake @@ -37,9 +37,9 @@ IF (DARWIN)  ELSE (DARWIN) -  SET(MONO_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include)   +  SET(MONO_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include)      SET(GLIB_2_0_PLATFORM_INCLUDE_DIR -    ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/glib-2.0) +    ${LIBS_PREBUILT_DIR}/include/glib-2.0)    SET(GLIB_2_0_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include/glib-2.0)    INCLUDE_DIRECTORIES( diff --git a/indra/cmake/MySQL.cmake b/indra/cmake/MySQL.cmake index e591fbc3d8..218482449d 100644 --- a/indra/cmake/MySQL.cmake +++ b/indra/cmake/MySQL.cmake @@ -7,7 +7,7 @@ use_prebuilt_binary(mysql)  if (LINUX)    if (WORD_SIZE EQUAL 32 OR DEBIAN_VERSION STREQUAL "3.1")      set(MYSQL_LIBRARIES mysqlclient) -    set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +    set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include)    else (WORD_SIZE EQUAL 32 OR DEBIAN_VERSION STREQUAL "3.1")      # Use the native MySQL library on a 64-bit system.      set(MYSQL_FIND_QUIETLY ON) @@ -16,9 +16,9 @@ if (LINUX)    endif (WORD_SIZE EQUAL 32 OR DEBIAN_VERSION STREQUAL "3.1")  elseif (WINDOWS)    set(MYSQL_LIBRARIES mysqlclient) -  set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +  set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include)  elseif (DARWIN) -  set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +  set(MYSQL_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include)    set(MYSQL_LIBRARIES      optimized ${ARCH_PREBUILT_DIRS_RELEASE}/libmysqlclient.a      debug ${ARCH_PREBUILT_DIRS_DEBUG}/libmysqlclient.a diff --git a/indra/cmake/OPENAL.cmake b/indra/cmake/OPENAL.cmake index d01c680ed1..a3e1fb924e 100644 --- a/indra/cmake/OPENAL.cmake +++ b/indra/cmake/OPENAL.cmake @@ -9,18 +9,26 @@ else (LINUX)  endif (LINUX)  if (OPENAL) +  set(OPENAL_LIB_INCLUDE_DIRS "${LIBS_PREBUILT_DIR}/include/AL")    if (STANDALONE)      include(FindPkgConfig)      include(FindOpenAL)      pkg_check_modules(OPENAL_LIB REQUIRED openal)      pkg_check_modules(FREEALUT_LIB REQUIRED freealut)    else (STANDALONE) -    use_prebuilt_binary(openal-soft) +    use_prebuilt_binary(openal_soft)    endif (STANDALONE) -  set(OPENAL_LIBRARIES  -    openal -    alut +  if(WINDOWS) +    set(OPENAL_LIBRARIES  +      OpenAL32 +      alut      ) +  else() +    set(OPENAL_LIBRARIES  +      openal +      alut +    ) +  endif()  endif (OPENAL)  if (OPENAL) diff --git a/indra/cmake/OpenGL.cmake b/indra/cmake/OpenGL.cmake index 6a2b6811af..661666f00d 100644 --- a/indra/cmake/OpenGL.cmake +++ b/indra/cmake/OpenGL.cmake @@ -5,5 +5,5 @@ if (NOT STANDALONE)    use_prebuilt_binary(GL)    # possible glh_linear should have its own .cmake file instead    use_prebuilt_binary(glh_linear) -  set(GLEXT_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +  set(GLEXT_INCLUDE_DIR ${LIBS_PREBUILT_DIR}/include)  endif (NOT STANDALONE) diff --git a/indra/cmake/OpenSSL.cmake b/indra/cmake/OpenSSL.cmake index 81584c09ea..5982ee9a49 100644 --- a/indra/cmake/OpenSSL.cmake +++ b/indra/cmake/OpenSSL.cmake @@ -13,11 +13,11 @@ else (STANDALONE)    else (WINDOWS)      set(OPENSSL_LIBRARIES ssl)    endif (WINDOWS) -  set(OPENSSL_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include) +  set(OPENSSL_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include)  endif (STANDALONE)  if (LINUX)    set(CRYPTO_LIBRARIES crypto)  elseif (DARWIN) -  set(CRYPTO_LIBRARIES llcrypto) +  set(CRYPTO_LIBRARIES crypto)  endif (LINUX) diff --git a/indra/cmake/PNG.cmake b/indra/cmake/PNG.cmake index f6522d9e2f..913c575672 100644 --- a/indra/cmake/PNG.cmake +++ b/indra/cmake/PNG.cmake @@ -8,6 +8,14 @@ if (STANDALONE)    include(FindPNG)  else (STANDALONE)    use_prebuilt_binary(libpng) -  set(PNG_LIBRARIES png12) -  set(PNG_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/libpng12) +  if (WINDOWS) +    set(PNG_LIBRARIES libpng15) +    set(PNG_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/libpng15) +  elseif(DARWIN) +    set(PNG_LIBRARIES png15) +    set(PNG_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/libpng15) +  else() +    set(PNG_LIBRARIES png15) +    set(PNG_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/libpng15) +  endif()  endif (STANDALONE) diff --git a/indra/cmake/Prebuilt.cmake b/indra/cmake/Prebuilt.cmake index a91519278c..1b60d176f1 100644 --- a/indra/cmake/Prebuilt.cmake +++ b/indra/cmake/Prebuilt.cmake @@ -1,36 +1,31 @@  # -*- cmake -*- -include(Python) -include(FindSCP) +include(FindAutobuild)  macro (use_prebuilt_binary _binary) -  if (NOT STANDALONE) +  if (NOT DEFINED STANDALONE_${_binary}) +    set(STANDALONE_${_binary} ${STANDALONE}) +  endif (NOT DEFINED STANDALONE_${_binary}) + +  if (NOT STANDALONE_${_binary})      if(${CMAKE_BINARY_DIR}/temp/sentinel_installed IS_NEWER_THAN ${CMAKE_BINARY_DIR}/temp/${_binary}_installed)        if(INSTALL_PROPRIETARY)          include(FindSCP) -        if(DEBUG_PREBUILT) -          message("cd ${SCRIPTS_DIR} && ${PYTHON_EXECUTABLE} install.py --install-dir=${CMAKE_SOURCE_DIR}/.. --scp=${SCP_EXECUTABLE} ${_binary}") -        endif(DEBUG_PREBUILT) -        execute_process(COMMAND ${PYTHON_EXECUTABLE} -          install.py  -          --install-dir=${CMAKE_SOURCE_DIR}/.. -          --scp=${SCP_EXECUTABLE} -          ${_binary} -          WORKING_DIRECTORY ${SCRIPTS_DIR} -          RESULT_VARIABLE ${_binary}_installed -          ) -      else(INSTALL_PROPRIETARY) -        if(DEBUG_PREBUILT) -          message("cd ${SCRIPTS_DIR} && ${PYTHON_EXECUTABLE} install.py --install-dir=${CMAKE_SOURCE_DIR}/.. ${_binary}") -        endif(DEBUG_PREBUILT) -        execute_process(COMMAND ${PYTHON_EXECUTABLE} -          install.py  -          --install-dir=${CMAKE_SOURCE_DIR}/.. -          ${_binary} -          WORKING_DIRECTORY ${SCRIPTS_DIR} -          RESULT_VARIABLE ${_binary}_installed -          )        endif(INSTALL_PROPRIETARY) +	  if(DEBUG_PREBUILT) +		message("cd ${CMAKE_SOURCE_DIR} && ${AUTOBUILD_EXECUTABLE} install +		--install-dir=${AUTOBUILD_INSTALL_DIR} +		--skip-license-check +		${_binary} ") +	  endif(DEBUG_PREBUILT) +	  execute_process(COMMAND "${AUTOBUILD_EXECUTABLE}" +		install +		--install-dir=${AUTOBUILD_INSTALL_DIR} +		--skip-license-check +		${_binary} +		WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}" +		RESULT_VARIABLE ${_binary}_installed +		)        file(WRITE ${CMAKE_BINARY_DIR}/temp/${_binary}_installed "${${_binary}_installed}")      else(${CMAKE_BINARY_DIR}/temp/sentinel_installed IS_NEWER_THAN ${CMAKE_BINARY_DIR}/temp/${_binary}_installed)        set(${_binary}_installed 0) @@ -40,5 +35,5 @@ macro (use_prebuilt_binary _binary)                "Failed to download or unpack prebuilt '${_binary}'."                " Process returned ${${_binary}_installed}.")      endif (NOT ${_binary}_installed EQUAL 0) -  endif (NOT STANDALONE) +  endif (NOT STANDALONE_${_binary})  endmacro (use_prebuilt_binary _binary) diff --git a/indra/cmake/QuickTimePlugin.cmake b/indra/cmake/QuickTimePlugin.cmake index 02f432e3c1..012f4e20d8 100644 --- a/indra/cmake/QuickTimePlugin.cmake +++ b/indra/cmake/QuickTimePlugin.cmake @@ -33,7 +33,7 @@ elseif (WINDOWS)    endif (DEBUG_QUICKTIME_LIBRARY AND RELEASE_QUICKTIME_LIBRARY)    include_directories( -    ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/quicktime +    ${LIBS_PREBUILT_DIR}/include/quicktime      "${QUICKTIME_SDK_DIR}\\CIncludes"      )  endif (DARWIN) diff --git a/indra/cmake/UI.cmake b/indra/cmake/UI.cmake index f529f5b644..91e5258fb7 100644 --- a/indra/cmake/UI.cmake +++ b/indra/cmake/UI.cmake @@ -51,11 +51,11 @@ else (STANDALONE)    endif (LINUX)    include_directories ( -      ${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include +      ${LIBS_PREBUILT_DIR}/include        ${LIBS_PREBUILT_DIR}/include        )    foreach(include ${${LL_ARCH}_INCLUDES}) -      include_directories(${LIBS_PREBUILT_DIR}/${LL_ARCH_DIR}/include/${include}) +      include_directories(${LIBS_PREBUILT_DIR}/include/${include})    endforeach(include)  endif (STANDALONE) diff --git a/indra/cmake/Variables.cmake b/indra/cmake/Variables.cmake index 0d7156b91d..77dd34d122 100644 --- a/indra/cmake/Variables.cmake +++ b/indra/cmake/Variables.cmake @@ -17,6 +17,10 @@  # Relative and absolute paths to subtrees. +if(NOT DEFINED COMMON_CMAKE_DIR) +    set(COMMON_CMAKE_DIR "${CMAKE_SOURCE_DIR}/cmake") +endif(NOT DEFINED COMMON_CMAKE_DIR) +  set(LIBS_CLOSED_PREFIX)  set(LIBS_OPEN_PREFIX)  set(LIBS_SERVER_PREFIX) @@ -26,24 +30,40 @@ set(VIEWER_PREFIX)  set(INTEGRATION_TESTS_PREFIX)  set(LL_TESTS ON CACHE BOOL "Build and run unit and integration tests (disable for build timing runs to reduce variation") -set(LIBS_CLOSED_DIR ${CMAKE_SOURCE_DIR}/${LIBS_CLOSED_PREFIX}) -set(LIBS_OPEN_DIR ${CMAKE_SOURCE_DIR}/${LIBS_OPEN_PREFIX}) +if(LIBS_CLOSED_DIR) +  file(TO_CMAKE_PATH "${LIBS_CLOSED_DIR}" LIBS_CLOSED_DIR) +else(LIBS_CLOSED_DIR) +  set(LIBS_CLOSED_DIR ${CMAKE_SOURCE_DIR}/${LIBS_CLOSED_PREFIX}) +endif(LIBS_CLOSED_DIR) +if(LIBS_COMMON_DIR) +  file(TO_CMAKE_PATH "${LIBS_COMMON_DIR}" LIBS_COMMON_DIR) +else(LIBS_COMMON_DIR) +  set(LIBS_COMMON_DIR ${CMAKE_SOURCE_DIR}/${LIBS_OPEN_PREFIX}) +endif(LIBS_COMMON_DIR) +set(LIBS_OPEN_DIR ${LIBS_COMMON_DIR}) +  set(LIBS_SERVER_DIR ${CMAKE_SOURCE_DIR}/${LIBS_SERVER_PREFIX})  set(SCRIPTS_DIR ${CMAKE_SOURCE_DIR}/${SCRIPTS_PREFIX})  set(SERVER_DIR ${CMAKE_SOURCE_DIR}/${SERVER_PREFIX})  set(VIEWER_DIR ${CMAKE_SOURCE_DIR}/${VIEWER_PREFIX}) -set(LIBS_PREBUILT_DIR ${CMAKE_SOURCE_DIR}/../libraries CACHE PATH +set(AUTOBUILD_INSTALL_DIR ${CMAKE_BINARY_DIR}/packages) + +set(LIBS_PREBUILT_DIR ${AUTOBUILD_INSTALL_DIR} CACHE PATH      "Location of prebuilt libraries.")  if (EXISTS ${CMAKE_SOURCE_DIR}/Server.cmake)    # We use this as a marker that you can try to use the proprietary libraries.    set(INSTALL_PROPRIETARY ON CACHE BOOL "Install proprietary binaries")  endif (EXISTS ${CMAKE_SOURCE_DIR}/Server.cmake) -  set(TEMPLATE_VERIFIER_OPTIONS "" CACHE STRING "Options for scripts/template_verifier.py")  set(TEMPLATE_VERIFIER_MASTER_URL "http://bitbucket.org/lindenlab/master-message-template/raw/tip/message_template.msg" CACHE STRING "Location of the master message template") +if (NOT CMAKE_BUILD_TYPE) +  set(CMAKE_BUILD_TYPE RelWithDebInfo CACHE STRING +      "Build type.  One of: Debug Release RelWithDebInfo" FORCE) +endif (NOT CMAKE_BUILD_TYPE) +  if (${CMAKE_SYSTEM_NAME} MATCHES "Windows")    set(WINDOWS ON BOOL FORCE)    set(ARCH i686) @@ -56,20 +76,19 @@ if (${CMAKE_SYSTEM_NAME} MATCHES "Linux")    set(LINUX ON BOOl FORCE)    # If someone has specified a word size, use that to determine the -  # architecture.  Otherwise, let the compiler specify the word size. -  # Using uname will break under chroots and other cross arch compiles. RC +  # architecture.  Otherwise, let the architecture specify the word size.    if (WORD_SIZE EQUAL 32)      set(ARCH i686)    elseif (WORD_SIZE EQUAL 64)      set(ARCH x86_64)    else (WORD_SIZE EQUAL 32) -    if(CMAKE_SIZEOF_VOID_P MATCHES 4) -      set(ARCH i686) -      set(WORD_SIZE 32) -    else(CMAKE_SIZEOF_VOID_P MATCHES 4) -      set(ARCH x86_64) +    execute_process(COMMAND uname -m COMMAND sed s/i.86/i686/ +                    OUTPUT_VARIABLE ARCH OUTPUT_STRIP_TRAILING_WHITESPACE) +    if (ARCH STREQUAL x86_64)        set(WORD_SIZE 64) -    endif(CMAKE_SIZEOF_VOID_P MATCHES 4) +    else (ARCH STREQUAL x86_64) +      set(WORD_SIZE 32) +    endif (ARCH STREQUAL x86_64)    endif (WORD_SIZE EQUAL 32)    set(LL_ARCH ${ARCH}_linux) @@ -78,25 +97,12 @@ endif (${CMAKE_SYSTEM_NAME} MATCHES "Linux")  if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")    set(DARWIN 1) - -  # NOTE: If specifying a different SDK with CMAKE_OSX_SYSROOT at configure -  # time you should also specify CMAKE_OSX_DEPLOYMENT_TARGET explicitly, -  # otherwise CMAKE_OSX_SYSROOT will be overridden here. We can't just check -  # for it being unset, as it gets set to the system default :( - -  # Default to building against the 10.4 SDK if no deployment target is -  # specified. -  if (NOT CMAKE_OSX_DEPLOYMENT_TARGET) -    # NOTE: setting -isysroot is NOT adequate: http://lists.apple.com/archives/Xcode-users/2007/Oct/msg00696.html -    # see http://public.kitware.com/Bug/view.php?id=9959 + poppy -    set(CMAKE_OSX_SYSROOT /Developer/SDKs/MacOSX10.5.sdk) -    set(CMAKE_OSX_DEPLOYMENT_TARGET 10.4) -  endif (NOT CMAKE_OSX_DEPLOYMENT_TARGET) - -  # GCC 4.2 is incompatible with the MacOSX 10.4 SDK -  if (${CMAKE_OSX_SYSROOT} MATCHES "10.4u") -    set(CMAKE_XCODE_ATTRIBUTE_GCC_VERSION "4.0") -  endif (${CMAKE_OSX_SYSROOT} MATCHES "10.4u") +   +  # To support a different SDK update these Xcode settings: +  set(CMAKE_OSX_DEPLOYMENT_TARGET 10.5) +  set(CMAKE_OSX_SYSROOT /Developer/SDKs/MacOSX10.5.sdk) +  set(CMAKE_XCODE_ATTRIBUTE_GCC_VERSION "4.2") +  set(CMAKE_XCODE_ATTRIBUTE_DEBUG_INFORMATION_FORMAT "DWARF with dSYM File")    # NOTE: To attempt an i386/PPC Universal build, add this on the configure line:    # -DCMAKE_OSX_ARCHITECTURES:STRING='i386;ppc' @@ -127,6 +133,7 @@ set(VIEWER ON CACHE BOOL "Build Second Life viewer.")  set(VIEWER_CHANNEL "LindenDeveloper" CACHE STRING "Viewer Channel Name")  set(VIEWER_LOGIN_CHANNEL ${VIEWER_CHANNEL} CACHE STRING "Fake login channel for A/B Testing") +set(VERSION_BUILD "0" CACHE STRING "Revision number passed in from the outside")  set(STANDALONE OFF CACHE BOOL "Do not use Linden-supplied prebuilt libraries.")  if (NOT STANDALONE AND EXISTS ${CMAKE_SOURCE_DIR}/llphysics) @@ -143,6 +150,7 @@ For more information, please see JIRA DEV-14943 - Cmake Linux cannot build both  endif (LINUX AND SERVER AND VIEWER) -set(USE_PRECOMPILED_HEADERS ON CACHE BOOL "Enable use of precompiled header directives where supported.") +set(USE_PRECOMPILED_HEADERS OFF CACHE BOOL "Enable use of precompiled header directives where supported.")  source_group("CMake Rules" FILES CMakeLists.txt) + diff --git a/indra/cmake/WebKitLibPlugin.cmake b/indra/cmake/WebKitLibPlugin.cmake index 1f5b0f5d84..0f5a81c020 100644 --- a/indra/cmake/WebKitLibPlugin.cmake +++ b/indra/cmake/WebKitLibPlugin.cmake @@ -62,16 +62,13 @@ elseif (LINUX)    else (STANDALONE)      set(WEBKIT_PLUGIN_LIBRARIES          llqtwebkit - -        qgif -        qjpeg -          QtWebKit          QtOpenGL          QtNetwork          QtGui          QtCore - +        qgif +        qjpeg          jpeg          fontconfig          X11 diff --git a/indra/cmake/XmlRpcEpi.cmake b/indra/cmake/XmlRpcEpi.cmake index 107d1926ba..5bd4848245 100644 --- a/indra/cmake/XmlRpcEpi.cmake +++ b/indra/cmake/XmlRpcEpi.cmake @@ -9,7 +9,10 @@ if (STANDALONE)  else (STANDALONE)      use_prebuilt_binary(xmlrpc-epi)      if (WINDOWS) -        set(XMLRPCEPI_LIBRARIES xmlrpcepi) +        set(XMLRPCEPI_LIBRARIES  +            debug xmlrpc-epid +            optimized xmlrpc-epi +        )      else (WINDOWS)          set(XMLRPCEPI_LIBRARIES xmlrpc-epi)      endif (WINDOWS) diff --git a/indra/cmake/run_build_test.py b/indra/cmake/run_build_test.py index 320a9be8ab..320a9be8ab 100644..100755 --- a/indra/cmake/run_build_test.py +++ b/indra/cmake/run_build_test.py | 
