|
|
|
@ -1,90 +1,83 @@ |
|
|
|
|
|
|
|
|
|
set(common_HEADERS internal.h mappings.h |
|
|
|
|
"${GLFW_BINARY_DIR}/src/glfw_config.h" |
|
|
|
|
add_library(glfw "${GLFW_BINARY_DIR}/src/glfw_config.h" |
|
|
|
|
"${GLFW_SOURCE_DIR}/include/GLFW/glfw3.h" |
|
|
|
|
"${GLFW_SOURCE_DIR}/include/GLFW/glfw3native.h") |
|
|
|
|
set(common_SOURCES context.c init.c input.c monitor.c vulkan.c window.c) |
|
|
|
|
"${GLFW_SOURCE_DIR}/include/GLFW/glfw3native.h" |
|
|
|
|
internal.h mappings.h context.c init.c input.c monitor.c |
|
|
|
|
vulkan.c window.c) |
|
|
|
|
|
|
|
|
|
if (_GLFW_COCOA) |
|
|
|
|
set(glfw_HEADERS ${common_HEADERS} cocoa_platform.h cocoa_joystick.h |
|
|
|
|
posix_thread.h nsgl_context.h egl_context.h osmesa_context.h) |
|
|
|
|
set(glfw_SOURCES ${common_SOURCES} cocoa_init.m cocoa_joystick.m |
|
|
|
|
cocoa_monitor.m cocoa_window.m cocoa_time.c posix_thread.c |
|
|
|
|
target_sources(glfw PRIVATE cocoa_platform.h cocoa_joystick.h posix_thread.h |
|
|
|
|
nsgl_context.h egl_context.h osmesa_context.h |
|
|
|
|
cocoa_init.m cocoa_joystick.m cocoa_monitor.m |
|
|
|
|
cocoa_window.m cocoa_time.c posix_thread.c |
|
|
|
|
nsgl_context.m egl_context.c osmesa_context.c) |
|
|
|
|
elseif (_GLFW_WIN32) |
|
|
|
|
set(glfw_HEADERS ${common_HEADERS} win32_platform.h win32_joystick.h |
|
|
|
|
wgl_context.h egl_context.h osmesa_context.h) |
|
|
|
|
set(glfw_SOURCES ${common_SOURCES} win32_init.c win32_joystick.c |
|
|
|
|
win32_monitor.c win32_time.c win32_thread.c win32_window.c |
|
|
|
|
wgl_context.c egl_context.c osmesa_context.c) |
|
|
|
|
elseif (_GLFW_X11) |
|
|
|
|
set(glfw_HEADERS ${common_HEADERS} x11_platform.h xkb_unicode.h posix_time.h |
|
|
|
|
posix_thread.h glx_context.h egl_context.h osmesa_context.h) |
|
|
|
|
set(glfw_SOURCES ${common_SOURCES} x11_init.c x11_monitor.c x11_window.c |
|
|
|
|
xkb_unicode.c posix_time.c posix_thread.c glx_context.c |
|
|
|
|
target_sources(glfw PRIVATE win32_platform.h win32_joystick.h wgl_context.h |
|
|
|
|
egl_context.h osmesa_context.h win32_init.c |
|
|
|
|
win32_joystick.c win32_monitor.c win32_time.c |
|
|
|
|
win32_thread.c win32_window.c wgl_context.c |
|
|
|
|
egl_context.c osmesa_context.c) |
|
|
|
|
elseif (_GLFW_X11) |
|
|
|
|
target_sources(glfw PRIVATE x11_platform.h xkb_unicode.h posix_time.h |
|
|
|
|
posix_thread.h glx_context.h egl_context.h |
|
|
|
|
osmesa_context.h x11_init.c x11_monitor.c |
|
|
|
|
x11_window.c xkb_unicode.c posix_time.c |
|
|
|
|
posix_thread.c glx_context.c egl_context.c |
|
|
|
|
osmesa_context.c) |
|
|
|
|
elseif (_GLFW_WAYLAND) |
|
|
|
|
set(glfw_HEADERS ${common_HEADERS} wl_platform.h |
|
|
|
|
posix_time.h posix_thread.h xkb_unicode.h egl_context.h |
|
|
|
|
osmesa_context.h) |
|
|
|
|
set(glfw_SOURCES ${common_SOURCES} wl_init.c wl_monitor.c wl_window.c |
|
|
|
|
posix_time.c posix_thread.c xkb_unicode.c |
|
|
|
|
egl_context.c osmesa_context.c) |
|
|
|
|
target_sources(glfw PRIVATE wl_platform.h posix_time.h posix_thread.h |
|
|
|
|
xkb_unicode.h egl_context.h osmesa_context.h |
|
|
|
|
wl_init.c wl_monitor.c wl_window.c posix_time.c |
|
|
|
|
posix_thread.c xkb_unicode.c egl_context.c |
|
|
|
|
osmesa_context.c) |
|
|
|
|
elseif (_GLFW_OSMESA) |
|
|
|
|
target_sources(glfw PRIVATE null_platform.h null_joystick.h posix_time.h |
|
|
|
|
posix_thread.h osmesa_context.h null_init.c |
|
|
|
|
null_monitor.c null_window.c null_joystick.c |
|
|
|
|
posix_time.c posix_thread.c osmesa_context.c) |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
if (_GLFW_X11 OR _GLFW_WAYLAND) |
|
|
|
|
if ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") |
|
|
|
|
target_sources(glfw PRIVATE linux_joystick.h linux_joystick.c) |
|
|
|
|
else() |
|
|
|
|
target_sources(glfw PRIVATE null_joystick.h null_joystick.c) |
|
|
|
|
endif() |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
if (_GLFW_WAYLAND) |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/stable/xdg-shell/xdg-shell.xml" |
|
|
|
|
BASENAME xdg-shell) |
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/unstable/xdg-decoration/xdg-decoration-unstable-v1.xml" |
|
|
|
|
BASENAME xdg-decoration) |
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/stable/viewporter/viewporter.xml" |
|
|
|
|
BASENAME viewporter) |
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/unstable/relative-pointer/relative-pointer-unstable-v1.xml" |
|
|
|
|
BASENAME relative-pointer-unstable-v1) |
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/unstable/pointer-constraints/pointer-constraints-unstable-v1.xml" |
|
|
|
|
BASENAME pointer-constraints-unstable-v1) |
|
|
|
|
ecm_add_wayland_client_protocol(glfw_SOURCES |
|
|
|
|
ecm_add_wayland_client_protocol(GLFW_WAYLAND_PROTOCOL_SOURCES |
|
|
|
|
PROTOCOL |
|
|
|
|
"${WAYLAND_PROTOCOLS_PKGDATADIR}/unstable/idle-inhibit/idle-inhibit-unstable-v1.xml" |
|
|
|
|
BASENAME idle-inhibit-unstable-v1) |
|
|
|
|
elseif (_GLFW_OSMESA) |
|
|
|
|
set(glfw_HEADERS ${common_HEADERS} null_platform.h null_joystick.h |
|
|
|
|
posix_time.h posix_thread.h osmesa_context.h) |
|
|
|
|
set(glfw_SOURCES ${common_SOURCES} null_init.c null_monitor.c null_window.c |
|
|
|
|
null_joystick.c posix_time.c posix_thread.c osmesa_context.c) |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
if (_GLFW_X11 OR _GLFW_WAYLAND) |
|
|
|
|
if ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") |
|
|
|
|
set(glfw_HEADERS ${glfw_HEADERS} linux_joystick.h) |
|
|
|
|
set(glfw_SOURCES ${glfw_SOURCES} linux_joystick.c) |
|
|
|
|
else() |
|
|
|
|
set(glfw_HEADERS ${glfw_HEADERS} null_joystick.h) |
|
|
|
|
set(glfw_SOURCES ${glfw_SOURCES} null_joystick.c) |
|
|
|
|
endif() |
|
|
|
|
target_sources(glfw PRIVATE ${GLFW_WAYLAND_PROTOCOL_SOURCES}) |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
if (WIN32 AND BUILD_SHARED_LIBS) |
|
|
|
|
configure_file(glfw.rc.in glfw.rc @ONLY) |
|
|
|
|
set(glfw_SOURCES ${glfw_SOURCES} "${CMAKE_CURRENT_BINARY_DIR}/glfw.rc") |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
if (APPLE) |
|
|
|
|
# For some reason CMake didn't know about .m until version 3.16 |
|
|
|
|
set_source_files_properties(cocoa_init.m cocoa_joystick.m cocoa_monitor.m |
|
|
|
|
cocoa_window.m nsgl_context.m PROPERTIES |
|
|
|
|
LANGUAGE C) |
|
|
|
|
target_sources(glfw PRIVATE "${CMAKE_CURRENT_BINARY_DIR}/glfw.rc") |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
add_library(glfw ${glfw_SOURCES} ${glfw_HEADERS}) |
|
|
|
|
set_target_properties(glfw PROPERTIES |
|
|
|
|
OUTPUT_NAME ${GLFW_LIB_NAME} |
|
|
|
|
VERSION ${GLFW_VERSION_MAJOR}.${GLFW_VERSION_MINOR} |
|
|
|
@ -103,6 +96,13 @@ target_include_directories(glfw PRIVATE |
|
|
|
|
${glfw_INCLUDE_DIRS}) |
|
|
|
|
target_link_libraries(glfw PRIVATE ${glfw_LIBRARIES}) |
|
|
|
|
|
|
|
|
|
if (APPLE) |
|
|
|
|
# For some reason CMake didn't know about .m until version 3.16 |
|
|
|
|
set_source_files_properties(cocoa_init.m cocoa_joystick.m cocoa_monitor.m |
|
|
|
|
cocoa_window.m nsgl_context.m PROPERTIES |
|
|
|
|
LANGUAGE C) |
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
if ("${CMAKE_C_COMPILER_ID}" STREQUAL "GNU" OR |
|
|
|
|
"${CMAKE_C_COMPILER_ID}" STREQUAL "Clang" OR |
|
|
|
|
"${CMAKE_C_COMPILER_ID}" STREQUAL "AppleClang") |
|
|
|
|