project(FlightGear)
+# We have some custom .cmake scripts not in the official distribution.
+set(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/CMakeModules;${CMAKE_MODULE_PATH}")
+
if(${CMAKE_VERSION} VERSION_GREATER 2.8.4)
# use official include provided by latest CMake
include(GNUInstallDirs)
else()
# clean tar-balls do not contain SCM (.git/.gitignore/...) files.
set(CPACK_SOURCE_IGNORE_FILES
- "^${PROJECT_SOURCE_DIR}/.git;\\\\.gitignore;Makefile.am;~$;${CPACK_SOURCE_IGNORE_FILES}")
+ "Makefile.am;~$;${CPACK_SOURCE_IGNORE_FILES}")
endif()
+list (APPEND CPACK_SOURCE_IGNORE_FILES "${PROJECT_SOURCE_DIR}/.git;\\\\.gitignore")
+
# split version string into components, note CMAKE_MATCH_0 is the entire regexp match
string(REGEX MATCH "([0-9]+)\\.([0-9]+)\\.([0-9]+)" CPACK_PACKAGE_VERSION ${FLIGHTGEAR_VERSION} )
set(CPACK_PACKAGE_VERSION_MAJOR ${CMAKE_MATCH_1})
SET(CPACK_RESOURCE_FILE_LICENSE "${PROJECT_SOURCE_DIR}/COPYING")
SET(CPACK_RESOURCE_FILE_README "${PROJECT_SOURCE_DIR}/README")
-set(CPACK_SOURCE_GENERATOR TBZ2 ZIP)
+set(CPACK_SOURCE_GENERATOR TBZ2)
set(CPACK_SOURCE_PACKAGE_FILE_NAME "flightgear-${FLIGHTGEAR_VERSION}" CACHE INTERNAL "tarball basename")
include (CPack)
-# We have some custom .cmake scripts not in the official distribution.
-set(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/CMakeModules;${CMAKE_MODULE_PATH}")
-
if (FG_DATA_DIR)
message(STATUS "Using explicit data-dir: ${FG_DATA_DIR}")
else()
FORCE)
endif(NOT CMAKE_BUILD_TYPE)
-if($ENV{BUILD_ID})
+if(NOT "$ENV{BUILD_ID}" STREQUAL "")
set(HUDSON_BUILD_ID $ENV{BUILD_ID})
set(HUDSON_BUILD_NUMBER $ENV{BUILD_NUMBER})
message(STATUS "running under Hudson, build-number is ${HUDSON_BUILD_NUMBER}")
list(APPEND PLATFORM_LIBS ${COCOA_LIBRARY} ${CORESERVICES_LIBRARY})
elseif(CMAKE_SYSTEM_NAME MATCHES "Linux")
- # disabled while DBus / HAL / udev issues are decided
- #set(EVENT_INPUT_DEFAULT 1)
+ find_package(UDev)
+
+ if(UDEV_FOUND)
+ set(EVENT_INPUT_DEFAULT 1)
+ endif(UDEV_FOUND)
endif()
find_package(Git)
if(EVENT_INPUT)
message(STATUS "checking event-based Input")
-
+
IF(APPLE)
elseif(CMAKE_SYSTEM_NAME MATCHES "Linux")
- find_package(DBus)
- if(NOT DBUS_FOUND)
- message(WARNING "DBus not found, event input will be disabled")
- set(EVENT_INPUT 0)
- endif()
-
+ if(NOT UDEV_FOUND)
+ message(WARNING "UDev not found, event input is disabled!")
+ set(EVENT_INPUT 0)
+ else()
+ set(EVENT_INPUT_LIBRARIES ${UDEV_LIBRARIES})
+ endif()
+
else()
message(WARNING "event input is not supported on this platform yet")
endif()
+
+ # Keep PLIB INPUT enabled as long as EventInput does not replace current joystick configurations.
+ set(ENABLE_PLIB_JOYSTICK 1)
else(EVENT_INPUT)
set(ENABLE_PLIB_JOYSTICK 1)
endif(EVENT_INPUT)
find_package(OpenSceneGraph 3.0.0 REQUIRED osgText osgSim osgDB osgParticle osgFX osgUtil osgViewer osgGA)
if(ENABLE_FGADMIN)
- find_package(FLTK)
+ find_package(FLTK)
+
+ if ( FLTK_FOUND )
+ if ( X11_Xinerama_FOUND )
+ message(STATUS "Found X11_Xinerama...")
+ list(APPEND FLTK_LIBRARIES ${X11_Xinerama_LIB})
+ endif()
+
+ if ( X11_Xft_FOUND )
+ message(STATUS "Found X11_Xft...")
+ list(APPEND FLTK_LIBRARIES ${X11_Xft_LIB})
+ endif()
+
+ set( CMAKE_REQUIRED_INCLUDES ${FLTK_INCLUDE_DIR} )
+ set( CMAKE_REQUIRED_LIBRARIES ${FLTK_LIBRARIES} )
+
+ message(STATUS "Using FLTK_LIBRARIES for fgadmin: ${FLTK_LIBRARIES}")
+ endif ( FLTK_FOUND )
endif(ENABLE_FGADMIN)
if(ENABLE_LIBSVN)
endif(ENABLE_LIBSVN)
find_package(PLIB REQUIRED puaux pu js fnt)
-find_package(SimGear 2.5.0 REQUIRED)
+
+# FlightGear and SimGear versions need to match
+find_package(SimGear ${FLIGHTGEAR_VERSION} REQUIRED)
if (JPEG_FACTORY)
# check simgear was built with JPEG-factory support
${Boost_INCLUDE_DIRS}
${ZLIB_INCLUDE_DIR}
${ALUT_INCLUDE_DIR}
+ ${OPENGL_INCLUDE_DIR}
${OPENAL_INCLUDE_DIR}
${SIMGEAR_INCLUDE_DIR}
${PLIB_INCLUDE_DIR} )