remove glfw source in advance to use packaged version of glfw
@ -1,48 +0,0 @@
|
|||||||
# Usage:
|
|
||||||
# cmake -P GenerateMappings.cmake <path/to/mappings.h.in> <path/to/mappings.h>
|
|
||||||
|
|
||||||
set(source_url "https://raw.githubusercontent.com/gabomdq/SDL_GameControllerDB/master/gamecontrollerdb.txt")
|
|
||||||
set(source_path "${CMAKE_CURRENT_BINARY_DIR}/gamecontrollerdb.txt")
|
|
||||||
set(template_path "${CMAKE_ARGV3}")
|
|
||||||
set(target_path "${CMAKE_ARGV4}")
|
|
||||||
|
|
||||||
if (NOT EXISTS "${template_path}")
|
|
||||||
message(FATAL_ERROR "Failed to find template file ${template_path}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
file(DOWNLOAD "${source_url}" "${source_path}"
|
|
||||||
STATUS download_status
|
|
||||||
TLS_VERIFY on)
|
|
||||||
|
|
||||||
list(GET download_status 0 status_code)
|
|
||||||
list(GET download_status 1 status_message)
|
|
||||||
|
|
||||||
if (status_code)
|
|
||||||
message(FATAL_ERROR "Failed to download ${source_url}: ${status_message}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
file(STRINGS "${source_path}" lines)
|
|
||||||
foreach(line ${lines})
|
|
||||||
if (line MATCHES "^[0-9a-fA-F]")
|
|
||||||
if (line MATCHES "platform:Windows")
|
|
||||||
if (GLFW_WIN32_MAPPINGS)
|
|
||||||
set(GLFW_WIN32_MAPPINGS "${GLFW_WIN32_MAPPINGS}\n")
|
|
||||||
endif()
|
|
||||||
set(GLFW_WIN32_MAPPINGS "${GLFW_WIN32_MAPPINGS}\"${line}\",")
|
|
||||||
elseif (line MATCHES "platform:Mac OS X")
|
|
||||||
if (GLFW_COCOA_MAPPINGS)
|
|
||||||
set(GLFW_COCOA_MAPPINGS "${GLFW_COCOA_MAPPINGS}\n")
|
|
||||||
endif()
|
|
||||||
set(GLFW_COCOA_MAPPINGS "${GLFW_COCOA_MAPPINGS}\"${line}\",")
|
|
||||||
elseif (line MATCHES "platform:Linux")
|
|
||||||
if (GLFW_LINUX_MAPPINGS)
|
|
||||||
set(GLFW_LINUX_MAPPINGS "${GLFW_LINUX_MAPPINGS}\n")
|
|
||||||
endif()
|
|
||||||
set(GLFW_LINUX_MAPPINGS "${GLFW_LINUX_MAPPINGS}\"${line}\",")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
configure_file("${template_path}" "${target_path}" @ONLY NEWLINE_STYLE UNIX)
|
|
||||||
file(REMOVE "${source_path}")
|
|
||||||
|
|
@ -1,38 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>CFBundleDevelopmentRegion</key>
|
|
||||||
<string>English</string>
|
|
||||||
<key>CFBundleExecutable</key>
|
|
||||||
<string>${MACOSX_BUNDLE_EXECUTABLE_NAME}</string>
|
|
||||||
<key>CFBundleGetInfoString</key>
|
|
||||||
<string>${MACOSX_BUNDLE_INFO_STRING}</string>
|
|
||||||
<key>CFBundleIconFile</key>
|
|
||||||
<string>${MACOSX_BUNDLE_ICON_FILE}</string>
|
|
||||||
<key>CFBundleIdentifier</key>
|
|
||||||
<string>${MACOSX_BUNDLE_GUI_IDENTIFIER}</string>
|
|
||||||
<key>CFBundleInfoDictionaryVersion</key>
|
|
||||||
<string>6.0</string>
|
|
||||||
<key>CFBundleLongVersionString</key>
|
|
||||||
<string>${MACOSX_BUNDLE_LONG_VERSION_STRING}</string>
|
|
||||||
<key>CFBundleName</key>
|
|
||||||
<string>${MACOSX_BUNDLE_BUNDLE_NAME}</string>
|
|
||||||
<key>CFBundlePackageType</key>
|
|
||||||
<string>APPL</string>
|
|
||||||
<key>CFBundleShortVersionString</key>
|
|
||||||
<string>${MACOSX_BUNDLE_SHORT_VERSION_STRING}</string>
|
|
||||||
<key>CFBundleSignature</key>
|
|
||||||
<string>????</string>
|
|
||||||
<key>CFBundleVersion</key>
|
|
||||||
<string>${MACOSX_BUNDLE_BUNDLE_VERSION}</string>
|
|
||||||
<key>CSResourcesFileMapped</key>
|
|
||||||
<true/>
|
|
||||||
<key>LSRequiresCarbon</key>
|
|
||||||
<true/>
|
|
||||||
<key>NSHumanReadableCopyright</key>
|
|
||||||
<string>${MACOSX_BUNDLE_COPYRIGHT}</string>
|
|
||||||
<key>NSHighResolutionCapable</key>
|
|
||||||
<true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@ -1,13 +0,0 @@
|
|||||||
# Define the environment for cross-compiling with 32-bit MinGW-w64 Clang
|
|
||||||
SET(CMAKE_SYSTEM_NAME Windows) # Target system name
|
|
||||||
SET(CMAKE_SYSTEM_VERSION 1)
|
|
||||||
SET(CMAKE_C_COMPILER "i686-w64-mingw32-clang")
|
|
||||||
SET(CMAKE_CXX_COMPILER "i686-w64-mingw32-clang++")
|
|
||||||
SET(CMAKE_RC_COMPILER "i686-w64-mingw32-windres")
|
|
||||||
SET(CMAKE_RANLIB "i686-w64-mingw32-ranlib")
|
|
||||||
|
|
||||||
# Configure the behaviour of the find commands
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH "/usr/i686-w64-mingw32")
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
|
@ -1,13 +0,0 @@
|
|||||||
# Define the environment for cross-compiling with 32-bit MinGW-w64 GCC
|
|
||||||
SET(CMAKE_SYSTEM_NAME Windows) # Target system name
|
|
||||||
SET(CMAKE_SYSTEM_VERSION 1)
|
|
||||||
SET(CMAKE_C_COMPILER "i686-w64-mingw32-gcc")
|
|
||||||
SET(CMAKE_CXX_COMPILER "i686-w64-mingw32-g++")
|
|
||||||
SET(CMAKE_RC_COMPILER "i686-w64-mingw32-windres")
|
|
||||||
SET(CMAKE_RANLIB "i686-w64-mingw32-ranlib")
|
|
||||||
|
|
||||||
# Configure the behaviour of the find commands
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH "/usr/i686-w64-mingw32")
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
|
@ -1,17 +0,0 @@
|
|||||||
# Find EpollShim
|
|
||||||
# Once done, this will define
|
|
||||||
#
|
|
||||||
# EPOLLSHIM_FOUND - System has EpollShim
|
|
||||||
# EPOLLSHIM_INCLUDE_DIRS - The EpollShim include directories
|
|
||||||
# EPOLLSHIM_LIBRARIES - The libraries needed to use EpollShim
|
|
||||||
|
|
||||||
find_path(EPOLLSHIM_INCLUDE_DIRS NAMES sys/epoll.h sys/timerfd.h HINTS /usr/local/include/libepoll-shim)
|
|
||||||
find_library(EPOLLSHIM_LIBRARIES NAMES epoll-shim libepoll-shim HINTS /usr/local/lib)
|
|
||||||
|
|
||||||
if (EPOLLSHIM_INCLUDE_DIRS AND EPOLLSHIM_LIBRARIES)
|
|
||||||
set(EPOLLSHIM_FOUND TRUE)
|
|
||||||
endif (EPOLLSHIM_INCLUDE_DIRS AND EPOLLSHIM_LIBRARIES)
|
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
|
||||||
find_package_handle_standard_args(EpollShim DEFAULT_MSG EPOLLSHIM_LIBRARIES EPOLLSHIM_INCLUDE_DIRS)
|
|
||||||
mark_as_advanced(EPOLLSHIM_INCLUDE_DIRS EPOLLSHIM_LIBRARIES)
|
|
@ -1,18 +0,0 @@
|
|||||||
# Try to find OSMesa on a Unix system
|
|
||||||
#
|
|
||||||
# This will define:
|
|
||||||
#
|
|
||||||
# OSMESA_LIBRARIES - Link these to use OSMesa
|
|
||||||
# OSMESA_INCLUDE_DIR - Include directory for OSMesa
|
|
||||||
#
|
|
||||||
# Copyright (c) 2014 Brandon Schaefer <brandon.schaefer@canonical.com>
|
|
||||||
|
|
||||||
if (NOT WIN32)
|
|
||||||
|
|
||||||
find_package (PkgConfig)
|
|
||||||
pkg_check_modules (PKG_OSMESA QUIET osmesa)
|
|
||||||
|
|
||||||
set (OSMESA_INCLUDE_DIR ${PKG_OSMESA_INCLUDE_DIRS})
|
|
||||||
set (OSMESA_LIBRARIES ${PKG_OSMESA_LIBRARIES})
|
|
||||||
|
|
||||||
endif ()
|
|
@ -1,26 +0,0 @@
|
|||||||
find_package(PkgConfig)
|
|
||||||
|
|
||||||
pkg_check_modules(WaylandProtocols QUIET wayland-protocols>=${WaylandProtocols_FIND_VERSION})
|
|
||||||
|
|
||||||
execute_process(COMMAND ${PKG_CONFIG_EXECUTABLE} --variable=pkgdatadir wayland-protocols
|
|
||||||
OUTPUT_VARIABLE WaylandProtocols_PKGDATADIR
|
|
||||||
RESULT_VARIABLE _pkgconfig_failed)
|
|
||||||
if (_pkgconfig_failed)
|
|
||||||
message(FATAL_ERROR "Missing wayland-protocols pkgdatadir")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
string(REGEX REPLACE "[\r\n]" "" WaylandProtocols_PKGDATADIR "${WaylandProtocols_PKGDATADIR}")
|
|
||||||
|
|
||||||
find_package_handle_standard_args(WaylandProtocols
|
|
||||||
FOUND_VAR
|
|
||||||
WaylandProtocols_FOUND
|
|
||||||
REQUIRED_VARS
|
|
||||||
WaylandProtocols_PKGDATADIR
|
|
||||||
VERSION_VAR
|
|
||||||
WaylandProtocols_VERSION
|
|
||||||
HANDLE_COMPONENTS
|
|
||||||
)
|
|
||||||
|
|
||||||
set(WAYLAND_PROTOCOLS_FOUND ${WaylandProtocols_FOUND})
|
|
||||||
set(WAYLAND_PROTOCOLS_PKGDATADIR ${WaylandProtocols_PKGDATADIR})
|
|
||||||
set(WAYLAND_PROTOCOLS_VERSION ${WaylandProtocols_VERSION})
|
|
@ -1,34 +0,0 @@
|
|||||||
# - Try to find XKBCommon
|
|
||||||
# Once done, this will define
|
|
||||||
#
|
|
||||||
# XKBCOMMON_FOUND - System has XKBCommon
|
|
||||||
# XKBCOMMON_INCLUDE_DIRS - The XKBCommon include directories
|
|
||||||
# XKBCOMMON_LIBRARIES - The libraries needed to use XKBCommon
|
|
||||||
# XKBCOMMON_DEFINITIONS - Compiler switches required for using XKBCommon
|
|
||||||
|
|
||||||
find_package(PkgConfig)
|
|
||||||
pkg_check_modules(PC_XKBCOMMON QUIET xkbcommon)
|
|
||||||
set(XKBCOMMON_DEFINITIONS ${PC_XKBCOMMON_CFLAGS_OTHER})
|
|
||||||
|
|
||||||
find_path(XKBCOMMON_INCLUDE_DIR
|
|
||||||
NAMES xkbcommon/xkbcommon.h
|
|
||||||
HINTS ${PC_XKBCOMMON_INCLUDE_DIR} ${PC_XKBCOMMON_INCLUDE_DIRS}
|
|
||||||
)
|
|
||||||
|
|
||||||
find_library(XKBCOMMON_LIBRARY
|
|
||||||
NAMES xkbcommon
|
|
||||||
HINTS ${PC_XKBCOMMON_LIBRARY} ${PC_XKBCOMMON_LIBRARY_DIRS}
|
|
||||||
)
|
|
||||||
|
|
||||||
set(XKBCOMMON_LIBRARIES ${XKBCOMMON_LIBRARY})
|
|
||||||
set(XKBCOMMON_LIBRARY_DIRS ${XKBCOMMON_LIBRARY_DIRS})
|
|
||||||
set(XKBCOMMON_INCLUDE_DIRS ${XKBCOMMON_INCLUDE_DIR})
|
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
|
||||||
find_package_handle_standard_args(XKBCommon DEFAULT_MSG
|
|
||||||
XKBCOMMON_LIBRARY
|
|
||||||
XKBCOMMON_INCLUDE_DIR
|
|
||||||
)
|
|
||||||
|
|
||||||
mark_as_advanced(XKBCOMMON_LIBRARY XKBCOMMON_INCLUDE_DIR)
|
|
||||||
|
|
@ -1,13 +0,0 @@
|
|||||||
# Define the environment for cross-compiling with 64-bit MinGW-w64 Clang
|
|
||||||
SET(CMAKE_SYSTEM_NAME Windows) # Target system name
|
|
||||||
SET(CMAKE_SYSTEM_VERSION 1)
|
|
||||||
SET(CMAKE_C_COMPILER "x86_64-w64-mingw32-clang")
|
|
||||||
SET(CMAKE_CXX_COMPILER "x86_64-w64-mingw32-clang++")
|
|
||||||
SET(CMAKE_RC_COMPILER "x86_64-w64-mingw32-windres")
|
|
||||||
SET(CMAKE_RANLIB "x86_64-w64-mingw32-ranlib")
|
|
||||||
|
|
||||||
# Configure the behaviour of the find commands
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH "/usr/x86_64-w64-mingw32")
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
|
@ -1,13 +0,0 @@
|
|||||||
# Define the environment for cross-compiling with 64-bit MinGW-w64 GCC
|
|
||||||
SET(CMAKE_SYSTEM_NAME Windows) # Target system name
|
|
||||||
SET(CMAKE_SYSTEM_VERSION 1)
|
|
||||||
SET(CMAKE_C_COMPILER "x86_64-w64-mingw32-gcc")
|
|
||||||
SET(CMAKE_CXX_COMPILER "x86_64-w64-mingw32-g++")
|
|
||||||
SET(CMAKE_RC_COMPILER "x86_64-w64-mingw32-windres")
|
|
||||||
SET(CMAKE_RANLIB "x86_64-w64-mingw32-ranlib")
|
|
||||||
|
|
||||||
# Configure the behaviour of the find commands
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH "/usr/x86_64-w64-mingw32")
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
|
||||||
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
|
@ -1,918 +0,0 @@
|
|||||||
# This is the CMakeCache file.
|
|
||||||
# For build in directory: /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
# It was generated by CMake: /usr/bin/cmake
|
|
||||||
# You can edit this file to change values found and used by cmake.
|
|
||||||
# If you do not want to change any of the values, simply exit the editor.
|
|
||||||
# If you do want to change a value, simply edit, save, and exit the editor.
|
|
||||||
# The syntax for the file is as follows:
|
|
||||||
# KEY:TYPE=VALUE
|
|
||||||
# KEY is the name of a variable in the cache.
|
|
||||||
# TYPE is a hint to GUIs for the type of VALUE, DO NOT EDIT TYPE!.
|
|
||||||
# VALUE is the current value for the KEY.
|
|
||||||
|
|
||||||
########################
|
|
||||||
# EXTERNAL cache entries
|
|
||||||
########################
|
|
||||||
|
|
||||||
//Build shared libraries
|
|
||||||
BUILD_SHARED_LIBS:BOOL=OFF
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_ADDR2LINE:FILEPATH=/usr/bin/addr2line
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_AR:FILEPATH=/usr/bin/ar
|
|
||||||
|
|
||||||
//Choose the type of build, options are: None Debug Release RelWithDebInfo
|
|
||||||
// MinSizeRel ...
|
|
||||||
CMAKE_BUILD_TYPE:STRING=
|
|
||||||
|
|
||||||
//Enable/Disable color output during build.
|
|
||||||
CMAKE_COLOR_MAKEFILE:BOOL=ON
|
|
||||||
|
|
||||||
//C compiler
|
|
||||||
CMAKE_C_COMPILER:FILEPATH=/usr/bin/cc
|
|
||||||
|
|
||||||
//A wrapper around 'ar' adding the appropriate '--plugin' option
|
|
||||||
// for the GCC compiler
|
|
||||||
CMAKE_C_COMPILER_AR:FILEPATH=/usr/bin/gcc-ar-10
|
|
||||||
|
|
||||||
//A wrapper around 'ranlib' adding the appropriate '--plugin' option
|
|
||||||
// for the GCC compiler
|
|
||||||
CMAKE_C_COMPILER_RANLIB:FILEPATH=/usr/bin/gcc-ranlib-10
|
|
||||||
|
|
||||||
//Flags used by the C compiler during all build types.
|
|
||||||
CMAKE_C_FLAGS:STRING=
|
|
||||||
|
|
||||||
//Flags used by the C compiler during DEBUG builds.
|
|
||||||
CMAKE_C_FLAGS_DEBUG:STRING=-g
|
|
||||||
|
|
||||||
//Flags used by the C compiler during MINSIZEREL builds.
|
|
||||||
CMAKE_C_FLAGS_MINSIZEREL:STRING=-Os -DNDEBUG
|
|
||||||
|
|
||||||
//Flags used by the C compiler during RELEASE builds.
|
|
||||||
CMAKE_C_FLAGS_RELEASE:STRING=-O3 -DNDEBUG
|
|
||||||
|
|
||||||
//Flags used by the C compiler during RELWITHDEBINFO builds.
|
|
||||||
CMAKE_C_FLAGS_RELWITHDEBINFO:STRING=-O2 -g -DNDEBUG
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_DLLTOOL:FILEPATH=CMAKE_DLLTOOL-NOTFOUND
|
|
||||||
|
|
||||||
//Flags used by the linker during all build types.
|
|
||||||
CMAKE_EXE_LINKER_FLAGS:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during DEBUG builds.
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_DEBUG:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during MINSIZEREL builds.
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_MINSIZEREL:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during RELEASE builds.
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_RELEASE:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during RELWITHDEBINFO builds.
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO:STRING=
|
|
||||||
|
|
||||||
//Enable/Disable output of compile commands during generation.
|
|
||||||
CMAKE_EXPORT_COMPILE_COMMANDS:BOOL=
|
|
||||||
|
|
||||||
//User executables (bin)
|
|
||||||
CMAKE_INSTALL_BINDIR:PATH=bin
|
|
||||||
|
|
||||||
//Read-only architecture-independent data (DATAROOTDIR)
|
|
||||||
CMAKE_INSTALL_DATADIR:PATH=
|
|
||||||
|
|
||||||
//Read-only architecture-independent data root (share)
|
|
||||||
CMAKE_INSTALL_DATAROOTDIR:PATH=share
|
|
||||||
|
|
||||||
//Documentation root (DATAROOTDIR/doc/PROJECT_NAME)
|
|
||||||
CMAKE_INSTALL_DOCDIR:PATH=
|
|
||||||
|
|
||||||
//C header files (include)
|
|
||||||
CMAKE_INSTALL_INCLUDEDIR:PATH=include
|
|
||||||
|
|
||||||
//Info documentation (DATAROOTDIR/info)
|
|
||||||
CMAKE_INSTALL_INFODIR:PATH=
|
|
||||||
|
|
||||||
//Object code libraries (lib)
|
|
||||||
CMAKE_INSTALL_LIBDIR:PATH=lib
|
|
||||||
|
|
||||||
//Program executables (libexec)
|
|
||||||
CMAKE_INSTALL_LIBEXECDIR:PATH=libexec
|
|
||||||
|
|
||||||
//Locale-dependent data (DATAROOTDIR/locale)
|
|
||||||
CMAKE_INSTALL_LOCALEDIR:PATH=
|
|
||||||
|
|
||||||
//Modifiable single-machine data (var)
|
|
||||||
CMAKE_INSTALL_LOCALSTATEDIR:PATH=var
|
|
||||||
|
|
||||||
//Man documentation (DATAROOTDIR/man)
|
|
||||||
CMAKE_INSTALL_MANDIR:PATH=
|
|
||||||
|
|
||||||
//C header files for non-gcc (/usr/include)
|
|
||||||
CMAKE_INSTALL_OLDINCLUDEDIR:PATH=/usr/include
|
|
||||||
|
|
||||||
//Install path prefix, prepended onto install directories.
|
|
||||||
CMAKE_INSTALL_PREFIX:PATH=/usr/local
|
|
||||||
|
|
||||||
//Run-time variable data (LOCALSTATEDIR/run)
|
|
||||||
CMAKE_INSTALL_RUNSTATEDIR:PATH=
|
|
||||||
|
|
||||||
//System admin executables (sbin)
|
|
||||||
CMAKE_INSTALL_SBINDIR:PATH=sbin
|
|
||||||
|
|
||||||
//Modifiable architecture-independent data (com)
|
|
||||||
CMAKE_INSTALL_SHAREDSTATEDIR:PATH=com
|
|
||||||
|
|
||||||
//Read-only single-machine data (etc)
|
|
||||||
CMAKE_INSTALL_SYSCONFDIR:PATH=etc
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_LINKER:FILEPATH=/usr/bin/ld
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_MAKE_PROGRAM:FILEPATH=/usr/bin/gmake
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of modules during
|
|
||||||
// all build types.
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of modules during
|
|
||||||
// DEBUG builds.
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_DEBUG:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of modules during
|
|
||||||
// MINSIZEREL builds.
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of modules during
|
|
||||||
// RELEASE builds.
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_RELEASE:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of modules during
|
|
||||||
// RELWITHDEBINFO builds.
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO:STRING=
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_NM:FILEPATH=/usr/bin/nm
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_OBJCOPY:FILEPATH=/usr/bin/objcopy
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_OBJDUMP:FILEPATH=/usr/bin/objdump
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_DESCRIPTION:STATIC=
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_HOMEPAGE_URL:STATIC=
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_NAME:STATIC=GLFW
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_VERSION:STATIC=3.3.5
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_VERSION_MAJOR:STATIC=3
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_VERSION_MINOR:STATIC=3
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_VERSION_PATCH:STATIC=5
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
CMAKE_PROJECT_VERSION_TWEAK:STATIC=
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_RANLIB:FILEPATH=/usr/bin/ranlib
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_READELF:FILEPATH=/usr/bin/readelf
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of shared libraries
|
|
||||||
// during all build types.
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of shared libraries
|
|
||||||
// during DEBUG builds.
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_DEBUG:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of shared libraries
|
|
||||||
// during MINSIZEREL builds.
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of shared libraries
|
|
||||||
// during RELEASE builds.
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_RELEASE:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of shared libraries
|
|
||||||
// during RELWITHDEBINFO builds.
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO:STRING=
|
|
||||||
|
|
||||||
//If set, runtime paths are not added when installing shared libraries,
|
|
||||||
// but are added when building.
|
|
||||||
CMAKE_SKIP_INSTALL_RPATH:BOOL=NO
|
|
||||||
|
|
||||||
//If set, runtime paths are not added when using shared libraries.
|
|
||||||
CMAKE_SKIP_RPATH:BOOL=NO
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of static libraries
|
|
||||||
// during all build types.
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of static libraries
|
|
||||||
// during DEBUG builds.
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_DEBUG:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of static libraries
|
|
||||||
// during MINSIZEREL builds.
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of static libraries
|
|
||||||
// during RELEASE builds.
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_RELEASE:STRING=
|
|
||||||
|
|
||||||
//Flags used by the linker during the creation of static libraries
|
|
||||||
// during RELWITHDEBINFO builds.
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO:STRING=
|
|
||||||
|
|
||||||
//Path to a program.
|
|
||||||
CMAKE_STRIP:FILEPATH=/usr/bin/strip
|
|
||||||
|
|
||||||
//If this value is on, makefiles will be generated without the
|
|
||||||
// .SILENT directive, and all commands will be echoed to the console
|
|
||||||
// during the make. This is useful for debugging only. With Visual
|
|
||||||
// Studio IDE projects all commands are done without /nologo.
|
|
||||||
CMAKE_VERBOSE_MAKEFILE:BOOL=FALSE
|
|
||||||
|
|
||||||
//Doxygen documentation generation tool (http://www.doxygen.org)
|
|
||||||
DOXYGEN_EXECUTABLE:FILEPATH=DOXYGEN_EXECUTABLE-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
FREETYPE_INCLUDE_DIR_freetype2:PATH=/usr/include/freetype2
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
FREETYPE_INCLUDE_DIR_ft2build:PATH=/usr/include/freetype2
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
FREETYPE_LIBRARY_DEBUG:FILEPATH=FREETYPE_LIBRARY_DEBUG-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
FREETYPE_LIBRARY_RELEASE:FILEPATH=/usr/lib/x86_64-linux-gnu/libfreetype.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
Fontconfig_INCLUDE_DIR:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
Fontconfig_LIBRARY:FILEPATH=/usr/lib/x86_64-linux-gnu/libfontconfig.so
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
GLFW_BINARY_DIR:STATIC=/home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
//Build the GLFW documentation
|
|
||||||
GLFW_BUILD_DOCS:BOOL=ON
|
|
||||||
|
|
||||||
//Build the GLFW example programs
|
|
||||||
GLFW_BUILD_EXAMPLES:BOOL=ON
|
|
||||||
|
|
||||||
//Build the GLFW test programs
|
|
||||||
GLFW_BUILD_TESTS:BOOL=ON
|
|
||||||
|
|
||||||
//Generate installation target
|
|
||||||
GLFW_INSTALL:BOOL=ON
|
|
||||||
|
|
||||||
//Value Computed by CMake
|
|
||||||
GLFW_SOURCE_DIR:STATIC=/home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
//Use OSMesa for offscreen context creation
|
|
||||||
GLFW_USE_OSMESA:BOOL=OFF
|
|
||||||
|
|
||||||
//Use Wayland for window creation
|
|
||||||
GLFW_USE_WAYLAND:BOOL=OFF
|
|
||||||
|
|
||||||
//Assume the Vulkan loader is linked with the application
|
|
||||||
GLFW_VULKAN_STATIC:BOOL=OFF
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
MATH_LIBRARY:FILEPATH=/usr/lib/x86_64-linux-gnu/libm.so
|
|
||||||
|
|
||||||
//pkg-config executable
|
|
||||||
PKG_CONFIG_EXECUTABLE:FILEPATH=/usr/bin/pkg-config
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
RT_LIBRARY:FILEPATH=/usr/lib/x86_64-linux-gnu/librt.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_ICE_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_ICE_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libICE.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_SM_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_SM_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libSM.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_X11_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_X11_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libX11.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_X11_xcb_INCLUDE_PATH:PATH=X11_X11_xcb_INCLUDE_PATH-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_X11_xcb_LIB:FILEPATH=X11_X11_xcb_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_XRes_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_XRes_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXRes.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_XShm_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_XSync_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xaccessrules_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xaccessstr_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xau_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xau_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXau.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xcomposite_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xcomposite_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXcomposite.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xcursor_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xcursor_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXcursor.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xdamage_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xdamage_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXdamage.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xdmcp_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xdmcp_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXdmcp.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xext_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xext_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXext.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xfixes_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xfixes_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXfixes.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xft_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xft_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXft.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xi_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xi_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXi.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xinerama_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xinerama_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXinerama.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xkb_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xkblib_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xlib_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xmu_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xmu_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXmu.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xpm_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xpm_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXpm.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xrandr_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xrandr_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXrandr.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xrender_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xrender_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXrender.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xshape_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xss_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xss_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXss.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xt_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xt_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXt.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xtst_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xtst_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXtst.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xutil_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xv_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xv_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXv.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xxf86misc_INCLUDE_PATH:PATH=X11_Xxf86misc_INCLUDE_PATH-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xxf86misc_LIB:FILEPATH=X11_Xxf86misc_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_Xxf86vm_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_Xxf86vm_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libXxf86vm.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_dpms_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_xcb_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xcb_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libxcb.so
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_xcb_icccm_INCLUDE_PATH:PATH=X11_xcb_icccm_INCLUDE_PATH-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xcb_icccm_LIB:FILEPATH=X11_xcb_icccm_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xcb_xkb_LIB:FILEPATH=X11_xcb_xkb_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_xkbcommon_INCLUDE_PATH:PATH=X11_xkbcommon_INCLUDE_PATH-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xkbcommon_LIB:FILEPATH=X11_xkbcommon_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_xkbcommon_X11_INCLUDE_PATH:PATH=X11_xkbcommon_X11_INCLUDE_PATH-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xkbcommon_X11_LIB:FILEPATH=X11_xkbcommon_X11_LIB-NOTFOUND
|
|
||||||
|
|
||||||
//Path to a file.
|
|
||||||
X11_xkbfile_INCLUDE_PATH:PATH=/usr/include
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
X11_xkbfile_LIB:FILEPATH=/usr/lib/x86_64-linux-gnu/libxkbfile.so
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
pkgcfg_lib_PKG_FONTCONFIG_fontconfig:FILEPATH=/usr/lib/x86_64-linux-gnu/libfontconfig.so
|
|
||||||
|
|
||||||
//Path to a library.
|
|
||||||
pkgcfg_lib_PKG_FONTCONFIG_freetype:FILEPATH=/usr/lib/x86_64-linux-gnu/libfreetype.so
|
|
||||||
|
|
||||||
|
|
||||||
########################
|
|
||||||
# INTERNAL cache entries
|
|
||||||
########################
|
|
||||||
|
|
||||||
//ADVANCED property for variable: CMAKE_ADDR2LINE
|
|
||||||
CMAKE_ADDR2LINE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_AR
|
|
||||||
CMAKE_AR-ADVANCED:INTERNAL=1
|
|
||||||
//This is the directory where this CMakeCache.txt was created
|
|
||||||
CMAKE_CACHEFILE_DIR:INTERNAL=/home/niklas/Downloads/glfw-3.3.5
|
|
||||||
//Major version of cmake used to create the current loaded cache
|
|
||||||
CMAKE_CACHE_MAJOR_VERSION:INTERNAL=3
|
|
||||||
//Minor version of cmake used to create the current loaded cache
|
|
||||||
CMAKE_CACHE_MINOR_VERSION:INTERNAL=18
|
|
||||||
//Patch version of cmake used to create the current loaded cache
|
|
||||||
CMAKE_CACHE_PATCH_VERSION:INTERNAL=4
|
|
||||||
//ADVANCED property for variable: CMAKE_COLOR_MAKEFILE
|
|
||||||
CMAKE_COLOR_MAKEFILE-ADVANCED:INTERNAL=1
|
|
||||||
//Path to CMake executable.
|
|
||||||
CMAKE_COMMAND:INTERNAL=/usr/bin/cmake
|
|
||||||
//Path to cpack program executable.
|
|
||||||
CMAKE_CPACK_COMMAND:INTERNAL=/usr/bin/cpack
|
|
||||||
//Path to ctest program executable.
|
|
||||||
CMAKE_CTEST_COMMAND:INTERNAL=/usr/bin/ctest
|
|
||||||
//ADVANCED property for variable: CMAKE_C_COMPILER
|
|
||||||
CMAKE_C_COMPILER-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_COMPILER_AR
|
|
||||||
CMAKE_C_COMPILER_AR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_COMPILER_RANLIB
|
|
||||||
CMAKE_C_COMPILER_RANLIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_FLAGS
|
|
||||||
CMAKE_C_FLAGS-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_FLAGS_DEBUG
|
|
||||||
CMAKE_C_FLAGS_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_C_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_FLAGS_RELEASE
|
|
||||||
CMAKE_C_FLAGS_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_C_FLAGS_RELWITHDEBINFO
|
|
||||||
CMAKE_C_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_DLLTOOL
|
|
||||||
CMAKE_DLLTOOL-ADVANCED:INTERNAL=1
|
|
||||||
//Executable file format
|
|
||||||
CMAKE_EXECUTABLE_FORMAT:INTERNAL=ELF
|
|
||||||
//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS
|
|
||||||
CMAKE_EXE_LINKER_FLAGS-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_DEBUG
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_RELEASE
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO
|
|
||||||
CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_EXPORT_COMPILE_COMMANDS
|
|
||||||
CMAKE_EXPORT_COMPILE_COMMANDS-ADVANCED:INTERNAL=1
|
|
||||||
//Name of external makefile project generator.
|
|
||||||
CMAKE_EXTRA_GENERATOR:INTERNAL=
|
|
||||||
//Name of generator.
|
|
||||||
CMAKE_GENERATOR:INTERNAL=Unix Makefiles
|
|
||||||
//Generator instance identifier.
|
|
||||||
CMAKE_GENERATOR_INSTANCE:INTERNAL=
|
|
||||||
//Name of generator platform.
|
|
||||||
CMAKE_GENERATOR_PLATFORM:INTERNAL=
|
|
||||||
//Name of generator toolset.
|
|
||||||
CMAKE_GENERATOR_TOOLSET:INTERNAL=
|
|
||||||
//Have function connect
|
|
||||||
CMAKE_HAVE_CONNECT:INTERNAL=1
|
|
||||||
//Have function gethostbyname
|
|
||||||
CMAKE_HAVE_GETHOSTBYNAME:INTERNAL=1
|
|
||||||
//Test CMAKE_HAVE_LIBC_PTHREAD
|
|
||||||
CMAKE_HAVE_LIBC_PTHREAD:INTERNAL=
|
|
||||||
//Have library pthreads
|
|
||||||
CMAKE_HAVE_PTHREADS_CREATE:INTERNAL=
|
|
||||||
//Have library pthread
|
|
||||||
CMAKE_HAVE_PTHREAD_CREATE:INTERNAL=1
|
|
||||||
//Have include pthread.h
|
|
||||||
CMAKE_HAVE_PTHREAD_H:INTERNAL=1
|
|
||||||
//Have function remove
|
|
||||||
CMAKE_HAVE_REMOVE:INTERNAL=1
|
|
||||||
//Have function shmat
|
|
||||||
CMAKE_HAVE_SHMAT:INTERNAL=1
|
|
||||||
//Source directory with the top level CMakeLists.txt file for this
|
|
||||||
// project
|
|
||||||
CMAKE_HOME_DIRECTORY:INTERNAL=/home/niklas/Downloads/glfw-3.3.5
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_BINDIR
|
|
||||||
CMAKE_INSTALL_BINDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_DATADIR
|
|
||||||
CMAKE_INSTALL_DATADIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_DATAROOTDIR
|
|
||||||
CMAKE_INSTALL_DATAROOTDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_DOCDIR
|
|
||||||
CMAKE_INSTALL_DOCDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_INCLUDEDIR
|
|
||||||
CMAKE_INSTALL_INCLUDEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_INFODIR
|
|
||||||
CMAKE_INSTALL_INFODIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_LIBDIR
|
|
||||||
CMAKE_INSTALL_LIBDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_LIBEXECDIR
|
|
||||||
CMAKE_INSTALL_LIBEXECDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_LOCALEDIR
|
|
||||||
CMAKE_INSTALL_LOCALEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_LOCALSTATEDIR
|
|
||||||
CMAKE_INSTALL_LOCALSTATEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_MANDIR
|
|
||||||
CMAKE_INSTALL_MANDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_OLDINCLUDEDIR
|
|
||||||
CMAKE_INSTALL_OLDINCLUDEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_RUNSTATEDIR
|
|
||||||
CMAKE_INSTALL_RUNSTATEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_SBINDIR
|
|
||||||
CMAKE_INSTALL_SBINDIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_SHAREDSTATEDIR
|
|
||||||
CMAKE_INSTALL_SHAREDSTATEDIR-ADVANCED:INTERNAL=1
|
|
||||||
//Install .so files without execute permission.
|
|
||||||
CMAKE_INSTALL_SO_NO_EXE:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_INSTALL_SYSCONFDIR
|
|
||||||
CMAKE_INSTALL_SYSCONFDIR-ADVANCED:INTERNAL=1
|
|
||||||
//Have library ICE
|
|
||||||
CMAKE_LIB_ICE_HAS_ICECONNECTIONNUMBER:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_LINKER
|
|
||||||
CMAKE_LINKER-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MAKE_PROGRAM
|
|
||||||
CMAKE_MAKE_PROGRAM-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_DEBUG
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_RELEASE
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO
|
|
||||||
CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_NM
|
|
||||||
CMAKE_NM-ADVANCED:INTERNAL=1
|
|
||||||
//number of local generators
|
|
||||||
CMAKE_NUMBER_OF_MAKEFILES:INTERNAL=4
|
|
||||||
//ADVANCED property for variable: CMAKE_OBJCOPY
|
|
||||||
CMAKE_OBJCOPY-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_OBJDUMP
|
|
||||||
CMAKE_OBJDUMP-ADVANCED:INTERNAL=1
|
|
||||||
//Platform information initialized
|
|
||||||
CMAKE_PLATFORM_INFO_INITIALIZED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_RANLIB
|
|
||||||
CMAKE_RANLIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_READELF
|
|
||||||
CMAKE_READELF-ADVANCED:INTERNAL=1
|
|
||||||
//Path to CMake installation.
|
|
||||||
CMAKE_ROOT:INTERNAL=/usr/share/cmake-3.18
|
|
||||||
//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_DEBUG
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_RELEASE
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO
|
|
||||||
CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SKIP_INSTALL_RPATH
|
|
||||||
CMAKE_SKIP_INSTALL_RPATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_SKIP_RPATH
|
|
||||||
CMAKE_SKIP_RPATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_DEBUG
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_RELEASE
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO
|
|
||||||
CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: CMAKE_STRIP
|
|
||||||
CMAKE_STRIP-ADVANCED:INTERNAL=1
|
|
||||||
//uname command
|
|
||||||
CMAKE_UNAME:INTERNAL=/usr/bin/uname
|
|
||||||
//ADVANCED property for variable: CMAKE_VERBOSE_MAKEFILE
|
|
||||||
CMAKE_VERBOSE_MAKEFILE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: DOXYGEN_EXECUTABLE
|
|
||||||
DOXYGEN_EXECUTABLE-ADVANCED:INTERNAL=1
|
|
||||||
//Details about finding Threads
|
|
||||||
FIND_PACKAGE_MESSAGE_DETAILS_Threads:INTERNAL=[TRUE][v()]
|
|
||||||
//Details about finding X11
|
|
||||||
FIND_PACKAGE_MESSAGE_DETAILS_X11:INTERNAL=[/usr/include][/usr/lib/x86_64-linux-gnu/libX11.so][c ][v()]
|
|
||||||
//ADVANCED property for variable: FREETYPE_INCLUDE_DIR_freetype2
|
|
||||||
FREETYPE_INCLUDE_DIR_freetype2-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: FREETYPE_INCLUDE_DIR_ft2build
|
|
||||||
FREETYPE_INCLUDE_DIR_ft2build-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: FREETYPE_LIBRARY_DEBUG
|
|
||||||
FREETYPE_LIBRARY_DEBUG-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: FREETYPE_LIBRARY_RELEASE
|
|
||||||
FREETYPE_LIBRARY_RELEASE-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: Fontconfig_INCLUDE_DIR
|
|
||||||
Fontconfig_INCLUDE_DIR-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: Fontconfig_LIBRARY
|
|
||||||
Fontconfig_LIBRARY-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: MATH_LIBRARY
|
|
||||||
MATH_LIBRARY-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: PKG_CONFIG_EXECUTABLE
|
|
||||||
PKG_CONFIG_EXECUTABLE-ADVANCED:INTERNAL=1
|
|
||||||
PKG_FONTCONFIG_CFLAGS:INTERNAL=-I/usr/include/uuid;-I/usr/include/freetype2;-I/usr/include/libpng16
|
|
||||||
PKG_FONTCONFIG_CFLAGS_I:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_CFLAGS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_FOUND:INTERNAL=1
|
|
||||||
PKG_FONTCONFIG_INCLUDEDIR:INTERNAL=/usr/include
|
|
||||||
PKG_FONTCONFIG_INCLUDE_DIRS:INTERNAL=/usr/include/uuid;/usr/include/freetype2;/usr/include/libpng16
|
|
||||||
PKG_FONTCONFIG_LDFLAGS:INTERNAL=-lfontconfig;-lfreetype
|
|
||||||
PKG_FONTCONFIG_LDFLAGS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_LIBDIR:INTERNAL=/usr/lib/x86_64-linux-gnu
|
|
||||||
PKG_FONTCONFIG_LIBRARIES:INTERNAL=fontconfig;freetype
|
|
||||||
PKG_FONTCONFIG_LIBRARY_DIRS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_LIBS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_LIBS_L:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_LIBS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_LIBS_PATHS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_MODULE_NAME:INTERNAL=fontconfig
|
|
||||||
PKG_FONTCONFIG_PREFIX:INTERNAL=/usr
|
|
||||||
PKG_FONTCONFIG_STATIC_CFLAGS:INTERNAL=-I/usr/include/uuid;-I/usr/include/freetype2;-I/usr/include/libpng16
|
|
||||||
PKG_FONTCONFIG_STATIC_CFLAGS_I:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_CFLAGS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_INCLUDE_DIRS:INTERNAL=/usr/include/uuid;/usr/include/freetype2;/usr/include/libpng16
|
|
||||||
PKG_FONTCONFIG_STATIC_LDFLAGS:INTERNAL=-lfontconfig;-luuid;-lexpat;-lfreetype;-lpng16;-lm;-lz;-lm;-lz;-lbrotlidec;-lbrotlicommon
|
|
||||||
PKG_FONTCONFIG_STATIC_LDFLAGS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBDIR:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBRARIES:INTERNAL=fontconfig;uuid;expat;freetype;png16;m;z;m;z;brotlidec;brotlicommon
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBRARY_DIRS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBS_L:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBS_OTHER:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_STATIC_LIBS_PATHS:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_VERSION:INTERNAL=2.13.1
|
|
||||||
PKG_FONTCONFIG_fontconfig_INCLUDEDIR:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_fontconfig_LIBDIR:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_fontconfig_PREFIX:INTERNAL=
|
|
||||||
PKG_FONTCONFIG_fontconfig_VERSION:INTERNAL=
|
|
||||||
//ADVANCED property for variable: RT_LIBRARY
|
|
||||||
RT_LIBRARY-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_ICE_INCLUDE_PATH
|
|
||||||
X11_ICE_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_ICE_LIB
|
|
||||||
X11_ICE_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//Have library /usr/lib/x86_64-linux-gnu/libX11.so;/usr/lib/x86_64-linux-gnu/libXext.so
|
|
||||||
X11_LIB_X11_SOLO:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_SM_INCLUDE_PATH
|
|
||||||
X11_SM_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_SM_LIB
|
|
||||||
X11_SM_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_X11_INCLUDE_PATH
|
|
||||||
X11_X11_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_X11_LIB
|
|
||||||
X11_X11_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_X11_xcb_INCLUDE_PATH
|
|
||||||
X11_X11_xcb_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_X11_xcb_LIB
|
|
||||||
X11_X11_xcb_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_XRes_INCLUDE_PATH
|
|
||||||
X11_XRes_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_XRes_LIB
|
|
||||||
X11_XRes_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_XShm_INCLUDE_PATH
|
|
||||||
X11_XShm_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_XSync_INCLUDE_PATH
|
|
||||||
X11_XSync_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xaccessrules_INCLUDE_PATH
|
|
||||||
X11_Xaccessrules_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xaccessstr_INCLUDE_PATH
|
|
||||||
X11_Xaccessstr_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xau_INCLUDE_PATH
|
|
||||||
X11_Xau_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xau_LIB
|
|
||||||
X11_Xau_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xcomposite_INCLUDE_PATH
|
|
||||||
X11_Xcomposite_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xcomposite_LIB
|
|
||||||
X11_Xcomposite_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xcursor_INCLUDE_PATH
|
|
||||||
X11_Xcursor_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xcursor_LIB
|
|
||||||
X11_Xcursor_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xdamage_INCLUDE_PATH
|
|
||||||
X11_Xdamage_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xdamage_LIB
|
|
||||||
X11_Xdamage_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xdmcp_INCLUDE_PATH
|
|
||||||
X11_Xdmcp_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xdmcp_LIB
|
|
||||||
X11_Xdmcp_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xext_INCLUDE_PATH
|
|
||||||
X11_Xext_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xext_LIB
|
|
||||||
X11_Xext_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xfixes_INCLUDE_PATH
|
|
||||||
X11_Xfixes_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xfixes_LIB
|
|
||||||
X11_Xfixes_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xft_INCLUDE_PATH
|
|
||||||
X11_Xft_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xft_LIB
|
|
||||||
X11_Xft_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xi_INCLUDE_PATH
|
|
||||||
X11_Xi_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xi_LIB
|
|
||||||
X11_Xi_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xinerama_INCLUDE_PATH
|
|
||||||
X11_Xinerama_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xinerama_LIB
|
|
||||||
X11_Xinerama_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xkb_INCLUDE_PATH
|
|
||||||
X11_Xkb_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xkblib_INCLUDE_PATH
|
|
||||||
X11_Xkblib_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xlib_INCLUDE_PATH
|
|
||||||
X11_Xlib_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xmu_INCLUDE_PATH
|
|
||||||
X11_Xmu_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xmu_LIB
|
|
||||||
X11_Xmu_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xpm_INCLUDE_PATH
|
|
||||||
X11_Xpm_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xpm_LIB
|
|
||||||
X11_Xpm_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xrandr_INCLUDE_PATH
|
|
||||||
X11_Xrandr_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xrandr_LIB
|
|
||||||
X11_Xrandr_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xrender_INCLUDE_PATH
|
|
||||||
X11_Xrender_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xrender_LIB
|
|
||||||
X11_Xrender_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xshape_INCLUDE_PATH
|
|
||||||
X11_Xshape_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xss_INCLUDE_PATH
|
|
||||||
X11_Xss_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xss_LIB
|
|
||||||
X11_Xss_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xt_INCLUDE_PATH
|
|
||||||
X11_Xt_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xt_LIB
|
|
||||||
X11_Xt_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xtst_INCLUDE_PATH
|
|
||||||
X11_Xtst_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xtst_LIB
|
|
||||||
X11_Xtst_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xutil_INCLUDE_PATH
|
|
||||||
X11_Xutil_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xv_INCLUDE_PATH
|
|
||||||
X11_Xv_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xv_LIB
|
|
||||||
X11_Xv_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xxf86misc_INCLUDE_PATH
|
|
||||||
X11_Xxf86misc_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xxf86misc_LIB
|
|
||||||
X11_Xxf86misc_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xxf86vm_INCLUDE_PATH
|
|
||||||
X11_Xxf86vm_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_Xxf86vm_LIB
|
|
||||||
X11_Xxf86vm_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_dpms_INCLUDE_PATH
|
|
||||||
X11_dpms_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xcb_INCLUDE_PATH
|
|
||||||
X11_xcb_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xcb_LIB
|
|
||||||
X11_xcb_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xcb_xkb_LIB
|
|
||||||
X11_xcb_xkb_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbcommon_INCLUDE_PATH
|
|
||||||
X11_xkbcommon_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbcommon_LIB
|
|
||||||
X11_xkbcommon_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbcommon_X11_INCLUDE_PATH
|
|
||||||
X11_xkbcommon_X11_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbcommon_X11_LIB
|
|
||||||
X11_xkbcommon_X11_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbfile_INCLUDE_PATH
|
|
||||||
X11_xkbfile_INCLUDE_PATH-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: X11_xkbfile_LIB
|
|
||||||
X11_xkbfile_LIB-ADVANCED:INTERNAL=1
|
|
||||||
//CMAKE_INSTALL_PREFIX during last run
|
|
||||||
_GNUInstallDirs_LAST_CMAKE_INSTALL_PREFIX:INTERNAL=/usr/local
|
|
||||||
__pkg_config_arguments_PKG_FONTCONFIG:INTERNAL=QUIET;fontconfig
|
|
||||||
__pkg_config_checked_PKG_FONTCONFIG:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: pkgcfg_lib_PKG_FONTCONFIG_fontconfig
|
|
||||||
pkgcfg_lib_PKG_FONTCONFIG_fontconfig-ADVANCED:INTERNAL=1
|
|
||||||
//ADVANCED property for variable: pkgcfg_lib_PKG_FONTCONFIG_freetype
|
|
||||||
pkgcfg_lib_PKG_FONTCONFIG_freetype-ADVANCED:INTERNAL=1
|
|
||||||
prefix_result:INTERNAL=/usr/lib/x86_64-linux-gnu
|
|
||||||
|
|
@ -1,77 +0,0 @@
|
|||||||
set(CMAKE_C_COMPILER "/usr/bin/cc")
|
|
||||||
set(CMAKE_C_COMPILER_ARG1 "")
|
|
||||||
set(CMAKE_C_COMPILER_ID "GNU")
|
|
||||||
set(CMAKE_C_COMPILER_VERSION "10.3.0")
|
|
||||||
set(CMAKE_C_COMPILER_VERSION_INTERNAL "")
|
|
||||||
set(CMAKE_C_COMPILER_WRAPPER "")
|
|
||||||
set(CMAKE_C_STANDARD_COMPUTED_DEFAULT "11")
|
|
||||||
set(CMAKE_C_COMPILE_FEATURES "c_std_90;c_function_prototypes;c_std_99;c_restrict;c_variadic_macros;c_std_11;c_static_assert")
|
|
||||||
set(CMAKE_C90_COMPILE_FEATURES "c_std_90;c_function_prototypes")
|
|
||||||
set(CMAKE_C99_COMPILE_FEATURES "c_std_99;c_restrict;c_variadic_macros")
|
|
||||||
set(CMAKE_C11_COMPILE_FEATURES "c_std_11;c_static_assert")
|
|
||||||
|
|
||||||
set(CMAKE_C_PLATFORM_ID "Linux")
|
|
||||||
set(CMAKE_C_SIMULATE_ID "")
|
|
||||||
set(CMAKE_C_COMPILER_FRONTEND_VARIANT "")
|
|
||||||
set(CMAKE_C_SIMULATE_VERSION "")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
set(CMAKE_AR "/usr/bin/ar")
|
|
||||||
set(CMAKE_C_COMPILER_AR "/usr/bin/gcc-ar-10")
|
|
||||||
set(CMAKE_RANLIB "/usr/bin/ranlib")
|
|
||||||
set(CMAKE_C_COMPILER_RANLIB "/usr/bin/gcc-ranlib-10")
|
|
||||||
set(CMAKE_LINKER "/usr/bin/ld")
|
|
||||||
set(CMAKE_MT "")
|
|
||||||
set(CMAKE_COMPILER_IS_GNUCC 1)
|
|
||||||
set(CMAKE_C_COMPILER_LOADED 1)
|
|
||||||
set(CMAKE_C_COMPILER_WORKS TRUE)
|
|
||||||
set(CMAKE_C_ABI_COMPILED TRUE)
|
|
||||||
set(CMAKE_COMPILER_IS_MINGW )
|
|
||||||
set(CMAKE_COMPILER_IS_CYGWIN )
|
|
||||||
if(CMAKE_COMPILER_IS_CYGWIN)
|
|
||||||
set(CYGWIN 1)
|
|
||||||
set(UNIX 1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(CMAKE_C_COMPILER_ENV_VAR "CC")
|
|
||||||
|
|
||||||
if(CMAKE_COMPILER_IS_MINGW)
|
|
||||||
set(MINGW 1)
|
|
||||||
endif()
|
|
||||||
set(CMAKE_C_COMPILER_ID_RUN 1)
|
|
||||||
set(CMAKE_C_SOURCE_FILE_EXTENSIONS c;m)
|
|
||||||
set(CMAKE_C_IGNORE_EXTENSIONS h;H;o;O;obj;OBJ;def;DEF;rc;RC)
|
|
||||||
set(CMAKE_C_LINKER_PREFERENCE 10)
|
|
||||||
|
|
||||||
# Save compiler ABI information.
|
|
||||||
set(CMAKE_C_SIZEOF_DATA_PTR "8")
|
|
||||||
set(CMAKE_C_COMPILER_ABI "ELF")
|
|
||||||
set(CMAKE_C_LIBRARY_ARCHITECTURE "x86_64-linux-gnu")
|
|
||||||
|
|
||||||
if(CMAKE_C_SIZEOF_DATA_PTR)
|
|
||||||
set(CMAKE_SIZEOF_VOID_P "${CMAKE_C_SIZEOF_DATA_PTR}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_C_COMPILER_ABI)
|
|
||||||
set(CMAKE_INTERNAL_PLATFORM_ABI "${CMAKE_C_COMPILER_ABI}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_C_LIBRARY_ARCHITECTURE)
|
|
||||||
set(CMAKE_LIBRARY_ARCHITECTURE "x86_64-linux-gnu")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(CMAKE_C_CL_SHOWINCLUDES_PREFIX "")
|
|
||||||
if(CMAKE_C_CL_SHOWINCLUDES_PREFIX)
|
|
||||||
set(CMAKE_CL_SHOWINCLUDES_PREFIX "${CMAKE_C_CL_SHOWINCLUDES_PREFIX}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
set(CMAKE_C_IMPLICIT_INCLUDE_DIRECTORIES "/usr/lib/gcc/x86_64-linux-gnu/10/include;/usr/local/include;/usr/include/x86_64-linux-gnu;/usr/include")
|
|
||||||
set(CMAKE_C_IMPLICIT_LINK_LIBRARIES "gcc;gcc_s;c;gcc;gcc_s")
|
|
||||||
set(CMAKE_C_IMPLICIT_LINK_DIRECTORIES "/usr/lib/gcc/x86_64-linux-gnu/10;/usr/lib/x86_64-linux-gnu;/usr/lib;/lib/x86_64-linux-gnu;/lib")
|
|
||||||
set(CMAKE_C_IMPLICIT_LINK_FRAMEWORK_DIRECTORIES "")
|
|
@ -1,15 +0,0 @@
|
|||||||
set(CMAKE_HOST_SYSTEM "Linux-5.13.0-7620-generic")
|
|
||||||
set(CMAKE_HOST_SYSTEM_NAME "Linux")
|
|
||||||
set(CMAKE_HOST_SYSTEM_VERSION "5.13.0-7620-generic")
|
|
||||||
set(CMAKE_HOST_SYSTEM_PROCESSOR "x86_64")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
set(CMAKE_SYSTEM "Linux-5.13.0-7620-generic")
|
|
||||||
set(CMAKE_SYSTEM_NAME "Linux")
|
|
||||||
set(CMAKE_SYSTEM_VERSION "5.13.0-7620-generic")
|
|
||||||
set(CMAKE_SYSTEM_PROCESSOR "x86_64")
|
|
||||||
|
|
||||||
set(CMAKE_CROSSCOMPILING "FALSE")
|
|
||||||
|
|
||||||
set(CMAKE_SYSTEM_LOADED 1)
|
|
@ -1,674 +0,0 @@
|
|||||||
#ifdef __cplusplus
|
|
||||||
# error "A C++ compiler has been selected for C."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__18CXX)
|
|
||||||
# define ID_VOID_MAIN
|
|
||||||
#endif
|
|
||||||
#if defined(__CLASSIC_C__)
|
|
||||||
/* cv-qualifiers did not exist in K&R C */
|
|
||||||
# define const
|
|
||||||
# define volatile
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Version number components: V=Version, R=Revision, P=Patch
|
|
||||||
Version date components: YYYY=Year, MM=Month, DD=Day */
|
|
||||||
|
|
||||||
#if defined(__INTEL_COMPILER) || defined(__ICC)
|
|
||||||
# define COMPILER_ID "Intel"
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
# define SIMULATE_ID "MSVC"
|
|
||||||
# endif
|
|
||||||
# if defined(__GNUC__)
|
|
||||||
# define SIMULATE_ID "GNU"
|
|
||||||
# endif
|
|
||||||
/* __INTEL_COMPILER = VRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10)
|
|
||||||
# if defined(__INTEL_COMPILER_UPDATE)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE)
|
|
||||||
# else
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10)
|
|
||||||
# endif
|
|
||||||
# if defined(__INTEL_COMPILER_BUILD_DATE)
|
|
||||||
/* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */
|
|
||||||
# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE)
|
|
||||||
# endif
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
/* _MSC_VER = VVRR */
|
|
||||||
# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
|
|
||||||
# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
|
|
||||||
# endif
|
|
||||||
# if defined(__GNUC__)
|
|
||||||
# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
|
|
||||||
# elif defined(__GNUG__)
|
|
||||||
# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
|
|
||||||
# endif
|
|
||||||
# if defined(__GNUC_MINOR__)
|
|
||||||
# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
|
|
||||||
# endif
|
|
||||||
# if defined(__GNUC_PATCHLEVEL__)
|
|
||||||
# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__PATHCC__)
|
|
||||||
# define COMPILER_ID "PathScale"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__PATHCC__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__)
|
|
||||||
# if defined(__PATHCC_PATCHLEVEL__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__)
|
|
||||||
# define COMPILER_ID "Embarcadero"
|
|
||||||
# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF)
|
|
||||||
# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF)
|
|
||||||
|
|
||||||
#elif defined(__BORLANDC__)
|
|
||||||
# define COMPILER_ID "Borland"
|
|
||||||
/* __BORLANDC__ = 0xVRR */
|
|
||||||
# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8)
|
|
||||||
# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF)
|
|
||||||
|
|
||||||
#elif defined(__WATCOMC__) && __WATCOMC__ < 1200
|
|
||||||
# define COMPILER_ID "Watcom"
|
|
||||||
/* __WATCOMC__ = VVRR */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
|
|
||||||
# if (__WATCOMC__ % 10) > 0
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__WATCOMC__)
|
|
||||||
# define COMPILER_ID "OpenWatcom"
|
|
||||||
/* __WATCOMC__ = VVRP + 1100 */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
|
|
||||||
# if (__WATCOMC__ % 10) > 0
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__SUNPRO_C)
|
|
||||||
# define COMPILER_ID "SunPro"
|
|
||||||
# if __SUNPRO_C >= 0x5100
|
|
||||||
/* __SUNPRO_C = 0xVRRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>12)
|
|
||||||
# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xFF)
|
|
||||||
# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
|
|
||||||
# else
|
|
||||||
/* __SUNPRO_CC = 0xVRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>8)
|
|
||||||
# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xF)
|
|
||||||
# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__HP_cc)
|
|
||||||
# define COMPILER_ID "HP"
|
|
||||||
/* __HP_cc = VVRRPP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__HP_cc/10000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__HP_cc/100 % 100)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__HP_cc % 100)
|
|
||||||
|
|
||||||
#elif defined(__DECC)
|
|
||||||
# define COMPILER_ID "Compaq"
|
|
||||||
/* __DECC_VER = VVRRTPPPP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__DECC_VER/10000000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__DECC_VER/100000 % 100)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__DECC_VER % 10000)
|
|
||||||
|
|
||||||
#elif defined(__IBMC__) && defined(__COMPILER_VER__)
|
|
||||||
# define COMPILER_ID "zOS"
|
|
||||||
/* __IBMC__ = VRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
|
|
||||||
|
|
||||||
#elif defined(__ibmxl__) && defined(__clang__)
|
|
||||||
# define COMPILER_ID "XLClang"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__)
|
|
||||||
# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__)
|
|
||||||
|
|
||||||
|
|
||||||
#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ >= 800
|
|
||||||
# define COMPILER_ID "XL"
|
|
||||||
/* __IBMC__ = VRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
|
|
||||||
|
|
||||||
#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ < 800
|
|
||||||
# define COMPILER_ID "VisualAge"
|
|
||||||
/* __IBMC__ = VRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
|
|
||||||
|
|
||||||
#elif defined(__PGI)
|
|
||||||
# define COMPILER_ID "PGI"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__PGIC__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__)
|
|
||||||
# if defined(__PGIC_PATCHLEVEL__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(_CRAYC)
|
|
||||||
# define COMPILER_ID "Cray"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR)
|
|
||||||
|
|
||||||
#elif defined(__TI_COMPILER_VERSION__)
|
|
||||||
# define COMPILER_ID "TI"
|
|
||||||
/* __TI_COMPILER_VERSION__ = VVVRRRPPP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000)
|
|
||||||
|
|
||||||
#elif defined(__FUJITSU) || defined(__FCC_VERSION) || defined(__fcc_version)
|
|
||||||
# define COMPILER_ID "Fujitsu"
|
|
||||||
|
|
||||||
#elif defined(__ghs__)
|
|
||||||
# define COMPILER_ID "GHS"
|
|
||||||
/* __GHS_VERSION_NUMBER = VVVVRP */
|
|
||||||
# ifdef __GHS_VERSION_NUMBER
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__TINYC__)
|
|
||||||
# define COMPILER_ID "TinyCC"
|
|
||||||
|
|
||||||
#elif defined(__BCC__)
|
|
||||||
# define COMPILER_ID "Bruce"
|
|
||||||
|
|
||||||
#elif defined(__SCO_VERSION__)
|
|
||||||
# define COMPILER_ID "SCO"
|
|
||||||
|
|
||||||
#elif defined(__ARMCC_VERSION) && !defined(__clang__)
|
|
||||||
# define COMPILER_ID "ARMCC"
|
|
||||||
#if __ARMCC_VERSION >= 1000000
|
|
||||||
/* __ARMCC_VERSION = VRRPPPP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
|
|
||||||
#else
|
|
||||||
/* __ARMCC_VERSION = VRPPPP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#elif defined(__clang__) && defined(__apple_build_version__)
|
|
||||||
# define COMPILER_ID "AppleClang"
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
# define SIMULATE_ID "MSVC"
|
|
||||||
# endif
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
/* _MSC_VER = VVRR */
|
|
||||||
# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
|
|
||||||
# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
|
|
||||||
# endif
|
|
||||||
# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__)
|
|
||||||
|
|
||||||
#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION)
|
|
||||||
# define COMPILER_ID "ARMClang"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION % 10000)
|
|
||||||
# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION)
|
|
||||||
|
|
||||||
#elif defined(__clang__)
|
|
||||||
# define COMPILER_ID "Clang"
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
# define SIMULATE_ID "MSVC"
|
|
||||||
# endif
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
/* _MSC_VER = VVRR */
|
|
||||||
# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
|
|
||||||
# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__GNUC__)
|
|
||||||
# define COMPILER_ID "GNU"
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__GNUC__)
|
|
||||||
# if defined(__GNUC_MINOR__)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__)
|
|
||||||
# endif
|
|
||||||
# if defined(__GNUC_PATCHLEVEL__)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(_MSC_VER)
|
|
||||||
# define COMPILER_ID "MSVC"
|
|
||||||
/* _MSC_VER = VVRR */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100)
|
|
||||||
# if defined(_MSC_FULL_VER)
|
|
||||||
# if _MSC_VER >= 1400
|
|
||||||
/* _MSC_FULL_VER = VVRRPPPPP */
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000)
|
|
||||||
# else
|
|
||||||
/* _MSC_FULL_VER = VVRRPPPP */
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000)
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# if defined(_MSC_BUILD)
|
|
||||||
# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__VISUALDSPVERSION__) || defined(__ADSPBLACKFIN__) || defined(__ADSPTS__) || defined(__ADSP21000__)
|
|
||||||
# define COMPILER_ID "ADSP"
|
|
||||||
#if defined(__VISUALDSPVERSION__)
|
|
||||||
/* __VISUALDSPVERSION__ = 0xVVRRPP00 */
|
|
||||||
# define COMPILER_VERSION_MAJOR HEX(__VISUALDSPVERSION__>>24)
|
|
||||||
# define COMPILER_VERSION_MINOR HEX(__VISUALDSPVERSION__>>16 & 0xFF)
|
|
||||||
# define COMPILER_VERSION_PATCH HEX(__VISUALDSPVERSION__>>8 & 0xFF)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
|
|
||||||
# define COMPILER_ID "IAR"
|
|
||||||
# if defined(__VER__) && defined(__ICCARM__)
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000)
|
|
||||||
# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
|
|
||||||
# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__))
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100))
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__)
|
|
||||||
# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__SDCC_VERSION_MAJOR) || defined(SDCC)
|
|
||||||
# define COMPILER_ID "SDCC"
|
|
||||||
# if defined(__SDCC_VERSION_MAJOR)
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(__SDCC_VERSION_MAJOR)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(__SDCC_VERSION_MINOR)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(__SDCC_VERSION_PATCH)
|
|
||||||
# else
|
|
||||||
/* SDCC = VRP */
|
|
||||||
# define COMPILER_VERSION_MAJOR DEC(SDCC/100)
|
|
||||||
# define COMPILER_VERSION_MINOR DEC(SDCC/10 % 10)
|
|
||||||
# define COMPILER_VERSION_PATCH DEC(SDCC % 10)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
|
|
||||||
/* These compilers are either not known or too old to define an
|
|
||||||
identification macro. Try to identify the platform and guess that
|
|
||||||
it is the native compiler. */
|
|
||||||
#elif defined(__hpux) || defined(__hpua)
|
|
||||||
# define COMPILER_ID "HP"
|
|
||||||
|
|
||||||
#else /* unknown compiler */
|
|
||||||
# define COMPILER_ID ""
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Construct the string literal in pieces to prevent the source from
|
|
||||||
getting matched. Store it in a pointer rather than an array
|
|
||||||
because some compilers will just produce instructions to fill the
|
|
||||||
array rather than assigning a pointer to a static array. */
|
|
||||||
char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]";
|
|
||||||
#ifdef SIMULATE_ID
|
|
||||||
char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __QNXNTO__
|
|
||||||
char const* qnxnto = "INFO" ":" "qnxnto[]";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__CRAYXE) || defined(__CRAYXC)
|
|
||||||
char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define STRINGIFY_HELPER(X) #X
|
|
||||||
#define STRINGIFY(X) STRINGIFY_HELPER(X)
|
|
||||||
|
|
||||||
/* Identify known platforms by name. */
|
|
||||||
#if defined(__linux) || defined(__linux__) || defined(linux)
|
|
||||||
# define PLATFORM_ID "Linux"
|
|
||||||
|
|
||||||
#elif defined(__CYGWIN__)
|
|
||||||
# define PLATFORM_ID "Cygwin"
|
|
||||||
|
|
||||||
#elif defined(__MINGW32__)
|
|
||||||
# define PLATFORM_ID "MinGW"
|
|
||||||
|
|
||||||
#elif defined(__APPLE__)
|
|
||||||
# define PLATFORM_ID "Darwin"
|
|
||||||
|
|
||||||
#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
||||||
# define PLATFORM_ID "Windows"
|
|
||||||
|
|
||||||
#elif defined(__FreeBSD__) || defined(__FreeBSD)
|
|
||||||
# define PLATFORM_ID "FreeBSD"
|
|
||||||
|
|
||||||
#elif defined(__NetBSD__) || defined(__NetBSD)
|
|
||||||
# define PLATFORM_ID "NetBSD"
|
|
||||||
|
|
||||||
#elif defined(__OpenBSD__) || defined(__OPENBSD)
|
|
||||||
# define PLATFORM_ID "OpenBSD"
|
|
||||||
|
|
||||||
#elif defined(__sun) || defined(sun)
|
|
||||||
# define PLATFORM_ID "SunOS"
|
|
||||||
|
|
||||||
#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__)
|
|
||||||
# define PLATFORM_ID "AIX"
|
|
||||||
|
|
||||||
#elif defined(__hpux) || defined(__hpux__)
|
|
||||||
# define PLATFORM_ID "HP-UX"
|
|
||||||
|
|
||||||
#elif defined(__HAIKU__)
|
|
||||||
# define PLATFORM_ID "Haiku"
|
|
||||||
|
|
||||||
#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS)
|
|
||||||
# define PLATFORM_ID "BeOS"
|
|
||||||
|
|
||||||
#elif defined(__QNX__) || defined(__QNXNTO__)
|
|
||||||
# define PLATFORM_ID "QNX"
|
|
||||||
|
|
||||||
#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__)
|
|
||||||
# define PLATFORM_ID "Tru64"
|
|
||||||
|
|
||||||
#elif defined(__riscos) || defined(__riscos__)
|
|
||||||
# define PLATFORM_ID "RISCos"
|
|
||||||
|
|
||||||
#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__)
|
|
||||||
# define PLATFORM_ID "SINIX"
|
|
||||||
|
|
||||||
#elif defined(__UNIX_SV__)
|
|
||||||
# define PLATFORM_ID "UNIX_SV"
|
|
||||||
|
|
||||||
#elif defined(__bsdos__)
|
|
||||||
# define PLATFORM_ID "BSDOS"
|
|
||||||
|
|
||||||
#elif defined(_MPRAS) || defined(MPRAS)
|
|
||||||
# define PLATFORM_ID "MP-RAS"
|
|
||||||
|
|
||||||
#elif defined(__osf) || defined(__osf__)
|
|
||||||
# define PLATFORM_ID "OSF1"
|
|
||||||
|
|
||||||
#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv)
|
|
||||||
# define PLATFORM_ID "SCO_SV"
|
|
||||||
|
|
||||||
#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX)
|
|
||||||
# define PLATFORM_ID "ULTRIX"
|
|
||||||
|
|
||||||
#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX)
|
|
||||||
# define PLATFORM_ID "Xenix"
|
|
||||||
|
|
||||||
#elif defined(__WATCOMC__)
|
|
||||||
# if defined(__LINUX__)
|
|
||||||
# define PLATFORM_ID "Linux"
|
|
||||||
|
|
||||||
# elif defined(__DOS__)
|
|
||||||
# define PLATFORM_ID "DOS"
|
|
||||||
|
|
||||||
# elif defined(__OS2__)
|
|
||||||
# define PLATFORM_ID "OS2"
|
|
||||||
|
|
||||||
# elif defined(__WINDOWS__)
|
|
||||||
# define PLATFORM_ID "Windows3x"
|
|
||||||
|
|
||||||
# elif defined(__VXWORKS__)
|
|
||||||
# define PLATFORM_ID "VxWorks"
|
|
||||||
|
|
||||||
# else /* unknown platform */
|
|
||||||
# define PLATFORM_ID
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__INTEGRITY)
|
|
||||||
# if defined(INT_178B)
|
|
||||||
# define PLATFORM_ID "Integrity178"
|
|
||||||
|
|
||||||
# else /* regular Integrity */
|
|
||||||
# define PLATFORM_ID "Integrity"
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#else /* unknown platform */
|
|
||||||
# define PLATFORM_ID
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* For windows compilers MSVC and Intel we can determine
|
|
||||||
the architecture of the compiler being used. This is because
|
|
||||||
the compilers do not have flags that can change the architecture,
|
|
||||||
but rather depend on which compiler is being used
|
|
||||||
*/
|
|
||||||
#if defined(_WIN32) && defined(_MSC_VER)
|
|
||||||
# if defined(_M_IA64)
|
|
||||||
# define ARCHITECTURE_ID "IA64"
|
|
||||||
|
|
||||||
# elif defined(_M_X64) || defined(_M_AMD64)
|
|
||||||
# define ARCHITECTURE_ID "x64"
|
|
||||||
|
|
||||||
# elif defined(_M_IX86)
|
|
||||||
# define ARCHITECTURE_ID "X86"
|
|
||||||
|
|
||||||
# elif defined(_M_ARM64)
|
|
||||||
# define ARCHITECTURE_ID "ARM64"
|
|
||||||
|
|
||||||
# elif defined(_M_ARM)
|
|
||||||
# if _M_ARM == 4
|
|
||||||
# define ARCHITECTURE_ID "ARMV4I"
|
|
||||||
# elif _M_ARM == 5
|
|
||||||
# define ARCHITECTURE_ID "ARMV5I"
|
|
||||||
# else
|
|
||||||
# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM)
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# elif defined(_M_MIPS)
|
|
||||||
# define ARCHITECTURE_ID "MIPS"
|
|
||||||
|
|
||||||
# elif defined(_M_SH)
|
|
||||||
# define ARCHITECTURE_ID "SHx"
|
|
||||||
|
|
||||||
# else /* unknown architecture */
|
|
||||||
# define ARCHITECTURE_ID ""
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__WATCOMC__)
|
|
||||||
# if defined(_M_I86)
|
|
||||||
# define ARCHITECTURE_ID "I86"
|
|
||||||
|
|
||||||
# elif defined(_M_IX86)
|
|
||||||
# define ARCHITECTURE_ID "X86"
|
|
||||||
|
|
||||||
# else /* unknown architecture */
|
|
||||||
# define ARCHITECTURE_ID ""
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
|
|
||||||
# if defined(__ICCARM__)
|
|
||||||
# define ARCHITECTURE_ID "ARM"
|
|
||||||
|
|
||||||
# elif defined(__ICCRX__)
|
|
||||||
# define ARCHITECTURE_ID "RX"
|
|
||||||
|
|
||||||
# elif defined(__ICCRH850__)
|
|
||||||
# define ARCHITECTURE_ID "RH850"
|
|
||||||
|
|
||||||
# elif defined(__ICCRL78__)
|
|
||||||
# define ARCHITECTURE_ID "RL78"
|
|
||||||
|
|
||||||
# elif defined(__ICCRISCV__)
|
|
||||||
# define ARCHITECTURE_ID "RISCV"
|
|
||||||
|
|
||||||
# elif defined(__ICCAVR__)
|
|
||||||
# define ARCHITECTURE_ID "AVR"
|
|
||||||
|
|
||||||
# elif defined(__ICC430__)
|
|
||||||
# define ARCHITECTURE_ID "MSP430"
|
|
||||||
|
|
||||||
# elif defined(__ICCV850__)
|
|
||||||
# define ARCHITECTURE_ID "V850"
|
|
||||||
|
|
||||||
# elif defined(__ICC8051__)
|
|
||||||
# define ARCHITECTURE_ID "8051"
|
|
||||||
|
|
||||||
# else /* unknown architecture */
|
|
||||||
# define ARCHITECTURE_ID ""
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined(__ghs__)
|
|
||||||
# if defined(__PPC64__)
|
|
||||||
# define ARCHITECTURE_ID "PPC64"
|
|
||||||
|
|
||||||
# elif defined(__ppc__)
|
|
||||||
# define ARCHITECTURE_ID "PPC"
|
|
||||||
|
|
||||||
# elif defined(__ARM__)
|
|
||||||
# define ARCHITECTURE_ID "ARM"
|
|
||||||
|
|
||||||
# elif defined(__x86_64__)
|
|
||||||
# define ARCHITECTURE_ID "x64"
|
|
||||||
|
|
||||||
# elif defined(__i386__)
|
|
||||||
# define ARCHITECTURE_ID "X86"
|
|
||||||
|
|
||||||
# else /* unknown architecture */
|
|
||||||
# define ARCHITECTURE_ID ""
|
|
||||||
# endif
|
|
||||||
#else
|
|
||||||
# define ARCHITECTURE_ID
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Convert integer to decimal digit literals. */
|
|
||||||
#define DEC(n) \
|
|
||||||
('0' + (((n) / 10000000)%10)), \
|
|
||||||
('0' + (((n) / 1000000)%10)), \
|
|
||||||
('0' + (((n) / 100000)%10)), \
|
|
||||||
('0' + (((n) / 10000)%10)), \
|
|
||||||
('0' + (((n) / 1000)%10)), \
|
|
||||||
('0' + (((n) / 100)%10)), \
|
|
||||||
('0' + (((n) / 10)%10)), \
|
|
||||||
('0' + ((n) % 10))
|
|
||||||
|
|
||||||
/* Convert integer to hex digit literals. */
|
|
||||||
#define HEX(n) \
|
|
||||||
('0' + ((n)>>28 & 0xF)), \
|
|
||||||
('0' + ((n)>>24 & 0xF)), \
|
|
||||||
('0' + ((n)>>20 & 0xF)), \
|
|
||||||
('0' + ((n)>>16 & 0xF)), \
|
|
||||||
('0' + ((n)>>12 & 0xF)), \
|
|
||||||
('0' + ((n)>>8 & 0xF)), \
|
|
||||||
('0' + ((n)>>4 & 0xF)), \
|
|
||||||
('0' + ((n) & 0xF))
|
|
||||||
|
|
||||||
/* Construct a string literal encoding the version number components. */
|
|
||||||
#ifdef COMPILER_VERSION_MAJOR
|
|
||||||
char const info_version[] = {
|
|
||||||
'I', 'N', 'F', 'O', ':',
|
|
||||||
'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[',
|
|
||||||
COMPILER_VERSION_MAJOR,
|
|
||||||
# ifdef COMPILER_VERSION_MINOR
|
|
||||||
'.', COMPILER_VERSION_MINOR,
|
|
||||||
# ifdef COMPILER_VERSION_PATCH
|
|
||||||
'.', COMPILER_VERSION_PATCH,
|
|
||||||
# ifdef COMPILER_VERSION_TWEAK
|
|
||||||
'.', COMPILER_VERSION_TWEAK,
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
']','\0'};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Construct a string literal encoding the internal version number. */
|
|
||||||
#ifdef COMPILER_VERSION_INTERNAL
|
|
||||||
char const info_version_internal[] = {
|
|
||||||
'I', 'N', 'F', 'O', ':',
|
|
||||||
'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_',
|
|
||||||
'i','n','t','e','r','n','a','l','[',
|
|
||||||
COMPILER_VERSION_INTERNAL,']','\0'};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Construct a string literal encoding the version number components. */
|
|
||||||
#ifdef SIMULATE_VERSION_MAJOR
|
|
||||||
char const info_simulate_version[] = {
|
|
||||||
'I', 'N', 'F', 'O', ':',
|
|
||||||
's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[',
|
|
||||||
SIMULATE_VERSION_MAJOR,
|
|
||||||
# ifdef SIMULATE_VERSION_MINOR
|
|
||||||
'.', SIMULATE_VERSION_MINOR,
|
|
||||||
# ifdef SIMULATE_VERSION_PATCH
|
|
||||||
'.', SIMULATE_VERSION_PATCH,
|
|
||||||
# ifdef SIMULATE_VERSION_TWEAK
|
|
||||||
'.', SIMULATE_VERSION_TWEAK,
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
']','\0'};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Construct the string literal in pieces to prevent the source from
|
|
||||||
getting matched. Store it in a pointer rather than an array
|
|
||||||
because some compilers will just produce instructions to fill the
|
|
||||||
array rather than assigning a pointer to a static array. */
|
|
||||||
char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]";
|
|
||||||
char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]";
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#if !defined(__STDC__)
|
|
||||||
# if (defined(_MSC_VER) && !defined(__clang__)) \
|
|
||||||
|| (defined(__ibmxl__) || defined(__IBMC__))
|
|
||||||
# define C_DIALECT "90"
|
|
||||||
# else
|
|
||||||
# define C_DIALECT
|
|
||||||
# endif
|
|
||||||
#elif __STDC_VERSION__ >= 201000L
|
|
||||||
# define C_DIALECT "11"
|
|
||||||
#elif __STDC_VERSION__ >= 199901L
|
|
||||||
# define C_DIALECT "99"
|
|
||||||
#else
|
|
||||||
# define C_DIALECT "90"
|
|
||||||
#endif
|
|
||||||
const char* info_language_dialect_default =
|
|
||||||
"INFO" ":" "dialect_default[" C_DIALECT "]";
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#ifdef ID_VOID_MAIN
|
|
||||||
void main() {}
|
|
||||||
#else
|
|
||||||
# if defined(__CLASSIC_C__)
|
|
||||||
int main(argc, argv) int argc; char *argv[];
|
|
||||||
# else
|
|
||||||
int main(int argc, char* argv[])
|
|
||||||
# endif
|
|
||||||
{
|
|
||||||
int require = 0;
|
|
||||||
require += info_compiler[argc];
|
|
||||||
require += info_platform[argc];
|
|
||||||
require += info_arch[argc];
|
|
||||||
#ifdef COMPILER_VERSION_MAJOR
|
|
||||||
require += info_version[argc];
|
|
||||||
#endif
|
|
||||||
#ifdef COMPILER_VERSION_INTERNAL
|
|
||||||
require += info_version_internal[argc];
|
|
||||||
#endif
|
|
||||||
#ifdef SIMULATE_ID
|
|
||||||
require += info_simulate[argc];
|
|
||||||
#endif
|
|
||||||
#ifdef SIMULATE_VERSION_MAJOR
|
|
||||||
require += info_simulate_version[argc];
|
|
||||||
#endif
|
|
||||||
#if defined(__CRAYXE) || defined(__CRAYXC)
|
|
||||||
require += info_cray[argc];
|
|
||||||
#endif
|
|
||||||
require += info_language_dialect_default[argc];
|
|
||||||
(void)argv;
|
|
||||||
return require;
|
|
||||||
}
|
|
||||||
#endif
|
|
@ -1,16 +0,0 @@
|
|||||||
# CMAKE generated file: DO NOT EDIT!
|
|
||||||
# Generated by "Unix Makefiles" Generator, CMake Version 3.18
|
|
||||||
|
|
||||||
# Relative path conversion top directories.
|
|
||||||
set(CMAKE_RELATIVE_PATH_TOP_SOURCE "/home/niklas/Downloads/glfw-3.3.5")
|
|
||||||
set(CMAKE_RELATIVE_PATH_TOP_BINARY "/home/niklas/Downloads/glfw-3.3.5")
|
|
||||||
|
|
||||||
# Force unix paths in dependencies.
|
|
||||||
set(CMAKE_FORCE_UNIX_PATHS 1)
|
|
||||||
|
|
||||||
|
|
||||||
# The C and CXX include file regular expressions for this directory.
|
|
||||||
set(CMAKE_C_INCLUDE_REGEX_SCAN "^.*$")
|
|
||||||
set(CMAKE_C_INCLUDE_REGEX_COMPLAIN "^$")
|
|
||||||
set(CMAKE_CXX_INCLUDE_REGEX_SCAN ${CMAKE_C_INCLUDE_REGEX_SCAN})
|
|
||||||
set(CMAKE_CXX_INCLUDE_REGEX_COMPLAIN ${CMAKE_C_INCLUDE_REGEX_COMPLAIN})
|
|
@ -1,60 +0,0 @@
|
|||||||
Performing C SOURCE FILE Test CMAKE_HAVE_LIBC_PTHREAD failed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_aaf61/fast && /usr/bin/gmake -f CMakeFiles/cmTC_aaf61.dir/build.make CMakeFiles/cmTC_aaf61.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_aaf61.dir/src.c.o
|
|
||||||
/usr/bin/cc -DCMAKE_HAVE_LIBC_PTHREAD -o CMakeFiles/cmTC_aaf61.dir/src.c.o -c /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp/src.c
|
|
||||||
Linking C executable cmTC_aaf61
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_aaf61.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCMAKE_HAVE_LIBC_PTHREAD CMakeFiles/cmTC_aaf61.dir/src.c.o -o cmTC_aaf61
|
|
||||||
/usr/bin/ld: CMakeFiles/cmTC_aaf61.dir/src.c.o: in function `main':
|
|
||||||
src.c:(.text+0x46): undefined reference to `pthread_create'
|
|
||||||
/usr/bin/ld: src.c:(.text+0x52): undefined reference to `pthread_detach'
|
|
||||||
/usr/bin/ld: src.c:(.text+0x5e): undefined reference to `pthread_cancel'
|
|
||||||
/usr/bin/ld: src.c:(.text+0x6f): undefined reference to `pthread_join'
|
|
||||||
collect2: error: ld returned 1 exit status
|
|
||||||
gmake[1]: *** [CMakeFiles/cmTC_aaf61.dir/build.make:106: cmTC_aaf61] Fehler 1
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
gmake: *** [Makefile:140: cmTC_aaf61/fast] Fehler 2
|
|
||||||
|
|
||||||
|
|
||||||
Source file was:
|
|
||||||
#include <pthread.h>
|
|
||||||
|
|
||||||
void* test_func(void* data)
|
|
||||||
{
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
pthread_t thread;
|
|
||||||
pthread_create(&thread, NULL, test_func, NULL);
|
|
||||||
pthread_detach(thread);
|
|
||||||
pthread_cancel(thread);
|
|
||||||
pthread_join(thread, NULL);
|
|
||||||
pthread_atfork(NULL, NULL, NULL);
|
|
||||||
pthread_exit(NULL);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Determining if the function pthread_create exists in the pthreads failed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_5e51e/fast && /usr/bin/gmake -f CMakeFiles/cmTC_5e51e.dir/build.make CMakeFiles/cmTC_5e51e.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_5e51e.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=pthread_create -o CMakeFiles/cmTC_5e51e.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_5e51e
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_5e51e.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=pthread_create CMakeFiles/cmTC_5e51e.dir/CheckFunctionExists.c.o -o cmTC_5e51e -lpthreads
|
|
||||||
/usr/bin/ld: -lpthreads kann nicht gefunden werden
|
|
||||||
collect2: error: ld returned 1 exit status
|
|
||||||
gmake[1]: *** [CMakeFiles/cmTC_5e51e.dir/build.make:106: cmTC_5e51e] Fehler 1
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
gmake: *** [Makefile:140: cmTC_5e51e/fast] Fehler 2
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,328 +0,0 @@
|
|||||||
The system is: Linux - 5.13.0-7620-generic - x86_64
|
|
||||||
Compiling the C compiler identification source file "CMakeCCompilerId.c" succeeded.
|
|
||||||
Compiler: /usr/bin/cc
|
|
||||||
Build flags:
|
|
||||||
Id flags:
|
|
||||||
|
|
||||||
The output was:
|
|
||||||
0
|
|
||||||
|
|
||||||
|
|
||||||
Compilation of the C compiler identification source "CMakeCCompilerId.c" produced "a.out"
|
|
||||||
|
|
||||||
The C compiler identification is GNU, found in "/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/3.18.4/CompilerIdC/a.out"
|
|
||||||
|
|
||||||
Detecting C compiler ABI info compiled with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_f9c40/fast && /usr/bin/gmake -f CMakeFiles/cmTC_f9c40.dir/build.make CMakeFiles/cmTC_f9c40.dir/build
|
|
||||||
gmake[1]: Entering directory '/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp'
|
|
||||||
Building C object CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o
|
|
||||||
/usr/bin/cc -v -o CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -c /usr/share/cmake-3.18/Modules/CMakeCCompilerABI.c
|
|
||||||
Using built-in specs.
|
|
||||||
COLLECT_GCC=/usr/bin/cc
|
|
||||||
OFFLOAD_TARGET_NAMES=nvptx-none:amdgcn-amdhsa:hsa
|
|
||||||
OFFLOAD_TARGET_DEFAULT=1
|
|
||||||
Target: x86_64-linux-gnu
|
|
||||||
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 10.3.0-1ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-10/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,m2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-10 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-bootstrap --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --enable-libphobos-checking=release --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-nvptx/usr,amdgcn-amdhsa=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-gcn/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu --with-build-config=bootstrap-lto-lean --enable-link-mutex
|
|
||||||
Thread model: posix
|
|
||||||
Supported LTO compression algorithms: zlib zstd
|
|
||||||
gcc version 10.3.0 (Ubuntu 10.3.0-1ubuntu1)
|
|
||||||
COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'
|
|
||||||
/usr/lib/gcc/x86_64-linux-gnu/10/cc1 -quiet -v -imultiarch x86_64-linux-gnu /usr/share/cmake-3.18/Modules/CMakeCCompilerABI.c -quiet -dumpbase CMakeCCompilerABI.c -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/cceyw2fY.s
|
|
||||||
GNU C17 (Ubuntu 10.3.0-1ubuntu1) version 10.3.0 (x86_64-linux-gnu)
|
|
||||||
compiled by GNU C version 10.3.0, GMP version 6.2.1, MPFR version 4.1.0, MPC version 1.2.0, isl version isl-0.23-GMP
|
|
||||||
|
|
||||||
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
|
|
||||||
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
|
|
||||||
ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/10/include-fixed"
|
|
||||||
ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/10/../../../../x86_64-linux-gnu/include"
|
|
||||||
#include "..." search starts here:
|
|
||||||
#include <...> search starts here:
|
|
||||||
/usr/lib/gcc/x86_64-linux-gnu/10/include
|
|
||||||
/usr/local/include
|
|
||||||
/usr/include/x86_64-linux-gnu
|
|
||||||
/usr/include
|
|
||||||
End of search list.
|
|
||||||
GNU C17 (Ubuntu 10.3.0-1ubuntu1) version 10.3.0 (x86_64-linux-gnu)
|
|
||||||
compiled by GNU C version 10.3.0, GMP version 6.2.1, MPFR version 4.1.0, MPC version 1.2.0, isl version isl-0.23-GMP
|
|
||||||
|
|
||||||
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
|
|
||||||
Compiler executable checksum: 58794417508a053c2d813aa212cbee7e
|
|
||||||
COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'
|
|
||||||
as -v --64 -o CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o /tmp/cceyw2fY.s
|
|
||||||
GNU assembler version 2.36.1 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.36.1
|
|
||||||
COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/
|
|
||||||
LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../:/lib/:/usr/lib/
|
|
||||||
COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64'
|
|
||||||
Linking C executable cmTC_f9c40
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_f9c40.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -v CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -o cmTC_f9c40
|
|
||||||
Using built-in specs.
|
|
||||||
COLLECT_GCC=/usr/bin/cc
|
|
||||||
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/10/lto-wrapper
|
|
||||||
OFFLOAD_TARGET_NAMES=nvptx-none:amdgcn-amdhsa:hsa
|
|
||||||
OFFLOAD_TARGET_DEFAULT=1
|
|
||||||
Target: x86_64-linux-gnu
|
|
||||||
Configured with: ../src/configure -v --with-pkgversion='Ubuntu 10.3.0-1ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-10/README.Bugs --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,m2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-10 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-bootstrap --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --enable-libphobos-checking=release --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-nvptx/usr,amdgcn-amdhsa=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-gcn/usr,hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu --with-build-config=bootstrap-lto-lean --enable-link-mutex
|
|
||||||
Thread model: posix
|
|
||||||
Supported LTO compression algorithms: zlib zstd
|
|
||||||
gcc version 10.3.0 (Ubuntu 10.3.0-1ubuntu1)
|
|
||||||
COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/
|
|
||||||
LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../:/lib/:/usr/lib/
|
|
||||||
COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_f9c40' '-mtune=generic' '-march=x86-64'
|
|
||||||
/usr/lib/gcc/x86_64-linux-gnu/10/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/10/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/10/lto-wrapper -plugin-opt=-fresolution=/tmp/ccbodrlE.res -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_f9c40 /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/10/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/10 -L/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/10/../../.. CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc --push-state --as-needed -lgcc_s --pop-state /usr/lib/gcc/x86_64-linux-gnu/10/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crtn.o
|
|
||||||
COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_f9c40' '-mtune=generic' '-march=x86-64'
|
|
||||||
gmake[1]: Leaving directory '/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp'
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Parsed C implicit include dir info from above output: rv=done
|
|
||||||
found start of include info
|
|
||||||
found start of implicit include info
|
|
||||||
add: [/usr/lib/gcc/x86_64-linux-gnu/10/include]
|
|
||||||
add: [/usr/local/include]
|
|
||||||
add: [/usr/include/x86_64-linux-gnu]
|
|
||||||
add: [/usr/include]
|
|
||||||
end of search list found
|
|
||||||
collapse include dir [/usr/lib/gcc/x86_64-linux-gnu/10/include] ==> [/usr/lib/gcc/x86_64-linux-gnu/10/include]
|
|
||||||
collapse include dir [/usr/local/include] ==> [/usr/local/include]
|
|
||||||
collapse include dir [/usr/include/x86_64-linux-gnu] ==> [/usr/include/x86_64-linux-gnu]
|
|
||||||
collapse include dir [/usr/include] ==> [/usr/include]
|
|
||||||
implicit include dirs: [/usr/lib/gcc/x86_64-linux-gnu/10/include;/usr/local/include;/usr/include/x86_64-linux-gnu;/usr/include]
|
|
||||||
|
|
||||||
|
|
||||||
Parsed C implicit link information from above output:
|
|
||||||
link line regex: [^( *|.*[/\])(ld|CMAKE_LINK_STARTFILE-NOTFOUND|([^/\]+-)?ld|collect2)[^/\]*( |$)]
|
|
||||||
ignore line: [Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp]
|
|
||||||
ignore line: []
|
|
||||||
ignore line: [Run Build Command(s):/usr/bin/gmake cmTC_f9c40/fast && /usr/bin/gmake -f CMakeFiles/cmTC_f9c40.dir/build.make CMakeFiles/cmTC_f9c40.dir/build]
|
|
||||||
ignore line: [gmake[1]: Entering directory '/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp']
|
|
||||||
ignore line: [Building C object CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o]
|
|
||||||
ignore line: [/usr/bin/cc -v -o CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -c /usr/share/cmake-3.18/Modules/CMakeCCompilerABI.c]
|
|
||||||
ignore line: [Using built-in specs.]
|
|
||||||
ignore line: [COLLECT_GCC=/usr/bin/cc]
|
|
||||||
ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:amdgcn-amdhsa:hsa]
|
|
||||||
ignore line: [OFFLOAD_TARGET_DEFAULT=1]
|
|
||||||
ignore line: [Target: x86_64-linux-gnu]
|
|
||||||
ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 10.3.0-1ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-10/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ m2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-10 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-bootstrap --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --enable-libphobos-checking=release --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-nvptx/usr amdgcn-amdhsa=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-gcn/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu --with-build-config=bootstrap-lto-lean --enable-link-mutex]
|
|
||||||
ignore line: [Thread model: posix]
|
|
||||||
ignore line: [Supported LTO compression algorithms: zlib zstd]
|
|
||||||
ignore line: [gcc version 10.3.0 (Ubuntu 10.3.0-1ubuntu1) ]
|
|
||||||
ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64']
|
|
||||||
ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/10/cc1 -quiet -v -imultiarch x86_64-linux-gnu /usr/share/cmake-3.18/Modules/CMakeCCompilerABI.c -quiet -dumpbase CMakeCCompilerABI.c -mtune=generic -march=x86-64 -auxbase-strip CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -version -fasynchronous-unwind-tables -fstack-protector-strong -Wformat -Wformat-security -fstack-clash-protection -fcf-protection -o /tmp/cceyw2fY.s]
|
|
||||||
ignore line: [GNU C17 (Ubuntu 10.3.0-1ubuntu1) version 10.3.0 (x86_64-linux-gnu)]
|
|
||||||
ignore line: [ compiled by GNU C version 10.3.0 GMP version 6.2.1 MPFR version 4.1.0 MPC version 1.2.0 isl version isl-0.23-GMP]
|
|
||||||
ignore line: []
|
|
||||||
ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072]
|
|
||||||
ignore line: [ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"]
|
|
||||||
ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/10/include-fixed"]
|
|
||||||
ignore line: [ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/10/../../../../x86_64-linux-gnu/include"]
|
|
||||||
ignore line: [#include "..." search starts here:]
|
|
||||||
ignore line: [#include <...> search starts here:]
|
|
||||||
ignore line: [ /usr/lib/gcc/x86_64-linux-gnu/10/include]
|
|
||||||
ignore line: [ /usr/local/include]
|
|
||||||
ignore line: [ /usr/include/x86_64-linux-gnu]
|
|
||||||
ignore line: [ /usr/include]
|
|
||||||
ignore line: [End of search list.]
|
|
||||||
ignore line: [GNU C17 (Ubuntu 10.3.0-1ubuntu1) version 10.3.0 (x86_64-linux-gnu)]
|
|
||||||
ignore line: [ compiled by GNU C version 10.3.0 GMP version 6.2.1 MPFR version 4.1.0 MPC version 1.2.0 isl version isl-0.23-GMP]
|
|
||||||
ignore line: []
|
|
||||||
ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072]
|
|
||||||
ignore line: [Compiler executable checksum: 58794417508a053c2d813aa212cbee7e]
|
|
||||||
ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64']
|
|
||||||
ignore line: [ as -v --64 -o CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o /tmp/cceyw2fY.s]
|
|
||||||
ignore line: [GNU assembler version 2.36.1 (x86_64-linux-gnu) using BFD version (GNU Binutils for Ubuntu) 2.36.1]
|
|
||||||
ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/]
|
|
||||||
ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../:/lib/:/usr/lib/]
|
|
||||||
ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o' '-c' '-mtune=generic' '-march=x86-64']
|
|
||||||
ignore line: [Linking C executable cmTC_f9c40]
|
|
||||||
ignore line: [/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_f9c40.dir/link.txt --verbose=1]
|
|
||||||
ignore line: [/usr/bin/cc -v CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -o cmTC_f9c40 ]
|
|
||||||
ignore line: [Using built-in specs.]
|
|
||||||
ignore line: [COLLECT_GCC=/usr/bin/cc]
|
|
||||||
ignore line: [COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/10/lto-wrapper]
|
|
||||||
ignore line: [OFFLOAD_TARGET_NAMES=nvptx-none:amdgcn-amdhsa:hsa]
|
|
||||||
ignore line: [OFFLOAD_TARGET_DEFAULT=1]
|
|
||||||
ignore line: [Target: x86_64-linux-gnu]
|
|
||||||
ignore line: [Configured with: ../src/configure -v --with-pkgversion='Ubuntu 10.3.0-1ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-10/README.Bugs --enable-languages=c ada c++ go brig d fortran objc obj-c++ m2 --prefix=/usr --with-gcc-major-version-only --program-suffix=-10 --program-prefix=x86_64-linux-gnu- --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --libdir=/usr/lib --enable-nls --enable-bootstrap --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --with-default-libstdcxx-abi=new --enable-gnu-unique-object --disable-vtable-verify --enable-plugin --enable-default-pie --with-system-zlib --enable-libphobos-checking=release --with-target-system-zlib=auto --enable-objc-gc=auto --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32 m64 mx32 --enable-multilib --with-tune=generic --enable-offload-targets=nvptx-none=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-nvptx/usr amdgcn-amdhsa=/build/gcc-10-gDeRY6/gcc-10-10.3.0/debian/tmp-gcn/usr hsa --without-cuda-driver --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu --with-build-config=bootstrap-lto-lean --enable-link-mutex]
|
|
||||||
ignore line: [Thread model: posix]
|
|
||||||
ignore line: [Supported LTO compression algorithms: zlib zstd]
|
|
||||||
ignore line: [gcc version 10.3.0 (Ubuntu 10.3.0-1ubuntu1) ]
|
|
||||||
ignore line: [COMPILER_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/]
|
|
||||||
ignore line: [LIBRARY_PATH=/usr/lib/gcc/x86_64-linux-gnu/10/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib/:/lib/x86_64-linux-gnu/:/lib/../lib/:/usr/lib/x86_64-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/x86_64-linux-gnu/10/../../../:/lib/:/usr/lib/]
|
|
||||||
ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_f9c40' '-mtune=generic' '-march=x86-64']
|
|
||||||
link line: [ /usr/lib/gcc/x86_64-linux-gnu/10/collect2 -plugin /usr/lib/gcc/x86_64-linux-gnu/10/liblto_plugin.so -plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/10/lto-wrapper -plugin-opt=-fresolution=/tmp/ccbodrlE.res -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc -plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s --build-id --eh-frame-hdr -m elf_x86_64 --hash-style=gnu --as-needed -dynamic-linker /lib64/ld-linux-x86-64.so.2 -pie -z now -z relro -o cmTC_f9c40 /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/Scrt1.o /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/10/crtbeginS.o -L/usr/lib/gcc/x86_64-linux-gnu/10 -L/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib -L/lib/x86_64-linux-gnu -L/lib/../lib -L/usr/lib/x86_64-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/x86_64-linux-gnu/10/../../.. CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc --push-state --as-needed -lgcc_s --pop-state /usr/lib/gcc/x86_64-linux-gnu/10/crtendS.o /usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crtn.o]
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/collect2] ==> ignore
|
|
||||||
arg [-plugin] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/liblto_plugin.so] ==> ignore
|
|
||||||
arg [-plugin-opt=/usr/lib/gcc/x86_64-linux-gnu/10/lto-wrapper] ==> ignore
|
|
||||||
arg [-plugin-opt=-fresolution=/tmp/ccbodrlE.res] ==> ignore
|
|
||||||
arg [-plugin-opt=-pass-through=-lgcc] ==> ignore
|
|
||||||
arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore
|
|
||||||
arg [-plugin-opt=-pass-through=-lc] ==> ignore
|
|
||||||
arg [-plugin-opt=-pass-through=-lgcc] ==> ignore
|
|
||||||
arg [-plugin-opt=-pass-through=-lgcc_s] ==> ignore
|
|
||||||
arg [--build-id] ==> ignore
|
|
||||||
arg [--eh-frame-hdr] ==> ignore
|
|
||||||
arg [-m] ==> ignore
|
|
||||||
arg [elf_x86_64] ==> ignore
|
|
||||||
arg [--hash-style=gnu] ==> ignore
|
|
||||||
arg [--as-needed] ==> ignore
|
|
||||||
arg [-dynamic-linker] ==> ignore
|
|
||||||
arg [/lib64/ld-linux-x86-64.so.2] ==> ignore
|
|
||||||
arg [-pie] ==> ignore
|
|
||||||
arg [-znow] ==> ignore
|
|
||||||
arg [-zrelro] ==> ignore
|
|
||||||
arg [-o] ==> ignore
|
|
||||||
arg [cmTC_f9c40] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/Scrt1.o] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crti.o] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/crtbeginS.o] ==> ignore
|
|
||||||
arg [-L/usr/lib/gcc/x86_64-linux-gnu/10] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/10]
|
|
||||||
arg [-L/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu]
|
|
||||||
arg [-L/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib]
|
|
||||||
arg [-L/lib/x86_64-linux-gnu] ==> dir [/lib/x86_64-linux-gnu]
|
|
||||||
arg [-L/lib/../lib] ==> dir [/lib/../lib]
|
|
||||||
arg [-L/usr/lib/x86_64-linux-gnu] ==> dir [/usr/lib/x86_64-linux-gnu]
|
|
||||||
arg [-L/usr/lib/../lib] ==> dir [/usr/lib/../lib]
|
|
||||||
arg [-L/usr/lib/gcc/x86_64-linux-gnu/10/../../..] ==> dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../..]
|
|
||||||
arg [CMakeFiles/cmTC_f9c40.dir/CMakeCCompilerABI.c.o] ==> ignore
|
|
||||||
arg [-lgcc] ==> lib [gcc]
|
|
||||||
arg [--push-state] ==> ignore
|
|
||||||
arg [--as-needed] ==> ignore
|
|
||||||
arg [-lgcc_s] ==> lib [gcc_s]
|
|
||||||
arg [--pop-state] ==> ignore
|
|
||||||
arg [-lc] ==> lib [c]
|
|
||||||
arg [-lgcc] ==> lib [gcc]
|
|
||||||
arg [--push-state] ==> ignore
|
|
||||||
arg [--as-needed] ==> ignore
|
|
||||||
arg [-lgcc_s] ==> lib [gcc_s]
|
|
||||||
arg [--pop-state] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/crtendS.o] ==> ignore
|
|
||||||
arg [/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu/crtn.o] ==> ignore
|
|
||||||
collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/10] ==> [/usr/lib/gcc/x86_64-linux-gnu/10]
|
|
||||||
collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../../x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu]
|
|
||||||
collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../../../lib] ==> [/usr/lib]
|
|
||||||
collapse library dir [/lib/x86_64-linux-gnu] ==> [/lib/x86_64-linux-gnu]
|
|
||||||
collapse library dir [/lib/../lib] ==> [/lib]
|
|
||||||
collapse library dir [/usr/lib/x86_64-linux-gnu] ==> [/usr/lib/x86_64-linux-gnu]
|
|
||||||
collapse library dir [/usr/lib/../lib] ==> [/usr/lib]
|
|
||||||
collapse library dir [/usr/lib/gcc/x86_64-linux-gnu/10/../../..] ==> [/usr/lib]
|
|
||||||
implicit libs: [gcc;gcc_s;c;gcc;gcc_s]
|
|
||||||
implicit dirs: [/usr/lib/gcc/x86_64-linux-gnu/10;/usr/lib/x86_64-linux-gnu;/usr/lib;/lib/x86_64-linux-gnu;/lib]
|
|
||||||
implicit fwks: []
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the include file pthread.h exists passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_dd8f1/fast && /usr/bin/gmake -f CMakeFiles/cmTC_dd8f1.dir/build.make CMakeFiles/cmTC_dd8f1.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_dd8f1.dir/CheckIncludeFile.c.o
|
|
||||||
/usr/bin/cc -o CMakeFiles/cmTC_dd8f1.dir/CheckIncludeFile.c.o -c /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp/CheckIncludeFile.c
|
|
||||||
Linking C executable cmTC_dd8f1
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_dd8f1.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc CMakeFiles/cmTC_dd8f1.dir/CheckIncludeFile.c.o -o cmTC_dd8f1
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function pthread_create exists in the pthread passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_79f2e/fast && /usr/bin/gmake -f CMakeFiles/cmTC_79f2e.dir/build.make CMakeFiles/cmTC_79f2e.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_79f2e.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=pthread_create -o CMakeFiles/cmTC_79f2e.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_79f2e
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_79f2e.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=pthread_create CMakeFiles/cmTC_79f2e.dir/CheckFunctionExists.c.o -o cmTC_79f2e -lpthread
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function XOpenDisplay exists in the /usr/lib/x86_64-linux-gnu/libX11.so;/usr/lib/x86_64-linux-gnu/libXext.so passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_b23c7/fast && /usr/bin/gmake -f CMakeFiles/cmTC_b23c7.dir/build.make CMakeFiles/cmTC_b23c7.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_b23c7.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=XOpenDisplay -o CMakeFiles/cmTC_b23c7.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_b23c7
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_b23c7.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=XOpenDisplay CMakeFiles/cmTC_b23c7.dir/CheckFunctionExists.c.o -o cmTC_b23c7 /usr/lib/x86_64-linux-gnu/libX11.so /usr/lib/x86_64-linux-gnu/libXext.so
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function gethostbyname exists passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_f6d01/fast && /usr/bin/gmake -f CMakeFiles/cmTC_f6d01.dir/build.make CMakeFiles/cmTC_f6d01.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_f6d01.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=gethostbyname -o CMakeFiles/cmTC_f6d01.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_f6d01
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_f6d01.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=gethostbyname CMakeFiles/cmTC_f6d01.dir/CheckFunctionExists.c.o -o cmTC_f6d01
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function connect exists passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_768b9/fast && /usr/bin/gmake -f CMakeFiles/cmTC_768b9.dir/build.make CMakeFiles/cmTC_768b9.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_768b9.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=connect -o CMakeFiles/cmTC_768b9.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_768b9
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_768b9.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=connect CMakeFiles/cmTC_768b9.dir/CheckFunctionExists.c.o -o cmTC_768b9
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function remove exists passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_67907/fast && /usr/bin/gmake -f CMakeFiles/cmTC_67907.dir/build.make CMakeFiles/cmTC_67907.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_67907.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=remove -o CMakeFiles/cmTC_67907.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_67907
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_67907.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=remove CMakeFiles/cmTC_67907.dir/CheckFunctionExists.c.o -o cmTC_67907
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function shmat exists passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_c8a05/fast && /usr/bin/gmake -f CMakeFiles/cmTC_c8a05.dir/build.make CMakeFiles/cmTC_c8a05.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_c8a05.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=shmat -o CMakeFiles/cmTC_c8a05.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_c8a05
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_c8a05.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=shmat CMakeFiles/cmTC_c8a05.dir/CheckFunctionExists.c.o -o cmTC_c8a05
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Determining if the function IceConnectionNumber exists in the ICE passed with the following output:
|
|
||||||
Change Dir: /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp
|
|
||||||
|
|
||||||
Run Build Command(s):/usr/bin/gmake cmTC_50398/fast && /usr/bin/gmake -f CMakeFiles/cmTC_50398.dir/build.make CMakeFiles/cmTC_50398.dir/build
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird betreten
|
|
||||||
Building C object CMakeFiles/cmTC_50398.dir/CheckFunctionExists.c.o
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=IceConnectionNumber -o CMakeFiles/cmTC_50398.dir/CheckFunctionExists.c.o -c /usr/share/cmake-3.18/Modules/CheckFunctionExists.c
|
|
||||||
Linking C executable cmTC_50398
|
|
||||||
/usr/bin/cmake -E cmake_link_script CMakeFiles/cmTC_50398.dir/link.txt --verbose=1
|
|
||||||
/usr/bin/cc -DCHECK_FUNCTION_EXISTS=IceConnectionNumber CMakeFiles/cmTC_50398.dir/CheckFunctionExists.c.o -o cmTC_50398 -lICE
|
|
||||||
gmake[1]: Verzeichnis „/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/CMakeTmp“ wird verlassen
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
|||||||
# Hashes of file build rules.
|
|
||||||
3c05adda0bfc3583ccca95b98db27dde CMakeFiles/uninstall
|
|
||||||
451cce79b908859137e0571324b5a561 src/CMakeFiles/update_mappings
|
|
@ -1,19 +0,0 @@
|
|||||||
#----------------------------------------------------------------
|
|
||||||
# Generated CMake target import file.
|
|
||||||
#----------------------------------------------------------------
|
|
||||||
|
|
||||||
# Commands may need to know the format version.
|
|
||||||
set(CMAKE_IMPORT_FILE_VERSION 1)
|
|
||||||
|
|
||||||
# Import target "glfw" for configuration ""
|
|
||||||
set_property(TARGET glfw APPEND PROPERTY IMPORTED_CONFIGURATIONS NOCONFIG)
|
|
||||||
set_target_properties(glfw PROPERTIES
|
|
||||||
IMPORTED_LINK_INTERFACE_LANGUAGES_NOCONFIG "C"
|
|
||||||
IMPORTED_LOCATION_NOCONFIG "${_IMPORT_PREFIX}/lib/libglfw3.a"
|
|
||||||
)
|
|
||||||
|
|
||||||
list(APPEND _IMPORT_CHECK_TARGETS glfw )
|
|
||||||
list(APPEND _IMPORT_CHECK_FILES_FOR_glfw "${_IMPORT_PREFIX}/lib/libglfw3.a" )
|
|
||||||
|
|
||||||
# Commands beyond this point should not need to know the version.
|
|
||||||
set(CMAKE_IMPORT_FILE_VERSION)
|
|
@ -1,95 +0,0 @@
|
|||||||
# Generated by CMake
|
|
||||||
|
|
||||||
if("${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}" LESS 2.5)
|
|
||||||
message(FATAL_ERROR "CMake >= 2.6.0 required")
|
|
||||||
endif()
|
|
||||||
cmake_policy(PUSH)
|
|
||||||
cmake_policy(VERSION 2.6...3.17)
|
|
||||||
#----------------------------------------------------------------
|
|
||||||
# Generated CMake target import file.
|
|
||||||
#----------------------------------------------------------------
|
|
||||||
|
|
||||||
# Commands may need to know the format version.
|
|
||||||
set(CMAKE_IMPORT_FILE_VERSION 1)
|
|
||||||
|
|
||||||
# Protect against multiple inclusion, which would fail when already imported targets are added once more.
|
|
||||||
set(_targetsDefined)
|
|
||||||
set(_targetsNotDefined)
|
|
||||||
set(_expectedTargets)
|
|
||||||
foreach(_expectedTarget glfw)
|
|
||||||
list(APPEND _expectedTargets ${_expectedTarget})
|
|
||||||
if(NOT TARGET ${_expectedTarget})
|
|
||||||
list(APPEND _targetsNotDefined ${_expectedTarget})
|
|
||||||
endif()
|
|
||||||
if(TARGET ${_expectedTarget})
|
|
||||||
list(APPEND _targetsDefined ${_expectedTarget})
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
if("${_targetsDefined}" STREQUAL "${_expectedTargets}")
|
|
||||||
unset(_targetsDefined)
|
|
||||||
unset(_targetsNotDefined)
|
|
||||||
unset(_expectedTargets)
|
|
||||||
set(CMAKE_IMPORT_FILE_VERSION)
|
|
||||||
cmake_policy(POP)
|
|
||||||
return()
|
|
||||||
endif()
|
|
||||||
if(NOT "${_targetsDefined}" STREQUAL "")
|
|
||||||
message(FATAL_ERROR "Some (but not all) targets in this export set were already defined.\nTargets Defined: ${_targetsDefined}\nTargets not yet defined: ${_targetsNotDefined}\n")
|
|
||||||
endif()
|
|
||||||
unset(_targetsDefined)
|
|
||||||
unset(_targetsNotDefined)
|
|
||||||
unset(_expectedTargets)
|
|
||||||
|
|
||||||
|
|
||||||
# Compute the installation prefix relative to this file.
|
|
||||||
get_filename_component(_IMPORT_PREFIX "glfw3Targets.cmake" PATH)
|
|
||||||
get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH)
|
|
||||||
get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH)
|
|
||||||
get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH)
|
|
||||||
if(_IMPORT_PREFIX STREQUAL "/")
|
|
||||||
set(_IMPORT_PREFIX "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Create imported target glfw
|
|
||||||
add_library(glfw STATIC IMPORTED)
|
|
||||||
|
|
||||||
set_target_properties(glfw PROPERTIES
|
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "${_IMPORT_PREFIX}/include"
|
|
||||||
INTERFACE_LINK_LIBRARIES "/usr/lib/x86_64-linux-gnu/librt.so;/usr/lib/x86_64-linux-gnu/libm.so;\$<LINK_ONLY:dl>;/usr/lib/x86_64-linux-gnu/libX11.so;\$<LINK_ONLY:-lpthread>"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Load information for each installed configuration.
|
|
||||||
get_filename_component(_DIR "glfw3Targets.cmake" PATH)
|
|
||||||
file(GLOB CONFIG_FILES "${_DIR}/glfw3Targets-*.cmake")
|
|
||||||
foreach(f ${CONFIG_FILES})
|
|
||||||
include(${f})
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
# Cleanup temporary variables.
|
|
||||||
set(_IMPORT_PREFIX)
|
|
||||||
|
|
||||||
# Loop over all imported files and verify that they actually exist
|
|
||||||
foreach(target ${_IMPORT_CHECK_TARGETS} )
|
|
||||||
foreach(file ${_IMPORT_CHECK_FILES_FOR_${target}} )
|
|
||||||
if(NOT EXISTS "${file}" )
|
|
||||||
message(FATAL_ERROR "The imported target \"${target}\" references the file
|
|
||||||
\"${file}\"
|
|
||||||
but this file does not exist. Possible reasons include:
|
|
||||||
* The file was deleted, renamed, or moved to another location.
|
|
||||||
* An install or uninstall procedure did not complete successfully.
|
|
||||||
* The installation package was faulty and contained
|
|
||||||
\"${CMAKE_CURRENT_LIST_FILE}\"
|
|
||||||
but not all the files it references.
|
|
||||||
")
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
unset(_IMPORT_CHECK_FILES_FOR_${target})
|
|
||||||
endforeach()
|
|
||||||
unset(_IMPORT_CHECK_TARGETS)
|
|
||||||
|
|
||||||
# This file does not depend on other imported targets which have
|
|
||||||
# been exported from the same project but in a separate export set.
|
|
||||||
|
|
||||||
# Commands beyond this point should not need to know the version.
|
|
||||||
set(CMAKE_IMPORT_FILE_VERSION)
|
|
||||||
cmake_policy(POP)
|
|
@ -1,109 +0,0 @@
|
|||||||
# CMAKE generated file: DO NOT EDIT!
|
|
||||||
# Generated by "Unix Makefiles" Generator, CMake Version 3.18
|
|
||||||
|
|
||||||
# The generator used is:
|
|
||||||
set(CMAKE_DEPENDS_GENERATOR "Unix Makefiles")
|
|
||||||
|
|
||||||
# The top level Makefile was generated from the following files:
|
|
||||||
set(CMAKE_MAKEFILE_DEPENDS
|
|
||||||
"CMakeCache.txt"
|
|
||||||
"CMakeFiles/3.18.4/CMakeCCompiler.cmake"
|
|
||||||
"CMakeFiles/3.18.4/CMakeSystem.cmake"
|
|
||||||
"CMakeLists.txt"
|
|
||||||
"cmake_uninstall.cmake.in"
|
|
||||||
"examples/CMakeLists.txt"
|
|
||||||
"src/CMakeLists.txt"
|
|
||||||
"src/glfw3.pc.in"
|
|
||||||
"src/glfw3Config.cmake.in"
|
|
||||||
"src/glfw_config.h.in"
|
|
||||||
"tests/CMakeLists.txt"
|
|
||||||
"/usr/share/cmake-3.18/Modules/BasicConfigVersion-SameMajorVersion.cmake.in"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeCInformation.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeCheckCompilerFlagCommonPatterns.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeCommonLanguageInclude.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeDependentOption.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeGenericSystem.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeInitializeConfigs.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeLanguageInformation.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakePackageConfigHelpers.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeSystemSpecificInformation.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CMakeSystemSpecificInitialize.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CheckCSourceCompiles.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CheckFunctionExists.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CheckIncludeFile.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/CheckLibraryExists.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Compiler/CMakeCommonCompilerMacros.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Compiler/GNU-C.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Compiler/GNU.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindDoxygen.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindFontconfig.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindFreetype.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindPackageHandleStandardArgs.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindPackageMessage.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindPkgConfig.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindThreads.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/FindX11.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/GNUInstallDirs.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Internal/CMakeCheckCompilerFlag.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Platform/Linux-GNU-C.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Platform/Linux-GNU.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Platform/Linux.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/Platform/UnixPaths.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/SelectLibraryConfigurations.cmake"
|
|
||||||
"/usr/share/cmake-3.18/Modules/WriteBasicConfigVersionFile.cmake"
|
|
||||||
)
|
|
||||||
|
|
||||||
# The corresponding makefile is:
|
|
||||||
set(CMAKE_MAKEFILE_OUTPUTS
|
|
||||||
"Makefile"
|
|
||||||
"CMakeFiles/cmake.check_cache"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Byproducts of CMake generate step:
|
|
||||||
set(CMAKE_MAKEFILE_PRODUCTS
|
|
||||||
"src/glfw3Config.cmake"
|
|
||||||
"src/glfw3ConfigVersion.cmake"
|
|
||||||
"src/glfw_config.h"
|
|
||||||
"src/glfw3.pc"
|
|
||||||
"cmake_uninstall.cmake"
|
|
||||||
"CMakeFiles/CMakeDirectoryInformation.cmake"
|
|
||||||
"src/CMakeFiles/CMakeDirectoryInformation.cmake"
|
|
||||||
"examples/CMakeFiles/CMakeDirectoryInformation.cmake"
|
|
||||||
"tests/CMakeFiles/CMakeDirectoryInformation.cmake"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Dependency information for all targets:
|
|
||||||
set(CMAKE_DEPEND_INFO_FILES
|
|
||||||
"CMakeFiles/uninstall.dir/DependInfo.cmake"
|
|
||||||
"src/CMakeFiles/glfw.dir/DependInfo.cmake"
|
|
||||||
"src/CMakeFiles/update_mappings.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/boing.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/gears.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/heightmap.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/sharing.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/particles.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/simple.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/splitview.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/offscreen.dir/DependInfo.cmake"
|
|
||||||
"examples/CMakeFiles/wave.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/triangle-vulkan.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/tearing.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/title.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/opacity.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/clipboard.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/msaa.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/glfwinfo.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/iconify.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/reopen.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/gamma.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/monitors.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/windows.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/timeout.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/inputlag.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/threads.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/cursor.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/empty.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/icon.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/events.dir/DependInfo.cmake"
|
|
||||||
"tests/CMakeFiles/joysticks.dir/DependInfo.cmake"
|
|
||||||
)
|
|
@ -1,56 +0,0 @@
|
|||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/install/strip.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/install/local.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/install.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/list_install_components.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/rebuild_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/edit_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/uninstall.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/install/strip.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/install.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/list_install_components.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/rebuild_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/edit_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/install/local.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/glfw.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/src/CMakeFiles/update_mappings.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/install/strip.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/boing.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/list_install_components.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/install.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/install/local.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/gears.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/heightmap.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/sharing.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/particles.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/simple.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/splitview.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/offscreen.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/wave.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/rebuild_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/examples/CMakeFiles/edit_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/triangle-vulkan.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/tearing.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/title.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/opacity.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/clipboard.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/list_install_components.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/msaa.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/glfwinfo.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/iconify.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/rebuild_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/edit_cache.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/reopen.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/install.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/gamma.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/monitors.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/windows.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/timeout.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/inputlag.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/threads.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/cursor.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/install/local.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/empty.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/icon.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/install/strip.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/events.dir
|
|
||||||
/home/niklas/Downloads/glfw-3.3.5/tests/CMakeFiles/joysticks.dir
|
|
@ -1 +0,0 @@
|
|||||||
# This file is generated by cmake for dependency checking of the CMakeCache.txt file
|
|
@ -1 +0,0 @@
|
|||||||
99
|
|
@ -1,11 +0,0 @@
|
|||||||
# The set of languages for which implicit dependencies are needed:
|
|
||||||
set(CMAKE_DEPENDS_LANGUAGES
|
|
||||||
)
|
|
||||||
# The set of files for implicit dependencies of each language:
|
|
||||||
|
|
||||||
# Targets to which this target links.
|
|
||||||
set(CMAKE_TARGET_LINKED_INFO_FILES
|
|
||||||
)
|
|
||||||
|
|
||||||
# Fortran module output directory.
|
|
||||||
set(CMAKE_Fortran_TARGET_MODULE_DIR "")
|
|
@ -1,95 +0,0 @@
|
|||||||
# CMAKE generated file: DO NOT EDIT!
|
|
||||||
# Generated by "Unix Makefiles" Generator, CMake Version 3.18
|
|
||||||
|
|
||||||
# Delete rule output on recipe failure.
|
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Special targets provided by cmake.
|
|
||||||
|
|
||||||
# Disable implicit rules so canonical targets will work.
|
|
||||||
.SUFFIXES:
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : %,v
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : RCS/%
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : RCS/%,v
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : SCCS/s.%
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : s.%
|
|
||||||
|
|
||||||
|
|
||||||
.SUFFIXES: .hpux_make_needs_suffix_list
|
|
||||||
|
|
||||||
|
|
||||||
# Command-line flag to silence nested $(MAKE).
|
|
||||||
$(VERBOSE)MAKESILENT = -s
|
|
||||||
|
|
||||||
#Suppress display of executed commands.
|
|
||||||
$(VERBOSE).SILENT:
|
|
||||||
|
|
||||||
# A target that is always out of date.
|
|
||||||
cmake_force:
|
|
||||||
|
|
||||||
.PHONY : cmake_force
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Set environment variables for the build.
|
|
||||||
|
|
||||||
# The shell in which to execute make rules.
|
|
||||||
SHELL = /bin/sh
|
|
||||||
|
|
||||||
# The CMake executable.
|
|
||||||
CMAKE_COMMAND = /usr/bin/cmake
|
|
||||||
|
|
||||||
# The command to remove a file.
|
|
||||||
RM = /usr/bin/cmake -E rm -f
|
|
||||||
|
|
||||||
# Escaping for special characters.
|
|
||||||
EQUALS = =
|
|
||||||
|
|
||||||
# The top-level source directory on which CMake was run.
|
|
||||||
CMAKE_SOURCE_DIR = /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
# The top-level build directory on which CMake was run.
|
|
||||||
CMAKE_BINARY_DIR = /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
# Utility rule file for uninstall.
|
|
||||||
|
|
||||||
# Include the progress variables for this target.
|
|
||||||
include CMakeFiles/uninstall.dir/progress.make
|
|
||||||
|
|
||||||
CMakeFiles/uninstall:
|
|
||||||
/usr/bin/cmake -P /home/niklas/Downloads/glfw-3.3.5/cmake_uninstall.cmake
|
|
||||||
|
|
||||||
uninstall: CMakeFiles/uninstall
|
|
||||||
uninstall: CMakeFiles/uninstall.dir/build.make
|
|
||||||
|
|
||||||
.PHONY : uninstall
|
|
||||||
|
|
||||||
# Rule to build all files generated by this target.
|
|
||||||
CMakeFiles/uninstall.dir/build: uninstall
|
|
||||||
|
|
||||||
.PHONY : CMakeFiles/uninstall.dir/build
|
|
||||||
|
|
||||||
CMakeFiles/uninstall.dir/clean:
|
|
||||||
$(CMAKE_COMMAND) -P CMakeFiles/uninstall.dir/cmake_clean.cmake
|
|
||||||
.PHONY : CMakeFiles/uninstall.dir/clean
|
|
||||||
|
|
||||||
CMakeFiles/uninstall.dir/depend:
|
|
||||||
cd /home/niklas/Downloads/glfw-3.3.5 && $(CMAKE_COMMAND) -E cmake_depends "Unix Makefiles" /home/niklas/Downloads/glfw-3.3.5 /home/niklas/Downloads/glfw-3.3.5 /home/niklas/Downloads/glfw-3.3.5 /home/niklas/Downloads/glfw-3.3.5 /home/niklas/Downloads/glfw-3.3.5/CMakeFiles/uninstall.dir/DependInfo.cmake --color=$(COLOR)
|
|
||||||
.PHONY : CMakeFiles/uninstall.dir/depend
|
|
||||||
|
|
@ -1,8 +0,0 @@
|
|||||||
file(REMOVE_RECURSE
|
|
||||||
"CMakeFiles/uninstall"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Per-language clean rules from dependency scanning.
|
|
||||||
foreach(lang )
|
|
||||||
include(CMakeFiles/uninstall.dir/cmake_clean_${lang}.cmake OPTIONAL)
|
|
||||||
endforeach()
|
|
@ -1 +0,0 @@
|
|||||||
|
|
@ -1,386 +0,0 @@
|
|||||||
cmake_minimum_required(VERSION 3.0...3.20 FATAL_ERROR)
|
|
||||||
|
|
||||||
project(GLFW VERSION 3.3.5 LANGUAGES C)
|
|
||||||
|
|
||||||
set(CMAKE_LEGACY_CYGWIN_WIN32 OFF)
|
|
||||||
|
|
||||||
if (POLICY CMP0054)
|
|
||||||
cmake_policy(SET CMP0054 NEW)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (POLICY CMP0069)
|
|
||||||
cmake_policy(SET CMP0069 NEW)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (POLICY CMP0077)
|
|
||||||
cmake_policy(SET CMP0077 NEW)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
|
||||||
|
|
||||||
option(BUILD_SHARED_LIBS "Build shared libraries" OFF)
|
|
||||||
option(GLFW_BUILD_EXAMPLES "Build the GLFW example programs" ON)
|
|
||||||
option(GLFW_BUILD_TESTS "Build the GLFW test programs" ON)
|
|
||||||
option(GLFW_BUILD_DOCS "Build the GLFW documentation" ON)
|
|
||||||
option(GLFW_INSTALL "Generate installation target" ON)
|
|
||||||
option(GLFW_VULKAN_STATIC "Assume the Vulkan loader is linked with the application" OFF)
|
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
|
||||||
include(CMakeDependentOption)
|
|
||||||
|
|
||||||
cmake_dependent_option(GLFW_USE_OSMESA "Use OSMesa for offscreen context creation" OFF
|
|
||||||
"UNIX" OFF)
|
|
||||||
cmake_dependent_option(GLFW_USE_HYBRID_HPG "Force use of high-performance GPU on hybrid systems" OFF
|
|
||||||
"WIN32" OFF)
|
|
||||||
cmake_dependent_option(GLFW_USE_WAYLAND "Use Wayland for window creation" OFF
|
|
||||||
"UNIX;NOT APPLE" OFF)
|
|
||||||
cmake_dependent_option(USE_MSVC_RUNTIME_LIBRARY_DLL "Use MSVC runtime library DLL" ON
|
|
||||||
"MSVC" OFF)
|
|
||||||
|
|
||||||
if (BUILD_SHARED_LIBS)
|
|
||||||
set(_GLFW_BUILD_DLL 1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (BUILD_SHARED_LIBS AND UNIX)
|
|
||||||
# On Unix-like systems, shared libraries can use the soname system.
|
|
||||||
set(GLFW_LIB_NAME glfw)
|
|
||||||
else()
|
|
||||||
set(GLFW_LIB_NAME glfw3)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (GLFW_VULKAN_STATIC)
|
|
||||||
if (BUILD_SHARED_LIBS)
|
|
||||||
# If you absolutely must do this, remove this line and add the Vulkan
|
|
||||||
# loader static library via the CMAKE_SHARED_LINKER_FLAGS
|
|
||||||
message(FATAL_ERROR "You are trying to link the Vulkan loader static library into the GLFW shared library")
|
|
||||||
endif()
|
|
||||||
set(_GLFW_VULKAN_STATIC 1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${GLFW_SOURCE_DIR}/CMake/modules")
|
|
||||||
|
|
||||||
find_package(Threads REQUIRED)
|
|
||||||
|
|
||||||
if (GLFW_BUILD_DOCS)
|
|
||||||
set(DOXYGEN_SKIP_DOT TRUE)
|
|
||||||
find_package(Doxygen)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Apply Microsoft C runtime library option
|
|
||||||
# This is here because it also applies to tests and examples
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (MSVC)
|
|
||||||
if (MSVC90)
|
|
||||||
# Workaround for VS 2008 not shipping with the DirectX 9 SDK
|
|
||||||
include(CheckIncludeFile)
|
|
||||||
check_include_file(dinput.h DINPUT_H_FOUND)
|
|
||||||
if (NOT DINPUT_H_FOUND)
|
|
||||||
message(FATAL_ERROR "DirectX 9 headers not found; install DirectX 9 SDK")
|
|
||||||
endif()
|
|
||||||
# Workaround for VS 2008 not shipping with stdint.h
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${GLFW_SOURCE_DIR}/deps/vs2008")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (MSVC AND NOT USE_MSVC_RUNTIME_LIBRARY_DLL)
|
|
||||||
if (CMAKE_VERSION VERSION_LESS 3.15)
|
|
||||||
foreach (flag CMAKE_C_FLAGS
|
|
||||||
CMAKE_C_FLAGS_DEBUG
|
|
||||||
CMAKE_C_FLAGS_RELEASE
|
|
||||||
CMAKE_C_FLAGS_MINSIZEREL
|
|
||||||
CMAKE_C_FLAGS_RELWITHDEBINFO)
|
|
||||||
|
|
||||||
if (flag MATCHES "/MD")
|
|
||||||
string(REGEX REPLACE "/MD" "/MT" ${flag} "${${flag}}")
|
|
||||||
endif()
|
|
||||||
if (flag MATCHES "/MDd")
|
|
||||||
string(REGEX REPLACE "/MDd" "/MTd" ${flag} "${${flag}}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endforeach()
|
|
||||||
else()
|
|
||||||
set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$<CONFIG:Debug>:Debug>")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (MINGW)
|
|
||||||
# Workaround for legacy MinGW not providing XInput and DirectInput
|
|
||||||
include(CheckIncludeFile)
|
|
||||||
|
|
||||||
check_include_file(dinput.h DINPUT_H_FOUND)
|
|
||||||
check_include_file(xinput.h XINPUT_H_FOUND)
|
|
||||||
if (NOT DINPUT_H_FOUND OR NOT XINPUT_H_FOUND)
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${GLFW_SOURCE_DIR}/deps/mingw")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Enable link-time exploit mitigation features enabled by default on MSVC
|
|
||||||
include(CheckCCompilerFlag)
|
|
||||||
|
|
||||||
# Compatibility with data execution prevention (DEP)
|
|
||||||
set(CMAKE_REQUIRED_FLAGS "-Wl,--nxcompat")
|
|
||||||
check_c_compiler_flag("" _GLFW_HAS_DEP)
|
|
||||||
if (_GLFW_HAS_DEP)
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--nxcompat ${CMAKE_SHARED_LINKER_FLAGS}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Compatibility with address space layout randomization (ASLR)
|
|
||||||
set(CMAKE_REQUIRED_FLAGS "-Wl,--dynamicbase")
|
|
||||||
check_c_compiler_flag("" _GLFW_HAS_ASLR)
|
|
||||||
if (_GLFW_HAS_ASLR)
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--dynamicbase ${CMAKE_SHARED_LINKER_FLAGS}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Compatibility with 64-bit address space layout randomization (ASLR)
|
|
||||||
set(CMAKE_REQUIRED_FLAGS "-Wl,--high-entropy-va")
|
|
||||||
check_c_compiler_flag("" _GLFW_HAS_64ASLR)
|
|
||||||
if (_GLFW_HAS_64ASLR)
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--high-entropy-va ${CMAKE_SHARED_LINKER_FLAGS}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Clear flags again to avoid breaking later tests
|
|
||||||
set(CMAKE_REQUIRED_FLAGS)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Detect and select backend APIs
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (GLFW_USE_WAYLAND)
|
|
||||||
set(_GLFW_WAYLAND 1)
|
|
||||||
message(STATUS "Using Wayland for window creation")
|
|
||||||
elseif (GLFW_USE_OSMESA)
|
|
||||||
set(_GLFW_OSMESA 1)
|
|
||||||
message(STATUS "Using OSMesa for headless context creation")
|
|
||||||
elseif (WIN32)
|
|
||||||
set(_GLFW_WIN32 1)
|
|
||||||
message(STATUS "Using Win32 for window creation")
|
|
||||||
elseif (APPLE)
|
|
||||||
set(_GLFW_COCOA 1)
|
|
||||||
message(STATUS "Using Cocoa for window creation")
|
|
||||||
elseif (UNIX)
|
|
||||||
set(_GLFW_X11 1)
|
|
||||||
message(STATUS "Using X11 for window creation")
|
|
||||||
else()
|
|
||||||
message(FATAL_ERROR "No supported platform was detected")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Find and add Unix math and time libraries
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (UNIX AND NOT APPLE)
|
|
||||||
find_library(RT_LIBRARY rt)
|
|
||||||
mark_as_advanced(RT_LIBRARY)
|
|
||||||
if (RT_LIBRARY)
|
|
||||||
list(APPEND glfw_LIBRARIES "${RT_LIBRARY}")
|
|
||||||
list(APPEND glfw_PKG_LIBS "-lrt")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
find_library(MATH_LIBRARY m)
|
|
||||||
mark_as_advanced(MATH_LIBRARY)
|
|
||||||
if (MATH_LIBRARY)
|
|
||||||
list(APPEND glfw_LIBRARIES "${MATH_LIBRARY}")
|
|
||||||
list(APPEND glfw_PKG_LIBS "-lm")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (CMAKE_DL_LIBS)
|
|
||||||
list(APPEND glfw_LIBRARIES "${CMAKE_DL_LIBS}")
|
|
||||||
list(APPEND glfw_PKG_LIBS "-l${CMAKE_DL_LIBS}")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Use Win32 for window creation
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (_GLFW_WIN32)
|
|
||||||
|
|
||||||
list(APPEND glfw_PKG_LIBS "-lgdi32")
|
|
||||||
|
|
||||||
if (GLFW_USE_HYBRID_HPG)
|
|
||||||
set(_GLFW_USE_HYBRID_HPG 1)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Use X11 for window creation
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (_GLFW_X11)
|
|
||||||
|
|
||||||
find_package(X11 REQUIRED)
|
|
||||||
|
|
||||||
list(APPEND glfw_PKG_DEPS "x11")
|
|
||||||
|
|
||||||
# Set up library and include paths
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${X11_X11_INCLUDE_PATH}")
|
|
||||||
list(APPEND glfw_LIBRARIES "${X11_X11_LIB}" "${CMAKE_THREAD_LIBS_INIT}")
|
|
||||||
|
|
||||||
# Check for XRandR (modern resolution switching and gamma control)
|
|
||||||
if (NOT X11_Xrandr_INCLUDE_PATH)
|
|
||||||
message(FATAL_ERROR "RandR headers not found; install libxrandr development package")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for Xinerama (legacy multi-monitor support)
|
|
||||||
if (NOT X11_Xinerama_INCLUDE_PATH)
|
|
||||||
message(FATAL_ERROR "Xinerama headers not found; install libxinerama development package")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for Xkb (X keyboard extension)
|
|
||||||
if (NOT X11_Xkb_INCLUDE_PATH)
|
|
||||||
message(FATAL_ERROR "XKB headers not found; install X11 development package")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for Xcursor (cursor creation from RGBA images)
|
|
||||||
if (NOT X11_Xcursor_INCLUDE_PATH)
|
|
||||||
message(FATAL_ERROR "Xcursor headers not found; install libxcursor development package")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for XInput (modern HID input)
|
|
||||||
if (NOT X11_Xi_INCLUDE_PATH)
|
|
||||||
message(FATAL_ERROR "XInput headers not found; install libxi development package")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${X11_Xrandr_INCLUDE_PATH}"
|
|
||||||
"${X11_Xinerama_INCLUDE_PATH}"
|
|
||||||
"${X11_Xkb_INCLUDE_PATH}"
|
|
||||||
"${X11_Xcursor_INCLUDE_PATH}"
|
|
||||||
"${X11_Xi_INCLUDE_PATH}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Use Wayland for window creation
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (_GLFW_WAYLAND)
|
|
||||||
find_package(ECM REQUIRED NO_MODULE)
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${ECM_MODULE_PATH}")
|
|
||||||
|
|
||||||
find_package(Wayland REQUIRED Client Cursor Egl)
|
|
||||||
find_package(WaylandScanner REQUIRED)
|
|
||||||
find_package(WaylandProtocols 1.15 REQUIRED)
|
|
||||||
|
|
||||||
list(APPEND glfw_PKG_DEPS "wayland-client")
|
|
||||||
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${Wayland_INCLUDE_DIRS}")
|
|
||||||
list(APPEND glfw_LIBRARIES "${Wayland_LIBRARIES}" "${CMAKE_THREAD_LIBS_INIT}")
|
|
||||||
|
|
||||||
find_package(XKBCommon REQUIRED)
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${XKBCOMMON_INCLUDE_DIRS}")
|
|
||||||
|
|
||||||
include(CheckIncludeFiles)
|
|
||||||
include(CheckFunctionExists)
|
|
||||||
check_include_files(xkbcommon/xkbcommon-compose.h HAVE_XKBCOMMON_COMPOSE_H)
|
|
||||||
check_function_exists(memfd_create HAVE_MEMFD_CREATE)
|
|
||||||
|
|
||||||
if (NOT CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
|
||||||
find_package(EpollShim)
|
|
||||||
if (EPOLLSHIM_FOUND)
|
|
||||||
list(APPEND glfw_INCLUDE_DIRS "${EPOLLSHIM_INCLUDE_DIRS}")
|
|
||||||
list(APPEND glfw_LIBRARIES "${EPOLLSHIM_LIBRARIES}")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Use OSMesa for offscreen context creation
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (_GLFW_OSMESA)
|
|
||||||
find_package(OSMesa REQUIRED)
|
|
||||||
list(APPEND glfw_LIBRARIES "${CMAKE_THREAD_LIBS_INIT}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Use Cocoa for window creation and NSOpenGL for context creation
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (_GLFW_COCOA)
|
|
||||||
|
|
||||||
list(APPEND glfw_LIBRARIES
|
|
||||||
"-framework Cocoa"
|
|
||||||
"-framework IOKit"
|
|
||||||
"-framework CoreFoundation")
|
|
||||||
|
|
||||||
set(glfw_PKG_DEPS "")
|
|
||||||
set(glfw_PKG_LIBS "-framework Cocoa -framework IOKit -framework CoreFoundation")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Add the Vulkan loader as a dependency if necessary
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (GLFW_VULKAN_STATIC)
|
|
||||||
list(APPEND glfw_PKG_DEPS "vulkan")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Export GLFW library dependencies
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
foreach(arg ${glfw_PKG_DEPS})
|
|
||||||
set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} ${arg}")
|
|
||||||
endforeach()
|
|
||||||
foreach(arg ${glfw_PKG_LIBS})
|
|
||||||
set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} ${arg}")
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Create generated files
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
include(CMakePackageConfigHelpers)
|
|
||||||
|
|
||||||
set(GLFW_CONFIG_PATH "${CMAKE_INSTALL_LIBDIR}/cmake/glfw3")
|
|
||||||
|
|
||||||
configure_package_config_file(src/glfw3Config.cmake.in
|
|
||||||
src/glfw3Config.cmake
|
|
||||||
INSTALL_DESTINATION "${GLFW_CONFIG_PATH}"
|
|
||||||
NO_CHECK_REQUIRED_COMPONENTS_MACRO)
|
|
||||||
|
|
||||||
write_basic_package_version_file(src/glfw3ConfigVersion.cmake
|
|
||||||
VERSION ${GLFW_VERSION}
|
|
||||||
COMPATIBILITY SameMajorVersion)
|
|
||||||
|
|
||||||
configure_file(src/glfw_config.h.in src/glfw_config.h @ONLY)
|
|
||||||
|
|
||||||
configure_file(src/glfw3.pc.in src/glfw3.pc @ONLY)
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Add subdirectories
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
add_subdirectory(src)
|
|
||||||
|
|
||||||
if (GLFW_BUILD_EXAMPLES)
|
|
||||||
add_subdirectory(examples)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (GLFW_BUILD_TESTS)
|
|
||||||
add_subdirectory(tests)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (DOXYGEN_FOUND AND GLFW_BUILD_DOCS)
|
|
||||||
add_subdirectory(docs)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
# Install files other than the library
|
|
||||||
# The library is installed by src/CMakeLists.txt
|
|
||||||
#--------------------------------------------------------------------
|
|
||||||
if (GLFW_INSTALL)
|
|
||||||
install(DIRECTORY include/GLFW DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
|
|
||||||
FILES_MATCHING PATTERN glfw3.h PATTERN glfw3native.h)
|
|
||||||
|
|
||||||
install(FILES "${GLFW_BINARY_DIR}/src/glfw3Config.cmake"
|
|
||||||
"${GLFW_BINARY_DIR}/src/glfw3ConfigVersion.cmake"
|
|
||||||
DESTINATION "${GLFW_CONFIG_PATH}")
|
|
||||||
|
|
||||||
install(EXPORT glfwTargets FILE glfw3Targets.cmake
|
|
||||||
EXPORT_LINK_INTERFACE_LIBRARIES
|
|
||||||
DESTINATION "${GLFW_CONFIG_PATH}")
|
|
||||||
install(FILES "${GLFW_BINARY_DIR}/src/glfw3.pc"
|
|
||||||
DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig")
|
|
||||||
|
|
||||||
# Only generate this target if no higher-level project already has
|
|
||||||
if (NOT TARGET uninstall)
|
|
||||||
configure_file(cmake_uninstall.cmake.in
|
|
||||||
cmake_uninstall.cmake IMMEDIATE @ONLY)
|
|
||||||
|
|
||||||
add_custom_target(uninstall
|
|
||||||
"${CMAKE_COMMAND}" -P
|
|
||||||
"${GLFW_BINARY_DIR}/cmake_uninstall.cmake")
|
|
||||||
set_target_properties(uninstall PROPERTIES FOLDER "GLFW3")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
@ -1,220 +0,0 @@
|
|||||||
# Acknowledgements
|
|
||||||
|
|
||||||
GLFW exists because people around the world donated their time and lent their
|
|
||||||
skills. This list only includes contributions to the main repository and
|
|
||||||
excludes other invaluable contributions like language bindings and text and
|
|
||||||
video tutorials.
|
|
||||||
|
|
||||||
- Bobyshev Alexander
|
|
||||||
- Laurent Aphecetche
|
|
||||||
- Matt Arsenault
|
|
||||||
- ashishgamedev
|
|
||||||
- David Avedissian
|
|
||||||
- Keith Bauer
|
|
||||||
- John Bartholomew
|
|
||||||
- Coşku Baş
|
|
||||||
- Niklas Behrens
|
|
||||||
- Andrew Belt
|
|
||||||
- Nevyn Bengtsson
|
|
||||||
- Niklas Bergström
|
|
||||||
- Denis Bernard
|
|
||||||
- Doug Binks
|
|
||||||
- blanco
|
|
||||||
- Waris Boonyasiriwat
|
|
||||||
- Kyle Brenneman
|
|
||||||
- Rok Breulj
|
|
||||||
- Kai Burjack
|
|
||||||
- Martin Capitanio
|
|
||||||
- Nicolas Caramelli
|
|
||||||
- David Carlier
|
|
||||||
- Arturo Castro
|
|
||||||
- Chi-kwan Chan
|
|
||||||
- Joseph Chua
|
|
||||||
- Ian Clarkson
|
|
||||||
- Michał Cichoń
|
|
||||||
- Lambert Clara
|
|
||||||
- Anna Clarke
|
|
||||||
- Josh Codd
|
|
||||||
- Yaron Cohen-Tal
|
|
||||||
- Omar Cornut
|
|
||||||
- Andrew Corrigan
|
|
||||||
- Bailey Cosier
|
|
||||||
- Noel Cower
|
|
||||||
- CuriouserThing
|
|
||||||
- Jason Daly
|
|
||||||
- Jarrod Davis
|
|
||||||
- Olivier Delannoy
|
|
||||||
- Paul R. Deppe
|
|
||||||
- Michael Dickens
|
|
||||||
- Роман Донченко
|
|
||||||
- Mario Dorn
|
|
||||||
- Wolfgang Draxinger
|
|
||||||
- Jonathan Dummer
|
|
||||||
- Ralph Eastwood
|
|
||||||
- Fredrik Ehnbom
|
|
||||||
- Robin Eklind
|
|
||||||
- Siavash Eliasi
|
|
||||||
- TheExileFox
|
|
||||||
- Felipe Ferreira
|
|
||||||
- Michael Fogleman
|
|
||||||
- Gerald Franz
|
|
||||||
- Mário Freitas
|
|
||||||
- GeO4d
|
|
||||||
- Marcus Geelnard
|
|
||||||
- Charles Giessen
|
|
||||||
- Ryan C. Gordon
|
|
||||||
- Stephen Gowen
|
|
||||||
- Kovid Goyal
|
|
||||||
- Eloi Marín Gratacós
|
|
||||||
- Stefan Gustavson
|
|
||||||
- Jonathan Hale
|
|
||||||
- hdf89shfdfs
|
|
||||||
- Sylvain Hellegouarch
|
|
||||||
- Matthew Henry
|
|
||||||
- heromyth
|
|
||||||
- Lucas Hinderberger
|
|
||||||
- Paul Holden
|
|
||||||
- Warren Hu
|
|
||||||
- Charles Huber
|
|
||||||
- IntellectualKitty
|
|
||||||
- Aaron Jacobs
|
|
||||||
- Erik S. V. Jansson
|
|
||||||
- Toni Jovanoski
|
|
||||||
- Arseny Kapoulkine
|
|
||||||
- Cem Karan
|
|
||||||
- Osman Keskin
|
|
||||||
- Koray Kilinc
|
|
||||||
- Josh Kilmer
|
|
||||||
- Byunghoon Kim
|
|
||||||
- Cameron King
|
|
||||||
- Peter Knut
|
|
||||||
- Christoph Kubisch
|
|
||||||
- Yuri Kunde Schlesner
|
|
||||||
- Rokas Kupstys
|
|
||||||
- Konstantin Käfer
|
|
||||||
- Eric Larson
|
|
||||||
- Francis Lecavalier
|
|
||||||
- Jong Won Lee
|
|
||||||
- Robin Leffmann
|
|
||||||
- Glenn Lewis
|
|
||||||
- Shane Liesegang
|
|
||||||
- Anders Lindqvist
|
|
||||||
- Leon Linhart
|
|
||||||
- Marco Lizza
|
|
||||||
- Eyal Lotem
|
|
||||||
- Aaron Loucks
|
|
||||||
- Luflosi
|
|
||||||
- lukect
|
|
||||||
- Tristam MacDonald
|
|
||||||
- Hans Mackowiak
|
|
||||||
- Дмитри Малышев
|
|
||||||
- Zbigniew Mandziejewicz
|
|
||||||
- Adam Marcus
|
|
||||||
- Célestin Marot
|
|
||||||
- Kyle McDonald
|
|
||||||
- David V. McKay
|
|
||||||
- David Medlock
|
|
||||||
- Bryce Mehring
|
|
||||||
- Jonathan Mercier
|
|
||||||
- Marcel Metz
|
|
||||||
- Liam Middlebrook
|
|
||||||
- Ave Milia
|
|
||||||
- Jonathan Miller
|
|
||||||
- Kenneth Miller
|
|
||||||
- Bruce Mitchener
|
|
||||||
- Jack Moffitt
|
|
||||||
- Jeff Molofee
|
|
||||||
- Alexander Monakov
|
|
||||||
- Pierre Morel
|
|
||||||
- Jon Morton
|
|
||||||
- Pierre Moulon
|
|
||||||
- Martins Mozeiko
|
|
||||||
- Julian Møller
|
|
||||||
- ndogxj
|
|
||||||
- Kristian Nielsen
|
|
||||||
- Kamil Nowakowski
|
|
||||||
- onox
|
|
||||||
- Denis Ovod
|
|
||||||
- Ozzy
|
|
||||||
- Andri Pálsson
|
|
||||||
- Peoro
|
|
||||||
- Braden Pellett
|
|
||||||
- Christopher Pelloux
|
|
||||||
- Arturo J. Pérez
|
|
||||||
- Vladimir Perminov
|
|
||||||
- Anthony Pesch
|
|
||||||
- Orson Peters
|
|
||||||
- Emmanuel Gil Peyrot
|
|
||||||
- Cyril Pichard
|
|
||||||
- Keith Pitt
|
|
||||||
- Stanislav Podgorskiy
|
|
||||||
- Konstantin Podsvirov
|
|
||||||
- Nathan Poirier
|
|
||||||
- Alexandre Pretyman
|
|
||||||
- Pablo Prietz
|
|
||||||
- przemekmirek
|
|
||||||
- pthom
|
|
||||||
- Guillaume Racicot
|
|
||||||
- Philip Rideout
|
|
||||||
- Eddie Ringle
|
|
||||||
- Max Risuhin
|
|
||||||
- Jorge Rodriguez
|
|
||||||
- Luca Rood
|
|
||||||
- Ed Ropple
|
|
||||||
- Aleksey Rybalkin
|
|
||||||
- Mikko Rytkönen
|
|
||||||
- Riku Salminen
|
|
||||||
- Brandon Schaefer
|
|
||||||
- Sebastian Schuberth
|
|
||||||
- Christian Sdunek
|
|
||||||
- Matt Sealey
|
|
||||||
- Steve Sexton
|
|
||||||
- Arkady Shapkin
|
|
||||||
- Ali Sherief
|
|
||||||
- Yoshiki Shibukawa
|
|
||||||
- Dmitri Shuralyov
|
|
||||||
- Daniel Skorupski
|
|
||||||
- Bradley Smith
|
|
||||||
- Cliff Smolinsky
|
|
||||||
- Patrick Snape
|
|
||||||
- Erlend Sogge Heggen
|
|
||||||
- Julian Squires
|
|
||||||
- Johannes Stein
|
|
||||||
- Pontus Stenetorp
|
|
||||||
- Michael Stocker
|
|
||||||
- Justin Stoecker
|
|
||||||
- Elviss Strazdins
|
|
||||||
- Paul Sultana
|
|
||||||
- Nathan Sweet
|
|
||||||
- TTK-Bandit
|
|
||||||
- Sergey Tikhomirov
|
|
||||||
- Arthur Tombs
|
|
||||||
- Ioannis Tsakpinis
|
|
||||||
- Samuli Tuomola
|
|
||||||
- Matthew Turner
|
|
||||||
- urraka
|
|
||||||
- Elias Vanderstuyft
|
|
||||||
- Stef Velzel
|
|
||||||
- Jari Vetoniemi
|
|
||||||
- Ricardo Vieira
|
|
||||||
- Nicholas Vitovitch
|
|
||||||
- Simon Voordouw
|
|
||||||
- Corentin Wallez
|
|
||||||
- Torsten Walluhn
|
|
||||||
- Patrick Walton
|
|
||||||
- Xo Wang
|
|
||||||
- Jay Weisskopf
|
|
||||||
- Frank Wille
|
|
||||||
- Richard A. Wilkes
|
|
||||||
- Tatsuya Yatagawa
|
|
||||||
- Ryogo Yoshimura
|
|
||||||
- Lukas Zanner
|
|
||||||
- Andrey Zholos
|
|
||||||
- Aihui Zhu
|
|
||||||
- Santi Zupancic
|
|
||||||
- Jonas Ådahl
|
|
||||||
- Lasse Öörni
|
|
||||||
- Leonard König
|
|
||||||
- All the unmentioned and anonymous contributors in the GLFW community, for bug
|
|
||||||
reports, patches, feedback, testing and encouragement
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
|||||||
Copyright (c) 2002-2006 Marcus Geelnard
|
|
||||||
|
|
||||||
Copyright (c) 2006-2019 Camilla Löwy
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
|
||||||
warranty. In no event will the authors be held liable for any damages
|
|
||||||
arising from the use of this software.
|
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it
|
|
||||||
freely, subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
|
||||||
claim that you wrote the original software. If you use this software
|
|
||||||
in a product, an acknowledgment in the product documentation would
|
|
||||||
be appreciated but is not required.
|
|
||||||
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not
|
|
||||||
be misrepresented as being the original software.
|
|
||||||
|
|
||||||
3. This notice may not be removed or altered from any source
|
|
||||||
distribution.
|
|
||||||
|
|
651
glfw/Makefile
@ -1,651 +0,0 @@
|
|||||||
# CMAKE generated file: DO NOT EDIT!
|
|
||||||
# Generated by "Unix Makefiles" Generator, CMake Version 3.18
|
|
||||||
|
|
||||||
# Default target executed when no arguments are given to make.
|
|
||||||
default_target: all
|
|
||||||
|
|
||||||
.PHONY : default_target
|
|
||||||
|
|
||||||
# Allow only one "make -f Makefile2" at a time, but pass parallelism.
|
|
||||||
.NOTPARALLEL:
|
|
||||||
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Special targets provided by cmake.
|
|
||||||
|
|
||||||
# Disable implicit rules so canonical targets will work.
|
|
||||||
.SUFFIXES:
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : %,v
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : RCS/%
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : RCS/%,v
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : SCCS/s.%
|
|
||||||
|
|
||||||
|
|
||||||
# Disable VCS-based implicit rules.
|
|
||||||
% : s.%
|
|
||||||
|
|
||||||
|
|
||||||
.SUFFIXES: .hpux_make_needs_suffix_list
|
|
||||||
|
|
||||||
|
|
||||||
# Command-line flag to silence nested $(MAKE).
|
|
||||||
$(VERBOSE)MAKESILENT = -s
|
|
||||||
|
|
||||||
#Suppress display of executed commands.
|
|
||||||
$(VERBOSE).SILENT:
|
|
||||||
|
|
||||||
# A target that is always out of date.
|
|
||||||
cmake_force:
|
|
||||||
|
|
||||||
.PHONY : cmake_force
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Set environment variables for the build.
|
|
||||||
|
|
||||||
# The shell in which to execute make rules.
|
|
||||||
SHELL = /bin/sh
|
|
||||||
|
|
||||||
# The CMake executable.
|
|
||||||
CMAKE_COMMAND = /usr/bin/cmake
|
|
||||||
|
|
||||||
# The command to remove a file.
|
|
||||||
RM = /usr/bin/cmake -E rm -f
|
|
||||||
|
|
||||||
# Escaping for special characters.
|
|
||||||
EQUALS = =
|
|
||||||
|
|
||||||
# The top-level source directory on which CMake was run.
|
|
||||||
CMAKE_SOURCE_DIR = /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
# The top-level build directory on which CMake was run.
|
|
||||||
CMAKE_BINARY_DIR = /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Targets provided globally by CMake.
|
|
||||||
|
|
||||||
# Special rule for the target install/strip
|
|
||||||
install/strip: preinstall
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..."
|
|
||||||
/usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake
|
|
||||||
.PHONY : install/strip
|
|
||||||
|
|
||||||
# Special rule for the target install/strip
|
|
||||||
install/strip/fast: preinstall/fast
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing the project stripped..."
|
|
||||||
/usr/bin/cmake -DCMAKE_INSTALL_DO_STRIP=1 -P cmake_install.cmake
|
|
||||||
.PHONY : install/strip/fast
|
|
||||||
|
|
||||||
# Special rule for the target install/local
|
|
||||||
install/local: preinstall
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..."
|
|
||||||
/usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake
|
|
||||||
.PHONY : install/local
|
|
||||||
|
|
||||||
# Special rule for the target install/local
|
|
||||||
install/local/fast: preinstall/fast
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Installing only the local directory..."
|
|
||||||
/usr/bin/cmake -DCMAKE_INSTALL_LOCAL_ONLY=1 -P cmake_install.cmake
|
|
||||||
.PHONY : install/local/fast
|
|
||||||
|
|
||||||
# Special rule for the target install
|
|
||||||
install: preinstall
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..."
|
|
||||||
/usr/bin/cmake -P cmake_install.cmake
|
|
||||||
.PHONY : install
|
|
||||||
|
|
||||||
# Special rule for the target install
|
|
||||||
install/fast: preinstall/fast
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Install the project..."
|
|
||||||
/usr/bin/cmake -P cmake_install.cmake
|
|
||||||
.PHONY : install/fast
|
|
||||||
|
|
||||||
# Special rule for the target list_install_components
|
|
||||||
list_install_components:
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Available install components are: \"Unspecified\""
|
|
||||||
.PHONY : list_install_components
|
|
||||||
|
|
||||||
# Special rule for the target list_install_components
|
|
||||||
list_install_components/fast: list_install_components
|
|
||||||
|
|
||||||
.PHONY : list_install_components/fast
|
|
||||||
|
|
||||||
# Special rule for the target rebuild_cache
|
|
||||||
rebuild_cache:
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "Running CMake to regenerate build system..."
|
|
||||||
/usr/bin/cmake --regenerate-during-build -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)
|
|
||||||
.PHONY : rebuild_cache
|
|
||||||
|
|
||||||
# Special rule for the target rebuild_cache
|
|
||||||
rebuild_cache/fast: rebuild_cache
|
|
||||||
|
|
||||||
.PHONY : rebuild_cache/fast
|
|
||||||
|
|
||||||
# Special rule for the target edit_cache
|
|
||||||
edit_cache:
|
|
||||||
@$(CMAKE_COMMAND) -E cmake_echo_color --switch=$(COLOR) --cyan "No interactive CMake dialog available..."
|
|
||||||
/usr/bin/cmake -E echo No\ interactive\ CMake\ dialog\ available.
|
|
||||||
.PHONY : edit_cache
|
|
||||||
|
|
||||||
# Special rule for the target edit_cache
|
|
||||||
edit_cache/fast: edit_cache
|
|
||||||
|
|
||||||
.PHONY : edit_cache/fast
|
|
||||||
|
|
||||||
# The main all target
|
|
||||||
all: cmake_check_build_system
|
|
||||||
$(CMAKE_COMMAND) -E cmake_progress_start /home/niklas/Downloads/glfw-3.3.5/CMakeFiles /home/niklas/Downloads/glfw-3.3.5//CMakeFiles/progress.marks
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 all
|
|
||||||
$(CMAKE_COMMAND) -E cmake_progress_start /home/niklas/Downloads/glfw-3.3.5/CMakeFiles 0
|
|
||||||
.PHONY : all
|
|
||||||
|
|
||||||
# The main clean target
|
|
||||||
clean:
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 clean
|
|
||||||
.PHONY : clean
|
|
||||||
|
|
||||||
# The main clean target
|
|
||||||
clean/fast: clean
|
|
||||||
|
|
||||||
.PHONY : clean/fast
|
|
||||||
|
|
||||||
# Prepare targets for installation.
|
|
||||||
preinstall: all
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 preinstall
|
|
||||||
.PHONY : preinstall
|
|
||||||
|
|
||||||
# Prepare targets for installation.
|
|
||||||
preinstall/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 preinstall
|
|
||||||
.PHONY : preinstall/fast
|
|
||||||
|
|
||||||
# clear depends
|
|
||||||
depend:
|
|
||||||
$(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1
|
|
||||||
.PHONY : depend
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named uninstall
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
uninstall: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 uninstall
|
|
||||||
.PHONY : uninstall
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
uninstall/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/uninstall.dir/build.make CMakeFiles/uninstall.dir/build
|
|
||||||
.PHONY : uninstall/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named glfw
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
glfw: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 glfw
|
|
||||||
.PHONY : glfw
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
glfw/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f src/CMakeFiles/glfw.dir/build.make src/CMakeFiles/glfw.dir/build
|
|
||||||
.PHONY : glfw/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named update_mappings
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
update_mappings: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 update_mappings
|
|
||||||
.PHONY : update_mappings
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
update_mappings/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f src/CMakeFiles/update_mappings.dir/build.make src/CMakeFiles/update_mappings.dir/build
|
|
||||||
.PHONY : update_mappings/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named boing
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
boing: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 boing
|
|
||||||
.PHONY : boing
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
boing/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/boing.dir/build.make examples/CMakeFiles/boing.dir/build
|
|
||||||
.PHONY : boing/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named gears
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
gears: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 gears
|
|
||||||
.PHONY : gears
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
gears/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/gears.dir/build.make examples/CMakeFiles/gears.dir/build
|
|
||||||
.PHONY : gears/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named heightmap
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
heightmap: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 heightmap
|
|
||||||
.PHONY : heightmap
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
heightmap/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/heightmap.dir/build.make examples/CMakeFiles/heightmap.dir/build
|
|
||||||
.PHONY : heightmap/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named sharing
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
sharing: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 sharing
|
|
||||||
.PHONY : sharing
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
sharing/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/sharing.dir/build.make examples/CMakeFiles/sharing.dir/build
|
|
||||||
.PHONY : sharing/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named particles
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
particles: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 particles
|
|
||||||
.PHONY : particles
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
particles/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/particles.dir/build.make examples/CMakeFiles/particles.dir/build
|
|
||||||
.PHONY : particles/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named simple
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
simple: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 simple
|
|
||||||
.PHONY : simple
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
simple/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/simple.dir/build.make examples/CMakeFiles/simple.dir/build
|
|
||||||
.PHONY : simple/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named splitview
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
splitview: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 splitview
|
|
||||||
.PHONY : splitview
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
splitview/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/splitview.dir/build.make examples/CMakeFiles/splitview.dir/build
|
|
||||||
.PHONY : splitview/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named offscreen
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
offscreen: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 offscreen
|
|
||||||
.PHONY : offscreen
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
offscreen/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/offscreen.dir/build.make examples/CMakeFiles/offscreen.dir/build
|
|
||||||
.PHONY : offscreen/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named wave
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
wave: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 wave
|
|
||||||
.PHONY : wave
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
wave/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f examples/CMakeFiles/wave.dir/build.make examples/CMakeFiles/wave.dir/build
|
|
||||||
.PHONY : wave/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named triangle-vulkan
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
triangle-vulkan: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 triangle-vulkan
|
|
||||||
.PHONY : triangle-vulkan
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
triangle-vulkan/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/triangle-vulkan.dir/build.make tests/CMakeFiles/triangle-vulkan.dir/build
|
|
||||||
.PHONY : triangle-vulkan/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named tearing
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
tearing: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 tearing
|
|
||||||
.PHONY : tearing
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
tearing/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/tearing.dir/build.make tests/CMakeFiles/tearing.dir/build
|
|
||||||
.PHONY : tearing/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named title
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
title: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 title
|
|
||||||
.PHONY : title
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
title/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/title.dir/build.make tests/CMakeFiles/title.dir/build
|
|
||||||
.PHONY : title/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named opacity
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
opacity: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 opacity
|
|
||||||
.PHONY : opacity
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
opacity/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/opacity.dir/build.make tests/CMakeFiles/opacity.dir/build
|
|
||||||
.PHONY : opacity/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named clipboard
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
clipboard: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 clipboard
|
|
||||||
.PHONY : clipboard
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
clipboard/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/clipboard.dir/build.make tests/CMakeFiles/clipboard.dir/build
|
|
||||||
.PHONY : clipboard/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named msaa
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
msaa: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 msaa
|
|
||||||
.PHONY : msaa
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
msaa/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/msaa.dir/build.make tests/CMakeFiles/msaa.dir/build
|
|
||||||
.PHONY : msaa/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named glfwinfo
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
glfwinfo: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 glfwinfo
|
|
||||||
.PHONY : glfwinfo
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
glfwinfo/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/glfwinfo.dir/build.make tests/CMakeFiles/glfwinfo.dir/build
|
|
||||||
.PHONY : glfwinfo/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named iconify
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
iconify: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 iconify
|
|
||||||
.PHONY : iconify
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
iconify/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/iconify.dir/build.make tests/CMakeFiles/iconify.dir/build
|
|
||||||
.PHONY : iconify/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named reopen
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
reopen: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 reopen
|
|
||||||
.PHONY : reopen
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
reopen/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/reopen.dir/build.make tests/CMakeFiles/reopen.dir/build
|
|
||||||
.PHONY : reopen/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named gamma
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
gamma: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 gamma
|
|
||||||
.PHONY : gamma
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
gamma/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/gamma.dir/build.make tests/CMakeFiles/gamma.dir/build
|
|
||||||
.PHONY : gamma/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named monitors
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
monitors: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 monitors
|
|
||||||
.PHONY : monitors
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
monitors/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/monitors.dir/build.make tests/CMakeFiles/monitors.dir/build
|
|
||||||
.PHONY : monitors/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named windows
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
windows: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 windows
|
|
||||||
.PHONY : windows
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
windows/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/windows.dir/build.make tests/CMakeFiles/windows.dir/build
|
|
||||||
.PHONY : windows/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named timeout
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
timeout: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 timeout
|
|
||||||
.PHONY : timeout
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
timeout/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/timeout.dir/build.make tests/CMakeFiles/timeout.dir/build
|
|
||||||
.PHONY : timeout/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named inputlag
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
inputlag: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 inputlag
|
|
||||||
.PHONY : inputlag
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
inputlag/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/inputlag.dir/build.make tests/CMakeFiles/inputlag.dir/build
|
|
||||||
.PHONY : inputlag/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named threads
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
threads: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 threads
|
|
||||||
.PHONY : threads
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
threads/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/threads.dir/build.make tests/CMakeFiles/threads.dir/build
|
|
||||||
.PHONY : threads/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named cursor
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
cursor: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 cursor
|
|
||||||
.PHONY : cursor
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
cursor/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/cursor.dir/build.make tests/CMakeFiles/cursor.dir/build
|
|
||||||
.PHONY : cursor/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named empty
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
empty: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 empty
|
|
||||||
.PHONY : empty
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
empty/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/empty.dir/build.make tests/CMakeFiles/empty.dir/build
|
|
||||||
.PHONY : empty/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named icon
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
icon: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 icon
|
|
||||||
.PHONY : icon
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
icon/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/icon.dir/build.make tests/CMakeFiles/icon.dir/build
|
|
||||||
.PHONY : icon/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named events
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
events: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 events
|
|
||||||
.PHONY : events
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
events/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/events.dir/build.make tests/CMakeFiles/events.dir/build
|
|
||||||
.PHONY : events/fast
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Target rules for targets named joysticks
|
|
||||||
|
|
||||||
# Build rule for target.
|
|
||||||
joysticks: cmake_check_build_system
|
|
||||||
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 joysticks
|
|
||||||
.PHONY : joysticks
|
|
||||||
|
|
||||||
# fast build rule for target.
|
|
||||||
joysticks/fast:
|
|
||||||
$(MAKE) $(MAKESILENT) -f tests/CMakeFiles/joysticks.dir/build.make tests/CMakeFiles/joysticks.dir/build
|
|
||||||
.PHONY : joysticks/fast
|
|
||||||
|
|
||||||
# Help Target
|
|
||||||
help:
|
|
||||||
@echo "The following are some of the valid targets for this Makefile:"
|
|
||||||
@echo "... all (the default if no target is provided)"
|
|
||||||
@echo "... clean"
|
|
||||||
@echo "... depend"
|
|
||||||
@echo "... edit_cache"
|
|
||||||
@echo "... install"
|
|
||||||
@echo "... install/local"
|
|
||||||
@echo "... install/strip"
|
|
||||||
@echo "... list_install_components"
|
|
||||||
@echo "... rebuild_cache"
|
|
||||||
@echo "... uninstall"
|
|
||||||
@echo "... update_mappings"
|
|
||||||
@echo "... boing"
|
|
||||||
@echo "... clipboard"
|
|
||||||
@echo "... cursor"
|
|
||||||
@echo "... empty"
|
|
||||||
@echo "... events"
|
|
||||||
@echo "... gamma"
|
|
||||||
@echo "... gears"
|
|
||||||
@echo "... glfw"
|
|
||||||
@echo "... glfwinfo"
|
|
||||||
@echo "... heightmap"
|
|
||||||
@echo "... icon"
|
|
||||||
@echo "... iconify"
|
|
||||||
@echo "... inputlag"
|
|
||||||
@echo "... joysticks"
|
|
||||||
@echo "... monitors"
|
|
||||||
@echo "... msaa"
|
|
||||||
@echo "... offscreen"
|
|
||||||
@echo "... opacity"
|
|
||||||
@echo "... particles"
|
|
||||||
@echo "... reopen"
|
|
||||||
@echo "... sharing"
|
|
||||||
@echo "... simple"
|
|
||||||
@echo "... splitview"
|
|
||||||
@echo "... tearing"
|
|
||||||
@echo "... threads"
|
|
||||||
@echo "... timeout"
|
|
||||||
@echo "... title"
|
|
||||||
@echo "... triangle-vulkan"
|
|
||||||
@echo "... wave"
|
|
||||||
@echo "... windows"
|
|
||||||
.PHONY : help
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Special targets to cleanup operation of make.
|
|
||||||
|
|
||||||
# Special rule to run CMake to check the build system integrity.
|
|
||||||
# No rule that depends on this can have commands that come from listfiles
|
|
||||||
# because they might be regenerated.
|
|
||||||
cmake_check_build_system:
|
|
||||||
$(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0
|
|
||||||
.PHONY : cmake_check_build_system
|
|
||||||
|
|
163
glfw/README.md
@ -1,163 +0,0 @@
|
|||||||
# GLFW
|
|
||||||
|
|
||||||
[![Build status](https://github.com/glfw/glfw/actions/workflows/build.yml/badge.svg)](https://github.com/glfw/glfw/actions)
|
|
||||||
[![Build status](https://ci.appveyor.com/api/projects/status/0kf0ct9831i5l6sp/branch/master?svg=true)](https://ci.appveyor.com/project/elmindreda/glfw)
|
|
||||||
[![Coverity Scan](https://scan.coverity.com/projects/4884/badge.svg)](https://scan.coverity.com/projects/glfw-glfw)
|
|
||||||
|
|
||||||
## Introduction
|
|
||||||
|
|
||||||
GLFW is an Open Source, multi-platform library for OpenGL, OpenGL ES and Vulkan
|
|
||||||
application development. It provides a simple, platform-independent API for
|
|
||||||
creating windows, contexts and surfaces, reading input, handling events, etc.
|
|
||||||
|
|
||||||
GLFW natively supports Windows, macOS and Linux and other Unix-like systems. On
|
|
||||||
Linux both X11 and Wayland are supported.
|
|
||||||
|
|
||||||
GLFW is licensed under the [zlib/libpng
|
|
||||||
license](https://www.glfw.org/license.html).
|
|
||||||
|
|
||||||
You can [download](https://www.glfw.org/download.html) the latest stable release
|
|
||||||
as source or Windows binaries, or fetch the `latest` branch from GitHub. Each
|
|
||||||
release starting with 3.0 also has a corresponding [annotated
|
|
||||||
tag](https://github.com/glfw/glfw/releases) with source and binary archives.
|
|
||||||
|
|
||||||
The [documentation](https://www.glfw.org/docs/latest/) is available online and is
|
|
||||||
included in all source and binary archives. See the [release
|
|
||||||
notes](https://www.glfw.org/docs/latest/news.html) for new features, caveats and
|
|
||||||
deprecations in the latest release. For more details see the [version
|
|
||||||
history](https://www.glfw.org/changelog.html).
|
|
||||||
|
|
||||||
The `master` branch is the stable integration branch and _should_ always compile
|
|
||||||
and run on all supported platforms, although details of newly added features may
|
|
||||||
change until they have been included in a release. New features and many bug
|
|
||||||
fixes live in [other branches](https://github.com/glfw/glfw/branches/all) until
|
|
||||||
they are stable enough to merge.
|
|
||||||
|
|
||||||
If you are new to GLFW, you may find the
|
|
||||||
[tutorial](https://www.glfw.org/docs/latest/quick.html) for GLFW 3 useful. If
|
|
||||||
you have used GLFW 2 in the past, there is a [transition
|
|
||||||
guide](https://www.glfw.org/docs/latest/moving.html) for moving to the GLFW
|
|
||||||
3 API.
|
|
||||||
|
|
||||||
GLFW exists because of the contributions of [many people](CONTRIBUTORS.md)
|
|
||||||
around the world, whether by reporting bugs, providing community support, adding
|
|
||||||
features, reviewing or testing code, debugging, proofreading docs, suggesting
|
|
||||||
features or fixing bugs.
|
|
||||||
|
|
||||||
|
|
||||||
## Compiling GLFW
|
|
||||||
|
|
||||||
GLFW itself requires only the headers and libraries for your OS and window
|
|
||||||
system. It does not need the headers for any context creation API (WGL, GLX,
|
|
||||||
EGL, NSGL, OSMesa) or rendering API (OpenGL, OpenGL ES, Vulkan) to enable
|
|
||||||
support for them.
|
|
||||||
|
|
||||||
GLFW supports compilation on Windows with Visual C++ 2010 and later, MinGW and
|
|
||||||
MinGW-w64, on macOS with Clang and on Linux and other Unix-like systems with GCC
|
|
||||||
and Clang. It will likely compile in other environments as well, but this is
|
|
||||||
not regularly tested.
|
|
||||||
|
|
||||||
There are [pre-compiled Windows binaries](https://www.glfw.org/download.html)
|
|
||||||
available for all supported compilers.
|
|
||||||
|
|
||||||
See the [compilation guide](https://www.glfw.org/docs/latest/compile.html) for
|
|
||||||
more information about how to compile GLFW yourself.
|
|
||||||
|
|
||||||
|
|
||||||
## Using GLFW
|
|
||||||
|
|
||||||
See the [documentation](https://www.glfw.org/docs/latest/) for tutorials, guides
|
|
||||||
and the API reference.
|
|
||||||
|
|
||||||
|
|
||||||
## Contributing to GLFW
|
|
||||||
|
|
||||||
See the [contribution
|
|
||||||
guide](https://github.com/glfw/glfw/blob/master/docs/CONTRIBUTING.md) for
|
|
||||||
more information.
|
|
||||||
|
|
||||||
|
|
||||||
## System requirements
|
|
||||||
|
|
||||||
GLFW supports Windows XP and later and macOS 10.8 and later. Linux and other
|
|
||||||
Unix-like systems running the X Window System are supported even without
|
|
||||||
a desktop environment or modern extensions, although some features require
|
|
||||||
a running window or clipboard manager. The OSMesa backend requires Mesa 6.3.
|
|
||||||
|
|
||||||
See the [compatibility guide](https://www.glfw.org/docs/latest/compat.html)
|
|
||||||
in the documentation for more information.
|
|
||||||
|
|
||||||
|
|
||||||
## Dependencies
|
|
||||||
|
|
||||||
GLFW itself depends only on the headers and libraries for your window system.
|
|
||||||
|
|
||||||
The (experimental) Wayland backend also depends on the `extra-cmake-modules`
|
|
||||||
package, which is used to generate Wayland protocol headers.
|
|
||||||
|
|
||||||
The examples and test programs depend on a number of tiny libraries. These are
|
|
||||||
located in the `deps/` directory.
|
|
||||||
|
|
||||||
- [getopt\_port](https://github.com/kimgr/getopt_port/) for examples
|
|
||||||
with command-line options
|
|
||||||
- [TinyCThread](https://github.com/tinycthread/tinycthread) for threaded
|
|
||||||
examples
|
|
||||||
- [glad2](https://github.com/Dav1dde/glad) for loading OpenGL and Vulkan
|
|
||||||
functions
|
|
||||||
- [linmath.h](https://github.com/datenwolf/linmath.h) for linear algebra in
|
|
||||||
examples
|
|
||||||
- [Nuklear](https://github.com/Immediate-Mode-UI/Nuklear) for test and example UI
|
|
||||||
- [stb\_image\_write](https://github.com/nothings/stb) for writing images to disk
|
|
||||||
|
|
||||||
The documentation is generated with [Doxygen](https://doxygen.org/) if CMake can
|
|
||||||
find that tool.
|
|
||||||
|
|
||||||
|
|
||||||
## Reporting bugs
|
|
||||||
|
|
||||||
Bugs are reported to our [issue tracker](https://github.com/glfw/glfw/issues).
|
|
||||||
Please check the [contribution
|
|
||||||
guide](https://github.com/glfw/glfw/blob/master/docs/CONTRIBUTING.md) for
|
|
||||||
information on what to include when reporting a bug.
|
|
||||||
|
|
||||||
|
|
||||||
## Changelog
|
|
||||||
|
|
||||||
- Updated gamepad mappings from upstream
|
|
||||||
- Bugfix: Buffers were swapped at creation on single-buffered windows (#1873)
|
|
||||||
- Bugfix: Gamepad mapping updates could spam `GLFW_INVALID_VALUE` due to
|
|
||||||
incompatible controllers sharing hardware ID (#1763)
|
|
||||||
- Bugfix: Native access functions for context handles did not check that the API matched
|
|
||||||
- [Win32] Bugfix: `USE_MSVC_RUNTIME_LIBRARY_DLL` had no effect on CMake 3.15 or
|
|
||||||
later (#1783,#1796)
|
|
||||||
- [Win32] Bugfix: Compilation with LLVM for Windows failed (#1807,#1824,#1874)
|
|
||||||
- [Cocoa] Bugfix: The MoltenVK layer contents scale was updated only after
|
|
||||||
related events were emitted
|
|
||||||
- [Cocoa] Bugfix: Moving the cursor programmatically would freeze it for
|
|
||||||
a fraction of a second (#1962)
|
|
||||||
- [Cocoa] Bugfix: `kIOMasterPortDefault` was deprecated in macOS 12.0 (#1980)
|
|
||||||
- [X11] Bugfix: Changing `GLFW_FLOATING` could leak memory
|
|
||||||
- [Wayland] Bugfix: Some keys were not repeating in Wayland (#1908)
|
|
||||||
- [Wayland] Bugfix: Non-arrow cursors are offset from the hotspot (#1706,#1899)
|
|
||||||
- [Wayland] Bugfix: The `O_CLOEXEC` flag was not defined on FreeBSD
|
|
||||||
- [NSGL] Bugfix: Defining `GL_SILENCE_DEPRECATION` externally caused
|
|
||||||
a duplicate definition warning (#1840)
|
|
||||||
- [EGL] Bugfix: The `GLFW_DOUBLEBUFFER` context attribute was ignored (#1843)
|
|
||||||
|
|
||||||
|
|
||||||
## Contact
|
|
||||||
|
|
||||||
On [glfw.org](https://www.glfw.org/) you can find the latest version of GLFW, as
|
|
||||||
well as news, documentation and other information about the project.
|
|
||||||
|
|
||||||
If you have questions related to the use of GLFW, we have a
|
|
||||||
[forum](https://discourse.glfw.org/), and the `#glfw` IRC channel on
|
|
||||||
[Libera.Chat](https://libera.chat/).
|
|
||||||
|
|
||||||
If you have a bug to report, a patch to submit or a feature you'd like to
|
|
||||||
request, please file it in the
|
|
||||||
[issue tracker](https://github.com/glfw/glfw/issues) on GitHub.
|
|
||||||
|
|
||||||
Finally, if you're interested in helping out with the development of GLFW or
|
|
||||||
porting it to your favorite platform, join us on the forum, GitHub or IRC.
|
|
||||||
|
|
@ -1,103 +0,0 @@
|
|||||||
# Install script for directory: /home/niklas/Downloads/glfw-3.3.5
|
|
||||||
|
|
||||||
# Set the install prefix
|
|
||||||
if(NOT DEFINED CMAKE_INSTALL_PREFIX)
|
|
||||||
set(CMAKE_INSTALL_PREFIX "/usr/local")
|
|
||||||
endif()
|
|
||||||
string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
|
|
||||||
|
|
||||||
# Set the install configuration name.
|
|
||||||
if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME)
|
|
||||||
if(BUILD_TYPE)
|
|
||||||
string(REGEX REPLACE "^[^A-Za-z0-9_]+" ""
|
|
||||||
CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}")
|
|
||||||
else()
|
|
||||||
set(CMAKE_INSTALL_CONFIG_NAME "")
|
|
||||||
endif()
|
|
||||||
message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Set the component getting installed.
|
|
||||||
if(NOT CMAKE_INSTALL_COMPONENT)
|
|
||||||
if(COMPONENT)
|
|
||||||
message(STATUS "Install component: \"${COMPONENT}\"")
|
|
||||||
set(CMAKE_INSTALL_COMPONENT "${COMPONENT}")
|
|
||||||
else()
|
|
||||||
set(CMAKE_INSTALL_COMPONENT)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Install shared libraries without execute permission?
|
|
||||||
if(NOT DEFINED CMAKE_INSTALL_SO_NO_EXE)
|
|
||||||
set(CMAKE_INSTALL_SO_NO_EXE "1")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Is this installation the result of a crosscompile?
|
|
||||||
if(NOT DEFINED CMAKE_CROSSCOMPILING)
|
|
||||||
set(CMAKE_CROSSCOMPILING "FALSE")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Set default install directory permissions.
|
|
||||||
if(NOT DEFINED CMAKE_OBJDUMP)
|
|
||||||
set(CMAKE_OBJDUMP "/usr/bin/objdump")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT CMAKE_INSTALL_LOCAL_ONLY)
|
|
||||||
# Include the install script for the subdirectory.
|
|
||||||
include("/home/niklas/Downloads/glfw-3.3.5/src/cmake_install.cmake")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT CMAKE_INSTALL_LOCAL_ONLY)
|
|
||||||
# Include the install script for the subdirectory.
|
|
||||||
include("/home/niklas/Downloads/glfw-3.3.5/examples/cmake_install.cmake")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT CMAKE_INSTALL_LOCAL_ONLY)
|
|
||||||
# Include the install script for the subdirectory.
|
|
||||||
include("/home/niklas/Downloads/glfw-3.3.5/tests/cmake_install.cmake")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT)
|
|
||||||
file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/include" TYPE DIRECTORY FILES "/home/niklas/Downloads/glfw-3.3.5/include/GLFW" FILES_MATCHING REGEX "/glfw3\\.h$" REGEX "/glfw3native\\.h$")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT)
|
|
||||||
file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3" TYPE FILE FILES
|
|
||||||
"/home/niklas/Downloads/glfw-3.3.5/src/glfw3Config.cmake"
|
|
||||||
"/home/niklas/Downloads/glfw-3.3.5/src/glfw3ConfigVersion.cmake"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT)
|
|
||||||
if(EXISTS "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3/glfw3Targets.cmake")
|
|
||||||
file(DIFFERENT EXPORT_FILE_CHANGED FILES
|
|
||||||
"$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3/glfw3Targets.cmake"
|
|
||||||
"/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/Export/lib/cmake/glfw3/glfw3Targets.cmake")
|
|
||||||
if(EXPORT_FILE_CHANGED)
|
|
||||||
file(GLOB OLD_CONFIG_FILES "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3/glfw3Targets-*.cmake")
|
|
||||||
if(OLD_CONFIG_FILES)
|
|
||||||
message(STATUS "Old export file \"$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3/glfw3Targets.cmake\" will be replaced. Removing files [${OLD_CONFIG_FILES}].")
|
|
||||||
file(REMOVE ${OLD_CONFIG_FILES})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3" TYPE FILE FILES "/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/Export/lib/cmake/glfw3/glfw3Targets.cmake")
|
|
||||||
if("${CMAKE_INSTALL_CONFIG_NAME}" MATCHES "^()$")
|
|
||||||
file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3" TYPE FILE FILES "/home/niklas/Downloads/glfw-3.3.5/CMakeFiles/Export/lib/cmake/glfw3/glfw3Targets-noconfig.cmake")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("x${CMAKE_INSTALL_COMPONENT}x" STREQUAL "xUnspecifiedx" OR NOT CMAKE_INSTALL_COMPONENT)
|
|
||||||
file(INSTALL DESTINATION "${CMAKE_INSTALL_PREFIX}/lib/pkgconfig" TYPE FILE FILES "/home/niklas/Downloads/glfw-3.3.5/src/glfw3.pc")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_INSTALL_COMPONENT)
|
|
||||||
set(CMAKE_INSTALL_MANIFEST "install_manifest_${CMAKE_INSTALL_COMPONENT}.txt")
|
|
||||||
else()
|
|
||||||
set(CMAKE_INSTALL_MANIFEST "install_manifest.txt")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
string(REPLACE ";" "\n" CMAKE_INSTALL_MANIFEST_CONTENT
|
|
||||||
"${CMAKE_INSTALL_MANIFEST_FILES}")
|
|
||||||
file(WRITE "/home/niklas/Downloads/glfw-3.3.5/${CMAKE_INSTALL_MANIFEST}"
|
|
||||||
"${CMAKE_INSTALL_MANIFEST_CONTENT}")
|
|
@ -1,29 +0,0 @@
|
|||||||
|
|
||||||
if (NOT EXISTS "/home/niklas/Downloads/glfw-3.3.5/install_manifest.txt")
|
|
||||||
message(FATAL_ERROR "Cannot find install manifest: \"/home/niklas/Downloads/glfw-3.3.5/install_manifest.txt\"")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
file(READ "/home/niklas/Downloads/glfw-3.3.5/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("/usr/bin/cmake" 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()
|
|
||||||
elseif (IS_SYMLINK "$ENV{DESTDIR}${file}")
|
|
||||||
EXEC_PROGRAM("/usr/bin/cmake" 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 symlink \"$ENV{DESTDIR}${file}\"")
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
message(STATUS "File \"$ENV{DESTDIR}${file}\" does not exist.")
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
|
|
@ -1,29 +0,0 @@
|
|||||||
|
|
||||||
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()
|
|
||||||
|
|
||||||
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()
|
|
||||||
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 symlink \"$ENV{DESTDIR}${file}\"")
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
message(STATUS "File \"$ENV{DESTDIR}${file}\" does not exist.")
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
|
|
@ -1,230 +0,0 @@
|
|||||||
/* Copyright (c) 2012, Kim Gräsman
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer in the documentation
|
|
||||||
* and/or other materials provided with the distribution.
|
|
||||||
* * Neither the name of Kim Gräsman nor the names of contributors may be used
|
|
||||||
* to endorse or promote products derived from this software without specific
|
|
||||||
* prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL KIM GRÄSMAN BE LIABLE FOR ANY DIRECT,
|
|
||||||
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
||||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
||||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
||||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "getopt.h"
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
const int no_argument = 0;
|
|
||||||
const int required_argument = 1;
|
|
||||||
const int optional_argument = 2;
|
|
||||||
|
|
||||||
char* optarg;
|
|
||||||
int optopt;
|
|
||||||
/* The variable optind [...] shall be initialized to 1 by the system. */
|
|
||||||
int optind = 1;
|
|
||||||
int opterr;
|
|
||||||
|
|
||||||
static char* optcursor = NULL;
|
|
||||||
|
|
||||||
/* Implemented based on [1] and [2] for optional arguments.
|
|
||||||
optopt is handled FreeBSD-style, per [3].
|
|
||||||
Other GNU and FreeBSD extensions are purely accidental.
|
|
||||||
|
|
||||||
[1] http://pubs.opengroup.org/onlinepubs/000095399/functions/getopt.html
|
|
||||||
[2] http://www.kernel.org/doc/man-pages/online/pages/man3/getopt.3.html
|
|
||||||
[3] http://www.freebsd.org/cgi/man.cgi?query=getopt&sektion=3&manpath=FreeBSD+9.0-RELEASE
|
|
||||||
*/
|
|
||||||
int getopt(int argc, char* const argv[], const char* optstring) {
|
|
||||||
int optchar = -1;
|
|
||||||
const char* optdecl = NULL;
|
|
||||||
|
|
||||||
optarg = NULL;
|
|
||||||
opterr = 0;
|
|
||||||
optopt = 0;
|
|
||||||
|
|
||||||
/* Unspecified, but we need it to avoid overrunning the argv bounds. */
|
|
||||||
if (optind >= argc)
|
|
||||||
goto no_more_optchars;
|
|
||||||
|
|
||||||
/* If, when getopt() is called argv[optind] is a null pointer, getopt()
|
|
||||||
shall return -1 without changing optind. */
|
|
||||||
if (argv[optind] == NULL)
|
|
||||||
goto no_more_optchars;
|
|
||||||
|
|
||||||
/* If, when getopt() is called *argv[optind] is not the character '-',
|
|
||||||
getopt() shall return -1 without changing optind. */
|
|
||||||
if (*argv[optind] != '-')
|
|
||||||
goto no_more_optchars;
|
|
||||||
|
|
||||||
/* If, when getopt() is called argv[optind] points to the string "-",
|
|
||||||
getopt() shall return -1 without changing optind. */
|
|
||||||
if (strcmp(argv[optind], "-") == 0)
|
|
||||||
goto no_more_optchars;
|
|
||||||
|
|
||||||
/* If, when getopt() is called argv[optind] points to the string "--",
|
|
||||||
getopt() shall return -1 after incrementing optind. */
|
|
||||||
if (strcmp(argv[optind], "--") == 0) {
|
|
||||||
++optind;
|
|
||||||
goto no_more_optchars;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (optcursor == NULL || *optcursor == '\0')
|
|
||||||
optcursor = argv[optind] + 1;
|
|
||||||
|
|
||||||
optchar = *optcursor;
|
|
||||||
|
|
||||||
/* FreeBSD: The variable optopt saves the last known option character
|
|
||||||
returned by getopt(). */
|
|
||||||
optopt = optchar;
|
|
||||||
|
|
||||||
/* The getopt() function shall return the next option character (if one is
|
|
||||||
found) from argv that matches a character in optstring, if there is
|
|
||||||
one that matches. */
|
|
||||||
optdecl = strchr(optstring, optchar);
|
|
||||||
if (optdecl) {
|
|
||||||
/* [I]f a character is followed by a colon, the option takes an
|
|
||||||
argument. */
|
|
||||||
if (optdecl[1] == ':') {
|
|
||||||
optarg = ++optcursor;
|
|
||||||
if (*optarg == '\0') {
|
|
||||||
/* GNU extension: Two colons mean an option takes an
|
|
||||||
optional arg; if there is text in the current argv-element
|
|
||||||
(i.e., in the same word as the option name itself, for example,
|
|
||||||
"-oarg"), then it is returned in optarg, otherwise optarg is set
|
|
||||||
to zero. */
|
|
||||||
if (optdecl[2] != ':') {
|
|
||||||
/* If the option was the last character in the string pointed to by
|
|
||||||
an element of argv, then optarg shall contain the next element
|
|
||||||
of argv, and optind shall be incremented by 2. If the resulting
|
|
||||||
value of optind is greater than argc, this indicates a missing
|
|
||||||
option-argument, and getopt() shall return an error indication.
|
|
||||||
|
|
||||||
Otherwise, optarg shall point to the string following the
|
|
||||||
option character in that element of argv, and optind shall be
|
|
||||||
incremented by 1.
|
|
||||||
*/
|
|
||||||
if (++optind < argc) {
|
|
||||||
optarg = argv[optind];
|
|
||||||
} else {
|
|
||||||
/* If it detects a missing option-argument, it shall return the
|
|
||||||
colon character ( ':' ) if the first character of optstring
|
|
||||||
was a colon, or a question-mark character ( '?' ) otherwise.
|
|
||||||
*/
|
|
||||||
optarg = NULL;
|
|
||||||
optchar = (optstring[0] == ':') ? ':' : '?';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
optarg = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
optcursor = NULL;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/* If getopt() encounters an option character that is not contained in
|
|
||||||
optstring, it shall return the question-mark ( '?' ) character. */
|
|
||||||
optchar = '?';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (optcursor == NULL || *++optcursor == '\0')
|
|
||||||
++optind;
|
|
||||||
|
|
||||||
return optchar;
|
|
||||||
|
|
||||||
no_more_optchars:
|
|
||||||
optcursor = NULL;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Implementation based on [1].
|
|
||||||
|
|
||||||
[1] http://www.kernel.org/doc/man-pages/online/pages/man3/getopt.3.html
|
|
||||||
*/
|
|
||||||
int getopt_long(int argc, char* const argv[], const char* optstring,
|
|
||||||
const struct option* longopts, int* longindex) {
|
|
||||||
const struct option* o = longopts;
|
|
||||||
const struct option* match = NULL;
|
|
||||||
int num_matches = 0;
|
|
||||||
size_t argument_name_length = 0;
|
|
||||||
const char* current_argument = NULL;
|
|
||||||
int retval = -1;
|
|
||||||
|
|
||||||
optarg = NULL;
|
|
||||||
optopt = 0;
|
|
||||||
|
|
||||||
if (optind >= argc)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (strlen(argv[optind]) < 3 || strncmp(argv[optind], "--", 2) != 0)
|
|
||||||
return getopt(argc, argv, optstring);
|
|
||||||
|
|
||||||
/* It's an option; starts with -- and is longer than two chars. */
|
|
||||||
current_argument = argv[optind] + 2;
|
|
||||||
argument_name_length = strcspn(current_argument, "=");
|
|
||||||
for (; o->name; ++o) {
|
|
||||||
if (strncmp(o->name, current_argument, argument_name_length) == 0) {
|
|
||||||
match = o;
|
|
||||||
++num_matches;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (num_matches == 1) {
|
|
||||||
/* If longindex is not NULL, it points to a variable which is set to the
|
|
||||||
index of the long option relative to longopts. */
|
|
||||||
if (longindex)
|
|
||||||
*longindex = (int) (match - longopts);
|
|
||||||
|
|
||||||
/* If flag is NULL, then getopt_long() shall return val.
|
|
||||||
Otherwise, getopt_long() returns 0, and flag shall point to a variable
|
|
||||||
which shall be set to val if the option is found, but left unchanged if
|
|
||||||
the option is not found. */
|
|
||||||
if (match->flag)
|
|
||||||
*(match->flag) = match->val;
|
|
||||||
|
|
||||||
retval = match->flag ? 0 : match->val;
|
|
||||||
|
|
||||||
if (match->has_arg != no_argument) {
|
|
||||||
optarg = strchr(argv[optind], '=');
|
|
||||||
if (optarg != NULL)
|
|
||||||
++optarg;
|
|
||||||
|
|
||||||
if (match->has_arg == required_argument) {
|
|
||||||
/* Only scan the next argv for required arguments. Behavior is not
|
|
||||||
specified, but has been observed with Ubuntu and Mac OSX. */
|
|
||||||
if (optarg == NULL && ++optind < argc) {
|
|
||||||
optarg = argv[optind];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (optarg == NULL)
|
|
||||||
retval = ':';
|
|
||||||
}
|
|
||||||
} else if (strchr(argv[optind], '=')) {
|
|
||||||
/* An argument was provided to a non-argument option.
|
|
||||||
I haven't seen this specified explicitly, but both GNU and BSD-based
|
|
||||||
implementations show this behavior.
|
|
||||||
*/
|
|
||||||
retval = '?';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/* Unknown option or ambiguous match. */
|
|
||||||
retval = '?';
|
|
||||||
}
|
|
||||||
|
|
||||||
++optind;
|
|
||||||
return retval;
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
/* Copyright (c) 2012, Kim Gräsman
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are met:
|
|
||||||
* * Redistributions of source code must retain the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer.
|
|
||||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
|
||||||
* this list of conditions and the following disclaimer in the documentation
|
|
||||||
* and/or other materials provided with the distribution.
|
|
||||||
* * Neither the name of Kim Gräsman nor the names of contributors may be used
|
|
||||||
* to endorse or promote products derived from this software without specific
|
|
||||||
* prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
* ARE DISCLAIMED. IN NO EVENT SHALL KIM GRÄSMAN BE LIABLE FOR ANY DIRECT,
|
|
||||||
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
||||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
||||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
||||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef INCLUDED_GETOPT_PORT_H
|
|
||||||
#define INCLUDED_GETOPT_PORT_H
|
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern const int no_argument;
|
|
||||||
extern const int required_argument;
|
|
||||||
extern const int optional_argument;
|
|
||||||
|
|
||||||
extern char* optarg;
|
|
||||||
extern int optind, opterr, optopt;
|
|
||||||
|
|
||||||
struct option {
|
|
||||||
const char* name;
|
|
||||||
int has_arg;
|
|
||||||
int* flag;
|
|
||||||
int val;
|
|
||||||
};
|
|
||||||
|
|
||||||
int getopt(int argc, char* const argv[], const char* optstring);
|
|
||||||
|
|
||||||
int getopt_long(int argc, char* const argv[],
|
|
||||||
const char* optstring, const struct option* longopts, int* longindex);
|
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // INCLUDED_GETOPT_PORT_H
|
|
3840
glfw/deps/glad/gl.h
@ -1,282 +0,0 @@
|
|||||||
#ifndef __khrplatform_h_
|
|
||||||
#define __khrplatform_h_
|
|
||||||
|
|
||||||
/*
|
|
||||||
** Copyright (c) 2008-2018 The Khronos Group Inc.
|
|
||||||
**
|
|
||||||
** Permission is hereby granted, free of charge, to any person obtaining a
|
|
||||||
** copy of this software and/or associated documentation files (the
|
|
||||||
** "Materials"), to deal in the Materials without restriction, including
|
|
||||||
** without limitation the rights to use, copy, modify, merge, publish,
|
|
||||||
** distribute, sublicense, and/or sell copies of the Materials, and to
|
|
||||||
** permit persons to whom the Materials are furnished to do so, subject to
|
|
||||||
** the following conditions:
|
|
||||||
**
|
|
||||||
** The above copyright notice and this permission notice shall be included
|
|
||||||
** in all copies or substantial portions of the Materials.
|
|
||||||
**
|
|
||||||
** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
||||||
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
||||||
** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Khronos platform-specific types and definitions.
|
|
||||||
*
|
|
||||||
* The master copy of khrplatform.h is maintained in the Khronos EGL
|
|
||||||
* Registry repository at https://github.com/KhronosGroup/EGL-Registry
|
|
||||||
* The last semantic modification to khrplatform.h was at commit ID:
|
|
||||||
* 67a3e0864c2d75ea5287b9f3d2eb74a745936692
|
|
||||||
*
|
|
||||||
* Adopters may modify this file to suit their platform. Adopters are
|
|
||||||
* encouraged to submit platform specific modifications to the Khronos
|
|
||||||
* group so that they can be included in future versions of this file.
|
|
||||||
* Please submit changes by filing pull requests or issues on
|
|
||||||
* the EGL Registry repository linked above.
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* See the Implementer's Guidelines for information about where this file
|
|
||||||
* should be located on your system and for more details of its use:
|
|
||||||
* http://www.khronos.org/registry/implementers_guide.pdf
|
|
||||||
*
|
|
||||||
* This file should be included as
|
|
||||||
* #include <KHR/khrplatform.h>
|
|
||||||
* by Khronos client API header files that use its types and defines.
|
|
||||||
*
|
|
||||||
* The types in khrplatform.h should only be used to define API-specific types.
|
|
||||||
*
|
|
||||||
* Types defined in khrplatform.h:
|
|
||||||
* khronos_int8_t signed 8 bit
|
|
||||||
* khronos_uint8_t unsigned 8 bit
|
|
||||||
* khronos_int16_t signed 16 bit
|
|
||||||
* khronos_uint16_t unsigned 16 bit
|
|
||||||
* khronos_int32_t signed 32 bit
|
|
||||||
* khronos_uint32_t unsigned 32 bit
|
|
||||||
* khronos_int64_t signed 64 bit
|
|
||||||
* khronos_uint64_t unsigned 64 bit
|
|
||||||
* khronos_intptr_t signed same number of bits as a pointer
|
|
||||||
* khronos_uintptr_t unsigned same number of bits as a pointer
|
|
||||||
* khronos_ssize_t signed size
|
|
||||||
* khronos_usize_t unsigned size
|
|
||||||
* khronos_float_t signed 32 bit floating point
|
|
||||||
* khronos_time_ns_t unsigned 64 bit time in nanoseconds
|
|
||||||
* khronos_utime_nanoseconds_t unsigned time interval or absolute time in
|
|
||||||
* nanoseconds
|
|
||||||
* khronos_stime_nanoseconds_t signed time interval in nanoseconds
|
|
||||||
* khronos_boolean_enum_t enumerated boolean type. This should
|
|
||||||
* only be used as a base type when a client API's boolean type is
|
|
||||||
* an enum. Client APIs which use an integer or other type for
|
|
||||||
* booleans cannot use this as the base type for their boolean.
|
|
||||||
*
|
|
||||||
* Tokens defined in khrplatform.h:
|
|
||||||
*
|
|
||||||
* KHRONOS_FALSE, KHRONOS_TRUE Enumerated boolean false/true values.
|
|
||||||
*
|
|
||||||
* KHRONOS_SUPPORT_INT64 is 1 if 64 bit integers are supported; otherwise 0.
|
|
||||||
* KHRONOS_SUPPORT_FLOAT is 1 if floats are supported; otherwise 0.
|
|
||||||
*
|
|
||||||
* Calling convention macros defined in this file:
|
|
||||||
* KHRONOS_APICALL
|
|
||||||
* KHRONOS_APIENTRY
|
|
||||||
* KHRONOS_APIATTRIBUTES
|
|
||||||
*
|
|
||||||
* These may be used in function prototypes as:
|
|
||||||
*
|
|
||||||
* KHRONOS_APICALL void KHRONOS_APIENTRY funcname(
|
|
||||||
* int arg1,
|
|
||||||
* int arg2) KHRONOS_APIATTRIBUTES;
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*-------------------------------------------------------------------------
|
|
||||||
* Definition of KHRONOS_APICALL
|
|
||||||
*-------------------------------------------------------------------------
|
|
||||||
* This precedes the return type of the function in the function prototype.
|
|
||||||
*/
|
|
||||||
#if defined(_WIN32) && !defined(__SCITECH_SNAP__)
|
|
||||||
# define KHRONOS_APICALL __declspec(dllimport)
|
|
||||||
#elif defined (__SYMBIAN32__)
|
|
||||||
# define KHRONOS_APICALL IMPORT_C
|
|
||||||
#elif defined(__ANDROID__)
|
|
||||||
# define KHRONOS_APICALL __attribute__((visibility("default")))
|
|
||||||
#else
|
|
||||||
# define KHRONOS_APICALL
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*-------------------------------------------------------------------------
|
|
||||||
* Definition of KHRONOS_APIENTRY
|
|
||||||
*-------------------------------------------------------------------------
|
|
||||||
* This follows the return type of the function and precedes the function
|
|
||||||
* name in the function prototype.
|
|
||||||
*/
|
|
||||||
#if defined(_WIN32) && !defined(_WIN32_WCE) && !defined(__SCITECH_SNAP__)
|
|
||||||
/* Win32 but not WinCE */
|
|
||||||
# define KHRONOS_APIENTRY __stdcall
|
|
||||||
#else
|
|
||||||
# define KHRONOS_APIENTRY
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*-------------------------------------------------------------------------
|
|
||||||
* Definition of KHRONOS_APIATTRIBUTES
|
|
||||||
*-------------------------------------------------------------------------
|
|
||||||
* This follows the closing parenthesis of the function prototype arguments.
|
|
||||||
*/
|
|
||||||
#if defined (__ARMCC_2__)
|
|
||||||
#define KHRONOS_APIATTRIBUTES __softfp
|
|
||||||
#else
|
|
||||||
#define KHRONOS_APIATTRIBUTES
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*-------------------------------------------------------------------------
|
|
||||||
* basic type definitions
|
|
||||||
*-----------------------------------------------------------------------*/
|
|
||||||
#if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || defined(__GNUC__) || defined(__SCO__) || defined(__USLC__)
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Using <stdint.h>
|
|
||||||
*/
|
|
||||||
#include <stdint.h>
|
|
||||||
typedef int32_t khronos_int32_t;
|
|
||||||
typedef uint32_t khronos_uint32_t;
|
|
||||||
typedef int64_t khronos_int64_t;
|
|
||||||
typedef uint64_t khronos_uint64_t;
|
|
||||||
#define KHRONOS_SUPPORT_INT64 1
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 1
|
|
||||||
|
|
||||||
#elif defined(__VMS ) || defined(__sgi)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Using <inttypes.h>
|
|
||||||
*/
|
|
||||||
#include <inttypes.h>
|
|
||||||
typedef int32_t khronos_int32_t;
|
|
||||||
typedef uint32_t khronos_uint32_t;
|
|
||||||
typedef int64_t khronos_int64_t;
|
|
||||||
typedef uint64_t khronos_uint64_t;
|
|
||||||
#define KHRONOS_SUPPORT_INT64 1
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 1
|
|
||||||
|
|
||||||
#elif defined(_WIN32) && !defined(__SCITECH_SNAP__)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Win32
|
|
||||||
*/
|
|
||||||
typedef __int32 khronos_int32_t;
|
|
||||||
typedef unsigned __int32 khronos_uint32_t;
|
|
||||||
typedef __int64 khronos_int64_t;
|
|
||||||
typedef unsigned __int64 khronos_uint64_t;
|
|
||||||
#define KHRONOS_SUPPORT_INT64 1
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 1
|
|
||||||
|
|
||||||
#elif defined(__sun__) || defined(__digital__)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Sun or Digital
|
|
||||||
*/
|
|
||||||
typedef int khronos_int32_t;
|
|
||||||
typedef unsigned int khronos_uint32_t;
|
|
||||||
#if defined(__arch64__) || defined(_LP64)
|
|
||||||
typedef long int khronos_int64_t;
|
|
||||||
typedef unsigned long int khronos_uint64_t;
|
|
||||||
#else
|
|
||||||
typedef long long int khronos_int64_t;
|
|
||||||
typedef unsigned long long int khronos_uint64_t;
|
|
||||||
#endif /* __arch64__ */
|
|
||||||
#define KHRONOS_SUPPORT_INT64 1
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 1
|
|
||||||
|
|
||||||
#elif 0
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Hypothetical platform with no float or int64 support
|
|
||||||
*/
|
|
||||||
typedef int khronos_int32_t;
|
|
||||||
typedef unsigned int khronos_uint32_t;
|
|
||||||
#define KHRONOS_SUPPORT_INT64 0
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 0
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Generic fallback
|
|
||||||
*/
|
|
||||||
#include <stdint.h>
|
|
||||||
typedef int32_t khronos_int32_t;
|
|
||||||
typedef uint32_t khronos_uint32_t;
|
|
||||||
typedef int64_t khronos_int64_t;
|
|
||||||
typedef uint64_t khronos_uint64_t;
|
|
||||||
#define KHRONOS_SUPPORT_INT64 1
|
|
||||||
#define KHRONOS_SUPPORT_FLOAT 1
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Types that are (so far) the same on all platforms
|
|
||||||
*/
|
|
||||||
typedef signed char khronos_int8_t;
|
|
||||||
typedef unsigned char khronos_uint8_t;
|
|
||||||
typedef signed short int khronos_int16_t;
|
|
||||||
typedef unsigned short int khronos_uint16_t;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Types that differ between LLP64 and LP64 architectures - in LLP64,
|
|
||||||
* pointers are 64 bits, but 'long' is still 32 bits. Win64 appears
|
|
||||||
* to be the only LLP64 architecture in current use.
|
|
||||||
*/
|
|
||||||
#ifdef _WIN64
|
|
||||||
typedef signed long long int khronos_intptr_t;
|
|
||||||
typedef unsigned long long int khronos_uintptr_t;
|
|
||||||
typedef signed long long int khronos_ssize_t;
|
|
||||||
typedef unsigned long long int khronos_usize_t;
|
|
||||||
#else
|
|
||||||
typedef signed long int khronos_intptr_t;
|
|
||||||
typedef unsigned long int khronos_uintptr_t;
|
|
||||||
typedef signed long int khronos_ssize_t;
|
|
||||||
typedef unsigned long int khronos_usize_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if KHRONOS_SUPPORT_FLOAT
|
|
||||||
/*
|
|
||||||
* Float type
|
|
||||||
*/
|
|
||||||
typedef float khronos_float_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if KHRONOS_SUPPORT_INT64
|
|
||||||
/* Time types
|
|
||||||
*
|
|
||||||
* These types can be used to represent a time interval in nanoseconds or
|
|
||||||
* an absolute Unadjusted System Time. Unadjusted System Time is the number
|
|
||||||
* of nanoseconds since some arbitrary system event (e.g. since the last
|
|
||||||
* time the system booted). The Unadjusted System Time is an unsigned
|
|
||||||
* 64 bit value that wraps back to 0 every 584 years. Time intervals
|
|
||||||
* may be either signed or unsigned.
|
|
||||||
*/
|
|
||||||
typedef khronos_uint64_t khronos_utime_nanoseconds_t;
|
|
||||||
typedef khronos_int64_t khronos_stime_nanoseconds_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Dummy value used to pad enum types to 32 bits.
|
|
||||||
*/
|
|
||||||
#ifndef KHRONOS_MAX_ENUM
|
|
||||||
#define KHRONOS_MAX_ENUM 0x7FFFFFFF
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Enumerated boolean type
|
|
||||||
*
|
|
||||||
* Values other than zero should be considered to be true. Therefore
|
|
||||||
* comparisons should not be made against KHRONOS_TRUE.
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
KHRONOS_FALSE = 0,
|
|
||||||
KHRONOS_TRUE = 1,
|
|
||||||
KHRONOS_BOOLEAN_ENUM_FORCE_SIZE = KHRONOS_MAX_ENUM
|
|
||||||
} khronos_boolean_enum_t;
|
|
||||||
|
|
||||||
#endif /* __khrplatform_h_ */
|
|
@ -1,92 +0,0 @@
|
|||||||
/* */
|
|
||||||
/* File: vk_platform.h */
|
|
||||||
/* */
|
|
||||||
/*
|
|
||||||
** Copyright (c) 2014-2017 The Khronos Group Inc.
|
|
||||||
**
|
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef VK_PLATFORM_H_
|
|
||||||
#define VK_PLATFORM_H_
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
/*
|
|
||||||
***************************************************************************************************
|
|
||||||
* Platform-specific directives and type declarations
|
|
||||||
***************************************************************************************************
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Platform-specific calling convention macros.
|
|
||||||
*
|
|
||||||
* Platforms should define these so that Vulkan clients call Vulkan commands
|
|
||||||
* with the same calling conventions that the Vulkan implementation expects.
|
|
||||||
*
|
|
||||||
* VKAPI_ATTR - Placed before the return type in function declarations.
|
|
||||||
* Useful for C++11 and GCC/Clang-style function attribute syntax.
|
|
||||||
* VKAPI_CALL - Placed after the return type in function declarations.
|
|
||||||
* Useful for MSVC-style calling convention syntax.
|
|
||||||
* VKAPI_PTR - Placed between the '(' and '*' in function pointer types.
|
|
||||||
*
|
|
||||||
* Function declaration: VKAPI_ATTR void VKAPI_CALL vkCommand(void);
|
|
||||||
* Function pointer type: typedef void (VKAPI_PTR *PFN_vkCommand)(void);
|
|
||||||
*/
|
|
||||||
#if defined(_WIN32)
|
|
||||||
/* On Windows, Vulkan commands use the stdcall convention */
|
|
||||||
#define VKAPI_ATTR
|
|
||||||
#define VKAPI_CALL __stdcall
|
|
||||||
#define VKAPI_PTR VKAPI_CALL
|
|
||||||
#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH < 7
|
|
||||||
#error "Vulkan isn't supported for the 'armeabi' NDK ABI"
|
|
||||||
#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH >= 7 && defined(__ARM_32BIT_STATE)
|
|
||||||
/* On Android 32-bit ARM targets, Vulkan functions use the "hardfloat" */
|
|
||||||
/* calling convention, i.e. float parameters are passed in registers. This */
|
|
||||||
/* is true even if the rest of the application passes floats on the stack, */
|
|
||||||
/* as it does by default when compiling for the armeabi-v7a NDK ABI. */
|
|
||||||
#define VKAPI_ATTR __attribute__((pcs("aapcs-vfp")))
|
|
||||||
#define VKAPI_CALL
|
|
||||||
#define VKAPI_PTR VKAPI_ATTR
|
|
||||||
#else
|
|
||||||
/* On other platforms, use the default calling convention */
|
|
||||||
#define VKAPI_ATTR
|
|
||||||
#define VKAPI_CALL
|
|
||||||
#define VKAPI_PTR
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
|
|
||||||
#if !defined(VK_NO_STDINT_H)
|
|
||||||
#if defined(_MSC_VER) && (_MSC_VER < 1600)
|
|
||||||
typedef signed __int8 int8_t;
|
|
||||||
typedef unsigned __int8 uint8_t;
|
|
||||||
typedef signed __int16 int16_t;
|
|
||||||
typedef unsigned __int16 uint16_t;
|
|
||||||
typedef signed __int32 int32_t;
|
|
||||||
typedef unsigned __int32 uint32_t;
|
|
||||||
typedef signed __int64 int64_t;
|
|
||||||
typedef unsigned __int64 uint64_t;
|
|
||||||
#else
|
|
||||||
#include <stdint.h>
|
|
||||||
#endif
|
|
||||||
#endif /* !defined(VK_NO_STDINT_H) */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
} /* extern "C" */
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif
|
|
1791
glfw/deps/glad_gl.c
@ -1,593 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <glad/vulkan.h>
|
|
||||||
|
|
||||||
#ifndef GLAD_IMPL_UTIL_C_
|
|
||||||
#define GLAD_IMPL_UTIL_C_
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
#define GLAD_IMPL_UTIL_SSCANF sscanf_s
|
|
||||||
#else
|
|
||||||
#define GLAD_IMPL_UTIL_SSCANF sscanf
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* GLAD_IMPL_UTIL_C_ */
|
|
||||||
|
|
||||||
|
|
||||||
int GLAD_VK_VERSION_1_0 = 0;
|
|
||||||
int GLAD_VK_VERSION_1_1 = 0;
|
|
||||||
int GLAD_VK_EXT_debug_report = 0;
|
|
||||||
int GLAD_VK_KHR_surface = 0;
|
|
||||||
int GLAD_VK_KHR_swapchain = 0;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
PFN_vkAcquireNextImage2KHR glad_vkAcquireNextImage2KHR = NULL;
|
|
||||||
PFN_vkAcquireNextImageKHR glad_vkAcquireNextImageKHR = NULL;
|
|
||||||
PFN_vkAllocateCommandBuffers glad_vkAllocateCommandBuffers = NULL;
|
|
||||||
PFN_vkAllocateDescriptorSets glad_vkAllocateDescriptorSets = NULL;
|
|
||||||
PFN_vkAllocateMemory glad_vkAllocateMemory = NULL;
|
|
||||||
PFN_vkBeginCommandBuffer glad_vkBeginCommandBuffer = NULL;
|
|
||||||
PFN_vkBindBufferMemory glad_vkBindBufferMemory = NULL;
|
|
||||||
PFN_vkBindBufferMemory2 glad_vkBindBufferMemory2 = NULL;
|
|
||||||
PFN_vkBindImageMemory glad_vkBindImageMemory = NULL;
|
|
||||||
PFN_vkBindImageMemory2 glad_vkBindImageMemory2 = NULL;
|
|
||||||
PFN_vkCmdBeginQuery glad_vkCmdBeginQuery = NULL;
|
|
||||||
PFN_vkCmdBeginRenderPass glad_vkCmdBeginRenderPass = NULL;
|
|
||||||
PFN_vkCmdBindDescriptorSets glad_vkCmdBindDescriptorSets = NULL;
|
|
||||||
PFN_vkCmdBindIndexBuffer glad_vkCmdBindIndexBuffer = NULL;
|
|
||||||
PFN_vkCmdBindPipeline glad_vkCmdBindPipeline = NULL;
|
|
||||||
PFN_vkCmdBindVertexBuffers glad_vkCmdBindVertexBuffers = NULL;
|
|
||||||
PFN_vkCmdBlitImage glad_vkCmdBlitImage = NULL;
|
|
||||||
PFN_vkCmdClearAttachments glad_vkCmdClearAttachments = NULL;
|
|
||||||
PFN_vkCmdClearColorImage glad_vkCmdClearColorImage = NULL;
|
|
||||||
PFN_vkCmdClearDepthStencilImage glad_vkCmdClearDepthStencilImage = NULL;
|
|
||||||
PFN_vkCmdCopyBuffer glad_vkCmdCopyBuffer = NULL;
|
|
||||||
PFN_vkCmdCopyBufferToImage glad_vkCmdCopyBufferToImage = NULL;
|
|
||||||
PFN_vkCmdCopyImage glad_vkCmdCopyImage = NULL;
|
|
||||||
PFN_vkCmdCopyImageToBuffer glad_vkCmdCopyImageToBuffer = NULL;
|
|
||||||
PFN_vkCmdCopyQueryPoolResults glad_vkCmdCopyQueryPoolResults = NULL;
|
|
||||||
PFN_vkCmdDispatch glad_vkCmdDispatch = NULL;
|
|
||||||
PFN_vkCmdDispatchBase glad_vkCmdDispatchBase = NULL;
|
|
||||||
PFN_vkCmdDispatchIndirect glad_vkCmdDispatchIndirect = NULL;
|
|
||||||
PFN_vkCmdDraw glad_vkCmdDraw = NULL;
|
|
||||||
PFN_vkCmdDrawIndexed glad_vkCmdDrawIndexed = NULL;
|
|
||||||
PFN_vkCmdDrawIndexedIndirect glad_vkCmdDrawIndexedIndirect = NULL;
|
|
||||||
PFN_vkCmdDrawIndirect glad_vkCmdDrawIndirect = NULL;
|
|
||||||
PFN_vkCmdEndQuery glad_vkCmdEndQuery = NULL;
|
|
||||||
PFN_vkCmdEndRenderPass glad_vkCmdEndRenderPass = NULL;
|
|
||||||
PFN_vkCmdExecuteCommands glad_vkCmdExecuteCommands = NULL;
|
|
||||||
PFN_vkCmdFillBuffer glad_vkCmdFillBuffer = NULL;
|
|
||||||
PFN_vkCmdNextSubpass glad_vkCmdNextSubpass = NULL;
|
|
||||||
PFN_vkCmdPipelineBarrier glad_vkCmdPipelineBarrier = NULL;
|
|
||||||
PFN_vkCmdPushConstants glad_vkCmdPushConstants = NULL;
|
|
||||||
PFN_vkCmdResetEvent glad_vkCmdResetEvent = NULL;
|
|
||||||
PFN_vkCmdResetQueryPool glad_vkCmdResetQueryPool = NULL;
|
|
||||||
PFN_vkCmdResolveImage glad_vkCmdResolveImage = NULL;
|
|
||||||
PFN_vkCmdSetBlendConstants glad_vkCmdSetBlendConstants = NULL;
|
|
||||||
PFN_vkCmdSetDepthBias glad_vkCmdSetDepthBias = NULL;
|
|
||||||
PFN_vkCmdSetDepthBounds glad_vkCmdSetDepthBounds = NULL;
|
|
||||||
PFN_vkCmdSetDeviceMask glad_vkCmdSetDeviceMask = NULL;
|
|
||||||
PFN_vkCmdSetEvent glad_vkCmdSetEvent = NULL;
|
|
||||||
PFN_vkCmdSetLineWidth glad_vkCmdSetLineWidth = NULL;
|
|
||||||
PFN_vkCmdSetScissor glad_vkCmdSetScissor = NULL;
|
|
||||||
PFN_vkCmdSetStencilCompareMask glad_vkCmdSetStencilCompareMask = NULL;
|
|
||||||
PFN_vkCmdSetStencilReference glad_vkCmdSetStencilReference = NULL;
|
|
||||||
PFN_vkCmdSetStencilWriteMask glad_vkCmdSetStencilWriteMask = NULL;
|
|
||||||
PFN_vkCmdSetViewport glad_vkCmdSetViewport = NULL;
|
|
||||||
PFN_vkCmdUpdateBuffer glad_vkCmdUpdateBuffer = NULL;
|
|
||||||
PFN_vkCmdWaitEvents glad_vkCmdWaitEvents = NULL;
|
|
||||||
PFN_vkCmdWriteTimestamp glad_vkCmdWriteTimestamp = NULL;
|
|
||||||
PFN_vkCreateBuffer glad_vkCreateBuffer = NULL;
|
|
||||||
PFN_vkCreateBufferView glad_vkCreateBufferView = NULL;
|
|
||||||
PFN_vkCreateCommandPool glad_vkCreateCommandPool = NULL;
|
|
||||||
PFN_vkCreateComputePipelines glad_vkCreateComputePipelines = NULL;
|
|
||||||
PFN_vkCreateDebugReportCallbackEXT glad_vkCreateDebugReportCallbackEXT = NULL;
|
|
||||||
PFN_vkCreateDescriptorPool glad_vkCreateDescriptorPool = NULL;
|
|
||||||
PFN_vkCreateDescriptorSetLayout glad_vkCreateDescriptorSetLayout = NULL;
|
|
||||||
PFN_vkCreateDescriptorUpdateTemplate glad_vkCreateDescriptorUpdateTemplate = NULL;
|
|
||||||
PFN_vkCreateDevice glad_vkCreateDevice = NULL;
|
|
||||||
PFN_vkCreateEvent glad_vkCreateEvent = NULL;
|
|
||||||
PFN_vkCreateFence glad_vkCreateFence = NULL;
|
|
||||||
PFN_vkCreateFramebuffer glad_vkCreateFramebuffer = NULL;
|
|
||||||
PFN_vkCreateGraphicsPipelines glad_vkCreateGraphicsPipelines = NULL;
|
|
||||||
PFN_vkCreateImage glad_vkCreateImage = NULL;
|
|
||||||
PFN_vkCreateImageView glad_vkCreateImageView = NULL;
|
|
||||||
PFN_vkCreateInstance glad_vkCreateInstance = NULL;
|
|
||||||
PFN_vkCreatePipelineCache glad_vkCreatePipelineCache = NULL;
|
|
||||||
PFN_vkCreatePipelineLayout glad_vkCreatePipelineLayout = NULL;
|
|
||||||
PFN_vkCreateQueryPool glad_vkCreateQueryPool = NULL;
|
|
||||||
PFN_vkCreateRenderPass glad_vkCreateRenderPass = NULL;
|
|
||||||
PFN_vkCreateSampler glad_vkCreateSampler = NULL;
|
|
||||||
PFN_vkCreateSamplerYcbcrConversion glad_vkCreateSamplerYcbcrConversion = NULL;
|
|
||||||
PFN_vkCreateSemaphore glad_vkCreateSemaphore = NULL;
|
|
||||||
PFN_vkCreateShaderModule glad_vkCreateShaderModule = NULL;
|
|
||||||
PFN_vkCreateSwapchainKHR glad_vkCreateSwapchainKHR = NULL;
|
|
||||||
PFN_vkDebugReportMessageEXT glad_vkDebugReportMessageEXT = NULL;
|
|
||||||
PFN_vkDestroyBuffer glad_vkDestroyBuffer = NULL;
|
|
||||||
PFN_vkDestroyBufferView glad_vkDestroyBufferView = NULL;
|
|
||||||
PFN_vkDestroyCommandPool glad_vkDestroyCommandPool = NULL;
|
|
||||||
PFN_vkDestroyDebugReportCallbackEXT glad_vkDestroyDebugReportCallbackEXT = NULL;
|
|
||||||
PFN_vkDestroyDescriptorPool glad_vkDestroyDescriptorPool = NULL;
|
|
||||||
PFN_vkDestroyDescriptorSetLayout glad_vkDestroyDescriptorSetLayout = NULL;
|
|
||||||
PFN_vkDestroyDescriptorUpdateTemplate glad_vkDestroyDescriptorUpdateTemplate = NULL;
|
|
||||||
PFN_vkDestroyDevice glad_vkDestroyDevice = NULL;
|
|
||||||
PFN_vkDestroyEvent glad_vkDestroyEvent = NULL;
|
|
||||||
PFN_vkDestroyFence glad_vkDestroyFence = NULL;
|
|
||||||
PFN_vkDestroyFramebuffer glad_vkDestroyFramebuffer = NULL;
|
|
||||||
PFN_vkDestroyImage glad_vkDestroyImage = NULL;
|
|
||||||
PFN_vkDestroyImageView glad_vkDestroyImageView = NULL;
|
|
||||||
PFN_vkDestroyInstance glad_vkDestroyInstance = NULL;
|
|
||||||
PFN_vkDestroyPipeline glad_vkDestroyPipeline = NULL;
|
|
||||||
PFN_vkDestroyPipelineCache glad_vkDestroyPipelineCache = NULL;
|
|
||||||
PFN_vkDestroyPipelineLayout glad_vkDestroyPipelineLayout = NULL;
|
|
||||||
PFN_vkDestroyQueryPool glad_vkDestroyQueryPool = NULL;
|
|
||||||
PFN_vkDestroyRenderPass glad_vkDestroyRenderPass = NULL;
|
|
||||||
PFN_vkDestroySampler glad_vkDestroySampler = NULL;
|
|
||||||
PFN_vkDestroySamplerYcbcrConversion glad_vkDestroySamplerYcbcrConversion = NULL;
|
|
||||||
PFN_vkDestroySemaphore glad_vkDestroySemaphore = NULL;
|
|
||||||
PFN_vkDestroyShaderModule glad_vkDestroyShaderModule = NULL;
|
|
||||||
PFN_vkDestroySurfaceKHR glad_vkDestroySurfaceKHR = NULL;
|
|
||||||
PFN_vkDestroySwapchainKHR glad_vkDestroySwapchainKHR = NULL;
|
|
||||||
PFN_vkDeviceWaitIdle glad_vkDeviceWaitIdle = NULL;
|
|
||||||
PFN_vkEndCommandBuffer glad_vkEndCommandBuffer = NULL;
|
|
||||||
PFN_vkEnumerateDeviceExtensionProperties glad_vkEnumerateDeviceExtensionProperties = NULL;
|
|
||||||
PFN_vkEnumerateDeviceLayerProperties glad_vkEnumerateDeviceLayerProperties = NULL;
|
|
||||||
PFN_vkEnumerateInstanceExtensionProperties glad_vkEnumerateInstanceExtensionProperties = NULL;
|
|
||||||
PFN_vkEnumerateInstanceLayerProperties glad_vkEnumerateInstanceLayerProperties = NULL;
|
|
||||||
PFN_vkEnumerateInstanceVersion glad_vkEnumerateInstanceVersion = NULL;
|
|
||||||
PFN_vkEnumeratePhysicalDeviceGroups glad_vkEnumeratePhysicalDeviceGroups = NULL;
|
|
||||||
PFN_vkEnumeratePhysicalDevices glad_vkEnumeratePhysicalDevices = NULL;
|
|
||||||
PFN_vkFlushMappedMemoryRanges glad_vkFlushMappedMemoryRanges = NULL;
|
|
||||||
PFN_vkFreeCommandBuffers glad_vkFreeCommandBuffers = NULL;
|
|
||||||
PFN_vkFreeDescriptorSets glad_vkFreeDescriptorSets = NULL;
|
|
||||||
PFN_vkFreeMemory glad_vkFreeMemory = NULL;
|
|
||||||
PFN_vkGetBufferMemoryRequirements glad_vkGetBufferMemoryRequirements = NULL;
|
|
||||||
PFN_vkGetBufferMemoryRequirements2 glad_vkGetBufferMemoryRequirements2 = NULL;
|
|
||||||
PFN_vkGetDescriptorSetLayoutSupport glad_vkGetDescriptorSetLayoutSupport = NULL;
|
|
||||||
PFN_vkGetDeviceGroupPeerMemoryFeatures glad_vkGetDeviceGroupPeerMemoryFeatures = NULL;
|
|
||||||
PFN_vkGetDeviceGroupPresentCapabilitiesKHR glad_vkGetDeviceGroupPresentCapabilitiesKHR = NULL;
|
|
||||||
PFN_vkGetDeviceGroupSurfacePresentModesKHR glad_vkGetDeviceGroupSurfacePresentModesKHR = NULL;
|
|
||||||
PFN_vkGetDeviceMemoryCommitment glad_vkGetDeviceMemoryCommitment = NULL;
|
|
||||||
PFN_vkGetDeviceProcAddr glad_vkGetDeviceProcAddr = NULL;
|
|
||||||
PFN_vkGetDeviceQueue glad_vkGetDeviceQueue = NULL;
|
|
||||||
PFN_vkGetDeviceQueue2 glad_vkGetDeviceQueue2 = NULL;
|
|
||||||
PFN_vkGetEventStatus glad_vkGetEventStatus = NULL;
|
|
||||||
PFN_vkGetFenceStatus glad_vkGetFenceStatus = NULL;
|
|
||||||
PFN_vkGetImageMemoryRequirements glad_vkGetImageMemoryRequirements = NULL;
|
|
||||||
PFN_vkGetImageMemoryRequirements2 glad_vkGetImageMemoryRequirements2 = NULL;
|
|
||||||
PFN_vkGetImageSparseMemoryRequirements glad_vkGetImageSparseMemoryRequirements = NULL;
|
|
||||||
PFN_vkGetImageSparseMemoryRequirements2 glad_vkGetImageSparseMemoryRequirements2 = NULL;
|
|
||||||
PFN_vkGetImageSubresourceLayout glad_vkGetImageSubresourceLayout = NULL;
|
|
||||||
PFN_vkGetInstanceProcAddr glad_vkGetInstanceProcAddr = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalBufferProperties glad_vkGetPhysicalDeviceExternalBufferProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalFenceProperties glad_vkGetPhysicalDeviceExternalFenceProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalSemaphoreProperties glad_vkGetPhysicalDeviceExternalSemaphoreProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceFeatures glad_vkGetPhysicalDeviceFeatures = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceFeatures2 glad_vkGetPhysicalDeviceFeatures2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceFormatProperties glad_vkGetPhysicalDeviceFormatProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceFormatProperties2 glad_vkGetPhysicalDeviceFormatProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceImageFormatProperties glad_vkGetPhysicalDeviceImageFormatProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceImageFormatProperties2 glad_vkGetPhysicalDeviceImageFormatProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceMemoryProperties glad_vkGetPhysicalDeviceMemoryProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceMemoryProperties2 glad_vkGetPhysicalDeviceMemoryProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDevicePresentRectanglesKHR glad_vkGetPhysicalDevicePresentRectanglesKHR = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceProperties glad_vkGetPhysicalDeviceProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceProperties2 glad_vkGetPhysicalDeviceProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceQueueFamilyProperties glad_vkGetPhysicalDeviceQueueFamilyProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceQueueFamilyProperties2 glad_vkGetPhysicalDeviceQueueFamilyProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSparseImageFormatProperties glad_vkGetPhysicalDeviceSparseImageFormatProperties = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSparseImageFormatProperties2 glad_vkGetPhysicalDeviceSparseImageFormatProperties2 = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR glad_vkGetPhysicalDeviceSurfaceCapabilitiesKHR = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceFormatsKHR glad_vkGetPhysicalDeviceSurfaceFormatsKHR = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfacePresentModesKHR glad_vkGetPhysicalDeviceSurfacePresentModesKHR = NULL;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceSupportKHR glad_vkGetPhysicalDeviceSurfaceSupportKHR = NULL;
|
|
||||||
PFN_vkGetPipelineCacheData glad_vkGetPipelineCacheData = NULL;
|
|
||||||
PFN_vkGetQueryPoolResults glad_vkGetQueryPoolResults = NULL;
|
|
||||||
PFN_vkGetRenderAreaGranularity glad_vkGetRenderAreaGranularity = NULL;
|
|
||||||
PFN_vkGetSwapchainImagesKHR glad_vkGetSwapchainImagesKHR = NULL;
|
|
||||||
PFN_vkInvalidateMappedMemoryRanges glad_vkInvalidateMappedMemoryRanges = NULL;
|
|
||||||
PFN_vkMapMemory glad_vkMapMemory = NULL;
|
|
||||||
PFN_vkMergePipelineCaches glad_vkMergePipelineCaches = NULL;
|
|
||||||
PFN_vkQueueBindSparse glad_vkQueueBindSparse = NULL;
|
|
||||||
PFN_vkQueuePresentKHR glad_vkQueuePresentKHR = NULL;
|
|
||||||
PFN_vkQueueSubmit glad_vkQueueSubmit = NULL;
|
|
||||||
PFN_vkQueueWaitIdle glad_vkQueueWaitIdle = NULL;
|
|
||||||
PFN_vkResetCommandBuffer glad_vkResetCommandBuffer = NULL;
|
|
||||||
PFN_vkResetCommandPool glad_vkResetCommandPool = NULL;
|
|
||||||
PFN_vkResetDescriptorPool glad_vkResetDescriptorPool = NULL;
|
|
||||||
PFN_vkResetEvent glad_vkResetEvent = NULL;
|
|
||||||
PFN_vkResetFences glad_vkResetFences = NULL;
|
|
||||||
PFN_vkSetEvent glad_vkSetEvent = NULL;
|
|
||||||
PFN_vkTrimCommandPool glad_vkTrimCommandPool = NULL;
|
|
||||||
PFN_vkUnmapMemory glad_vkUnmapMemory = NULL;
|
|
||||||
PFN_vkUpdateDescriptorSetWithTemplate glad_vkUpdateDescriptorSetWithTemplate = NULL;
|
|
||||||
PFN_vkUpdateDescriptorSets glad_vkUpdateDescriptorSets = NULL;
|
|
||||||
PFN_vkWaitForFences glad_vkWaitForFences = NULL;
|
|
||||||
|
|
||||||
|
|
||||||
static void glad_vk_load_VK_VERSION_1_0( GLADuserptrloadfunc load, void* userptr) {
|
|
||||||
if(!GLAD_VK_VERSION_1_0) return;
|
|
||||||
vkAllocateCommandBuffers = (PFN_vkAllocateCommandBuffers) load("vkAllocateCommandBuffers", userptr);
|
|
||||||
vkAllocateDescriptorSets = (PFN_vkAllocateDescriptorSets) load("vkAllocateDescriptorSets", userptr);
|
|
||||||
vkAllocateMemory = (PFN_vkAllocateMemory) load("vkAllocateMemory", userptr);
|
|
||||||
vkBeginCommandBuffer = (PFN_vkBeginCommandBuffer) load("vkBeginCommandBuffer", userptr);
|
|
||||||
vkBindBufferMemory = (PFN_vkBindBufferMemory) load("vkBindBufferMemory", userptr);
|
|
||||||
vkBindImageMemory = (PFN_vkBindImageMemory) load("vkBindImageMemory", userptr);
|
|
||||||
vkCmdBeginQuery = (PFN_vkCmdBeginQuery) load("vkCmdBeginQuery", userptr);
|
|
||||||
vkCmdBeginRenderPass = (PFN_vkCmdBeginRenderPass) load("vkCmdBeginRenderPass", userptr);
|
|
||||||
vkCmdBindDescriptorSets = (PFN_vkCmdBindDescriptorSets) load("vkCmdBindDescriptorSets", userptr);
|
|
||||||
vkCmdBindIndexBuffer = (PFN_vkCmdBindIndexBuffer) load("vkCmdBindIndexBuffer", userptr);
|
|
||||||
vkCmdBindPipeline = (PFN_vkCmdBindPipeline) load("vkCmdBindPipeline", userptr);
|
|
||||||
vkCmdBindVertexBuffers = (PFN_vkCmdBindVertexBuffers) load("vkCmdBindVertexBuffers", userptr);
|
|
||||||
vkCmdBlitImage = (PFN_vkCmdBlitImage) load("vkCmdBlitImage", userptr);
|
|
||||||
vkCmdClearAttachments = (PFN_vkCmdClearAttachments) load("vkCmdClearAttachments", userptr);
|
|
||||||
vkCmdClearColorImage = (PFN_vkCmdClearColorImage) load("vkCmdClearColorImage", userptr);
|
|
||||||
vkCmdClearDepthStencilImage = (PFN_vkCmdClearDepthStencilImage) load("vkCmdClearDepthStencilImage", userptr);
|
|
||||||
vkCmdCopyBuffer = (PFN_vkCmdCopyBuffer) load("vkCmdCopyBuffer", userptr);
|
|
||||||
vkCmdCopyBufferToImage = (PFN_vkCmdCopyBufferToImage) load("vkCmdCopyBufferToImage", userptr);
|
|
||||||
vkCmdCopyImage = (PFN_vkCmdCopyImage) load("vkCmdCopyImage", userptr);
|
|
||||||
vkCmdCopyImageToBuffer = (PFN_vkCmdCopyImageToBuffer) load("vkCmdCopyImageToBuffer", userptr);
|
|
||||||
vkCmdCopyQueryPoolResults = (PFN_vkCmdCopyQueryPoolResults) load("vkCmdCopyQueryPoolResults", userptr);
|
|
||||||
vkCmdDispatch = (PFN_vkCmdDispatch) load("vkCmdDispatch", userptr);
|
|
||||||
vkCmdDispatchIndirect = (PFN_vkCmdDispatchIndirect) load("vkCmdDispatchIndirect", userptr);
|
|
||||||
vkCmdDraw = (PFN_vkCmdDraw) load("vkCmdDraw", userptr);
|
|
||||||
vkCmdDrawIndexed = (PFN_vkCmdDrawIndexed) load("vkCmdDrawIndexed", userptr);
|
|
||||||
vkCmdDrawIndexedIndirect = (PFN_vkCmdDrawIndexedIndirect) load("vkCmdDrawIndexedIndirect", userptr);
|
|
||||||
vkCmdDrawIndirect = (PFN_vkCmdDrawIndirect) load("vkCmdDrawIndirect", userptr);
|
|
||||||
vkCmdEndQuery = (PFN_vkCmdEndQuery) load("vkCmdEndQuery", userptr);
|
|
||||||
vkCmdEndRenderPass = (PFN_vkCmdEndRenderPass) load("vkCmdEndRenderPass", userptr);
|
|
||||||
vkCmdExecuteCommands = (PFN_vkCmdExecuteCommands) load("vkCmdExecuteCommands", userptr);
|
|
||||||
vkCmdFillBuffer = (PFN_vkCmdFillBuffer) load("vkCmdFillBuffer", userptr);
|
|
||||||
vkCmdNextSubpass = (PFN_vkCmdNextSubpass) load("vkCmdNextSubpass", userptr);
|
|
||||||
vkCmdPipelineBarrier = (PFN_vkCmdPipelineBarrier) load("vkCmdPipelineBarrier", userptr);
|
|
||||||
vkCmdPushConstants = (PFN_vkCmdPushConstants) load("vkCmdPushConstants", userptr);
|
|
||||||
vkCmdResetEvent = (PFN_vkCmdResetEvent) load("vkCmdResetEvent", userptr);
|
|
||||||
vkCmdResetQueryPool = (PFN_vkCmdResetQueryPool) load("vkCmdResetQueryPool", userptr);
|
|
||||||
vkCmdResolveImage = (PFN_vkCmdResolveImage) load("vkCmdResolveImage", userptr);
|
|
||||||
vkCmdSetBlendConstants = (PFN_vkCmdSetBlendConstants) load("vkCmdSetBlendConstants", userptr);
|
|
||||||
vkCmdSetDepthBias = (PFN_vkCmdSetDepthBias) load("vkCmdSetDepthBias", userptr);
|
|
||||||
vkCmdSetDepthBounds = (PFN_vkCmdSetDepthBounds) load("vkCmdSetDepthBounds", userptr);
|
|
||||||
vkCmdSetEvent = (PFN_vkCmdSetEvent) load("vkCmdSetEvent", userptr);
|
|
||||||
vkCmdSetLineWidth = (PFN_vkCmdSetLineWidth) load("vkCmdSetLineWidth", userptr);
|
|
||||||
vkCmdSetScissor = (PFN_vkCmdSetScissor) load("vkCmdSetScissor", userptr);
|
|
||||||
vkCmdSetStencilCompareMask = (PFN_vkCmdSetStencilCompareMask) load("vkCmdSetStencilCompareMask", userptr);
|
|
||||||
vkCmdSetStencilReference = (PFN_vkCmdSetStencilReference) load("vkCmdSetStencilReference", userptr);
|
|
||||||
vkCmdSetStencilWriteMask = (PFN_vkCmdSetStencilWriteMask) load("vkCmdSetStencilWriteMask", userptr);
|
|
||||||
vkCmdSetViewport = (PFN_vkCmdSetViewport) load("vkCmdSetViewport", userptr);
|
|
||||||
vkCmdUpdateBuffer = (PFN_vkCmdUpdateBuffer) load("vkCmdUpdateBuffer", userptr);
|
|
||||||
vkCmdWaitEvents = (PFN_vkCmdWaitEvents) load("vkCmdWaitEvents", userptr);
|
|
||||||
vkCmdWriteTimestamp = (PFN_vkCmdWriteTimestamp) load("vkCmdWriteTimestamp", userptr);
|
|
||||||
vkCreateBuffer = (PFN_vkCreateBuffer) load("vkCreateBuffer", userptr);
|
|
||||||
vkCreateBufferView = (PFN_vkCreateBufferView) load("vkCreateBufferView", userptr);
|
|
||||||
vkCreateCommandPool = (PFN_vkCreateCommandPool) load("vkCreateCommandPool", userptr);
|
|
||||||
vkCreateComputePipelines = (PFN_vkCreateComputePipelines) load("vkCreateComputePipelines", userptr);
|
|
||||||
vkCreateDescriptorPool = (PFN_vkCreateDescriptorPool) load("vkCreateDescriptorPool", userptr);
|
|
||||||
vkCreateDescriptorSetLayout = (PFN_vkCreateDescriptorSetLayout) load("vkCreateDescriptorSetLayout", userptr);
|
|
||||||
vkCreateDevice = (PFN_vkCreateDevice) load("vkCreateDevice", userptr);
|
|
||||||
vkCreateEvent = (PFN_vkCreateEvent) load("vkCreateEvent", userptr);
|
|
||||||
vkCreateFence = (PFN_vkCreateFence) load("vkCreateFence", userptr);
|
|
||||||
vkCreateFramebuffer = (PFN_vkCreateFramebuffer) load("vkCreateFramebuffer", userptr);
|
|
||||||
vkCreateGraphicsPipelines = (PFN_vkCreateGraphicsPipelines) load("vkCreateGraphicsPipelines", userptr);
|
|
||||||
vkCreateImage = (PFN_vkCreateImage) load("vkCreateImage", userptr);
|
|
||||||
vkCreateImageView = (PFN_vkCreateImageView) load("vkCreateImageView", userptr);
|
|
||||||
vkCreateInstance = (PFN_vkCreateInstance) load("vkCreateInstance", userptr);
|
|
||||||
vkCreatePipelineCache = (PFN_vkCreatePipelineCache) load("vkCreatePipelineCache", userptr);
|
|
||||||
vkCreatePipelineLayout = (PFN_vkCreatePipelineLayout) load("vkCreatePipelineLayout", userptr);
|
|
||||||
vkCreateQueryPool = (PFN_vkCreateQueryPool) load("vkCreateQueryPool", userptr);
|
|
||||||
vkCreateRenderPass = (PFN_vkCreateRenderPass) load("vkCreateRenderPass", userptr);
|
|
||||||
vkCreateSampler = (PFN_vkCreateSampler) load("vkCreateSampler", userptr);
|
|
||||||
vkCreateSemaphore = (PFN_vkCreateSemaphore) load("vkCreateSemaphore", userptr);
|
|
||||||
vkCreateShaderModule = (PFN_vkCreateShaderModule) load("vkCreateShaderModule", userptr);
|
|
||||||
vkDestroyBuffer = (PFN_vkDestroyBuffer) load("vkDestroyBuffer", userptr);
|
|
||||||
vkDestroyBufferView = (PFN_vkDestroyBufferView) load("vkDestroyBufferView", userptr);
|
|
||||||
vkDestroyCommandPool = (PFN_vkDestroyCommandPool) load("vkDestroyCommandPool", userptr);
|
|
||||||
vkDestroyDescriptorPool = (PFN_vkDestroyDescriptorPool) load("vkDestroyDescriptorPool", userptr);
|
|
||||||
vkDestroyDescriptorSetLayout = (PFN_vkDestroyDescriptorSetLayout) load("vkDestroyDescriptorSetLayout", userptr);
|
|
||||||
vkDestroyDevice = (PFN_vkDestroyDevice) load("vkDestroyDevice", userptr);
|
|
||||||
vkDestroyEvent = (PFN_vkDestroyEvent) load("vkDestroyEvent", userptr);
|
|
||||||
vkDestroyFence = (PFN_vkDestroyFence) load("vkDestroyFence", userptr);
|
|
||||||
vkDestroyFramebuffer = (PFN_vkDestroyFramebuffer) load("vkDestroyFramebuffer", userptr);
|
|
||||||
vkDestroyImage = (PFN_vkDestroyImage) load("vkDestroyImage", userptr);
|
|
||||||
vkDestroyImageView = (PFN_vkDestroyImageView) load("vkDestroyImageView", userptr);
|
|
||||||
vkDestroyInstance = (PFN_vkDestroyInstance) load("vkDestroyInstance", userptr);
|
|
||||||
vkDestroyPipeline = (PFN_vkDestroyPipeline) load("vkDestroyPipeline", userptr);
|
|
||||||
vkDestroyPipelineCache = (PFN_vkDestroyPipelineCache) load("vkDestroyPipelineCache", userptr);
|
|
||||||
vkDestroyPipelineLayout = (PFN_vkDestroyPipelineLayout) load("vkDestroyPipelineLayout", userptr);
|
|
||||||
vkDestroyQueryPool = (PFN_vkDestroyQueryPool) load("vkDestroyQueryPool", userptr);
|
|
||||||
vkDestroyRenderPass = (PFN_vkDestroyRenderPass) load("vkDestroyRenderPass", userptr);
|
|
||||||
vkDestroySampler = (PFN_vkDestroySampler) load("vkDestroySampler", userptr);
|
|
||||||
vkDestroySemaphore = (PFN_vkDestroySemaphore) load("vkDestroySemaphore", userptr);
|
|
||||||
vkDestroyShaderModule = (PFN_vkDestroyShaderModule) load("vkDestroyShaderModule", userptr);
|
|
||||||
vkDeviceWaitIdle = (PFN_vkDeviceWaitIdle) load("vkDeviceWaitIdle", userptr);
|
|
||||||
vkEndCommandBuffer = (PFN_vkEndCommandBuffer) load("vkEndCommandBuffer", userptr);
|
|
||||||
vkEnumerateDeviceExtensionProperties = (PFN_vkEnumerateDeviceExtensionProperties) load("vkEnumerateDeviceExtensionProperties", userptr);
|
|
||||||
vkEnumerateDeviceLayerProperties = (PFN_vkEnumerateDeviceLayerProperties) load("vkEnumerateDeviceLayerProperties", userptr);
|
|
||||||
vkEnumerateInstanceExtensionProperties = (PFN_vkEnumerateInstanceExtensionProperties) load("vkEnumerateInstanceExtensionProperties", userptr);
|
|
||||||
vkEnumerateInstanceLayerProperties = (PFN_vkEnumerateInstanceLayerProperties) load("vkEnumerateInstanceLayerProperties", userptr);
|
|
||||||
vkEnumeratePhysicalDevices = (PFN_vkEnumeratePhysicalDevices) load("vkEnumeratePhysicalDevices", userptr);
|
|
||||||
vkFlushMappedMemoryRanges = (PFN_vkFlushMappedMemoryRanges) load("vkFlushMappedMemoryRanges", userptr);
|
|
||||||
vkFreeCommandBuffers = (PFN_vkFreeCommandBuffers) load("vkFreeCommandBuffers", userptr);
|
|
||||||
vkFreeDescriptorSets = (PFN_vkFreeDescriptorSets) load("vkFreeDescriptorSets", userptr);
|
|
||||||
vkFreeMemory = (PFN_vkFreeMemory) load("vkFreeMemory", userptr);
|
|
||||||
vkGetBufferMemoryRequirements = (PFN_vkGetBufferMemoryRequirements) load("vkGetBufferMemoryRequirements", userptr);
|
|
||||||
vkGetDeviceMemoryCommitment = (PFN_vkGetDeviceMemoryCommitment) load("vkGetDeviceMemoryCommitment", userptr);
|
|
||||||
vkGetDeviceProcAddr = (PFN_vkGetDeviceProcAddr) load("vkGetDeviceProcAddr", userptr);
|
|
||||||
vkGetDeviceQueue = (PFN_vkGetDeviceQueue) load("vkGetDeviceQueue", userptr);
|
|
||||||
vkGetEventStatus = (PFN_vkGetEventStatus) load("vkGetEventStatus", userptr);
|
|
||||||
vkGetFenceStatus = (PFN_vkGetFenceStatus) load("vkGetFenceStatus", userptr);
|
|
||||||
vkGetImageMemoryRequirements = (PFN_vkGetImageMemoryRequirements) load("vkGetImageMemoryRequirements", userptr);
|
|
||||||
vkGetImageSparseMemoryRequirements = (PFN_vkGetImageSparseMemoryRequirements) load("vkGetImageSparseMemoryRequirements", userptr);
|
|
||||||
vkGetImageSubresourceLayout = (PFN_vkGetImageSubresourceLayout) load("vkGetImageSubresourceLayout", userptr);
|
|
||||||
vkGetInstanceProcAddr = (PFN_vkGetInstanceProcAddr) load("vkGetInstanceProcAddr", userptr);
|
|
||||||
vkGetPhysicalDeviceFeatures = (PFN_vkGetPhysicalDeviceFeatures) load("vkGetPhysicalDeviceFeatures", userptr);
|
|
||||||
vkGetPhysicalDeviceFormatProperties = (PFN_vkGetPhysicalDeviceFormatProperties) load("vkGetPhysicalDeviceFormatProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceImageFormatProperties = (PFN_vkGetPhysicalDeviceImageFormatProperties) load("vkGetPhysicalDeviceImageFormatProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceMemoryProperties = (PFN_vkGetPhysicalDeviceMemoryProperties) load("vkGetPhysicalDeviceMemoryProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceProperties = (PFN_vkGetPhysicalDeviceProperties) load("vkGetPhysicalDeviceProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceQueueFamilyProperties = (PFN_vkGetPhysicalDeviceQueueFamilyProperties) load("vkGetPhysicalDeviceQueueFamilyProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceSparseImageFormatProperties = (PFN_vkGetPhysicalDeviceSparseImageFormatProperties) load("vkGetPhysicalDeviceSparseImageFormatProperties", userptr);
|
|
||||||
vkGetPipelineCacheData = (PFN_vkGetPipelineCacheData) load("vkGetPipelineCacheData", userptr);
|
|
||||||
vkGetQueryPoolResults = (PFN_vkGetQueryPoolResults) load("vkGetQueryPoolResults", userptr);
|
|
||||||
vkGetRenderAreaGranularity = (PFN_vkGetRenderAreaGranularity) load("vkGetRenderAreaGranularity", userptr);
|
|
||||||
vkInvalidateMappedMemoryRanges = (PFN_vkInvalidateMappedMemoryRanges) load("vkInvalidateMappedMemoryRanges", userptr);
|
|
||||||
vkMapMemory = (PFN_vkMapMemory) load("vkMapMemory", userptr);
|
|
||||||
vkMergePipelineCaches = (PFN_vkMergePipelineCaches) load("vkMergePipelineCaches", userptr);
|
|
||||||
vkQueueBindSparse = (PFN_vkQueueBindSparse) load("vkQueueBindSparse", userptr);
|
|
||||||
vkQueueSubmit = (PFN_vkQueueSubmit) load("vkQueueSubmit", userptr);
|
|
||||||
vkQueueWaitIdle = (PFN_vkQueueWaitIdle) load("vkQueueWaitIdle", userptr);
|
|
||||||
vkResetCommandBuffer = (PFN_vkResetCommandBuffer) load("vkResetCommandBuffer", userptr);
|
|
||||||
vkResetCommandPool = (PFN_vkResetCommandPool) load("vkResetCommandPool", userptr);
|
|
||||||
vkResetDescriptorPool = (PFN_vkResetDescriptorPool) load("vkResetDescriptorPool", userptr);
|
|
||||||
vkResetEvent = (PFN_vkResetEvent) load("vkResetEvent", userptr);
|
|
||||||
vkResetFences = (PFN_vkResetFences) load("vkResetFences", userptr);
|
|
||||||
vkSetEvent = (PFN_vkSetEvent) load("vkSetEvent", userptr);
|
|
||||||
vkUnmapMemory = (PFN_vkUnmapMemory) load("vkUnmapMemory", userptr);
|
|
||||||
vkUpdateDescriptorSets = (PFN_vkUpdateDescriptorSets) load("vkUpdateDescriptorSets", userptr);
|
|
||||||
vkWaitForFences = (PFN_vkWaitForFences) load("vkWaitForFences", userptr);
|
|
||||||
}
|
|
||||||
static void glad_vk_load_VK_VERSION_1_1( GLADuserptrloadfunc load, void* userptr) {
|
|
||||||
if(!GLAD_VK_VERSION_1_1) return;
|
|
||||||
vkBindBufferMemory2 = (PFN_vkBindBufferMemory2) load("vkBindBufferMemory2", userptr);
|
|
||||||
vkBindImageMemory2 = (PFN_vkBindImageMemory2) load("vkBindImageMemory2", userptr);
|
|
||||||
vkCmdDispatchBase = (PFN_vkCmdDispatchBase) load("vkCmdDispatchBase", userptr);
|
|
||||||
vkCmdSetDeviceMask = (PFN_vkCmdSetDeviceMask) load("vkCmdSetDeviceMask", userptr);
|
|
||||||
vkCreateDescriptorUpdateTemplate = (PFN_vkCreateDescriptorUpdateTemplate) load("vkCreateDescriptorUpdateTemplate", userptr);
|
|
||||||
vkCreateSamplerYcbcrConversion = (PFN_vkCreateSamplerYcbcrConversion) load("vkCreateSamplerYcbcrConversion", userptr);
|
|
||||||
vkDestroyDescriptorUpdateTemplate = (PFN_vkDestroyDescriptorUpdateTemplate) load("vkDestroyDescriptorUpdateTemplate", userptr);
|
|
||||||
vkDestroySamplerYcbcrConversion = (PFN_vkDestroySamplerYcbcrConversion) load("vkDestroySamplerYcbcrConversion", userptr);
|
|
||||||
vkEnumerateInstanceVersion = (PFN_vkEnumerateInstanceVersion) load("vkEnumerateInstanceVersion", userptr);
|
|
||||||
vkEnumeratePhysicalDeviceGroups = (PFN_vkEnumeratePhysicalDeviceGroups) load("vkEnumeratePhysicalDeviceGroups", userptr);
|
|
||||||
vkGetBufferMemoryRequirements2 = (PFN_vkGetBufferMemoryRequirements2) load("vkGetBufferMemoryRequirements2", userptr);
|
|
||||||
vkGetDescriptorSetLayoutSupport = (PFN_vkGetDescriptorSetLayoutSupport) load("vkGetDescriptorSetLayoutSupport", userptr);
|
|
||||||
vkGetDeviceGroupPeerMemoryFeatures = (PFN_vkGetDeviceGroupPeerMemoryFeatures) load("vkGetDeviceGroupPeerMemoryFeatures", userptr);
|
|
||||||
vkGetDeviceQueue2 = (PFN_vkGetDeviceQueue2) load("vkGetDeviceQueue2", userptr);
|
|
||||||
vkGetImageMemoryRequirements2 = (PFN_vkGetImageMemoryRequirements2) load("vkGetImageMemoryRequirements2", userptr);
|
|
||||||
vkGetImageSparseMemoryRequirements2 = (PFN_vkGetImageSparseMemoryRequirements2) load("vkGetImageSparseMemoryRequirements2", userptr);
|
|
||||||
vkGetPhysicalDeviceExternalBufferProperties = (PFN_vkGetPhysicalDeviceExternalBufferProperties) load("vkGetPhysicalDeviceExternalBufferProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceExternalFenceProperties = (PFN_vkGetPhysicalDeviceExternalFenceProperties) load("vkGetPhysicalDeviceExternalFenceProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceExternalSemaphoreProperties = (PFN_vkGetPhysicalDeviceExternalSemaphoreProperties) load("vkGetPhysicalDeviceExternalSemaphoreProperties", userptr);
|
|
||||||
vkGetPhysicalDeviceFeatures2 = (PFN_vkGetPhysicalDeviceFeatures2) load("vkGetPhysicalDeviceFeatures2", userptr);
|
|
||||||
vkGetPhysicalDeviceFormatProperties2 = (PFN_vkGetPhysicalDeviceFormatProperties2) load("vkGetPhysicalDeviceFormatProperties2", userptr);
|
|
||||||
vkGetPhysicalDeviceImageFormatProperties2 = (PFN_vkGetPhysicalDeviceImageFormatProperties2) load("vkGetPhysicalDeviceImageFormatProperties2", userptr);
|
|
||||||
vkGetPhysicalDeviceMemoryProperties2 = (PFN_vkGetPhysicalDeviceMemoryProperties2) load("vkGetPhysicalDeviceMemoryProperties2", userptr);
|
|
||||||
vkGetPhysicalDeviceProperties2 = (PFN_vkGetPhysicalDeviceProperties2) load("vkGetPhysicalDeviceProperties2", userptr);
|
|
||||||
vkGetPhysicalDeviceQueueFamilyProperties2 = (PFN_vkGetPhysicalDeviceQueueFamilyProperties2) load("vkGetPhysicalDeviceQueueFamilyProperties2", userptr);
|
|
||||||
vkGetPhysicalDeviceSparseImageFormatProperties2 = (PFN_vkGetPhysicalDeviceSparseImageFormatProperties2) load("vkGetPhysicalDeviceSparseImageFormatProperties2", userptr);
|
|
||||||
vkTrimCommandPool = (PFN_vkTrimCommandPool) load("vkTrimCommandPool", userptr);
|
|
||||||
vkUpdateDescriptorSetWithTemplate = (PFN_vkUpdateDescriptorSetWithTemplate) load("vkUpdateDescriptorSetWithTemplate", userptr);
|
|
||||||
}
|
|
||||||
static void glad_vk_load_VK_EXT_debug_report( GLADuserptrloadfunc load, void* userptr) {
|
|
||||||
if(!GLAD_VK_EXT_debug_report) return;
|
|
||||||
vkCreateDebugReportCallbackEXT = (PFN_vkCreateDebugReportCallbackEXT) load("vkCreateDebugReportCallbackEXT", userptr);
|
|
||||||
vkDebugReportMessageEXT = (PFN_vkDebugReportMessageEXT) load("vkDebugReportMessageEXT", userptr);
|
|
||||||
vkDestroyDebugReportCallbackEXT = (PFN_vkDestroyDebugReportCallbackEXT) load("vkDestroyDebugReportCallbackEXT", userptr);
|
|
||||||
}
|
|
||||||
static void glad_vk_load_VK_KHR_surface( GLADuserptrloadfunc load, void* userptr) {
|
|
||||||
if(!GLAD_VK_KHR_surface) return;
|
|
||||||
vkDestroySurfaceKHR = (PFN_vkDestroySurfaceKHR) load("vkDestroySurfaceKHR", userptr);
|
|
||||||
vkGetPhysicalDeviceSurfaceCapabilitiesKHR = (PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR) load("vkGetPhysicalDeviceSurfaceCapabilitiesKHR", userptr);
|
|
||||||
vkGetPhysicalDeviceSurfaceFormatsKHR = (PFN_vkGetPhysicalDeviceSurfaceFormatsKHR) load("vkGetPhysicalDeviceSurfaceFormatsKHR", userptr);
|
|
||||||
vkGetPhysicalDeviceSurfacePresentModesKHR = (PFN_vkGetPhysicalDeviceSurfacePresentModesKHR) load("vkGetPhysicalDeviceSurfacePresentModesKHR", userptr);
|
|
||||||
vkGetPhysicalDeviceSurfaceSupportKHR = (PFN_vkGetPhysicalDeviceSurfaceSupportKHR) load("vkGetPhysicalDeviceSurfaceSupportKHR", userptr);
|
|
||||||
}
|
|
||||||
static void glad_vk_load_VK_KHR_swapchain( GLADuserptrloadfunc load, void* userptr) {
|
|
||||||
if(!GLAD_VK_KHR_swapchain) return;
|
|
||||||
vkAcquireNextImage2KHR = (PFN_vkAcquireNextImage2KHR) load("vkAcquireNextImage2KHR", userptr);
|
|
||||||
vkAcquireNextImageKHR = (PFN_vkAcquireNextImageKHR) load("vkAcquireNextImageKHR", userptr);
|
|
||||||
vkCreateSwapchainKHR = (PFN_vkCreateSwapchainKHR) load("vkCreateSwapchainKHR", userptr);
|
|
||||||
vkDestroySwapchainKHR = (PFN_vkDestroySwapchainKHR) load("vkDestroySwapchainKHR", userptr);
|
|
||||||
vkGetDeviceGroupPresentCapabilitiesKHR = (PFN_vkGetDeviceGroupPresentCapabilitiesKHR) load("vkGetDeviceGroupPresentCapabilitiesKHR", userptr);
|
|
||||||
vkGetDeviceGroupSurfacePresentModesKHR = (PFN_vkGetDeviceGroupSurfacePresentModesKHR) load("vkGetDeviceGroupSurfacePresentModesKHR", userptr);
|
|
||||||
vkGetPhysicalDevicePresentRectanglesKHR = (PFN_vkGetPhysicalDevicePresentRectanglesKHR) load("vkGetPhysicalDevicePresentRectanglesKHR", userptr);
|
|
||||||
vkGetSwapchainImagesKHR = (PFN_vkGetSwapchainImagesKHR) load("vkGetSwapchainImagesKHR", userptr);
|
|
||||||
vkQueuePresentKHR = (PFN_vkQueuePresentKHR) load("vkQueuePresentKHR", userptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static int glad_vk_get_extensions( VkPhysicalDevice physical_device, uint32_t *out_extension_count, char ***out_extensions) {
|
|
||||||
uint32_t i;
|
|
||||||
uint32_t instance_extension_count = 0;
|
|
||||||
uint32_t device_extension_count = 0;
|
|
||||||
uint32_t max_extension_count;
|
|
||||||
uint32_t total_extension_count;
|
|
||||||
char **extensions;
|
|
||||||
VkExtensionProperties *ext_properties;
|
|
||||||
VkResult result;
|
|
||||||
|
|
||||||
if (vkEnumerateInstanceExtensionProperties == NULL || (physical_device != NULL && vkEnumerateDeviceExtensionProperties == NULL)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
result = vkEnumerateInstanceExtensionProperties(NULL, &instance_extension_count, NULL);
|
|
||||||
if (result != VK_SUCCESS) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (physical_device != NULL) {
|
|
||||||
result = vkEnumerateDeviceExtensionProperties(physical_device, NULL, &device_extension_count, NULL);
|
|
||||||
if (result != VK_SUCCESS) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
total_extension_count = instance_extension_count + device_extension_count;
|
|
||||||
max_extension_count = instance_extension_count > device_extension_count
|
|
||||||
? instance_extension_count : device_extension_count;
|
|
||||||
|
|
||||||
ext_properties = (VkExtensionProperties*) malloc(max_extension_count * sizeof(VkExtensionProperties));
|
|
||||||
if (ext_properties == NULL) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
result = vkEnumerateInstanceExtensionProperties(NULL, &instance_extension_count, ext_properties);
|
|
||||||
if (result != VK_SUCCESS) {
|
|
||||||
free((void*) ext_properties);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
extensions = (char**) calloc(total_extension_count, sizeof(char*));
|
|
||||||
if (extensions == NULL) {
|
|
||||||
free((void*) ext_properties);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < instance_extension_count; ++i) {
|
|
||||||
VkExtensionProperties ext = ext_properties[i];
|
|
||||||
|
|
||||||
size_t extension_name_length = strlen(ext.extensionName) + 1;
|
|
||||||
extensions[i] = (char*) malloc(extension_name_length * sizeof(char));
|
|
||||||
memcpy(extensions[i], ext.extensionName, extension_name_length * sizeof(char));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (physical_device != NULL) {
|
|
||||||
result = vkEnumerateDeviceExtensionProperties(physical_device, NULL, &device_extension_count, ext_properties);
|
|
||||||
if (result != VK_SUCCESS) {
|
|
||||||
for (i = 0; i < instance_extension_count; ++i) {
|
|
||||||
free((void*) extensions[i]);
|
|
||||||
}
|
|
||||||
free(extensions);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < device_extension_count; ++i) {
|
|
||||||
VkExtensionProperties ext = ext_properties[i];
|
|
||||||
|
|
||||||
size_t extension_name_length = strlen(ext.extensionName) + 1;
|
|
||||||
extensions[instance_extension_count + i] = (char*) malloc(extension_name_length * sizeof(char));
|
|
||||||
memcpy(extensions[instance_extension_count + i], ext.extensionName, extension_name_length * sizeof(char));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
free((void*) ext_properties);
|
|
||||||
|
|
||||||
*out_extension_count = total_extension_count;
|
|
||||||
*out_extensions = extensions;
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void glad_vk_free_extensions(uint32_t extension_count, char **extensions) {
|
|
||||||
uint32_t i;
|
|
||||||
|
|
||||||
for(i = 0; i < extension_count ; ++i) {
|
|
||||||
free((void*) (extensions[i]));
|
|
||||||
}
|
|
||||||
|
|
||||||
free((void*) extensions);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int glad_vk_has_extension(const char *name, uint32_t extension_count, char **extensions) {
|
|
||||||
uint32_t i;
|
|
||||||
|
|
||||||
for (i = 0; i < extension_count; ++i) {
|
|
||||||
if(strcmp(name, extensions[i]) == 0) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static GLADapiproc glad_vk_get_proc_from_userptr(const char* name, void *userptr) {
|
|
||||||
return (GLAD_GNUC_EXTENSION (GLADapiproc (*)(const char *name)) userptr)(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int glad_vk_find_extensions_vulkan( VkPhysicalDevice physical_device) {
|
|
||||||
uint32_t extension_count = 0;
|
|
||||||
char **extensions = NULL;
|
|
||||||
if (!glad_vk_get_extensions(physical_device, &extension_count, &extensions)) return 0;
|
|
||||||
|
|
||||||
GLAD_VK_EXT_debug_report = glad_vk_has_extension("VK_EXT_debug_report", extension_count, extensions);
|
|
||||||
GLAD_VK_KHR_surface = glad_vk_has_extension("VK_KHR_surface", extension_count, extensions);
|
|
||||||
GLAD_VK_KHR_swapchain = glad_vk_has_extension("VK_KHR_swapchain", extension_count, extensions);
|
|
||||||
|
|
||||||
glad_vk_free_extensions(extension_count, extensions);
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int glad_vk_find_core_vulkan( VkPhysicalDevice physical_device) {
|
|
||||||
int major = 1;
|
|
||||||
int minor = 0;
|
|
||||||
|
|
||||||
#ifdef VK_VERSION_1_1
|
|
||||||
if (vkEnumerateInstanceVersion != NULL) {
|
|
||||||
uint32_t version;
|
|
||||||
VkResult result;
|
|
||||||
|
|
||||||
result = vkEnumerateInstanceVersion(&version);
|
|
||||||
if (result == VK_SUCCESS) {
|
|
||||||
major = (int) VK_VERSION_MAJOR(version);
|
|
||||||
minor = (int) VK_VERSION_MINOR(version);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (physical_device != NULL && vkGetPhysicalDeviceProperties != NULL) {
|
|
||||||
VkPhysicalDeviceProperties properties;
|
|
||||||
vkGetPhysicalDeviceProperties(physical_device, &properties);
|
|
||||||
|
|
||||||
major = (int) VK_VERSION_MAJOR(properties.apiVersion);
|
|
||||||
minor = (int) VK_VERSION_MINOR(properties.apiVersion);
|
|
||||||
}
|
|
||||||
|
|
||||||
GLAD_VK_VERSION_1_0 = (major == 1 && minor >= 0) || major > 1;
|
|
||||||
GLAD_VK_VERSION_1_1 = (major == 1 && minor >= 1) || major > 1;
|
|
||||||
|
|
||||||
return GLAD_MAKE_VERSION(major, minor);
|
|
||||||
}
|
|
||||||
|
|
||||||
int gladLoadVulkanUserPtr( VkPhysicalDevice physical_device, GLADuserptrloadfunc load, void *userptr) {
|
|
||||||
int version;
|
|
||||||
|
|
||||||
#ifdef VK_VERSION_1_1
|
|
||||||
vkEnumerateInstanceVersion = (PFN_vkEnumerateInstanceVersion) load("vkEnumerateInstanceVersion", userptr);
|
|
||||||
#endif
|
|
||||||
version = glad_vk_find_core_vulkan( physical_device);
|
|
||||||
if (!version) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
glad_vk_load_VK_VERSION_1_0(load, userptr);
|
|
||||||
glad_vk_load_VK_VERSION_1_1(load, userptr);
|
|
||||||
|
|
||||||
if (!glad_vk_find_extensions_vulkan( physical_device)) return 0;
|
|
||||||
glad_vk_load_VK_EXT_debug_report(load, userptr);
|
|
||||||
glad_vk_load_VK_KHR_surface(load, userptr);
|
|
||||||
glad_vk_load_VK_KHR_swapchain(load, userptr);
|
|
||||||
|
|
||||||
|
|
||||||
return version;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int gladLoadVulkan( VkPhysicalDevice physical_device, GLADloadfunc load) {
|
|
||||||
return gladLoadVulkanUserPtr( physical_device, glad_vk_get_proc_from_userptr, GLAD_GNUC_EXTENSION (void*) load);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,574 +0,0 @@
|
|||||||
#ifndef LINMATH_H
|
|
||||||
#define LINMATH_H
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
#define inline __inline
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define LINMATH_H_DEFINE_VEC(n) \
|
|
||||||
typedef float vec##n[n]; \
|
|
||||||
static inline void vec##n##_add(vec##n r, vec##n const a, vec##n const b) \
|
|
||||||
{ \
|
|
||||||
int i; \
|
|
||||||
for(i=0; i<n; ++i) \
|
|
||||||
r[i] = a[i] + b[i]; \
|
|
||||||
} \
|
|
||||||
static inline void vec##n##_sub(vec##n r, vec##n const a, vec##n const b) \
|
|
||||||
{ \
|
|
||||||
int i; \
|
|
||||||
for(i=0; i<n; ++i) \
|
|
||||||
r[i] = a[i] - b[i]; \
|
|
||||||
} \
|
|
||||||
static inline void vec##n##_scale(vec##n r, vec##n const v, float const s) \
|
|
||||||
{ \
|
|
||||||
int i; \
|
|
||||||
for(i=0; i<n; ++i) \
|
|
||||||
r[i] = v[i] * s; \
|
|
||||||
} \
|
|
||||||
static inline float vec##n##_mul_inner(vec##n const a, vec##n const b) \
|
|
||||||
{ \
|
|
||||||
float p = 0.; \
|
|
||||||
int i; \
|
|
||||||
for(i=0; i<n; ++i) \
|
|
||||||
p += b[i]*a[i]; \
|
|
||||||
return p; \
|
|
||||||
} \
|
|
||||||
static inline float vec##n##_len(vec##n const v) \
|
|
||||||
{ \
|
|
||||||
return (float) sqrt(vec##n##_mul_inner(v,v)); \
|
|
||||||
} \
|
|
||||||
static inline void vec##n##_norm(vec##n r, vec##n const v) \
|
|
||||||
{ \
|
|
||||||
float k = 1.f / vec##n##_len(v); \
|
|
||||||
vec##n##_scale(r, v, k); \
|
|
||||||
}
|
|
||||||
|
|
||||||
LINMATH_H_DEFINE_VEC(2)
|
|
||||||
LINMATH_H_DEFINE_VEC(3)
|
|
||||||
LINMATH_H_DEFINE_VEC(4)
|
|
||||||
|
|
||||||
static inline void vec3_mul_cross(vec3 r, vec3 const a, vec3 const b)
|
|
||||||
{
|
|
||||||
r[0] = a[1]*b[2] - a[2]*b[1];
|
|
||||||
r[1] = a[2]*b[0] - a[0]*b[2];
|
|
||||||
r[2] = a[0]*b[1] - a[1]*b[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void vec3_reflect(vec3 r, vec3 const v, vec3 const n)
|
|
||||||
{
|
|
||||||
float p = 2.f*vec3_mul_inner(v, n);
|
|
||||||
int i;
|
|
||||||
for(i=0;i<3;++i)
|
|
||||||
r[i] = v[i] - p*n[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void vec4_mul_cross(vec4 r, vec4 a, vec4 b)
|
|
||||||
{
|
|
||||||
r[0] = a[1]*b[2] - a[2]*b[1];
|
|
||||||
r[1] = a[2]*b[0] - a[0]*b[2];
|
|
||||||
r[2] = a[0]*b[1] - a[1]*b[0];
|
|
||||||
r[3] = 1.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void vec4_reflect(vec4 r, vec4 v, vec4 n)
|
|
||||||
{
|
|
||||||
float p = 2.f*vec4_mul_inner(v, n);
|
|
||||||
int i;
|
|
||||||
for(i=0;i<4;++i)
|
|
||||||
r[i] = v[i] - p*n[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef vec4 mat4x4[4];
|
|
||||||
static inline void mat4x4_identity(mat4x4 M)
|
|
||||||
{
|
|
||||||
int i, j;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
for(j=0; j<4; ++j)
|
|
||||||
M[i][j] = i==j ? 1.f : 0.f;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_dup(mat4x4 M, mat4x4 N)
|
|
||||||
{
|
|
||||||
int i, j;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
for(j=0; j<4; ++j)
|
|
||||||
M[i][j] = N[i][j];
|
|
||||||
}
|
|
||||||
static inline void mat4x4_row(vec4 r, mat4x4 M, int i)
|
|
||||||
{
|
|
||||||
int k;
|
|
||||||
for(k=0; k<4; ++k)
|
|
||||||
r[k] = M[k][i];
|
|
||||||
}
|
|
||||||
static inline void mat4x4_col(vec4 r, mat4x4 M, int i)
|
|
||||||
{
|
|
||||||
int k;
|
|
||||||
for(k=0; k<4; ++k)
|
|
||||||
r[k] = M[i][k];
|
|
||||||
}
|
|
||||||
static inline void mat4x4_transpose(mat4x4 M, mat4x4 N)
|
|
||||||
{
|
|
||||||
int i, j;
|
|
||||||
for(j=0; j<4; ++j)
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
M[i][j] = N[j][i];
|
|
||||||
}
|
|
||||||
static inline void mat4x4_add(mat4x4 M, mat4x4 a, mat4x4 b)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
vec4_add(M[i], a[i], b[i]);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_sub(mat4x4 M, mat4x4 a, mat4x4 b)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
vec4_sub(M[i], a[i], b[i]);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_scale(mat4x4 M, mat4x4 a, float k)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
vec4_scale(M[i], a[i], k);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_scale_aniso(mat4x4 M, mat4x4 a, float x, float y, float z)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
vec4_scale(M[0], a[0], x);
|
|
||||||
vec4_scale(M[1], a[1], y);
|
|
||||||
vec4_scale(M[2], a[2], z);
|
|
||||||
for(i = 0; i < 4; ++i) {
|
|
||||||
M[3][i] = a[3][i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
static inline void mat4x4_mul(mat4x4 M, mat4x4 a, mat4x4 b)
|
|
||||||
{
|
|
||||||
mat4x4 temp;
|
|
||||||
int k, r, c;
|
|
||||||
for(c=0; c<4; ++c) for(r=0; r<4; ++r) {
|
|
||||||
temp[c][r] = 0.f;
|
|
||||||
for(k=0; k<4; ++k)
|
|
||||||
temp[c][r] += a[k][r] * b[c][k];
|
|
||||||
}
|
|
||||||
mat4x4_dup(M, temp);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_mul_vec4(vec4 r, mat4x4 M, vec4 v)
|
|
||||||
{
|
|
||||||
int i, j;
|
|
||||||
for(j=0; j<4; ++j) {
|
|
||||||
r[j] = 0.f;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
r[j] += M[i][j] * v[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
static inline void mat4x4_translate(mat4x4 T, float x, float y, float z)
|
|
||||||
{
|
|
||||||
mat4x4_identity(T);
|
|
||||||
T[3][0] = x;
|
|
||||||
T[3][1] = y;
|
|
||||||
T[3][2] = z;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_translate_in_place(mat4x4 M, float x, float y, float z)
|
|
||||||
{
|
|
||||||
vec4 t = {x, y, z, 0};
|
|
||||||
vec4 r;
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < 4; ++i) {
|
|
||||||
mat4x4_row(r, M, i);
|
|
||||||
M[3][i] += vec4_mul_inner(r, t);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
static inline void mat4x4_from_vec3_mul_outer(mat4x4 M, vec3 a, vec3 b)
|
|
||||||
{
|
|
||||||
int i, j;
|
|
||||||
for(i=0; i<4; ++i) for(j=0; j<4; ++j)
|
|
||||||
M[i][j] = i<3 && j<3 ? a[i] * b[j] : 0.f;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_rotate(mat4x4 R, mat4x4 M, float x, float y, float z, float angle)
|
|
||||||
{
|
|
||||||
float s = sinf(angle);
|
|
||||||
float c = cosf(angle);
|
|
||||||
vec3 u = {x, y, z};
|
|
||||||
|
|
||||||
if(vec3_len(u) > 1e-4) {
|
|
||||||
mat4x4 T, C, S = {{0}};
|
|
||||||
|
|
||||||
vec3_norm(u, u);
|
|
||||||
mat4x4_from_vec3_mul_outer(T, u, u);
|
|
||||||
|
|
||||||
S[1][2] = u[0];
|
|
||||||
S[2][1] = -u[0];
|
|
||||||
S[2][0] = u[1];
|
|
||||||
S[0][2] = -u[1];
|
|
||||||
S[0][1] = u[2];
|
|
||||||
S[1][0] = -u[2];
|
|
||||||
|
|
||||||
mat4x4_scale(S, S, s);
|
|
||||||
|
|
||||||
mat4x4_identity(C);
|
|
||||||
mat4x4_sub(C, C, T);
|
|
||||||
|
|
||||||
mat4x4_scale(C, C, c);
|
|
||||||
|
|
||||||
mat4x4_add(T, T, C);
|
|
||||||
mat4x4_add(T, T, S);
|
|
||||||
|
|
||||||
T[3][3] = 1.;
|
|
||||||
mat4x4_mul(R, M, T);
|
|
||||||
} else {
|
|
||||||
mat4x4_dup(R, M);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
static inline void mat4x4_rotate_X(mat4x4 Q, mat4x4 M, float angle)
|
|
||||||
{
|
|
||||||
float s = sinf(angle);
|
|
||||||
float c = cosf(angle);
|
|
||||||
mat4x4 R = {
|
|
||||||
{1.f, 0.f, 0.f, 0.f},
|
|
||||||
{0.f, c, s, 0.f},
|
|
||||||
{0.f, -s, c, 0.f},
|
|
||||||
{0.f, 0.f, 0.f, 1.f}
|
|
||||||
};
|
|
||||||
mat4x4_mul(Q, M, R);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_rotate_Y(mat4x4 Q, mat4x4 M, float angle)
|
|
||||||
{
|
|
||||||
float s = sinf(angle);
|
|
||||||
float c = cosf(angle);
|
|
||||||
mat4x4 R = {
|
|
||||||
{ c, 0.f, -s, 0.f},
|
|
||||||
{ 0.f, 1.f, 0.f, 0.f},
|
|
||||||
{ s, 0.f, c, 0.f},
|
|
||||||
{ 0.f, 0.f, 0.f, 1.f}
|
|
||||||
};
|
|
||||||
mat4x4_mul(Q, M, R);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_rotate_Z(mat4x4 Q, mat4x4 M, float angle)
|
|
||||||
{
|
|
||||||
float s = sinf(angle);
|
|
||||||
float c = cosf(angle);
|
|
||||||
mat4x4 R = {
|
|
||||||
{ c, s, 0.f, 0.f},
|
|
||||||
{ -s, c, 0.f, 0.f},
|
|
||||||
{ 0.f, 0.f, 1.f, 0.f},
|
|
||||||
{ 0.f, 0.f, 0.f, 1.f}
|
|
||||||
};
|
|
||||||
mat4x4_mul(Q, M, R);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_invert(mat4x4 T, mat4x4 M)
|
|
||||||
{
|
|
||||||
float idet;
|
|
||||||
float s[6];
|
|
||||||
float c[6];
|
|
||||||
s[0] = M[0][0]*M[1][1] - M[1][0]*M[0][1];
|
|
||||||
s[1] = M[0][0]*M[1][2] - M[1][0]*M[0][2];
|
|
||||||
s[2] = M[0][0]*M[1][3] - M[1][0]*M[0][3];
|
|
||||||
s[3] = M[0][1]*M[1][2] - M[1][1]*M[0][2];
|
|
||||||
s[4] = M[0][1]*M[1][3] - M[1][1]*M[0][3];
|
|
||||||
s[5] = M[0][2]*M[1][3] - M[1][2]*M[0][3];
|
|
||||||
|
|
||||||
c[0] = M[2][0]*M[3][1] - M[3][0]*M[2][1];
|
|
||||||
c[1] = M[2][0]*M[3][2] - M[3][0]*M[2][2];
|
|
||||||
c[2] = M[2][0]*M[3][3] - M[3][0]*M[2][3];
|
|
||||||
c[3] = M[2][1]*M[3][2] - M[3][1]*M[2][2];
|
|
||||||
c[4] = M[2][1]*M[3][3] - M[3][1]*M[2][3];
|
|
||||||
c[5] = M[2][2]*M[3][3] - M[3][2]*M[2][3];
|
|
||||||
|
|
||||||
/* Assumes it is invertible */
|
|
||||||
idet = 1.0f/( s[0]*c[5]-s[1]*c[4]+s[2]*c[3]+s[3]*c[2]-s[4]*c[1]+s[5]*c[0] );
|
|
||||||
|
|
||||||
T[0][0] = ( M[1][1] * c[5] - M[1][2] * c[4] + M[1][3] * c[3]) * idet;
|
|
||||||
T[0][1] = (-M[0][1] * c[5] + M[0][2] * c[4] - M[0][3] * c[3]) * idet;
|
|
||||||
T[0][2] = ( M[3][1] * s[5] - M[3][2] * s[4] + M[3][3] * s[3]) * idet;
|
|
||||||
T[0][3] = (-M[2][1] * s[5] + M[2][2] * s[4] - M[2][3] * s[3]) * idet;
|
|
||||||
|
|
||||||
T[1][0] = (-M[1][0] * c[5] + M[1][2] * c[2] - M[1][3] * c[1]) * idet;
|
|
||||||
T[1][1] = ( M[0][0] * c[5] - M[0][2] * c[2] + M[0][3] * c[1]) * idet;
|
|
||||||
T[1][2] = (-M[3][0] * s[5] + M[3][2] * s[2] - M[3][3] * s[1]) * idet;
|
|
||||||
T[1][3] = ( M[2][0] * s[5] - M[2][2] * s[2] + M[2][3] * s[1]) * idet;
|
|
||||||
|
|
||||||
T[2][0] = ( M[1][0] * c[4] - M[1][1] * c[2] + M[1][3] * c[0]) * idet;
|
|
||||||
T[2][1] = (-M[0][0] * c[4] + M[0][1] * c[2] - M[0][3] * c[0]) * idet;
|
|
||||||
T[2][2] = ( M[3][0] * s[4] - M[3][1] * s[2] + M[3][3] * s[0]) * idet;
|
|
||||||
T[2][3] = (-M[2][0] * s[4] + M[2][1] * s[2] - M[2][3] * s[0]) * idet;
|
|
||||||
|
|
||||||
T[3][0] = (-M[1][0] * c[3] + M[1][1] * c[1] - M[1][2] * c[0]) * idet;
|
|
||||||
T[3][1] = ( M[0][0] * c[3] - M[0][1] * c[1] + M[0][2] * c[0]) * idet;
|
|
||||||
T[3][2] = (-M[3][0] * s[3] + M[3][1] * s[1] - M[3][2] * s[0]) * idet;
|
|
||||||
T[3][3] = ( M[2][0] * s[3] - M[2][1] * s[1] + M[2][2] * s[0]) * idet;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_orthonormalize(mat4x4 R, mat4x4 M)
|
|
||||||
{
|
|
||||||
float s = 1.;
|
|
||||||
vec3 h;
|
|
||||||
|
|
||||||
mat4x4_dup(R, M);
|
|
||||||
vec3_norm(R[2], R[2]);
|
|
||||||
|
|
||||||
s = vec3_mul_inner(R[1], R[2]);
|
|
||||||
vec3_scale(h, R[2], s);
|
|
||||||
vec3_sub(R[1], R[1], h);
|
|
||||||
vec3_norm(R[2], R[2]);
|
|
||||||
|
|
||||||
s = vec3_mul_inner(R[1], R[2]);
|
|
||||||
vec3_scale(h, R[2], s);
|
|
||||||
vec3_sub(R[1], R[1], h);
|
|
||||||
vec3_norm(R[1], R[1]);
|
|
||||||
|
|
||||||
s = vec3_mul_inner(R[0], R[1]);
|
|
||||||
vec3_scale(h, R[1], s);
|
|
||||||
vec3_sub(R[0], R[0], h);
|
|
||||||
vec3_norm(R[0], R[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void mat4x4_frustum(mat4x4 M, float l, float r, float b, float t, float n, float f)
|
|
||||||
{
|
|
||||||
M[0][0] = 2.f*n/(r-l);
|
|
||||||
M[0][1] = M[0][2] = M[0][3] = 0.f;
|
|
||||||
|
|
||||||
M[1][1] = 2.f*n/(t-b);
|
|
||||||
M[1][0] = M[1][2] = M[1][3] = 0.f;
|
|
||||||
|
|
||||||
M[2][0] = (r+l)/(r-l);
|
|
||||||
M[2][1] = (t+b)/(t-b);
|
|
||||||
M[2][2] = -(f+n)/(f-n);
|
|
||||||
M[2][3] = -1.f;
|
|
||||||
|
|
||||||
M[3][2] = -2.f*(f*n)/(f-n);
|
|
||||||
M[3][0] = M[3][1] = M[3][3] = 0.f;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_ortho(mat4x4 M, float l, float r, float b, float t, float n, float f)
|
|
||||||
{
|
|
||||||
M[0][0] = 2.f/(r-l);
|
|
||||||
M[0][1] = M[0][2] = M[0][3] = 0.f;
|
|
||||||
|
|
||||||
M[1][1] = 2.f/(t-b);
|
|
||||||
M[1][0] = M[1][2] = M[1][3] = 0.f;
|
|
||||||
|
|
||||||
M[2][2] = -2.f/(f-n);
|
|
||||||
M[2][0] = M[2][1] = M[2][3] = 0.f;
|
|
||||||
|
|
||||||
M[3][0] = -(r+l)/(r-l);
|
|
||||||
M[3][1] = -(t+b)/(t-b);
|
|
||||||
M[3][2] = -(f+n)/(f-n);
|
|
||||||
M[3][3] = 1.f;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_perspective(mat4x4 m, float y_fov, float aspect, float n, float f)
|
|
||||||
{
|
|
||||||
/* NOTE: Degrees are an unhandy unit to work with.
|
|
||||||
* linmath.h uses radians for everything! */
|
|
||||||
float const a = 1.f / (float) tan(y_fov / 2.f);
|
|
||||||
|
|
||||||
m[0][0] = a / aspect;
|
|
||||||
m[0][1] = 0.f;
|
|
||||||
m[0][2] = 0.f;
|
|
||||||
m[0][3] = 0.f;
|
|
||||||
|
|
||||||
m[1][0] = 0.f;
|
|
||||||
m[1][1] = a;
|
|
||||||
m[1][2] = 0.f;
|
|
||||||
m[1][3] = 0.f;
|
|
||||||
|
|
||||||
m[2][0] = 0.f;
|
|
||||||
m[2][1] = 0.f;
|
|
||||||
m[2][2] = -((f + n) / (f - n));
|
|
||||||
m[2][3] = -1.f;
|
|
||||||
|
|
||||||
m[3][0] = 0.f;
|
|
||||||
m[3][1] = 0.f;
|
|
||||||
m[3][2] = -((2.f * f * n) / (f - n));
|
|
||||||
m[3][3] = 0.f;
|
|
||||||
}
|
|
||||||
static inline void mat4x4_look_at(mat4x4 m, vec3 eye, vec3 center, vec3 up)
|
|
||||||
{
|
|
||||||
/* Adapted from Android's OpenGL Matrix.java. */
|
|
||||||
/* See the OpenGL GLUT documentation for gluLookAt for a description */
|
|
||||||
/* of the algorithm. We implement it in a straightforward way: */
|
|
||||||
|
|
||||||
/* TODO: The negation of of can be spared by swapping the order of
|
|
||||||
* operands in the following cross products in the right way. */
|
|
||||||
vec3 f;
|
|
||||||
vec3 s;
|
|
||||||
vec3 t;
|
|
||||||
|
|
||||||
vec3_sub(f, center, eye);
|
|
||||||
vec3_norm(f, f);
|
|
||||||
|
|
||||||
vec3_mul_cross(s, f, up);
|
|
||||||
vec3_norm(s, s);
|
|
||||||
|
|
||||||
vec3_mul_cross(t, s, f);
|
|
||||||
|
|
||||||
m[0][0] = s[0];
|
|
||||||
m[0][1] = t[0];
|
|
||||||
m[0][2] = -f[0];
|
|
||||||
m[0][3] = 0.f;
|
|
||||||
|
|
||||||
m[1][0] = s[1];
|
|
||||||
m[1][1] = t[1];
|
|
||||||
m[1][2] = -f[1];
|
|
||||||
m[1][3] = 0.f;
|
|
||||||
|
|
||||||
m[2][0] = s[2];
|
|
||||||
m[2][1] = t[2];
|
|
||||||
m[2][2] = -f[2];
|
|
||||||
m[2][3] = 0.f;
|
|
||||||
|
|
||||||
m[3][0] = 0.f;
|
|
||||||
m[3][1] = 0.f;
|
|
||||||
m[3][2] = 0.f;
|
|
||||||
m[3][3] = 1.f;
|
|
||||||
|
|
||||||
mat4x4_translate_in_place(m, -eye[0], -eye[1], -eye[2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef float quat[4];
|
|
||||||
static inline void quat_identity(quat q)
|
|
||||||
{
|
|
||||||
q[0] = q[1] = q[2] = 0.f;
|
|
||||||
q[3] = 1.f;
|
|
||||||
}
|
|
||||||
static inline void quat_add(quat r, quat a, quat b)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
r[i] = a[i] + b[i];
|
|
||||||
}
|
|
||||||
static inline void quat_sub(quat r, quat a, quat b)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
r[i] = a[i] - b[i];
|
|
||||||
}
|
|
||||||
static inline void quat_mul(quat r, quat p, quat q)
|
|
||||||
{
|
|
||||||
vec3 w;
|
|
||||||
vec3_mul_cross(r, p, q);
|
|
||||||
vec3_scale(w, p, q[3]);
|
|
||||||
vec3_add(r, r, w);
|
|
||||||
vec3_scale(w, q, p[3]);
|
|
||||||
vec3_add(r, r, w);
|
|
||||||
r[3] = p[3]*q[3] - vec3_mul_inner(p, q);
|
|
||||||
}
|
|
||||||
static inline void quat_scale(quat r, quat v, float s)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
r[i] = v[i] * s;
|
|
||||||
}
|
|
||||||
static inline float quat_inner_product(quat a, quat b)
|
|
||||||
{
|
|
||||||
float p = 0.f;
|
|
||||||
int i;
|
|
||||||
for(i=0; i<4; ++i)
|
|
||||||
p += b[i]*a[i];
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
static inline void quat_conj(quat r, quat q)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for(i=0; i<3; ++i)
|
|
||||||
r[i] = -q[i];
|
|
||||||
r[3] = q[3];
|
|
||||||
}
|
|
||||||
static inline void quat_rotate(quat r, float angle, vec3 axis) {
|
|
||||||
int i;
|
|
||||||
vec3 v;
|
|
||||||
vec3_scale(v, axis, sinf(angle / 2));
|
|
||||||
for(i=0; i<3; ++i)
|
|
||||||
r[i] = v[i];
|
|
||||||
r[3] = cosf(angle / 2);
|
|
||||||
}
|
|
||||||
#define quat_norm vec4_norm
|
|
||||||
static inline void quat_mul_vec3(vec3 r, quat q, vec3 v)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* Method by Fabian 'ryg' Giessen (of Farbrausch)
|
|
||||||
t = 2 * cross(q.xyz, v)
|
|
||||||
v' = v + q.w * t + cross(q.xyz, t)
|
|
||||||
*/
|
|
||||||
vec3 t = {q[0], q[1], q[2]};
|
|
||||||
vec3 u = {q[0], q[1], q[2]};
|
|
||||||
|
|
||||||
vec3_mul_cross(t, t, v);
|
|
||||||
vec3_scale(t, t, 2);
|
|
||||||
|
|
||||||
vec3_mul_cross(u, u, t);
|
|
||||||
vec3_scale(t, t, q[3]);
|
|
||||||
|
|
||||||
vec3_add(r, v, t);
|
|
||||||
vec3_add(r, r, u);
|
|
||||||
}
|
|
||||||
static inline void mat4x4_from_quat(mat4x4 M, quat q)
|
|
||||||
{
|
|
||||||
float a = q[3];
|
|
||||||
float b = q[0];
|
|
||||||
float c = q[1];
|
|
||||||
float d = q[2];
|
|
||||||
float a2 = a*a;
|
|
||||||
float b2 = b*b;
|
|
||||||
float c2 = c*c;
|
|
||||||
float d2 = d*d;
|
|
||||||
|
|
||||||
M[0][0] = a2 + b2 - c2 - d2;
|
|
||||||
M[0][1] = 2.f*(b*c + a*d);
|
|
||||||
M[0][2] = 2.f*(b*d - a*c);
|
|
||||||
M[0][3] = 0.f;
|
|
||||||
|
|
||||||
M[1][0] = 2*(b*c - a*d);
|
|
||||||
M[1][1] = a2 - b2 + c2 - d2;
|
|
||||||
M[1][2] = 2.f*(c*d + a*b);
|
|
||||||
M[1][3] = 0.f;
|
|
||||||
|
|
||||||
M[2][0] = 2.f*(b*d + a*c);
|
|
||||||
M[2][1] = 2.f*(c*d - a*b);
|
|
||||||
M[2][2] = a2 - b2 - c2 + d2;
|
|
||||||
M[2][3] = 0.f;
|
|
||||||
|
|
||||||
M[3][0] = M[3][1] = M[3][2] = 0.f;
|
|
||||||
M[3][3] = 1.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void mat4x4o_mul_quat(mat4x4 R, mat4x4 M, quat q)
|
|
||||||
{
|
|
||||||
/* XXX: The way this is written only works for othogonal matrices. */
|
|
||||||
/* TODO: Take care of non-orthogonal case. */
|
|
||||||
quat_mul_vec3(R[0], q, M[0]);
|
|
||||||
quat_mul_vec3(R[1], q, M[1]);
|
|
||||||
quat_mul_vec3(R[2], q, M[2]);
|
|
||||||
|
|
||||||
R[3][0] = R[3][1] = R[3][2] = 0.f;
|
|
||||||
R[3][3] = 1.f;
|
|
||||||
}
|
|
||||||
static inline void quat_from_mat4x4(quat q, mat4x4 M)
|
|
||||||
{
|
|
||||||
float r=0.f;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
int perm[] = { 0, 1, 2, 0, 1 };
|
|
||||||
int *p = perm;
|
|
||||||
|
|
||||||
for(i = 0; i<3; i++) {
|
|
||||||
float m = M[i][i];
|
|
||||||
if( m < r )
|
|
||||||
continue;
|
|
||||||
m = r;
|
|
||||||
p = &perm[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
r = (float) sqrt(1.f + M[p[0]][p[0]] - M[p[1]][p[1]] - M[p[2]][p[2]] );
|
|
||||||
|
|
||||||
if(r < 1e-6) {
|
|
||||||
q[0] = 1.f;
|
|
||||||
q[1] = q[2] = q[3] = 0.f;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
q[0] = r/2.f;
|
|
||||||
q[1] = (M[p[0]][p[1]] - M[p[1]][p[0]])/(2.f*r);
|
|
||||||
q[2] = (M[p[2]][p[0]] - M[p[0]][p[2]])/(2.f*r);
|
|
||||||
q[3] = (M[p[2]][p[1]] - M[p[1]][p[2]])/(2.f*r);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,117 +0,0 @@
|
|||||||
/**
|
|
||||||
* This file has no copyright assigned and is placed in the Public Domain.
|
|
||||||
* This file is part of the mingw-w64 runtime package.
|
|
||||||
* No warranty is given; refer to the file DISCLAIMER within this package.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(_MSC_VER) && !defined(_MSC_EXTENSIONS)
|
|
||||||
#define NONAMELESSUNION 1
|
|
||||||
#endif
|
|
||||||
#if defined(NONAMELESSSTRUCT) && \
|
|
||||||
!defined(NONAMELESSUNION)
|
|
||||||
#define NONAMELESSUNION 1
|
|
||||||
#endif
|
|
||||||
#if defined(NONAMELESSUNION) && \
|
|
||||||
!defined(NONAMELESSSTRUCT)
|
|
||||||
#define NONAMELESSSTRUCT 1
|
|
||||||
#endif
|
|
||||||
#if !defined(__GNU_EXTENSION)
|
|
||||||
#if defined(__GNUC__) || defined(__GNUG__)
|
|
||||||
#define __GNU_EXTENSION __extension__
|
|
||||||
#else
|
|
||||||
#define __GNU_EXTENSION
|
|
||||||
#endif
|
|
||||||
#endif /* __extension__ */
|
|
||||||
|
|
||||||
#ifndef __ANONYMOUS_DEFINED
|
|
||||||
#define __ANONYMOUS_DEFINED
|
|
||||||
#if defined(__GNUC__) || defined(__GNUG__)
|
|
||||||
#define _ANONYMOUS_UNION __extension__
|
|
||||||
#define _ANONYMOUS_STRUCT __extension__
|
|
||||||
#else
|
|
||||||
#define _ANONYMOUS_UNION
|
|
||||||
#define _ANONYMOUS_STRUCT
|
|
||||||
#endif
|
|
||||||
#ifndef NONAMELESSUNION
|
|
||||||
#define _UNION_NAME(x)
|
|
||||||
#define _STRUCT_NAME(x)
|
|
||||||
#else /* NONAMELESSUNION */
|
|
||||||
#define _UNION_NAME(x) x
|
|
||||||
#define _STRUCT_NAME(x) x
|
|
||||||
#endif
|
|
||||||
#endif /* __ANONYMOUS_DEFINED */
|
|
||||||
|
|
||||||
#ifndef DUMMYUNIONNAME
|
|
||||||
# ifdef NONAMELESSUNION
|
|
||||||
# define DUMMYUNIONNAME u
|
|
||||||
# define DUMMYUNIONNAME1 u1 /* Wine uses this variant */
|
|
||||||
# define DUMMYUNIONNAME2 u2
|
|
||||||
# define DUMMYUNIONNAME3 u3
|
|
||||||
# define DUMMYUNIONNAME4 u4
|
|
||||||
# define DUMMYUNIONNAME5 u5
|
|
||||||
# define DUMMYUNIONNAME6 u6
|
|
||||||
# define DUMMYUNIONNAME7 u7
|
|
||||||
# define DUMMYUNIONNAME8 u8
|
|
||||||
# define DUMMYUNIONNAME9 u9
|
|
||||||
# else /* NONAMELESSUNION */
|
|
||||||
# define DUMMYUNIONNAME
|
|
||||||
# define DUMMYUNIONNAME1 /* Wine uses this variant */
|
|
||||||
# define DUMMYUNIONNAME2
|
|
||||||
# define DUMMYUNIONNAME3
|
|
||||||
# define DUMMYUNIONNAME4
|
|
||||||
# define DUMMYUNIONNAME5
|
|
||||||
# define DUMMYUNIONNAME6
|
|
||||||
# define DUMMYUNIONNAME7
|
|
||||||
# define DUMMYUNIONNAME8
|
|
||||||
# define DUMMYUNIONNAME9
|
|
||||||
# endif
|
|
||||||
#endif /* DUMMYUNIONNAME */
|
|
||||||
|
|
||||||
#if !defined(DUMMYUNIONNAME1) /* MinGW does not define this one */
|
|
||||||
# ifdef NONAMELESSUNION
|
|
||||||
# define DUMMYUNIONNAME1 u1 /* Wine uses this variant */
|
|
||||||
# else
|
|
||||||
# define DUMMYUNIONNAME1 /* Wine uses this variant */
|
|
||||||
# endif
|
|
||||||
#endif /* DUMMYUNIONNAME1 */
|
|
||||||
|
|
||||||
#ifndef DUMMYSTRUCTNAME
|
|
||||||
# ifdef NONAMELESSUNION
|
|
||||||
# define DUMMYSTRUCTNAME s
|
|
||||||
# define DUMMYSTRUCTNAME1 s1 /* Wine uses this variant */
|
|
||||||
# define DUMMYSTRUCTNAME2 s2
|
|
||||||
# define DUMMYSTRUCTNAME3 s3
|
|
||||||
# define DUMMYSTRUCTNAME4 s4
|
|
||||||
# define DUMMYSTRUCTNAME5 s5
|
|
||||||
# else
|
|
||||||
# define DUMMYSTRUCTNAME
|
|
||||||
# define DUMMYSTRUCTNAME1 /* Wine uses this variant */
|
|
||||||
# define DUMMYSTRUCTNAME2
|
|
||||||
# define DUMMYSTRUCTNAME3
|
|
||||||
# define DUMMYSTRUCTNAME4
|
|
||||||
# define DUMMYSTRUCTNAME5
|
|
||||||
# endif
|
|
||||||
#endif /* DUMMYSTRUCTNAME */
|
|
||||||
|
|
||||||
/* These are for compatibility with the Wine source tree */
|
|
||||||
|
|
||||||
#ifndef WINELIB_NAME_AW
|
|
||||||
# ifdef __MINGW_NAME_AW
|
|
||||||
# define WINELIB_NAME_AW __MINGW_NAME_AW
|
|
||||||
# else
|
|
||||||
# ifdef UNICODE
|
|
||||||
# define WINELIB_NAME_AW(func) func##W
|
|
||||||
# else
|
|
||||||
# define WINELIB_NAME_AW(func) func##A
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif /* WINELIB_NAME_AW */
|
|
||||||
|
|
||||||
#ifndef DECL_WINELIB_TYPE_AW
|
|
||||||
# ifdef __MINGW_TYPEDEF_AW
|
|
||||||
# define DECL_WINELIB_TYPE_AW __MINGW_TYPEDEF_AW
|
|
||||||
# else
|
|
||||||
# define DECL_WINELIB_TYPE_AW(type) typedef WINELIB_NAME_AW(type) type;
|
|
||||||
# endif
|
|
||||||
#endif /* DECL_WINELIB_TYPE_AW */
|
|
||||||
|
|
@ -1,239 +0,0 @@
|
|||||||
/*
|
|
||||||
* The Wine project - Xinput Joystick Library
|
|
||||||
* Copyright 2008 Andrew Fenn
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2.1 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library 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
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __WINE_XINPUT_H
|
|
||||||
#define __WINE_XINPUT_H
|
|
||||||
|
|
||||||
#include <windef.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Bitmasks for the joysticks buttons, determines what has
|
|
||||||
* been pressed on the joystick, these need to be mapped
|
|
||||||
* to whatever device you're using instead of an xbox 360
|
|
||||||
* joystick
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XINPUT_GAMEPAD_DPAD_UP 0x0001
|
|
||||||
#define XINPUT_GAMEPAD_DPAD_DOWN 0x0002
|
|
||||||
#define XINPUT_GAMEPAD_DPAD_LEFT 0x0004
|
|
||||||
#define XINPUT_GAMEPAD_DPAD_RIGHT 0x0008
|
|
||||||
#define XINPUT_GAMEPAD_START 0x0010
|
|
||||||
#define XINPUT_GAMEPAD_BACK 0x0020
|
|
||||||
#define XINPUT_GAMEPAD_LEFT_THUMB 0x0040
|
|
||||||
#define XINPUT_GAMEPAD_RIGHT_THUMB 0x0080
|
|
||||||
#define XINPUT_GAMEPAD_LEFT_SHOULDER 0x0100
|
|
||||||
#define XINPUT_GAMEPAD_RIGHT_SHOULDER 0x0200
|
|
||||||
#define XINPUT_GAMEPAD_A 0x1000
|
|
||||||
#define XINPUT_GAMEPAD_B 0x2000
|
|
||||||
#define XINPUT_GAMEPAD_X 0x4000
|
|
||||||
#define XINPUT_GAMEPAD_Y 0x8000
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the flags used to determine if the user is pushing
|
|
||||||
* down on a button, not holding a button, etc
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XINPUT_KEYSTROKE_KEYDOWN 0x0001
|
|
||||||
#define XINPUT_KEYSTROKE_KEYUP 0x0002
|
|
||||||
#define XINPUT_KEYSTROKE_REPEAT 0x0004
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the codes which are returned by XInputGetKeystroke
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define VK_PAD_A 0x5800
|
|
||||||
#define VK_PAD_B 0x5801
|
|
||||||
#define VK_PAD_X 0x5802
|
|
||||||
#define VK_PAD_Y 0x5803
|
|
||||||
#define VK_PAD_RSHOULDER 0x5804
|
|
||||||
#define VK_PAD_LSHOULDER 0x5805
|
|
||||||
#define VK_PAD_LTRIGGER 0x5806
|
|
||||||
#define VK_PAD_RTRIGGER 0x5807
|
|
||||||
#define VK_PAD_DPAD_UP 0x5810
|
|
||||||
#define VK_PAD_DPAD_DOWN 0x5811
|
|
||||||
#define VK_PAD_DPAD_LEFT 0x5812
|
|
||||||
#define VK_PAD_DPAD_RIGHT 0x5813
|
|
||||||
#define VK_PAD_START 0x5814
|
|
||||||
#define VK_PAD_BACK 0x5815
|
|
||||||
#define VK_PAD_LTHUMB_PRESS 0x5816
|
|
||||||
#define VK_PAD_RTHUMB_PRESS 0x5817
|
|
||||||
#define VK_PAD_LTHUMB_UP 0x5820
|
|
||||||
#define VK_PAD_LTHUMB_DOWN 0x5821
|
|
||||||
#define VK_PAD_LTHUMB_RIGHT 0x5822
|
|
||||||
#define VK_PAD_LTHUMB_LEFT 0x5823
|
|
||||||
#define VK_PAD_LTHUMB_UPLEFT 0x5824
|
|
||||||
#define VK_PAD_LTHUMB_UPRIGHT 0x5825
|
|
||||||
#define VK_PAD_LTHUMB_DOWNRIGHT 0x5826
|
|
||||||
#define VK_PAD_LTHUMB_DOWNLEFT 0x5827
|
|
||||||
#define VK_PAD_RTHUMB_UP 0x5830
|
|
||||||
#define VK_PAD_RTHUMB_DOWN 0x5831
|
|
||||||
#define VK_PAD_RTHUMB_RIGHT 0x5832
|
|
||||||
#define VK_PAD_RTHUMB_LEFT 0x5833
|
|
||||||
#define VK_PAD_RTHUMB_UPLEFT 0x5834
|
|
||||||
#define VK_PAD_RTHUMB_UPRIGHT 0x5835
|
|
||||||
#define VK_PAD_RTHUMB_DOWNRIGHT 0x5836
|
|
||||||
#define VK_PAD_RTHUMB_DOWNLEFT 0x5837
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Deadzones are for analogue joystick controls on the joypad
|
|
||||||
* which determine when input should be assumed to be in the
|
|
||||||
* middle of the pad. This is a threshold to stop a joypad
|
|
||||||
* controlling the game when the player isn't touching the
|
|
||||||
* controls.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XINPUT_GAMEPAD_LEFT_THUMB_DEADZONE 7849
|
|
||||||
#define XINPUT_GAMEPAD_RIGHT_THUMB_DEADZONE 8689
|
|
||||||
#define XINPUT_GAMEPAD_TRIGGER_THRESHOLD 30
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines what type of abilities the type of joystick has
|
|
||||||
* DEVTYPE_GAMEPAD is available for all joysticks, however
|
|
||||||
* there may be more specific identifiers for other joysticks
|
|
||||||
* which are being used.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XINPUT_DEVTYPE_GAMEPAD 0x01
|
|
||||||
#define XINPUT_DEVSUBTYPE_GAMEPAD 0x01
|
|
||||||
#define XINPUT_DEVSUBTYPE_WHEEL 0x02
|
|
||||||
#define XINPUT_DEVSUBTYPE_ARCADE_STICK 0x03
|
|
||||||
#define XINPUT_DEVSUBTYPE_FLIGHT_SICK 0x04
|
|
||||||
#define XINPUT_DEVSUBTYPE_DANCE_PAD 0x05
|
|
||||||
#define XINPUT_DEVSUBTYPE_GUITAR 0x06
|
|
||||||
#define XINPUT_DEVSUBTYPE_DRUM_KIT 0x08
|
|
||||||
|
|
||||||
/*
|
|
||||||
* These are used with the XInputGetCapabilities function to
|
|
||||||
* determine the abilities to the joystick which has been
|
|
||||||
* plugged in.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XINPUT_CAPS_VOICE_SUPPORTED 0x0004
|
|
||||||
#define XINPUT_FLAG_GAMEPAD 0x00000001
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the status of the battery if one is used in the
|
|
||||||
* attached joystick. The first two define if the joystick
|
|
||||||
* supports a battery. Disconnected means that the joystick
|
|
||||||
* isn't connected. Wired shows that the joystick is a wired
|
|
||||||
* joystick.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define BATTERY_DEVTYPE_GAMEPAD 0x00
|
|
||||||
#define BATTERY_DEVTYPE_HEADSET 0x01
|
|
||||||
#define BATTERY_TYPE_DISCONNECTED 0x00
|
|
||||||
#define BATTERY_TYPE_WIRED 0x01
|
|
||||||
#define BATTERY_TYPE_ALKALINE 0x02
|
|
||||||
#define BATTERY_TYPE_NIMH 0x03
|
|
||||||
#define BATTERY_TYPE_UNKNOWN 0xFF
|
|
||||||
#define BATTERY_LEVEL_EMPTY 0x00
|
|
||||||
#define BATTERY_LEVEL_LOW 0x01
|
|
||||||
#define BATTERY_LEVEL_MEDIUM 0x02
|
|
||||||
#define BATTERY_LEVEL_FULL 0x03
|
|
||||||
|
|
||||||
/*
|
|
||||||
* How many joysticks can be used with this library. Games that
|
|
||||||
* use the xinput library will not go over this number.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define XUSER_MAX_COUNT 4
|
|
||||||
#define XUSER_INDEX_ANY 0x000000FF
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the structure of an xbox 360 joystick.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct _XINPUT_GAMEPAD {
|
|
||||||
WORD wButtons;
|
|
||||||
BYTE bLeftTrigger;
|
|
||||||
BYTE bRightTrigger;
|
|
||||||
SHORT sThumbLX;
|
|
||||||
SHORT sThumbLY;
|
|
||||||
SHORT sThumbRX;
|
|
||||||
SHORT sThumbRY;
|
|
||||||
} XINPUT_GAMEPAD, *PXINPUT_GAMEPAD;
|
|
||||||
|
|
||||||
typedef struct _XINPUT_STATE {
|
|
||||||
DWORD dwPacketNumber;
|
|
||||||
XINPUT_GAMEPAD Gamepad;
|
|
||||||
} XINPUT_STATE, *PXINPUT_STATE;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the structure of how much vibration is set on both the
|
|
||||||
* right and left motors in a joystick. If you're not using a 360
|
|
||||||
* joystick you will have to map these to your device.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct _XINPUT_VIBRATION {
|
|
||||||
WORD wLeftMotorSpeed;
|
|
||||||
WORD wRightMotorSpeed;
|
|
||||||
} XINPUT_VIBRATION, *PXINPUT_VIBRATION;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the structure for what kind of abilities the joystick has
|
|
||||||
* such abilities are things such as if the joystick has the ability
|
|
||||||
* to send and receive audio, if the joystick is in fact a driving
|
|
||||||
* wheel or perhaps if the joystick is some kind of dance pad or
|
|
||||||
* guitar.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct _XINPUT_CAPABILITIES {
|
|
||||||
BYTE Type;
|
|
||||||
BYTE SubType;
|
|
||||||
WORD Flags;
|
|
||||||
XINPUT_GAMEPAD Gamepad;
|
|
||||||
XINPUT_VIBRATION Vibration;
|
|
||||||
} XINPUT_CAPABILITIES, *PXINPUT_CAPABILITIES;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Defines the structure for a joystick input event which is
|
|
||||||
* retrieved using the function XInputGetKeystroke
|
|
||||||
*/
|
|
||||||
typedef struct _XINPUT_KEYSTROKE {
|
|
||||||
WORD VirtualKey;
|
|
||||||
WCHAR Unicode;
|
|
||||||
WORD Flags;
|
|
||||||
BYTE UserIndex;
|
|
||||||
BYTE HidCode;
|
|
||||||
} XINPUT_KEYSTROKE, *PXINPUT_KEYSTROKE;
|
|
||||||
|
|
||||||
typedef struct _XINPUT_BATTERY_INFORMATION
|
|
||||||
{
|
|
||||||
BYTE BatteryType;
|
|
||||||
BYTE BatteryLevel;
|
|
||||||
} XINPUT_BATTERY_INFORMATION, *PXINPUT_BATTERY_INFORMATION;
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void WINAPI XInputEnable(WINBOOL);
|
|
||||||
DWORD WINAPI XInputSetState(DWORD, XINPUT_VIBRATION*);
|
|
||||||
DWORD WINAPI XInputGetState(DWORD, XINPUT_STATE*);
|
|
||||||
DWORD WINAPI XInputGetKeystroke(DWORD, DWORD, PXINPUT_KEYSTROKE);
|
|
||||||
DWORD WINAPI XInputGetCapabilities(DWORD, DWORD, XINPUT_CAPABILITIES*);
|
|
||||||
DWORD WINAPI XInputGetDSoundAudioDeviceGuids(DWORD, GUID*, GUID*);
|
|
||||||
DWORD WINAPI XInputGetBatteryInformation(DWORD, BYTE, XINPUT_BATTERY_INFORMATION*);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __WINE_XINPUT_H */
|
|
25539
glfw/deps/nuklear.h
@ -1,381 +0,0 @@
|
|||||||
/*
|
|
||||||
* Nuklear - v1.32.0 - public domain
|
|
||||||
* no warrenty implied; use at your own risk.
|
|
||||||
* authored from 2015-2017 by Micha Mettke
|
|
||||||
*/
|
|
||||||
/*
|
|
||||||
* ==============================================================
|
|
||||||
*
|
|
||||||
* API
|
|
||||||
*
|
|
||||||
* ===============================================================
|
|
||||||
*/
|
|
||||||
#ifndef NK_GLFW_GL2_H_
|
|
||||||
#define NK_GLFW_GL2_H_
|
|
||||||
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
|
|
||||||
enum nk_glfw_init_state{
|
|
||||||
NK_GLFW3_DEFAULT = 0,
|
|
||||||
NK_GLFW3_INSTALL_CALLBACKS
|
|
||||||
};
|
|
||||||
NK_API struct nk_context* nk_glfw3_init(GLFWwindow *win, enum nk_glfw_init_state);
|
|
||||||
NK_API void nk_glfw3_font_stash_begin(struct nk_font_atlas **atlas);
|
|
||||||
NK_API void nk_glfw3_font_stash_end(void);
|
|
||||||
|
|
||||||
NK_API void nk_glfw3_new_frame(void);
|
|
||||||
NK_API void nk_glfw3_render(enum nk_anti_aliasing);
|
|
||||||
NK_API void nk_glfw3_shutdown(void);
|
|
||||||
|
|
||||||
NK_API void nk_glfw3_char_callback(GLFWwindow *win, unsigned int codepoint);
|
|
||||||
NK_API void nk_gflw3_scroll_callback(GLFWwindow *win, double xoff, double yoff);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* ==============================================================
|
|
||||||
*
|
|
||||||
* IMPLEMENTATION
|
|
||||||
*
|
|
||||||
* ===============================================================
|
|
||||||
*/
|
|
||||||
#ifdef NK_GLFW_GL2_IMPLEMENTATION
|
|
||||||
|
|
||||||
#ifndef NK_GLFW_TEXT_MAX
|
|
||||||
#define NK_GLFW_TEXT_MAX 256
|
|
||||||
#endif
|
|
||||||
#ifndef NK_GLFW_DOUBLE_CLICK_LO
|
|
||||||
#define NK_GLFW_DOUBLE_CLICK_LO 0.02
|
|
||||||
#endif
|
|
||||||
#ifndef NK_GLFW_DOUBLE_CLICK_HI
|
|
||||||
#define NK_GLFW_DOUBLE_CLICK_HI 0.2
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct nk_glfw_device {
|
|
||||||
struct nk_buffer cmds;
|
|
||||||
struct nk_draw_null_texture null;
|
|
||||||
GLuint font_tex;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct nk_glfw_vertex {
|
|
||||||
float position[2];
|
|
||||||
float uv[2];
|
|
||||||
nk_byte col[4];
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct nk_glfw {
|
|
||||||
GLFWwindow *win;
|
|
||||||
int width, height;
|
|
||||||
int display_width, display_height;
|
|
||||||
struct nk_glfw_device ogl;
|
|
||||||
struct nk_context ctx;
|
|
||||||
struct nk_font_atlas atlas;
|
|
||||||
struct nk_vec2 fb_scale;
|
|
||||||
unsigned int text[NK_GLFW_TEXT_MAX];
|
|
||||||
int text_len;
|
|
||||||
struct nk_vec2 scroll;
|
|
||||||
double last_button_click;
|
|
||||||
int is_double_click_down;
|
|
||||||
struct nk_vec2 double_click_pos;
|
|
||||||
} glfw;
|
|
||||||
|
|
||||||
NK_INTERN void
|
|
||||||
nk_glfw3_device_upload_atlas(const void *image, int width, int height)
|
|
||||||
{
|
|
||||||
struct nk_glfw_device *dev = &glfw.ogl;
|
|
||||||
glGenTextures(1, &dev->font_tex);
|
|
||||||
glBindTexture(GL_TEXTURE_2D, dev->font_tex);
|
|
||||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, (GLsizei)width, (GLsizei)height, 0,
|
|
||||||
GL_RGBA, GL_UNSIGNED_BYTE, image);
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_render(enum nk_anti_aliasing AA)
|
|
||||||
{
|
|
||||||
/* setup global state */
|
|
||||||
struct nk_glfw_device *dev = &glfw.ogl;
|
|
||||||
glPushAttrib(GL_ENABLE_BIT|GL_COLOR_BUFFER_BIT|GL_TRANSFORM_BIT);
|
|
||||||
glDisable(GL_CULL_FACE);
|
|
||||||
glDisable(GL_DEPTH_TEST);
|
|
||||||
glEnable(GL_SCISSOR_TEST);
|
|
||||||
glEnable(GL_BLEND);
|
|
||||||
glEnable(GL_TEXTURE_2D);
|
|
||||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
|
||||||
|
|
||||||
/* setup viewport/project */
|
|
||||||
glViewport(0,0,(GLsizei)glfw.display_width,(GLsizei)glfw.display_height);
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
glPushMatrix();
|
|
||||||
glLoadIdentity();
|
|
||||||
glOrtho(0.0f, glfw.width, glfw.height, 0.0f, -1.0f, 1.0f);
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
glPushMatrix();
|
|
||||||
glLoadIdentity();
|
|
||||||
|
|
||||||
glEnableClientState(GL_VERTEX_ARRAY);
|
|
||||||
glEnableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
glEnableClientState(GL_COLOR_ARRAY);
|
|
||||||
{
|
|
||||||
GLsizei vs = sizeof(struct nk_glfw_vertex);
|
|
||||||
size_t vp = offsetof(struct nk_glfw_vertex, position);
|
|
||||||
size_t vt = offsetof(struct nk_glfw_vertex, uv);
|
|
||||||
size_t vc = offsetof(struct nk_glfw_vertex, col);
|
|
||||||
|
|
||||||
/* convert from command queue into draw list and draw to screen */
|
|
||||||
const struct nk_draw_command *cmd;
|
|
||||||
const nk_draw_index *offset = NULL;
|
|
||||||
struct nk_buffer vbuf, ebuf;
|
|
||||||
|
|
||||||
/* fill convert configuration */
|
|
||||||
struct nk_convert_config config;
|
|
||||||
static const struct nk_draw_vertex_layout_element vertex_layout[] = {
|
|
||||||
{NK_VERTEX_POSITION, NK_FORMAT_FLOAT, NK_OFFSETOF(struct nk_glfw_vertex, position)},
|
|
||||||
{NK_VERTEX_TEXCOORD, NK_FORMAT_FLOAT, NK_OFFSETOF(struct nk_glfw_vertex, uv)},
|
|
||||||
{NK_VERTEX_COLOR, NK_FORMAT_R8G8B8A8, NK_OFFSETOF(struct nk_glfw_vertex, col)},
|
|
||||||
{NK_VERTEX_LAYOUT_END}
|
|
||||||
};
|
|
||||||
NK_MEMSET(&config, 0, sizeof(config));
|
|
||||||
config.vertex_layout = vertex_layout;
|
|
||||||
config.vertex_size = sizeof(struct nk_glfw_vertex);
|
|
||||||
config.vertex_alignment = NK_ALIGNOF(struct nk_glfw_vertex);
|
|
||||||
config.null = dev->null;
|
|
||||||
config.circle_segment_count = 22;
|
|
||||||
config.curve_segment_count = 22;
|
|
||||||
config.arc_segment_count = 22;
|
|
||||||
config.global_alpha = 1.0f;
|
|
||||||
config.shape_AA = AA;
|
|
||||||
config.line_AA = AA;
|
|
||||||
|
|
||||||
/* convert shapes into vertexes */
|
|
||||||
nk_buffer_init_default(&vbuf);
|
|
||||||
nk_buffer_init_default(&ebuf);
|
|
||||||
nk_convert(&glfw.ctx, &dev->cmds, &vbuf, &ebuf, &config);
|
|
||||||
|
|
||||||
/* setup vertex buffer pointer */
|
|
||||||
{const void *vertices = nk_buffer_memory_const(&vbuf);
|
|
||||||
glVertexPointer(2, GL_FLOAT, vs, (const void*)((const nk_byte*)vertices + vp));
|
|
||||||
glTexCoordPointer(2, GL_FLOAT, vs, (const void*)((const nk_byte*)vertices + vt));
|
|
||||||
glColorPointer(4, GL_UNSIGNED_BYTE, vs, (const void*)((const nk_byte*)vertices + vc));}
|
|
||||||
|
|
||||||
/* iterate over and execute each draw command */
|
|
||||||
offset = (const nk_draw_index*)nk_buffer_memory_const(&ebuf);
|
|
||||||
nk_draw_foreach(cmd, &glfw.ctx, &dev->cmds)
|
|
||||||
{
|
|
||||||
if (!cmd->elem_count) continue;
|
|
||||||
glBindTexture(GL_TEXTURE_2D, (GLuint)cmd->texture.id);
|
|
||||||
glScissor(
|
|
||||||
(GLint)(cmd->clip_rect.x * glfw.fb_scale.x),
|
|
||||||
(GLint)((glfw.height - (GLint)(cmd->clip_rect.y + cmd->clip_rect.h)) * glfw.fb_scale.y),
|
|
||||||
(GLint)(cmd->clip_rect.w * glfw.fb_scale.x),
|
|
||||||
(GLint)(cmd->clip_rect.h * glfw.fb_scale.y));
|
|
||||||
glDrawElements(GL_TRIANGLES, (GLsizei)cmd->elem_count, GL_UNSIGNED_SHORT, offset);
|
|
||||||
offset += cmd->elem_count;
|
|
||||||
}
|
|
||||||
nk_clear(&glfw.ctx);
|
|
||||||
nk_buffer_free(&vbuf);
|
|
||||||
nk_buffer_free(&ebuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* default OpenGL state */
|
|
||||||
glDisableClientState(GL_VERTEX_ARRAY);
|
|
||||||
glDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
glDisableClientState(GL_COLOR_ARRAY);
|
|
||||||
|
|
||||||
glDisable(GL_CULL_FACE);
|
|
||||||
glDisable(GL_DEPTH_TEST);
|
|
||||||
glDisable(GL_SCISSOR_TEST);
|
|
||||||
glDisable(GL_BLEND);
|
|
||||||
glDisable(GL_TEXTURE_2D);
|
|
||||||
|
|
||||||
glBindTexture(GL_TEXTURE_2D, 0);
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
glPopMatrix();
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
glPopMatrix();
|
|
||||||
glPopAttrib();
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_char_callback(GLFWwindow *win, unsigned int codepoint)
|
|
||||||
{
|
|
||||||
(void)win;
|
|
||||||
if (glfw.text_len < NK_GLFW_TEXT_MAX)
|
|
||||||
glfw.text[glfw.text_len++] = codepoint;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_gflw3_scroll_callback(GLFWwindow *win, double xoff, double yoff)
|
|
||||||
{
|
|
||||||
(void)win; (void)xoff;
|
|
||||||
glfw.scroll.x += (float)xoff;
|
|
||||||
glfw.scroll.y += (float)yoff;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_mouse_button_callback(GLFWwindow* window, int button, int action, int mods)
|
|
||||||
{
|
|
||||||
double x, y;
|
|
||||||
if (button != GLFW_MOUSE_BUTTON_LEFT) return;
|
|
||||||
glfwGetCursorPos(window, &x, &y);
|
|
||||||
if (action == GLFW_PRESS) {
|
|
||||||
double dt = glfwGetTime() - glfw.last_button_click;
|
|
||||||
if (dt > NK_GLFW_DOUBLE_CLICK_LO && dt < NK_GLFW_DOUBLE_CLICK_HI) {
|
|
||||||
glfw.is_double_click_down = nk_true;
|
|
||||||
glfw.double_click_pos = nk_vec2((float)x, (float)y);
|
|
||||||
}
|
|
||||||
glfw.last_button_click = glfwGetTime();
|
|
||||||
} else glfw.is_double_click_down = nk_false;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_INTERN void
|
|
||||||
nk_glfw3_clipbard_paste(nk_handle usr, struct nk_text_edit *edit)
|
|
||||||
{
|
|
||||||
const char *text = glfwGetClipboardString(glfw.win);
|
|
||||||
if (text) nk_textedit_paste(edit, text, nk_strlen(text));
|
|
||||||
(void)usr;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_INTERN void
|
|
||||||
nk_glfw3_clipbard_copy(nk_handle usr, const char *text, int len)
|
|
||||||
{
|
|
||||||
char *str = 0;
|
|
||||||
(void)usr;
|
|
||||||
if (!len) return;
|
|
||||||
str = (char*)malloc((size_t)len+1);
|
|
||||||
if (!str) return;
|
|
||||||
NK_MEMCPY(str, text, (size_t)len);
|
|
||||||
str[len] = '\0';
|
|
||||||
glfwSetClipboardString(glfw.win, str);
|
|
||||||
free(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API struct nk_context*
|
|
||||||
nk_glfw3_init(GLFWwindow *win, enum nk_glfw_init_state init_state)
|
|
||||||
{
|
|
||||||
glfw.win = win;
|
|
||||||
if (init_state == NK_GLFW3_INSTALL_CALLBACKS) {
|
|
||||||
glfwSetScrollCallback(win, nk_gflw3_scroll_callback);
|
|
||||||
glfwSetCharCallback(win, nk_glfw3_char_callback);
|
|
||||||
glfwSetMouseButtonCallback(win, nk_glfw3_mouse_button_callback);
|
|
||||||
}
|
|
||||||
nk_init_default(&glfw.ctx, 0);
|
|
||||||
glfw.ctx.clip.copy = nk_glfw3_clipbard_copy;
|
|
||||||
glfw.ctx.clip.paste = nk_glfw3_clipbard_paste;
|
|
||||||
glfw.ctx.clip.userdata = nk_handle_ptr(0);
|
|
||||||
nk_buffer_init_default(&glfw.ogl.cmds);
|
|
||||||
|
|
||||||
glfw.is_double_click_down = nk_false;
|
|
||||||
glfw.double_click_pos = nk_vec2(0, 0);
|
|
||||||
|
|
||||||
return &glfw.ctx;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_font_stash_begin(struct nk_font_atlas **atlas)
|
|
||||||
{
|
|
||||||
nk_font_atlas_init_default(&glfw.atlas);
|
|
||||||
nk_font_atlas_begin(&glfw.atlas);
|
|
||||||
*atlas = &glfw.atlas;
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_font_stash_end(void)
|
|
||||||
{
|
|
||||||
const void *image; int w, h;
|
|
||||||
image = nk_font_atlas_bake(&glfw.atlas, &w, &h, NK_FONT_ATLAS_RGBA32);
|
|
||||||
nk_glfw3_device_upload_atlas(image, w, h);
|
|
||||||
nk_font_atlas_end(&glfw.atlas, nk_handle_id((int)glfw.ogl.font_tex), &glfw.ogl.null);
|
|
||||||
if (glfw.atlas.default_font)
|
|
||||||
nk_style_set_font(&glfw.ctx, &glfw.atlas.default_font->handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API void
|
|
||||||
nk_glfw3_new_frame(void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
double x, y;
|
|
||||||
struct nk_context *ctx = &glfw.ctx;
|
|
||||||
struct GLFWwindow *win = glfw.win;
|
|
||||||
|
|
||||||
glfwGetWindowSize(win, &glfw.width, &glfw.height);
|
|
||||||
glfwGetFramebufferSize(win, &glfw.display_width, &glfw.display_height);
|
|
||||||
glfw.fb_scale.x = (float)glfw.display_width/(float)glfw.width;
|
|
||||||
glfw.fb_scale.y = (float)glfw.display_height/(float)glfw.height;
|
|
||||||
|
|
||||||
nk_input_begin(ctx);
|
|
||||||
for (i = 0; i < glfw.text_len; ++i)
|
|
||||||
nk_input_unicode(ctx, glfw.text[i]);
|
|
||||||
|
|
||||||
/* optional grabbing behavior */
|
|
||||||
if (ctx->input.mouse.grab)
|
|
||||||
glfwSetInputMode(glfw.win, GLFW_CURSOR, GLFW_CURSOR_HIDDEN);
|
|
||||||
else if (ctx->input.mouse.ungrab)
|
|
||||||
glfwSetInputMode(glfw.win, GLFW_CURSOR, GLFW_CURSOR_NORMAL);
|
|
||||||
|
|
||||||
nk_input_key(ctx, NK_KEY_DEL, glfwGetKey(win, GLFW_KEY_DELETE) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_ENTER, glfwGetKey(win, GLFW_KEY_ENTER) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TAB, glfwGetKey(win, GLFW_KEY_TAB) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_BACKSPACE, glfwGetKey(win, GLFW_KEY_BACKSPACE) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_UP, glfwGetKey(win, GLFW_KEY_UP) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_DOWN, glfwGetKey(win, GLFW_KEY_DOWN) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_START, glfwGetKey(win, GLFW_KEY_HOME) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_END, glfwGetKey(win, GLFW_KEY_END) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_SCROLL_START, glfwGetKey(win, GLFW_KEY_HOME) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_SCROLL_END, glfwGetKey(win, GLFW_KEY_END) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_SCROLL_DOWN, glfwGetKey(win, GLFW_KEY_PAGE_DOWN) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_SCROLL_UP, glfwGetKey(win, GLFW_KEY_PAGE_UP) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_SHIFT, glfwGetKey(win, GLFW_KEY_LEFT_SHIFT) == GLFW_PRESS||
|
|
||||||
glfwGetKey(win, GLFW_KEY_RIGHT_SHIFT) == GLFW_PRESS);
|
|
||||||
|
|
||||||
if (glfwGetKey(win, GLFW_KEY_LEFT_CONTROL) == GLFW_PRESS ||
|
|
||||||
glfwGetKey(win, GLFW_KEY_RIGHT_CONTROL) == GLFW_PRESS) {
|
|
||||||
nk_input_key(ctx, NK_KEY_COPY, glfwGetKey(win, GLFW_KEY_C) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_PASTE, glfwGetKey(win, GLFW_KEY_V) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_CUT, glfwGetKey(win, GLFW_KEY_X) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_UNDO, glfwGetKey(win, GLFW_KEY_Z) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_REDO, glfwGetKey(win, GLFW_KEY_R) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_WORD_LEFT, glfwGetKey(win, GLFW_KEY_LEFT) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_WORD_RIGHT, glfwGetKey(win, GLFW_KEY_RIGHT) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_LINE_START, glfwGetKey(win, GLFW_KEY_B) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_TEXT_LINE_END, glfwGetKey(win, GLFW_KEY_E) == GLFW_PRESS);
|
|
||||||
} else {
|
|
||||||
nk_input_key(ctx, NK_KEY_LEFT, glfwGetKey(win, GLFW_KEY_LEFT) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_RIGHT, glfwGetKey(win, GLFW_KEY_RIGHT) == GLFW_PRESS);
|
|
||||||
nk_input_key(ctx, NK_KEY_COPY, 0);
|
|
||||||
nk_input_key(ctx, NK_KEY_PASTE, 0);
|
|
||||||
nk_input_key(ctx, NK_KEY_CUT, 0);
|
|
||||||
nk_input_key(ctx, NK_KEY_SHIFT, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
glfwGetCursorPos(win, &x, &y);
|
|
||||||
nk_input_motion(ctx, (int)x, (int)y);
|
|
||||||
if (ctx->input.mouse.grabbed) {
|
|
||||||
glfwSetCursorPos(glfw.win, (double)ctx->input.mouse.prev.x, (double)ctx->input.mouse.prev.y);
|
|
||||||
ctx->input.mouse.pos.x = ctx->input.mouse.prev.x;
|
|
||||||
ctx->input.mouse.pos.y = ctx->input.mouse.prev.y;
|
|
||||||
}
|
|
||||||
|
|
||||||
nk_input_button(ctx, NK_BUTTON_LEFT, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_LEFT) == GLFW_PRESS);
|
|
||||||
nk_input_button(ctx, NK_BUTTON_MIDDLE, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_MIDDLE) == GLFW_PRESS);
|
|
||||||
nk_input_button(ctx, NK_BUTTON_RIGHT, (int)x, (int)y, glfwGetMouseButton(win, GLFW_MOUSE_BUTTON_RIGHT) == GLFW_PRESS);
|
|
||||||
nk_input_button(ctx, NK_BUTTON_DOUBLE, (int)glfw.double_click_pos.x, (int)glfw.double_click_pos.y, glfw.is_double_click_down);
|
|
||||||
nk_input_scroll(ctx, glfw.scroll);
|
|
||||||
nk_input_end(&glfw.ctx);
|
|
||||||
glfw.text_len = 0;
|
|
||||||
glfw.scroll = nk_vec2(0,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
NK_API
|
|
||||||
void nk_glfw3_shutdown(void)
|
|
||||||
{
|
|
||||||
struct nk_glfw_device *dev = &glfw.ogl;
|
|
||||||
nk_font_atlas_clear(&glfw.atlas);
|
|
||||||
nk_free(&glfw.ctx);
|
|
||||||
glDeleteTextures(1, &dev->font_tex);
|
|
||||||
nk_buffer_free(&dev->cmds);
|
|
||||||
NK_MEMSET(&glfw, 0, sizeof(glfw));
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,594 +0,0 @@
|
|||||||
/* -*- mode: c; tab-width: 2; indent-tabs-mode: nil; -*-
|
|
||||||
Copyright (c) 2012 Marcus Geelnard
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
|
||||||
warranty. In no event will the authors be held liable for any damages
|
|
||||||
arising from the use of this software.
|
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it
|
|
||||||
freely, subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
|
||||||
claim that you wrote the original software. If you use this software
|
|
||||||
in a product, an acknowledgment in the product documentation would be
|
|
||||||
appreciated but is not required.
|
|
||||||
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
misrepresented as being the original software.
|
|
||||||
|
|
||||||
3. This notice may not be removed or altered from any source
|
|
||||||
distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* 2013-01-06 Camilla Löwy <elmindreda@glfw.org>
|
|
||||||
*
|
|
||||||
* Added casts from time_t to DWORD to avoid warnings on VC++.
|
|
||||||
* Fixed time retrieval on POSIX systems.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "tinycthread.h"
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
/* Platform specific includes */
|
|
||||||
#if defined(_TTHREAD_POSIX_)
|
|
||||||
#include <signal.h>
|
|
||||||
#include <sched.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <sys/time.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#elif defined(_TTHREAD_WIN32_)
|
|
||||||
#include <process.h>
|
|
||||||
#include <sys/timeb.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Standard, good-to-have defines */
|
|
||||||
#ifndef NULL
|
|
||||||
#define NULL (void*)0
|
|
||||||
#endif
|
|
||||||
#ifndef TRUE
|
|
||||||
#define TRUE 1
|
|
||||||
#endif
|
|
||||||
#ifndef FALSE
|
|
||||||
#define FALSE 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int mtx_init(mtx_t *mtx, int type)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
mtx->mAlreadyLocked = FALSE;
|
|
||||||
mtx->mRecursive = type & mtx_recursive;
|
|
||||||
InitializeCriticalSection(&mtx->mHandle);
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
int ret;
|
|
||||||
pthread_mutexattr_t attr;
|
|
||||||
pthread_mutexattr_init(&attr);
|
|
||||||
if (type & mtx_recursive)
|
|
||||||
{
|
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE);
|
|
||||||
}
|
|
||||||
ret = pthread_mutex_init(mtx, &attr);
|
|
||||||
pthread_mutexattr_destroy(&attr);
|
|
||||||
return ret == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void mtx_destroy(mtx_t *mtx)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
DeleteCriticalSection(&mtx->mHandle);
|
|
||||||
#else
|
|
||||||
pthread_mutex_destroy(mtx);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int mtx_lock(mtx_t *mtx)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
EnterCriticalSection(&mtx->mHandle);
|
|
||||||
if (!mtx->mRecursive)
|
|
||||||
{
|
|
||||||
while(mtx->mAlreadyLocked) Sleep(1000); /* Simulate deadlock... */
|
|
||||||
mtx->mAlreadyLocked = TRUE;
|
|
||||||
}
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
return pthread_mutex_lock(mtx) == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int mtx_timedlock(mtx_t *mtx, const struct timespec *ts)
|
|
||||||
{
|
|
||||||
/* FIXME! */
|
|
||||||
(void)mtx;
|
|
||||||
(void)ts;
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
int mtx_trylock(mtx_t *mtx)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
int ret = TryEnterCriticalSection(&mtx->mHandle) ? thrd_success : thrd_busy;
|
|
||||||
if ((!mtx->mRecursive) && (ret == thrd_success) && mtx->mAlreadyLocked)
|
|
||||||
{
|
|
||||||
LeaveCriticalSection(&mtx->mHandle);
|
|
||||||
ret = thrd_busy;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
#else
|
|
||||||
return (pthread_mutex_trylock(mtx) == 0) ? thrd_success : thrd_busy;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int mtx_unlock(mtx_t *mtx)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
mtx->mAlreadyLocked = FALSE;
|
|
||||||
LeaveCriticalSection(&mtx->mHandle);
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
return pthread_mutex_unlock(mtx) == 0 ? thrd_success : thrd_error;;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
#define _CONDITION_EVENT_ONE 0
|
|
||||||
#define _CONDITION_EVENT_ALL 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int cnd_init(cnd_t *cond)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
cond->mWaitersCount = 0;
|
|
||||||
|
|
||||||
/* Init critical section */
|
|
||||||
InitializeCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
|
|
||||||
/* Init events */
|
|
||||||
cond->mEvents[_CONDITION_EVENT_ONE] = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
||||||
if (cond->mEvents[_CONDITION_EVENT_ONE] == NULL)
|
|
||||||
{
|
|
||||||
cond->mEvents[_CONDITION_EVENT_ALL] = NULL;
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
cond->mEvents[_CONDITION_EVENT_ALL] = CreateEvent(NULL, TRUE, FALSE, NULL);
|
|
||||||
if (cond->mEvents[_CONDITION_EVENT_ALL] == NULL)
|
|
||||||
{
|
|
||||||
CloseHandle(cond->mEvents[_CONDITION_EVENT_ONE]);
|
|
||||||
cond->mEvents[_CONDITION_EVENT_ONE] = NULL;
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
return pthread_cond_init(cond, NULL) == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void cnd_destroy(cnd_t *cond)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
if (cond->mEvents[_CONDITION_EVENT_ONE] != NULL)
|
|
||||||
{
|
|
||||||
CloseHandle(cond->mEvents[_CONDITION_EVENT_ONE]);
|
|
||||||
}
|
|
||||||
if (cond->mEvents[_CONDITION_EVENT_ALL] != NULL)
|
|
||||||
{
|
|
||||||
CloseHandle(cond->mEvents[_CONDITION_EVENT_ALL]);
|
|
||||||
}
|
|
||||||
DeleteCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
#else
|
|
||||||
pthread_cond_destroy(cond);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int cnd_signal(cnd_t *cond)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
int haveWaiters;
|
|
||||||
|
|
||||||
/* Are there any waiters? */
|
|
||||||
EnterCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
haveWaiters = (cond->mWaitersCount > 0);
|
|
||||||
LeaveCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
|
|
||||||
/* If we have any waiting threads, send them a signal */
|
|
||||||
if(haveWaiters)
|
|
||||||
{
|
|
||||||
if (SetEvent(cond->mEvents[_CONDITION_EVENT_ONE]) == 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
return pthread_cond_signal(cond) == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int cnd_broadcast(cnd_t *cond)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
int haveWaiters;
|
|
||||||
|
|
||||||
/* Are there any waiters? */
|
|
||||||
EnterCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
haveWaiters = (cond->mWaitersCount > 0);
|
|
||||||
LeaveCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
|
|
||||||
/* If we have any waiting threads, send them a signal */
|
|
||||||
if(haveWaiters)
|
|
||||||
{
|
|
||||||
if (SetEvent(cond->mEvents[_CONDITION_EVENT_ALL]) == 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return thrd_success;
|
|
||||||
#else
|
|
||||||
return pthread_cond_signal(cond) == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
static int _cnd_timedwait_win32(cnd_t *cond, mtx_t *mtx, DWORD timeout)
|
|
||||||
{
|
|
||||||
int result, lastWaiter;
|
|
||||||
|
|
||||||
/* Increment number of waiters */
|
|
||||||
EnterCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
++ cond->mWaitersCount;
|
|
||||||
LeaveCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
|
|
||||||
/* Release the mutex while waiting for the condition (will decrease
|
|
||||||
the number of waiters when done)... */
|
|
||||||
mtx_unlock(mtx);
|
|
||||||
|
|
||||||
/* Wait for either event to become signaled due to cnd_signal() or
|
|
||||||
cnd_broadcast() being called */
|
|
||||||
result = WaitForMultipleObjects(2, cond->mEvents, FALSE, timeout);
|
|
||||||
if (result == WAIT_TIMEOUT)
|
|
||||||
{
|
|
||||||
return thrd_timeout;
|
|
||||||
}
|
|
||||||
else if (result == (int)WAIT_FAILED)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if we are the last waiter */
|
|
||||||
EnterCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
-- cond->mWaitersCount;
|
|
||||||
lastWaiter = (result == (WAIT_OBJECT_0 + _CONDITION_EVENT_ALL)) &&
|
|
||||||
(cond->mWaitersCount == 0);
|
|
||||||
LeaveCriticalSection(&cond->mWaitersCountLock);
|
|
||||||
|
|
||||||
/* If we are the last waiter to be notified to stop waiting, reset the event */
|
|
||||||
if (lastWaiter)
|
|
||||||
{
|
|
||||||
if (ResetEvent(cond->mEvents[_CONDITION_EVENT_ALL]) == 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Re-acquire the mutex */
|
|
||||||
mtx_lock(mtx);
|
|
||||||
|
|
||||||
return thrd_success;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int cnd_wait(cnd_t *cond, mtx_t *mtx)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
return _cnd_timedwait_win32(cond, mtx, INFINITE);
|
|
||||||
#else
|
|
||||||
return pthread_cond_wait(cond, mtx) == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int cnd_timedwait(cnd_t *cond, mtx_t *mtx, const struct timespec *ts)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
struct timespec now;
|
|
||||||
if (clock_gettime(CLOCK_REALTIME, &now) == 0)
|
|
||||||
{
|
|
||||||
DWORD delta = (DWORD) ((ts->tv_sec - now.tv_sec) * 1000 +
|
|
||||||
(ts->tv_nsec - now.tv_nsec + 500000) / 1000000);
|
|
||||||
return _cnd_timedwait_win32(cond, mtx, delta);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return thrd_error;
|
|
||||||
#else
|
|
||||||
int ret;
|
|
||||||
ret = pthread_cond_timedwait(cond, mtx, ts);
|
|
||||||
if (ret == ETIMEDOUT)
|
|
||||||
{
|
|
||||||
return thrd_timeout;
|
|
||||||
}
|
|
||||||
return ret == 0 ? thrd_success : thrd_error;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/** Information to pass to the new thread (what to run). */
|
|
||||||
typedef struct {
|
|
||||||
thrd_start_t mFunction; /**< Pointer to the function to be executed. */
|
|
||||||
void * mArg; /**< Function argument for the thread function. */
|
|
||||||
} _thread_start_info;
|
|
||||||
|
|
||||||
/* Thread wrapper function. */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
static unsigned WINAPI _thrd_wrapper_function(void * aArg)
|
|
||||||
#elif defined(_TTHREAD_POSIX_)
|
|
||||||
static void * _thrd_wrapper_function(void * aArg)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
thrd_start_t fun;
|
|
||||||
void *arg;
|
|
||||||
int res;
|
|
||||||
#if defined(_TTHREAD_POSIX_)
|
|
||||||
void *pres;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Get thread startup information */
|
|
||||||
_thread_start_info *ti = (_thread_start_info *) aArg;
|
|
||||||
fun = ti->mFunction;
|
|
||||||
arg = ti->mArg;
|
|
||||||
|
|
||||||
/* The thread is responsible for freeing the startup information */
|
|
||||||
free((void *)ti);
|
|
||||||
|
|
||||||
/* Call the actual client thread function */
|
|
||||||
res = fun(arg);
|
|
||||||
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
return res;
|
|
||||||
#else
|
|
||||||
pres = malloc(sizeof(int));
|
|
||||||
if (pres != NULL)
|
|
||||||
{
|
|
||||||
*(int*)pres = res;
|
|
||||||
}
|
|
||||||
return pres;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int thrd_create(thrd_t *thr, thrd_start_t func, void *arg)
|
|
||||||
{
|
|
||||||
/* Fill out the thread startup information (passed to the thread wrapper,
|
|
||||||
which will eventually free it) */
|
|
||||||
_thread_start_info* ti = (_thread_start_info*)malloc(sizeof(_thread_start_info));
|
|
||||||
if (ti == NULL)
|
|
||||||
{
|
|
||||||
return thrd_nomem;
|
|
||||||
}
|
|
||||||
ti->mFunction = func;
|
|
||||||
ti->mArg = arg;
|
|
||||||
|
|
||||||
/* Create the thread */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
*thr = (HANDLE)_beginthreadex(NULL, 0, _thrd_wrapper_function, (void *)ti, 0, NULL);
|
|
||||||
#elif defined(_TTHREAD_POSIX_)
|
|
||||||
if(pthread_create(thr, NULL, _thrd_wrapper_function, (void *)ti) != 0)
|
|
||||||
{
|
|
||||||
*thr = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Did we fail to create the thread? */
|
|
||||||
if(!*thr)
|
|
||||||
{
|
|
||||||
free(ti);
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
return thrd_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
thrd_t thrd_current(void)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
return GetCurrentThread();
|
|
||||||
#else
|
|
||||||
return pthread_self();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int thrd_detach(thrd_t thr)
|
|
||||||
{
|
|
||||||
/* FIXME! */
|
|
||||||
(void)thr;
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
int thrd_equal(thrd_t thr0, thrd_t thr1)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
return thr0 == thr1;
|
|
||||||
#else
|
|
||||||
return pthread_equal(thr0, thr1);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void thrd_exit(int res)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
ExitThread(res);
|
|
||||||
#else
|
|
||||||
void *pres = malloc(sizeof(int));
|
|
||||||
if (pres != NULL)
|
|
||||||
{
|
|
||||||
*(int*)pres = res;
|
|
||||||
}
|
|
||||||
pthread_exit(pres);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int thrd_join(thrd_t thr, int *res)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
if (WaitForSingleObject(thr, INFINITE) == WAIT_FAILED)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
if (res != NULL)
|
|
||||||
{
|
|
||||||
DWORD dwRes;
|
|
||||||
GetExitCodeThread(thr, &dwRes);
|
|
||||||
*res = dwRes;
|
|
||||||
}
|
|
||||||
#elif defined(_TTHREAD_POSIX_)
|
|
||||||
void *pres;
|
|
||||||
int ires = 0;
|
|
||||||
if (pthread_join(thr, &pres) != 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
if (pres != NULL)
|
|
||||||
{
|
|
||||||
ires = *(int*)pres;
|
|
||||||
free(pres);
|
|
||||||
}
|
|
||||||
if (res != NULL)
|
|
||||||
{
|
|
||||||
*res = ires;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return thrd_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
int thrd_sleep(const struct timespec *time_point, struct timespec *remaining)
|
|
||||||
{
|
|
||||||
struct timespec now;
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
DWORD delta;
|
|
||||||
#else
|
|
||||||
long delta;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Get the current time */
|
|
||||||
if (clock_gettime(CLOCK_REALTIME, &now) != 0)
|
|
||||||
return -2; // FIXME: Some specific error code?
|
|
||||||
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
/* Delta in milliseconds */
|
|
||||||
delta = (DWORD) ((time_point->tv_sec - now.tv_sec) * 1000 +
|
|
||||||
(time_point->tv_nsec - now.tv_nsec + 500000) / 1000000);
|
|
||||||
if (delta > 0)
|
|
||||||
{
|
|
||||||
Sleep(delta);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
/* Delta in microseconds */
|
|
||||||
delta = (time_point->tv_sec - now.tv_sec) * 1000000L +
|
|
||||||
(time_point->tv_nsec - now.tv_nsec + 500L) / 1000L;
|
|
||||||
|
|
||||||
/* On some systems, the usleep argument must be < 1000000 */
|
|
||||||
while (delta > 999999L)
|
|
||||||
{
|
|
||||||
usleep(999999);
|
|
||||||
delta -= 999999L;
|
|
||||||
}
|
|
||||||
if (delta > 0L)
|
|
||||||
{
|
|
||||||
usleep((useconds_t)delta);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* We don't support waking up prematurely (yet) */
|
|
||||||
if (remaining)
|
|
||||||
{
|
|
||||||
remaining->tv_sec = 0;
|
|
||||||
remaining->tv_nsec = 0;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void thrd_yield(void)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
Sleep(0);
|
|
||||||
#else
|
|
||||||
sched_yield();
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int tss_create(tss_t *key, tss_dtor_t dtor)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
/* FIXME: The destructor function is not supported yet... */
|
|
||||||
if (dtor != NULL)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
*key = TlsAlloc();
|
|
||||||
if (*key == TLS_OUT_OF_INDEXES)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
if (pthread_key_create(key, dtor) != 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return thrd_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
void tss_delete(tss_t key)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
TlsFree(key);
|
|
||||||
#else
|
|
||||||
pthread_key_delete(key);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void *tss_get(tss_t key)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
return TlsGetValue(key);
|
|
||||||
#else
|
|
||||||
return pthread_getspecific(key);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int tss_set(tss_t key, void *val)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
if (TlsSetValue(key, val) == 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
if (pthread_setspecific(key, val) != 0)
|
|
||||||
{
|
|
||||||
return thrd_error;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return thrd_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(_TTHREAD_EMULATE_CLOCK_GETTIME_)
|
|
||||||
int _tthread_clock_gettime(clockid_t clk_id, struct timespec *ts)
|
|
||||||
{
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
struct _timeb tb;
|
|
||||||
_ftime(&tb);
|
|
||||||
ts->tv_sec = (time_t)tb.time;
|
|
||||||
ts->tv_nsec = 1000000L * (long)tb.millitm;
|
|
||||||
#else
|
|
||||||
struct timeval tv;
|
|
||||||
gettimeofday(&tv, NULL);
|
|
||||||
ts->tv_sec = (time_t)tv.tv_sec;
|
|
||||||
ts->tv_nsec = 1000L * (long)tv.tv_usec;
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif // _TTHREAD_EMULATE_CLOCK_GETTIME_
|
|
||||||
|
|
@ -1,443 +0,0 @@
|
|||||||
/* -*- mode: c; tab-width: 2; indent-tabs-mode: nil; -*-
|
|
||||||
Copyright (c) 2012 Marcus Geelnard
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
|
||||||
warranty. In no event will the authors be held liable for any damages
|
|
||||||
arising from the use of this software.
|
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it
|
|
||||||
freely, subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
|
||||||
claim that you wrote the original software. If you use this software
|
|
||||||
in a product, an acknowledgment in the product documentation would be
|
|
||||||
appreciated but is not required.
|
|
||||||
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
misrepresented as being the original software.
|
|
||||||
|
|
||||||
3. This notice may not be removed or altered from any source
|
|
||||||
distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _TINYCTHREAD_H_
|
|
||||||
#define _TINYCTHREAD_H_
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @file
|
|
||||||
* @mainpage TinyCThread API Reference
|
|
||||||
*
|
|
||||||
* @section intro_sec Introduction
|
|
||||||
* TinyCThread is a minimal, portable implementation of basic threading
|
|
||||||
* classes for C.
|
|
||||||
*
|
|
||||||
* They closely mimic the functionality and naming of the C11 standard, and
|
|
||||||
* should be easily replaceable with the corresponding standard variants.
|
|
||||||
*
|
|
||||||
* @section port_sec Portability
|
|
||||||
* The Win32 variant uses the native Win32 API for implementing the thread
|
|
||||||
* classes, while for other systems, the POSIX threads API (pthread) is used.
|
|
||||||
*
|
|
||||||
* @section misc_sec Miscellaneous
|
|
||||||
* The following special keywords are available: #_Thread_local.
|
|
||||||
*
|
|
||||||
* For more detailed information, browse the different sections of this
|
|
||||||
* documentation. A good place to start is:
|
|
||||||
* tinycthread.h.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Which platform are we on? */
|
|
||||||
#if !defined(_TTHREAD_PLATFORM_DEFINED_)
|
|
||||||
#if defined(_WIN32) || defined(__WIN32__) || defined(__WINDOWS__)
|
|
||||||
#define _TTHREAD_WIN32_
|
|
||||||
#else
|
|
||||||
#define _TTHREAD_POSIX_
|
|
||||||
#endif
|
|
||||||
#define _TTHREAD_PLATFORM_DEFINED_
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Activate some POSIX functionality (e.g. clock_gettime and recursive mutexes) */
|
|
||||||
#if defined(_TTHREAD_POSIX_)
|
|
||||||
#undef _FEATURES_H
|
|
||||||
#if !defined(_GNU_SOURCE)
|
|
||||||
#define _GNU_SOURCE
|
|
||||||
#endif
|
|
||||||
#if !defined(_POSIX_C_SOURCE) || ((_POSIX_C_SOURCE - 0) < 199309L)
|
|
||||||
#undef _POSIX_C_SOURCE
|
|
||||||
#define _POSIX_C_SOURCE 199309L
|
|
||||||
#endif
|
|
||||||
#if !defined(_XOPEN_SOURCE) || ((_XOPEN_SOURCE - 0) < 500)
|
|
||||||
#undef _XOPEN_SOURCE
|
|
||||||
#define _XOPEN_SOURCE 500
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Generic includes */
|
|
||||||
#include <time.h>
|
|
||||||
|
|
||||||
/* Platform specific includes */
|
|
||||||
#if defined(_TTHREAD_POSIX_)
|
|
||||||
#include <sys/time.h>
|
|
||||||
#include <pthread.h>
|
|
||||||
#elif defined(_TTHREAD_WIN32_)
|
|
||||||
#ifndef WIN32_LEAN_AND_MEAN
|
|
||||||
#define WIN32_LEAN_AND_MEAN
|
|
||||||
#define __UNDEF_LEAN_AND_MEAN
|
|
||||||
#endif
|
|
||||||
#include <windows.h>
|
|
||||||
#ifdef __UNDEF_LEAN_AND_MEAN
|
|
||||||
#undef WIN32_LEAN_AND_MEAN
|
|
||||||
#undef __UNDEF_LEAN_AND_MEAN
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Workaround for missing TIME_UTC: If time.h doesn't provide TIME_UTC,
|
|
||||||
it's quite likely that libc does not support it either. Hence, fall back to
|
|
||||||
the only other supported time specifier: CLOCK_REALTIME (and if that fails,
|
|
||||||
we're probably emulating clock_gettime anyway, so anything goes). */
|
|
||||||
#ifndef TIME_UTC
|
|
||||||
#ifdef CLOCK_REALTIME
|
|
||||||
#define TIME_UTC CLOCK_REALTIME
|
|
||||||
#else
|
|
||||||
#define TIME_UTC 0
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Workaround for missing clock_gettime (most Windows compilers, afaik) */
|
|
||||||
#if defined(_TTHREAD_WIN32_) || defined(__APPLE_CC__)
|
|
||||||
#define _TTHREAD_EMULATE_CLOCK_GETTIME_
|
|
||||||
/* Emulate struct timespec */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
struct _ttherad_timespec {
|
|
||||||
time_t tv_sec;
|
|
||||||
long tv_nsec;
|
|
||||||
};
|
|
||||||
#define timespec _ttherad_timespec
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Emulate clockid_t */
|
|
||||||
typedef int _tthread_clockid_t;
|
|
||||||
#define clockid_t _tthread_clockid_t
|
|
||||||
|
|
||||||
/* Emulate clock_gettime */
|
|
||||||
int _tthread_clock_gettime(clockid_t clk_id, struct timespec *ts);
|
|
||||||
#define clock_gettime _tthread_clock_gettime
|
|
||||||
#ifndef CLOCK_REALTIME
|
|
||||||
#define CLOCK_REALTIME 0
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/** TinyCThread version (major number). */
|
|
||||||
#define TINYCTHREAD_VERSION_MAJOR 1
|
|
||||||
/** TinyCThread version (minor number). */
|
|
||||||
#define TINYCTHREAD_VERSION_MINOR 1
|
|
||||||
/** TinyCThread version (full version). */
|
|
||||||
#define TINYCTHREAD_VERSION (TINYCTHREAD_VERSION_MAJOR * 100 + TINYCTHREAD_VERSION_MINOR)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @def _Thread_local
|
|
||||||
* Thread local storage keyword.
|
|
||||||
* A variable that is declared with the @c _Thread_local keyword makes the
|
|
||||||
* value of the variable local to each thread (known as thread-local storage,
|
|
||||||
* or TLS). Example usage:
|
|
||||||
* @code
|
|
||||||
* // This variable is local to each thread.
|
|
||||||
* _Thread_local int variable;
|
|
||||||
* @endcode
|
|
||||||
* @note The @c _Thread_local keyword is a macro that maps to the corresponding
|
|
||||||
* compiler directive (e.g. @c __declspec(thread)).
|
|
||||||
* @note This directive is currently not supported on Mac OS X (it will give
|
|
||||||
* a compiler error), since compile-time TLS is not supported in the Mac OS X
|
|
||||||
* executable format. Also, some older versions of MinGW (before GCC 4.x) do
|
|
||||||
* not support this directive.
|
|
||||||
* @hideinitializer
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* FIXME: Check for a PROPER value of __STDC_VERSION__ to know if we have C11 */
|
|
||||||
#if !(defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201102L)) && !defined(_Thread_local)
|
|
||||||
#if defined(__GNUC__) || defined(__INTEL_COMPILER) || defined(__SUNPRO_CC) || defined(__IBMCPP__)
|
|
||||||
#define _Thread_local __thread
|
|
||||||
#else
|
|
||||||
#define _Thread_local __declspec(thread)
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Macros */
|
|
||||||
#define TSS_DTOR_ITERATIONS 0
|
|
||||||
|
|
||||||
/* Function return values */
|
|
||||||
#define thrd_error 0 /**< The requested operation failed */
|
|
||||||
#define thrd_success 1 /**< The requested operation succeeded */
|
|
||||||
#define thrd_timeout 2 /**< The time specified in the call was reached without acquiring the requested resource */
|
|
||||||
#define thrd_busy 3 /**< The requested operation failed because a tesource requested by a test and return function is already in use */
|
|
||||||
#define thrd_nomem 4 /**< The requested operation failed because it was unable to allocate memory */
|
|
||||||
|
|
||||||
/* Mutex types */
|
|
||||||
#define mtx_plain 1
|
|
||||||
#define mtx_timed 2
|
|
||||||
#define mtx_try 4
|
|
||||||
#define mtx_recursive 8
|
|
||||||
|
|
||||||
/* Mutex */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
typedef struct {
|
|
||||||
CRITICAL_SECTION mHandle; /* Critical section handle */
|
|
||||||
int mAlreadyLocked; /* TRUE if the mutex is already locked */
|
|
||||||
int mRecursive; /* TRUE if the mutex is recursive */
|
|
||||||
} mtx_t;
|
|
||||||
#else
|
|
||||||
typedef pthread_mutex_t mtx_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Create a mutex object.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @param type Bit-mask that must have one of the following six values:
|
|
||||||
* @li @c mtx_plain for a simple non-recursive mutex
|
|
||||||
* @li @c mtx_timed for a non-recursive mutex that supports timeout
|
|
||||||
* @li @c mtx_try for a non-recursive mutex that supports test and return
|
|
||||||
* @li @c mtx_plain | @c mtx_recursive (same as @c mtx_plain, but recursive)
|
|
||||||
* @li @c mtx_timed | @c mtx_recursive (same as @c mtx_timed, but recursive)
|
|
||||||
* @li @c mtx_try | @c mtx_recursive (same as @c mtx_try, but recursive)
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int mtx_init(mtx_t *mtx, int type);
|
|
||||||
|
|
||||||
/** Release any resources used by the given mutex.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
*/
|
|
||||||
void mtx_destroy(mtx_t *mtx);
|
|
||||||
|
|
||||||
/** Lock the given mutex.
|
|
||||||
* Blocks until the given mutex can be locked. If the mutex is non-recursive, and
|
|
||||||
* the calling thread already has a lock on the mutex, this call will block
|
|
||||||
* forever.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int mtx_lock(mtx_t *mtx);
|
|
||||||
|
|
||||||
/** NOT YET IMPLEMENTED.
|
|
||||||
*/
|
|
||||||
int mtx_timedlock(mtx_t *mtx, const struct timespec *ts);
|
|
||||||
|
|
||||||
/** Try to lock the given mutex.
|
|
||||||
* The specified mutex shall support either test and return or timeout. If the
|
|
||||||
* mutex is already locked, the function returns without blocking.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_busy if the resource
|
|
||||||
* requested is already in use, or @ref thrd_error if the request could not be
|
|
||||||
* honored.
|
|
||||||
*/
|
|
||||||
int mtx_trylock(mtx_t *mtx);
|
|
||||||
|
|
||||||
/** Unlock the given mutex.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int mtx_unlock(mtx_t *mtx);
|
|
||||||
|
|
||||||
/* Condition variable */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
typedef struct {
|
|
||||||
HANDLE mEvents[2]; /* Signal and broadcast event HANDLEs. */
|
|
||||||
unsigned int mWaitersCount; /* Count of the number of waiters. */
|
|
||||||
CRITICAL_SECTION mWaitersCountLock; /* Serialize access to mWaitersCount. */
|
|
||||||
} cnd_t;
|
|
||||||
#else
|
|
||||||
typedef pthread_cond_t cnd_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Create a condition variable object.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int cnd_init(cnd_t *cond);
|
|
||||||
|
|
||||||
/** Release any resources used by the given condition variable.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
*/
|
|
||||||
void cnd_destroy(cnd_t *cond);
|
|
||||||
|
|
||||||
/** Signal a condition variable.
|
|
||||||
* Unblocks one of the threads that are blocked on the given condition variable
|
|
||||||
* at the time of the call. If no threads are blocked on the condition variable
|
|
||||||
* at the time of the call, the function does nothing and return success.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int cnd_signal(cnd_t *cond);
|
|
||||||
|
|
||||||
/** Broadcast a condition variable.
|
|
||||||
* Unblocks all of the threads that are blocked on the given condition variable
|
|
||||||
* at the time of the call. If no threads are blocked on the condition variable
|
|
||||||
* at the time of the call, the function does nothing and return success.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int cnd_broadcast(cnd_t *cond);
|
|
||||||
|
|
||||||
/** Wait for a condition variable to become signaled.
|
|
||||||
* The function atomically unlocks the given mutex and endeavors to block until
|
|
||||||
* the given condition variable is signaled by a call to cnd_signal or to
|
|
||||||
* cnd_broadcast. When the calling thread becomes unblocked it locks the mutex
|
|
||||||
* before it returns.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int cnd_wait(cnd_t *cond, mtx_t *mtx);
|
|
||||||
|
|
||||||
/** Wait for a condition variable to become signaled.
|
|
||||||
* The function atomically unlocks the given mutex and endeavors to block until
|
|
||||||
* the given condition variable is signaled by a call to cnd_signal or to
|
|
||||||
* cnd_broadcast, or until after the specified time. When the calling thread
|
|
||||||
* becomes unblocked it locks the mutex before it returns.
|
|
||||||
* @param cond A condition variable object.
|
|
||||||
* @param mtx A mutex object.
|
|
||||||
* @param xt A point in time at which the request will time out (absolute time).
|
|
||||||
* @return @ref thrd_success upon success, or @ref thrd_timeout if the time
|
|
||||||
* specified in the call was reached without acquiring the requested resource, or
|
|
||||||
* @ref thrd_error if the request could not be honored.
|
|
||||||
*/
|
|
||||||
int cnd_timedwait(cnd_t *cond, mtx_t *mtx, const struct timespec *ts);
|
|
||||||
|
|
||||||
/* Thread */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
typedef HANDLE thrd_t;
|
|
||||||
#else
|
|
||||||
typedef pthread_t thrd_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Thread start function.
|
|
||||||
* Any thread that is started with the @ref thrd_create() function must be
|
|
||||||
* started through a function of this type.
|
|
||||||
* @param arg The thread argument (the @c arg argument of the corresponding
|
|
||||||
* @ref thrd_create() call).
|
|
||||||
* @return The thread return value, which can be obtained by another thread
|
|
||||||
* by using the @ref thrd_join() function.
|
|
||||||
*/
|
|
||||||
typedef int (*thrd_start_t)(void *arg);
|
|
||||||
|
|
||||||
/** Create a new thread.
|
|
||||||
* @param thr Identifier of the newly created thread.
|
|
||||||
* @param func A function pointer to the function that will be executed in
|
|
||||||
* the new thread.
|
|
||||||
* @param arg An argument to the thread function.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_nomem if no memory could
|
|
||||||
* be allocated for the thread requested, or @ref thrd_error if the request
|
|
||||||
* could not be honored.
|
|
||||||
* @note A thread’s identifier may be reused for a different thread once the
|
|
||||||
* original thread has exited and either been detached or joined to another
|
|
||||||
* thread.
|
|
||||||
*/
|
|
||||||
int thrd_create(thrd_t *thr, thrd_start_t func, void *arg);
|
|
||||||
|
|
||||||
/** Identify the calling thread.
|
|
||||||
* @return The identifier of the calling thread.
|
|
||||||
*/
|
|
||||||
thrd_t thrd_current(void);
|
|
||||||
|
|
||||||
/** NOT YET IMPLEMENTED.
|
|
||||||
*/
|
|
||||||
int thrd_detach(thrd_t thr);
|
|
||||||
|
|
||||||
/** Compare two thread identifiers.
|
|
||||||
* The function determines if two thread identifiers refer to the same thread.
|
|
||||||
* @return Zero if the two thread identifiers refer to different threads.
|
|
||||||
* Otherwise a nonzero value is returned.
|
|
||||||
*/
|
|
||||||
int thrd_equal(thrd_t thr0, thrd_t thr1);
|
|
||||||
|
|
||||||
/** Terminate execution of the calling thread.
|
|
||||||
* @param res Result code of the calling thread.
|
|
||||||
*/
|
|
||||||
void thrd_exit(int res);
|
|
||||||
|
|
||||||
/** Wait for a thread to terminate.
|
|
||||||
* The function joins the given thread with the current thread by blocking
|
|
||||||
* until the other thread has terminated.
|
|
||||||
* @param thr The thread to join with.
|
|
||||||
* @param res If this pointer is not NULL, the function will store the result
|
|
||||||
* code of the given thread in the integer pointed to by @c res.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int thrd_join(thrd_t thr, int *res);
|
|
||||||
|
|
||||||
/** Put the calling thread to sleep.
|
|
||||||
* Suspend execution of the calling thread.
|
|
||||||
* @param time_point A point in time at which the thread will resume (absolute time).
|
|
||||||
* @param remaining If non-NULL, this parameter will hold the remaining time until
|
|
||||||
* time_point upon return. This will typically be zero, but if
|
|
||||||
* the thread was woken up by a signal that is not ignored before
|
|
||||||
* time_point was reached @c remaining will hold a positive
|
|
||||||
* time.
|
|
||||||
* @return 0 (zero) on successful sleep, or -1 if an interrupt occurred.
|
|
||||||
*/
|
|
||||||
int thrd_sleep(const struct timespec *time_point, struct timespec *remaining);
|
|
||||||
|
|
||||||
/** Yield execution to another thread.
|
|
||||||
* Permit other threads to run, even if the current thread would ordinarily
|
|
||||||
* continue to run.
|
|
||||||
*/
|
|
||||||
void thrd_yield(void);
|
|
||||||
|
|
||||||
/* Thread local storage */
|
|
||||||
#if defined(_TTHREAD_WIN32_)
|
|
||||||
typedef DWORD tss_t;
|
|
||||||
#else
|
|
||||||
typedef pthread_key_t tss_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** Destructor function for a thread-specific storage.
|
|
||||||
* @param val The value of the destructed thread-specific storage.
|
|
||||||
*/
|
|
||||||
typedef void (*tss_dtor_t)(void *val);
|
|
||||||
|
|
||||||
/** Create a thread-specific storage.
|
|
||||||
* @param key The unique key identifier that will be set if the function is
|
|
||||||
* successful.
|
|
||||||
* @param dtor Destructor function. This can be NULL.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
* @note The destructor function is not supported under Windows. If @c dtor is
|
|
||||||
* not NULL when calling this function under Windows, the function will fail
|
|
||||||
* and return @ref thrd_error.
|
|
||||||
*/
|
|
||||||
int tss_create(tss_t *key, tss_dtor_t dtor);
|
|
||||||
|
|
||||||
/** Delete a thread-specific storage.
|
|
||||||
* The function releases any resources used by the given thread-specific
|
|
||||||
* storage.
|
|
||||||
* @param key The key that shall be deleted.
|
|
||||||
*/
|
|
||||||
void tss_delete(tss_t key);
|
|
||||||
|
|
||||||
/** Get the value for a thread-specific storage.
|
|
||||||
* @param key The thread-specific storage identifier.
|
|
||||||
* @return The value for the current thread held in the given thread-specific
|
|
||||||
* storage.
|
|
||||||
*/
|
|
||||||
void *tss_get(tss_t key);
|
|
||||||
|
|
||||||
/** Set the value for a thread-specific storage.
|
|
||||||
* @param key The thread-specific storage identifier.
|
|
||||||
* @param val The value of the thread-specific storage to set for the current
|
|
||||||
* thread.
|
|
||||||
* @return @ref thrd_success on success, or @ref thrd_error if the request could
|
|
||||||
* not be honored.
|
|
||||||
*/
|
|
||||||
int tss_set(tss_t key, void *val);
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* _TINYTHREAD_H_ */
|
|
||||||
|
|
@ -1,247 +0,0 @@
|
|||||||
// ISO C9x compliant stdint.h for Microsoft Visual Studio
|
|
||||||
// Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124
|
|
||||||
//
|
|
||||||
// Copyright (c) 2006-2008 Alexander Chemeris
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are met:
|
|
||||||
//
|
|
||||||
// 1. Redistributions of source code must retain the above copyright notice,
|
|
||||||
// this list of conditions and the following disclaimer.
|
|
||||||
//
|
|
||||||
// 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer in the
|
|
||||||
// documentation and/or other materials provided with the distribution.
|
|
||||||
//
|
|
||||||
// 3. The name of the author may be used to endorse or promote products
|
|
||||||
// derived from this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
||||||
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
||||||
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
|
|
||||||
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
||||||
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
||||||
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
||||||
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
||||||
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
#ifndef _MSC_VER // [
|
|
||||||
#error "Use this header only with Microsoft Visual C++ compilers!"
|
|
||||||
#endif // _MSC_VER ]
|
|
||||||
|
|
||||||
#ifndef _MSC_STDINT_H_ // [
|
|
||||||
#define _MSC_STDINT_H_
|
|
||||||
|
|
||||||
#if _MSC_VER > 1000
|
|
||||||
#pragma once
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <limits.h>
|
|
||||||
|
|
||||||
// For Visual Studio 6 in C++ mode and for many Visual Studio versions when
|
|
||||||
// compiling for ARM we should wrap <wchar.h> include with 'extern "C++" {}'
|
|
||||||
// or compiler give many errors like this:
|
|
||||||
// error C2733: second C linkage of overloaded function 'wmemchr' not allowed
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
# include <wchar.h>
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Define _W64 macros to mark types changing their size, like intptr_t.
|
|
||||||
#ifndef _W64
|
|
||||||
# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && _MSC_VER >= 1300
|
|
||||||
# define _W64 __w64
|
|
||||||
# else
|
|
||||||
# define _W64
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
// 7.18.1 Integer types
|
|
||||||
|
|
||||||
// 7.18.1.1 Exact-width integer types
|
|
||||||
|
|
||||||
// Visual Studio 6 and Embedded Visual C++ 4 doesn't
|
|
||||||
// realize that, e.g. char has the same size as __int8
|
|
||||||
// so we give up on __intX for them.
|
|
||||||
#if (_MSC_VER < 1300)
|
|
||||||
typedef signed char int8_t;
|
|
||||||
typedef signed short int16_t;
|
|
||||||
typedef signed int int32_t;
|
|
||||||
typedef unsigned char uint8_t;
|
|
||||||
typedef unsigned short uint16_t;
|
|
||||||
typedef unsigned int uint32_t;
|
|
||||||
#else
|
|
||||||
typedef signed __int8 int8_t;
|
|
||||||
typedef signed __int16 int16_t;
|
|
||||||
typedef signed __int32 int32_t;
|
|
||||||
typedef unsigned __int8 uint8_t;
|
|
||||||
typedef unsigned __int16 uint16_t;
|
|
||||||
typedef unsigned __int32 uint32_t;
|
|
||||||
#endif
|
|
||||||
typedef signed __int64 int64_t;
|
|
||||||
typedef unsigned __int64 uint64_t;
|
|
||||||
|
|
||||||
|
|
||||||
// 7.18.1.2 Minimum-width integer types
|
|
||||||
typedef int8_t int_least8_t;
|
|
||||||
typedef int16_t int_least16_t;
|
|
||||||
typedef int32_t int_least32_t;
|
|
||||||
typedef int64_t int_least64_t;
|
|
||||||
typedef uint8_t uint_least8_t;
|
|
||||||
typedef uint16_t uint_least16_t;
|
|
||||||
typedef uint32_t uint_least32_t;
|
|
||||||
typedef uint64_t uint_least64_t;
|
|
||||||
|
|
||||||
// 7.18.1.3 Fastest minimum-width integer types
|
|
||||||
typedef int8_t int_fast8_t;
|
|
||||||
typedef int16_t int_fast16_t;
|
|
||||||
typedef int32_t int_fast32_t;
|
|
||||||
typedef int64_t int_fast64_t;
|
|
||||||
typedef uint8_t uint_fast8_t;
|
|
||||||
typedef uint16_t uint_fast16_t;
|
|
||||||
typedef uint32_t uint_fast32_t;
|
|
||||||
typedef uint64_t uint_fast64_t;
|
|
||||||
|
|
||||||
// 7.18.1.4 Integer types capable of holding object pointers
|
|
||||||
#ifdef _WIN64 // [
|
|
||||||
typedef signed __int64 intptr_t;
|
|
||||||
typedef unsigned __int64 uintptr_t;
|
|
||||||
#else // _WIN64 ][
|
|
||||||
typedef _W64 signed int intptr_t;
|
|
||||||
typedef _W64 unsigned int uintptr_t;
|
|
||||||
#endif // _WIN64 ]
|
|
||||||
|
|
||||||
// 7.18.1.5 Greatest-width integer types
|
|
||||||
typedef int64_t intmax_t;
|
|
||||||
typedef uint64_t uintmax_t;
|
|
||||||
|
|
||||||
|
|
||||||
// 7.18.2 Limits of specified-width integer types
|
|
||||||
|
|
||||||
#if !defined(__cplusplus) || defined(__STDC_LIMIT_MACROS) // [ See footnote 220 at page 257 and footnote 221 at page 259
|
|
||||||
|
|
||||||
// 7.18.2.1 Limits of exact-width integer types
|
|
||||||
#define INT8_MIN ((int8_t)_I8_MIN)
|
|
||||||
#define INT8_MAX _I8_MAX
|
|
||||||
#define INT16_MIN ((int16_t)_I16_MIN)
|
|
||||||
#define INT16_MAX _I16_MAX
|
|
||||||
#define INT32_MIN ((int32_t)_I32_MIN)
|
|
||||||
#define INT32_MAX _I32_MAX
|
|
||||||
#define INT64_MIN ((int64_t)_I64_MIN)
|
|
||||||
#define INT64_MAX _I64_MAX
|
|
||||||
#define UINT8_MAX _UI8_MAX
|
|
||||||
#define UINT16_MAX _UI16_MAX
|
|
||||||
#define UINT32_MAX _UI32_MAX
|
|
||||||
#define UINT64_MAX _UI64_MAX
|
|
||||||
|
|
||||||
// 7.18.2.2 Limits of minimum-width integer types
|
|
||||||
#define INT_LEAST8_MIN INT8_MIN
|
|
||||||
#define INT_LEAST8_MAX INT8_MAX
|
|
||||||
#define INT_LEAST16_MIN INT16_MIN
|
|
||||||
#define INT_LEAST16_MAX INT16_MAX
|
|
||||||
#define INT_LEAST32_MIN INT32_MIN
|
|
||||||
#define INT_LEAST32_MAX INT32_MAX
|
|
||||||
#define INT_LEAST64_MIN INT64_MIN
|
|
||||||
#define INT_LEAST64_MAX INT64_MAX
|
|
||||||
#define UINT_LEAST8_MAX UINT8_MAX
|
|
||||||
#define UINT_LEAST16_MAX UINT16_MAX
|
|
||||||
#define UINT_LEAST32_MAX UINT32_MAX
|
|
||||||
#define UINT_LEAST64_MAX UINT64_MAX
|
|
||||||
|
|
||||||
// 7.18.2.3 Limits of fastest minimum-width integer types
|
|
||||||
#define INT_FAST8_MIN INT8_MIN
|
|
||||||
#define INT_FAST8_MAX INT8_MAX
|
|
||||||
#define INT_FAST16_MIN INT16_MIN
|
|
||||||
#define INT_FAST16_MAX INT16_MAX
|
|
||||||
#define INT_FAST32_MIN INT32_MIN
|
|
||||||
#define INT_FAST32_MAX INT32_MAX
|
|
||||||
#define INT_FAST64_MIN INT64_MIN
|
|
||||||
#define INT_FAST64_MAX INT64_MAX
|
|
||||||
#define UINT_FAST8_MAX UINT8_MAX
|
|
||||||
#define UINT_FAST16_MAX UINT16_MAX
|
|
||||||
#define UINT_FAST32_MAX UINT32_MAX
|
|
||||||
#define UINT_FAST64_MAX UINT64_MAX
|
|
||||||
|
|
||||||
// 7.18.2.4 Limits of integer types capable of holding object pointers
|
|
||||||
#ifdef _WIN64 // [
|
|
||||||
# define INTPTR_MIN INT64_MIN
|
|
||||||
# define INTPTR_MAX INT64_MAX
|
|
||||||
# define UINTPTR_MAX UINT64_MAX
|
|
||||||
#else // _WIN64 ][
|
|
||||||
# define INTPTR_MIN INT32_MIN
|
|
||||||
# define INTPTR_MAX INT32_MAX
|
|
||||||
# define UINTPTR_MAX UINT32_MAX
|
|
||||||
#endif // _WIN64 ]
|
|
||||||
|
|
||||||
// 7.18.2.5 Limits of greatest-width integer types
|
|
||||||
#define INTMAX_MIN INT64_MIN
|
|
||||||
#define INTMAX_MAX INT64_MAX
|
|
||||||
#define UINTMAX_MAX UINT64_MAX
|
|
||||||
|
|
||||||
// 7.18.3 Limits of other integer types
|
|
||||||
|
|
||||||
#ifdef _WIN64 // [
|
|
||||||
# define PTRDIFF_MIN _I64_MIN
|
|
||||||
# define PTRDIFF_MAX _I64_MAX
|
|
||||||
#else // _WIN64 ][
|
|
||||||
# define PTRDIFF_MIN _I32_MIN
|
|
||||||
# define PTRDIFF_MAX _I32_MAX
|
|
||||||
#endif // _WIN64 ]
|
|
||||||
|
|
||||||
#define SIG_ATOMIC_MIN INT_MIN
|
|
||||||
#define SIG_ATOMIC_MAX INT_MAX
|
|
||||||
|
|
||||||
#ifndef SIZE_MAX // [
|
|
||||||
# ifdef _WIN64 // [
|
|
||||||
# define SIZE_MAX _UI64_MAX
|
|
||||||
# else // _WIN64 ][
|
|
||||||
# define SIZE_MAX _UI32_MAX
|
|
||||||
# endif // _WIN64 ]
|
|
||||||
#endif // SIZE_MAX ]
|
|
||||||
|
|
||||||
// WCHAR_MIN and WCHAR_MAX are also defined in <wchar.h>
|
|
||||||
#ifndef WCHAR_MIN // [
|
|
||||||
# define WCHAR_MIN 0
|
|
||||||
#endif // WCHAR_MIN ]
|
|
||||||
#ifndef WCHAR_MAX // [
|
|
||||||
# define WCHAR_MAX _UI16_MAX
|
|
||||||
#endif // WCHAR_MAX ]
|
|
||||||
|
|
||||||
#define WINT_MIN 0
|
|
||||||
#define WINT_MAX _UI16_MAX
|
|
||||||
|
|
||||||
#endif // __STDC_LIMIT_MACROS ]
|
|
||||||
|
|
||||||
|
|
||||||
// 7.18.4 Limits of other integer types
|
|
||||||
|
|
||||||
#if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS) // [ See footnote 224 at page 260
|
|
||||||
|
|
||||||
// 7.18.4.1 Macros for minimum-width integer constants
|
|
||||||
|
|
||||||
#define INT8_C(val) val##i8
|
|
||||||
#define INT16_C(val) val##i16
|
|
||||||
#define INT32_C(val) val##i32
|
|
||||||
#define INT64_C(val) val##i64
|
|
||||||
|
|
||||||
#define UINT8_C(val) val##ui8
|
|
||||||
#define UINT16_C(val) val##ui16
|
|
||||||
#define UINT32_C(val) val##ui32
|
|
||||||
#define UINT64_C(val) val##ui64
|
|
||||||
|
|
||||||
// 7.18.4.2 Macros for greatest-width integer constants
|
|
||||||
#define INTMAX_C INT64_C
|
|
||||||
#define UINTMAX_C UINT64_C
|
|
||||||
|
|
||||||
#endif // __STDC_CONSTANT_MACROS ]
|
|
||||||
|
|
||||||
|
|
||||||
#endif // _MSC_STDINT_H_ ]
|
|
@ -1,34 +0,0 @@
|
|||||||
|
|
||||||
# NOTE: The order of this list determines the order of items in the Guides
|
|
||||||
# (i.e. Pages) list in the generated documentation
|
|
||||||
set(GLFW_DOXYGEN_SOURCES
|
|
||||||
"include/GLFW/glfw3.h"
|
|
||||||
"include/GLFW/glfw3native.h"
|
|
||||||
"docs/main.dox"
|
|
||||||
"docs/news.dox"
|
|
||||||
"docs/quick.dox"
|
|
||||||
"docs/moving.dox"
|
|
||||||
"docs/compile.dox"
|
|
||||||
"docs/build.dox"
|
|
||||||
"docs/intro.dox"
|
|
||||||
"docs/context.dox"
|
|
||||||
"docs/monitor.dox"
|
|
||||||
"docs/window.dox"
|
|
||||||
"docs/input.dox"
|
|
||||||
"docs/vulkan.dox"
|
|
||||||
"docs/compat.dox"
|
|
||||||
"docs/internal.dox")
|
|
||||||
|
|
||||||
# Format the source list into a Doxyfile INPUT value that Doxygen can parse
|
|
||||||
foreach(path IN LISTS GLFW_DOXYGEN_SOURCES)
|
|
||||||
set(GLFW_DOXYGEN_INPUT "${GLFW_DOXYGEN_INPUT} \\\n\"${GLFW_SOURCE_DIR}/${path}\"")
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
configure_file(Doxyfile.in Doxyfile @ONLY)
|
|
||||||
|
|
||||||
add_custom_target(docs ALL "${DOXYGEN_EXECUTABLE}"
|
|
||||||
WORKING_DIRECTORY "${GLFW_BINARY_DIR}/docs"
|
|
||||||
COMMENT "Generating HTML documentation" VERBATIM)
|
|
||||||
|
|
||||||
set_target_properties(docs PROPERTIES FOLDER "GLFW3")
|
|
||||||
|
|
@ -1,10 +0,0 @@
|
|||||||
|
|
||||||
* @elmindreda
|
|
||||||
|
|
||||||
src/wl_* @linkmauve
|
|
||||||
|
|
||||||
docs/*.css @glfw/webdev
|
|
||||||
docs/*.scss @glfw/webdev
|
|
||||||
docs/*.html @glfw/webdev
|
|
||||||
docs/*.xml @glfw/webdev
|
|
||||||
|
|
@ -1,391 +0,0 @@
|
|||||||
# Contribution Guide
|
|
||||||
|
|
||||||
## Contents
|
|
||||||
|
|
||||||
- [Asking a question](#asking-a-question)
|
|
||||||
- [Reporting a bug](#reporting-a-bug)
|
|
||||||
- [Reporting a compile or link bug](#reporting-a-compile-or-link-bug)
|
|
||||||
- [Reporting a segfault or other crash bug](#reporting-a-segfault-or-other-crash-bug)
|
|
||||||
- [Reporting a context creation bug](#reporting-a-context-creation-bug)
|
|
||||||
- [Reporting a monitor or video mode bug](#reporting-a-monitor-or-video-mode-bug)
|
|
||||||
- [Reporting a window, input or event bug](#reporting-a-window-input-or-event-bug)
|
|
||||||
- [Reporting some other library bug](#reporting-some-other-library-bug)
|
|
||||||
- [Reporting a documentation bug](#reporting-a-documentation-bug)
|
|
||||||
- [Reporting a website bug](#reporting-a-website-bug)
|
|
||||||
- [Requesting a feature](#requesting-a-feature)
|
|
||||||
- [Contributing a bug fix](#contributing-a-bug-fix)
|
|
||||||
- [Contributing a feature](#contributing-a-feature)
|
|
||||||
|
|
||||||
|
|
||||||
## Asking a question
|
|
||||||
|
|
||||||
Questions about how to use GLFW should be asked either in the [support
|
|
||||||
section](https://discourse.glfw.org/c/support) of the forum, under the [Stack
|
|
||||||
Overflow tag](https://stackoverflow.com/questions/tagged/glfw) or [Game
|
|
||||||
Development tag](https://gamedev.stackexchange.com/questions/tagged/glfw) on
|
|
||||||
Stack Exchange or in the IRC channel `#glfw` on
|
|
||||||
[Libera.Chat](https://libera.chat/).
|
|
||||||
|
|
||||||
Questions about the design or implementation of GLFW or about future plans
|
|
||||||
should be asked in the [dev section](https://discourse.glfw.org/c/dev) of the
|
|
||||||
forum or in the IRC channel. Please don't open a GitHub issue to discuss design
|
|
||||||
questions without first checking with a maintainer.
|
|
||||||
|
|
||||||
|
|
||||||
## Reporting a bug
|
|
||||||
|
|
||||||
If GLFW is behaving unexpectedly at run-time, start by setting an [error
|
|
||||||
callback](https://www.glfw.org/docs/latest/intro_guide.html#error_handling).
|
|
||||||
GLFW will often tell you the cause of an error via this callback. If it
|
|
||||||
doesn't, that might be a separate bug.
|
|
||||||
|
|
||||||
If GLFW is crashing or triggering asserts, make sure that all your object
|
|
||||||
handles and other pointers are valid.
|
|
||||||
|
|
||||||
For bugs where it makes sense, a short, self contained example is absolutely
|
|
||||||
invaluable. Just put it inline in the body text. Note that if the bug is
|
|
||||||
reproducible with one of the test programs that come with GLFW, just mention
|
|
||||||
that instead.
|
|
||||||
|
|
||||||
__Don't worry about adding too much information__. Unimportant information can
|
|
||||||
be abbreviated or removed later, but missing information can stall bug fixing,
|
|
||||||
especially when your schedule doesn't align with that of the maintainer.
|
|
||||||
|
|
||||||
__Please provide text as text, not as images__. This includes code, error
|
|
||||||
messages and any other text. Text in images cannot be found by other users
|
|
||||||
searching for the same problem and may have to be re-typed by maintainers when
|
|
||||||
debugging.
|
|
||||||
|
|
||||||
You don't need to manually indent your code or other text to quote it with
|
|
||||||
GitHub Markdown; just surround it with triple backticks:
|
|
||||||
|
|
||||||
```
|
|
||||||
Some quoted text.
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also add syntax highlighting by appending the common file extension:
|
|
||||||
|
|
||||||
```c
|
|
||||||
int five(void)
|
|
||||||
{
|
|
||||||
return 5;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
There are issue labels for both platforms and GPU manufacturers, so there is no
|
|
||||||
need to mention these in the subject line. If you do, it will be removed when
|
|
||||||
the issue is labeled.
|
|
||||||
|
|
||||||
If your bug is already reported, please add any new information you have, or if
|
|
||||||
it already has everything, give it a :+1:.
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a compile or link bug
|
|
||||||
|
|
||||||
__Note:__ GLFW needs many system APIs to do its job, which on some platforms
|
|
||||||
means linking to many system libraries. If you are using GLFW as a static
|
|
||||||
library, that means your application needs to link to these in addition to GLFW.
|
|
||||||
|
|
||||||
__Note:__ Check the [Compiling
|
|
||||||
GLFW](https://www.glfw.org/docs/latest/compile.html) guide and or [Building
|
|
||||||
applications](https://www.glfw.org/docs/latest/build.html) guide for before
|
|
||||||
opening an issue of this kind. Most issues are caused by a missing package or
|
|
||||||
linker flag.
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`) and the __compiler name and version__ (e.g. `Visual
|
|
||||||
C++ 2015 Update 2`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
Please also include the __complete build log__ from your compiler and linker,
|
|
||||||
even if it's long. It can always be shortened later, if necessary.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
Compiler version:
|
|
||||||
Release or commit:
|
|
||||||
Build log:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a segfault or other crash bug
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
Please also include any __error messages__ provided to your application via the
|
|
||||||
[error
|
|
||||||
callback](https://www.glfw.org/docs/latest/intro_guide.html#error_handling) and
|
|
||||||
the __full call stack__ of the crash, or if the crash does not occur in debug
|
|
||||||
mode, mention that instead.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
Release or commit:
|
|
||||||
Error messages:
|
|
||||||
Call stack:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a context creation bug
|
|
||||||
|
|
||||||
__Note:__ Windows ships with graphics drivers that do not support OpenGL. If
|
|
||||||
GLFW says that your machine lacks support for OpenGL, it very likely does.
|
|
||||||
Install drivers from the computer manufacturer or graphics card manufacturer
|
|
||||||
([Nvidia](https://www.geforce.com/drivers),
|
|
||||||
[AMD](https://www.amd.com/en/support),
|
|
||||||
[Intel](https://www-ssl.intel.com/content/www/us/en/support/detect.html)) to
|
|
||||||
fix this.
|
|
||||||
|
|
||||||
__Note:__ AMD only supports OpenGL ES on Windows via EGL. See the
|
|
||||||
[GLFW\_CONTEXT\_CREATION\_API](https://www.glfw.org/docs/latest/window_guide.html#window_hints_ctx)
|
|
||||||
hint for how to select EGL.
|
|
||||||
|
|
||||||
Please verify that context creation also fails with the `glfwinfo` tool before
|
|
||||||
reporting it as a bug. This tool is included in the GLFW source tree as
|
|
||||||
`tests/glfwinfo.c` and is built along with the library. It has switches for all
|
|
||||||
GLFW context and framebuffer hints. Run `glfwinfo -h` for a complete list.
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
If you are running your program in a virtual machine, please mention this and
|
|
||||||
include the __VM name and version__ (e.g. `VirtualBox 5.1`).
|
|
||||||
|
|
||||||
Please also include the __GLFW version string__ (`3.2.0 X11 EGL clock_gettime
|
|
||||||
/dev/js`), as described
|
|
||||||
[here](https://www.glfw.org/docs/latest/intro.html#intro_version_string), the
|
|
||||||
__GPU model and driver version__ (e.g. `GeForce GTX660 with 352.79`), and the
|
|
||||||
__output of `glfwinfo`__ (with switches matching any hints you set in your
|
|
||||||
code) when reporting this kind of bug. If this tool doesn't run on the machine,
|
|
||||||
mention that instead.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
GPU and driver:
|
|
||||||
Release or commit:
|
|
||||||
Version string:
|
|
||||||
glfwinfo output:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a monitor or video mode bug
|
|
||||||
|
|
||||||
__Note:__ On headless systems on some platforms, no monitors are reported. This
|
|
||||||
causes glfwGetPrimaryMonitor to return `NULL`, which not all applications are
|
|
||||||
prepared for.
|
|
||||||
|
|
||||||
__Note:__ Some third-party tools report more video modes than are approved of
|
|
||||||
by the OS. For safety and compatibility, GLFW only reports video modes the OS
|
|
||||||
wants programs to use. This is not a bug.
|
|
||||||
|
|
||||||
The `monitors` tool is included in the GLFW source tree as `tests/monitors.c`
|
|
||||||
and is built along with the library. It lists all information GLFW provides
|
|
||||||
about monitors it detects.
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
If you are running your program in a virtual machine, please mention this and
|
|
||||||
include the __VM name and version__ (e.g. `VirtualBox 5.1`).
|
|
||||||
|
|
||||||
Please also include any __error messages__ provided to your application via the
|
|
||||||
[error
|
|
||||||
callback](https://www.glfw.org/docs/latest/intro_guide.html#error_handling) and
|
|
||||||
the __output of `monitors`__ when reporting this kind of bug. If this tool
|
|
||||||
doesn't run on the machine, mention this instead.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
Release or commit:
|
|
||||||
Error messages:
|
|
||||||
monitors output:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a window, input or event bug
|
|
||||||
|
|
||||||
__Note:__ The exact ordering of related window events will sometimes differ.
|
|
||||||
|
|
||||||
__Note:__ Window moving and resizing (by the user) will block the main thread on
|
|
||||||
some platforms. This is not a bug. Set a [refresh
|
|
||||||
callback](https://www.glfw.org/docs/latest/window.html#window_refresh) if you
|
|
||||||
want to keep the window contents updated during a move or size operation.
|
|
||||||
|
|
||||||
The `events` tool is included in the GLFW source tree as `tests/events.c` and is
|
|
||||||
built along with the library. It prints all information provided to every
|
|
||||||
callback supported by GLFW as events occur. Each event is listed with the time
|
|
||||||
and a unique number to make discussions about event logs easier. The tool has
|
|
||||||
command-line options for creating multiple windows and full screen windows.
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
If you are running your program in a virtual machine, please mention this and
|
|
||||||
include the __VM name and version__ (e.g. `VirtualBox 5.1`).
|
|
||||||
|
|
||||||
Please also include any __error messages__ provided to your application via the
|
|
||||||
[error
|
|
||||||
callback](https://www.glfw.org/docs/latest/intro_guide.html#error_handling) and
|
|
||||||
if relevant, the __output of `events`__ when reporting this kind of bug. If
|
|
||||||
this tool doesn't run on the machine, mention this instead.
|
|
||||||
|
|
||||||
__X11:__ If possible, please include what desktop environment (e.g. GNOME,
|
|
||||||
Unity, KDE) and/or window manager (e.g. Openbox, dwm, Window Maker) you are
|
|
||||||
running. If the bug is related to keyboard input, please include any input
|
|
||||||
method (e.g. ibus, SCIM) you are using.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
Release or commit:
|
|
||||||
Error messages:
|
|
||||||
events output:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting some other library bug
|
|
||||||
|
|
||||||
Always include the __operating system name and version__ (e.g. `Windows
|
|
||||||
7 64-bit` or `Ubuntu 15.10`). If you are using an official release of GLFW,
|
|
||||||
include the __GLFW release version__ (e.g. `3.1.2`), otherwise include the
|
|
||||||
__GLFW commit ID__ (e.g. `3795d78b14ef06008889cc422a1fb8d642597751`) from Git.
|
|
||||||
|
|
||||||
Please also include any __error messages__ provided to your application via the
|
|
||||||
[error
|
|
||||||
callback](https://www.glfw.org/docs/latest/intro_guide.html#error_handling), if
|
|
||||||
relevant.
|
|
||||||
|
|
||||||
|
|
||||||
#### Quick template
|
|
||||||
|
|
||||||
```
|
|
||||||
OS and version:
|
|
||||||
Release or commit:
|
|
||||||
Error messages:
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a documentation bug
|
|
||||||
|
|
||||||
If you found a bug in the documentation, including this file, then it's fine to
|
|
||||||
just link to that web page or mention that source file. You don't need to match
|
|
||||||
the source to the output or vice versa.
|
|
||||||
|
|
||||||
|
|
||||||
### Reporting a website bug
|
|
||||||
|
|
||||||
If the bug is in the documentation (anything under `/docs/`) then please see the
|
|
||||||
section above. Bugs in the rest of the site are reported to the [website
|
|
||||||
source repository](https://github.com/glfw/website/issues).
|
|
||||||
|
|
||||||
|
|
||||||
## Requesting a feature
|
|
||||||
|
|
||||||
Please explain why you need the feature and how you intend to use it. If you
|
|
||||||
have a specific API design in mind, please add that as well. If you have or are
|
|
||||||
planning to write code for the feature, see the section below.
|
|
||||||
|
|
||||||
If there already is a request for the feature you need, add your specific use
|
|
||||||
case unless it is already mentioned. If it is, give it a :+1:.
|
|
||||||
|
|
||||||
|
|
||||||
## Contributing a bug fix
|
|
||||||
|
|
||||||
__Note:__ You must have all necessary [intellectual
|
|
||||||
property rights](https://en.wikipedia.org/wiki/Intellectual_property) to any
|
|
||||||
code you contribute. If you did not write the code yourself, you must explain
|
|
||||||
where it came from and under what license you received it. Even code using the
|
|
||||||
same license as GLFW may not be copied without attribution.
|
|
||||||
|
|
||||||
__There is no preferred patch size__. A one character fix is just as welcome as
|
|
||||||
a thousand line one, if that is the appropriate size for the fix.
|
|
||||||
|
|
||||||
In addition to the code, a complete bug fix includes:
|
|
||||||
|
|
||||||
- Change log entry in `README.md`, describing the incorrect behavior
|
|
||||||
- Credits entries for all authors of the bug fix
|
|
||||||
|
|
||||||
Bug fixes will not be rejected because they don't include all the above parts,
|
|
||||||
but please keep in mind that maintainer time is finite and that there are many
|
|
||||||
other bugs and features to work on.
|
|
||||||
|
|
||||||
If the patch fixes a bug introduced after the last release, it should not get
|
|
||||||
a change log entry.
|
|
||||||
|
|
||||||
If you haven't already, read the excellent article [How to Write a Git Commit
|
|
||||||
Message](https://chris.beams.io/posts/git-commit/).
|
|
||||||
|
|
||||||
|
|
||||||
## Contributing a feature
|
|
||||||
|
|
||||||
__Note:__ You must have all necessary rights to any code you contribute. If you
|
|
||||||
did not write the code yourself, you must explain where it came from and under
|
|
||||||
what license. Even code using the same license as GLFW may not be copied
|
|
||||||
without attribution.
|
|
||||||
|
|
||||||
__Note:__ If you haven't already implemented the feature, check first if there
|
|
||||||
already is an open issue for it and if it's already being developed in an
|
|
||||||
[experimental branch](https://github.com/glfw/glfw/branches/all).
|
|
||||||
|
|
||||||
__There is no preferred patch size__. A one character change is just as welcome
|
|
||||||
as one adding a thousand line one, if that is the appropriate size for the
|
|
||||||
feature.
|
|
||||||
|
|
||||||
In addition to the code, a complete feature includes:
|
|
||||||
|
|
||||||
- Change log entry in `README.md`, listing all new symbols
|
|
||||||
- News page entry, briefly describing the feature
|
|
||||||
- Guide documentation, with minimal examples, in the relevant guide
|
|
||||||
- Reference documentation, with all applicable tags
|
|
||||||
- Cross-references and mentions in appropriate places
|
|
||||||
- Credits entries for all authors of the feature
|
|
||||||
|
|
||||||
If the feature requires platform-specific code, at minimum stubs must be added
|
|
||||||
for the new platform function to all supported and experimental platforms.
|
|
||||||
|
|
||||||
If it adds a new callback, support for it must be added to `tests/event.c`.
|
|
||||||
|
|
||||||
If it adds a new monitor property, support for it must be added to
|
|
||||||
`tests/monitor.c`.
|
|
||||||
|
|
||||||
If it adds a new OpenGL, OpenGL ES or Vulkan option or extension, support
|
|
||||||
for it must be added to `tests/glfwinfo.c` and the behavior of the library when
|
|
||||||
the extension is missing documented in `docs/compat.dox`.
|
|
||||||
|
|
||||||
If you haven't already, read the excellent article [How to Write a Git Commit
|
|
||||||
Message](https://chris.beams.io/posts/git-commit/).
|
|
||||||
|
|
||||||
Features will not be rejected because they don't include all the above parts,
|
|
||||||
but please keep in mind that maintainer time is finite and that there are many
|
|
||||||
other features and bugs to work on.
|
|
||||||
|
|
||||||
Please also keep in mind that any part of the public API that has been included
|
|
||||||
in a release cannot be changed until the next _major_ version. Features can be
|
|
||||||
added and existing parts can sometimes be overloaded (in the general sense of
|
|
||||||
doing more things, not in the C++ sense), but code written to the API of one
|
|
||||||
minor release should both compile and run on subsequent minor releases.
|
|
||||||
|
|
@ -1,71 +0,0 @@
|
|||||||
<doxygenlayout version="1.0">
|
|
||||||
<!-- Generated by doxygen 1.8.14 -->
|
|
||||||
<!-- Navigation index tabs for HTML output -->
|
|
||||||
<navindex>
|
|
||||||
<tab type="mainpage" visible="yes" title="Introduction"/>
|
|
||||||
<tab type="user" url="quick_guide.html" title="Tutorial"/>
|
|
||||||
<tab type="pages" visible="yes" title="Guides" intro=""/>
|
|
||||||
<tab type="modules" visible="yes" title="Reference" intro=""/>
|
|
||||||
<tab type="filelist" visible="yes" title="Files"/>
|
|
||||||
</navindex>
|
|
||||||
|
|
||||||
<!-- Layout definition for a file page -->
|
|
||||||
<file>
|
|
||||||
<detaileddescription title="Description"/>
|
|
||||||
<includes visible="$SHOW_INCLUDE_FILES"/>
|
|
||||||
<sourcelink visible="yes"/>
|
|
||||||
<memberdecl>
|
|
||||||
<constantgroups visible="yes" title=""/>
|
|
||||||
<defines title=""/>
|
|
||||||
<typedefs title=""/>
|
|
||||||
<enums title=""/>
|
|
||||||
<functions title=""/>
|
|
||||||
<variables title=""/>
|
|
||||||
<membergroups visible="yes"/>
|
|
||||||
</memberdecl>
|
|
||||||
<memberdef>
|
|
||||||
<defines title=""/>
|
|
||||||
<typedefs title=""/>
|
|
||||||
<enums title=""/>
|
|
||||||
<functions title=""/>
|
|
||||||
<variables title=""/>
|
|
||||||
</memberdef>
|
|
||||||
<authorsection/>
|
|
||||||
</file>
|
|
||||||
|
|
||||||
<!-- Layout definition for a group page -->
|
|
||||||
<group>
|
|
||||||
<detaileddescription title="Description"/>
|
|
||||||
<memberdecl>
|
|
||||||
<nestedgroups visible="yes" title=""/>
|
|
||||||
<dirs visible="yes" title=""/>
|
|
||||||
<files visible="yes" title=""/>
|
|
||||||
<defines title=""/>
|
|
||||||
<typedefs title=""/>
|
|
||||||
<enums title=""/>
|
|
||||||
<enumvalues title=""/>
|
|
||||||
<functions title=""/>
|
|
||||||
<variables title=""/>
|
|
||||||
</memberdecl>
|
|
||||||
<memberdef>
|
|
||||||
<pagedocs/>
|
|
||||||
<defines title=""/>
|
|
||||||
<typedefs title=""/>
|
|
||||||
<enums title=""/>
|
|
||||||
<enumvalues title=""/>
|
|
||||||
<functions title=""/>
|
|
||||||
<variables title=""/>
|
|
||||||
</memberdef>
|
|
||||||
<authorsection visible="yes"/>
|
|
||||||
</group>
|
|
||||||
|
|
||||||
<!-- Layout definition for a directory page -->
|
|
||||||
<directory>
|
|
||||||
<briefdescription visible="yes"/>
|
|
||||||
<memberdecl>
|
|
||||||
<dirs visible="yes"/>
|
|
||||||
<files visible="yes"/>
|
|
||||||
</memberdecl>
|
|
||||||
<detaileddescription title=""/>
|
|
||||||
</directory>
|
|
||||||
</doxygenlayout>
|
|
@ -1,14 +0,0 @@
|
|||||||
# Support resources
|
|
||||||
|
|
||||||
See the [latest documentation](https://www.glfw.org/docs/latest/) for tutorials,
|
|
||||||
guides and the API reference.
|
|
||||||
|
|
||||||
If you have questions about using GLFW, we have a
|
|
||||||
[forum](https://discourse.glfw.org/), and the `#glfw` IRC channel on
|
|
||||||
[Libera.Chat](https://libera.chat/).
|
|
||||||
|
|
||||||
Bugs are reported to our [issue tracker](https://github.com/glfw/glfw/issues).
|
|
||||||
Please check the [contribution
|
|
||||||
guide](https://github.com/glfw/glfw/blob/master/docs/CONTRIBUTING.md) for
|
|
||||||
information on what to include when reporting a bug.
|
|
||||||
|
|
@ -1,348 +0,0 @@
|
|||||||
/*!
|
|
||||||
|
|
||||||
@page build_guide Building applications
|
|
||||||
|
|
||||||
@tableofcontents
|
|
||||||
|
|
||||||
This is about compiling and linking applications that use GLFW. For information on
|
|
||||||
how to write such applications, start with the
|
|
||||||
[introductory tutorial](@ref quick_guide). For information on how to compile
|
|
||||||
the GLFW library itself, see @ref compile_guide.
|
|
||||||
|
|
||||||
This is not a tutorial on compilation or linking. It assumes basic
|
|
||||||
understanding of how to compile and link a C program as well as how to use the
|
|
||||||
specific compiler of your chosen development environment. The compilation
|
|
||||||
and linking process should be explained in your C programming material and in
|
|
||||||
the documentation for your development environment.
|
|
||||||
|
|
||||||
|
|
||||||
@section build_include Including the GLFW header file
|
|
||||||
|
|
||||||
You should include the GLFW header in the source files where you use OpenGL or
|
|
||||||
GLFW.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
This header defines all the constants and declares all the types and function
|
|
||||||
prototypes of the GLFW API. By default it also includes the OpenGL header from
|
|
||||||
your development environment. See [option macros](@ref build_macros) below for
|
|
||||||
how to select OpenGL ES headers and more.
|
|
||||||
|
|
||||||
The GLFW header also defines any platform-specific macros needed by your OpenGL
|
|
||||||
header, so that it can be included without needing any window system headers.
|
|
||||||
|
|
||||||
It does this only when needed, so if window system headers are included, the
|
|
||||||
GLFW header does not try to redefine those symbols. The reverse is not true,
|
|
||||||
i.e. `windows.h` cannot cope if any Win32 symbols have already been defined.
|
|
||||||
|
|
||||||
In other words:
|
|
||||||
|
|
||||||
- Use the GLFW header to include OpenGL or OpenGL ES headers portably
|
|
||||||
- Do not include window system headers unless you will use those APIs directly
|
|
||||||
- If you do need such headers, include them before the GLFW header
|
|
||||||
|
|
||||||
If you are using an OpenGL extension loading library such as
|
|
||||||
[glad](https://github.com/Dav1dde/glad), the extension loader header should
|
|
||||||
be included before the GLFW one. GLFW attempts to detect any OpenGL or OpenGL
|
|
||||||
ES header or extension loader header included before it and will then disable
|
|
||||||
the inclusion of the default OpenGL header. Most extension loaders also define
|
|
||||||
macros that disable similar headers below it.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#include <glad/gl.h>
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Both of these mechanisms depend on the extension loader header defining a known
|
|
||||||
macro. If yours doesn't or you don't know which one your users will pick, the
|
|
||||||
@ref GLFW_INCLUDE_NONE macro will explicitly to prevent the GLFW header from
|
|
||||||
including the OpenGL header. This will also allow you to include the two
|
|
||||||
headers in any order.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#define GLFW_INCLUDE_NONE
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
#include <glad/gl.h>
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_macros GLFW header option macros
|
|
||||||
|
|
||||||
These macros may be defined before the inclusion of the GLFW header and affect
|
|
||||||
its behavior.
|
|
||||||
|
|
||||||
@anchor GLFW_DLL
|
|
||||||
__GLFW_DLL__ is required on Windows when using the GLFW DLL, to tell the
|
|
||||||
compiler that the GLFW functions are defined in a DLL.
|
|
||||||
|
|
||||||
The following macros control which OpenGL or OpenGL ES API header is included.
|
|
||||||
Only one of these may be defined at a time.
|
|
||||||
|
|
||||||
@note GLFW does not provide any of the API headers mentioned below. They are
|
|
||||||
provided by your development environment or your OpenGL, OpenGL ES or Vulkan
|
|
||||||
SDK, and most of them can be downloaded from the
|
|
||||||
[Khronos Registry](https://www.khronos.org/registry/).
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_GLCOREARB
|
|
||||||
__GLFW_INCLUDE_GLCOREARB__ makes the GLFW header include the modern
|
|
||||||
`GL/glcorearb.h` header (`OpenGL/gl3.h` on macOS) instead of the regular OpenGL
|
|
||||||
header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_ES1
|
|
||||||
__GLFW_INCLUDE_ES1__ makes the GLFW header include the OpenGL ES 1.x `GLES/gl.h`
|
|
||||||
header instead of the regular OpenGL header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_ES2
|
|
||||||
__GLFW_INCLUDE_ES2__ makes the GLFW header include the OpenGL ES 2.0
|
|
||||||
`GLES2/gl2.h` header instead of the regular OpenGL header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_ES3
|
|
||||||
__GLFW_INCLUDE_ES3__ makes the GLFW header include the OpenGL ES 3.0
|
|
||||||
`GLES3/gl3.h` header instead of the regular OpenGL header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_ES31
|
|
||||||
__GLFW_INCLUDE_ES31__ makes the GLFW header include the OpenGL ES 3.1
|
|
||||||
`GLES3/gl31.h` header instead of the regular OpenGL header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_ES32
|
|
||||||
__GLFW_INCLUDE_ES32__ makes the GLFW header include the OpenGL ES 3.2
|
|
||||||
`GLES3/gl32.h` header instead of the regular OpenGL header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_NONE
|
|
||||||
__GLFW_INCLUDE_NONE__ makes the GLFW header not include any OpenGL or OpenGL ES
|
|
||||||
API header. This is useful in combination with an extension loading library.
|
|
||||||
|
|
||||||
If none of the above inclusion macros are defined, the standard OpenGL `GL/gl.h`
|
|
||||||
header (`OpenGL/gl.h` on macOS) is included, unless GLFW detects the inclusion
|
|
||||||
guards of any OpenGL, OpenGL ES or extension loader header it knows about.
|
|
||||||
|
|
||||||
The following macros control the inclusion of additional API headers. Any
|
|
||||||
number of these may be defined simultaneously, and/or together with one of the
|
|
||||||
above macros.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_VULKAN
|
|
||||||
__GLFW_INCLUDE_VULKAN__ makes the GLFW header include the Vulkan
|
|
||||||
`vulkan/vulkan.h` header in addition to any selected OpenGL or OpenGL ES header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_GLEXT
|
|
||||||
__GLFW_INCLUDE_GLEXT__ makes the GLFW header include the appropriate extension
|
|
||||||
header for the OpenGL or OpenGL ES header selected above after and in addition
|
|
||||||
to that header.
|
|
||||||
|
|
||||||
@anchor GLFW_INCLUDE_GLU
|
|
||||||
__GLFW_INCLUDE_GLU__ makes the header include the GLU header in addition to the
|
|
||||||
header selected above. This should only be used with the standard OpenGL header
|
|
||||||
and only for compatibility with legacy code. GLU has been deprecated and should
|
|
||||||
not be used in new code.
|
|
||||||
|
|
||||||
@note None of these macros may be defined during the compilation of GLFW itself.
|
|
||||||
If your build includes GLFW and you define any these in your build files, make
|
|
||||||
sure they are not applied to the GLFW sources.
|
|
||||||
|
|
||||||
|
|
||||||
@section build_link Link with the right libraries
|
|
||||||
|
|
||||||
GLFW is essentially a wrapper of various platform-specific APIs and therefore
|
|
||||||
needs to link against many different system libraries. If you are using GLFW as
|
|
||||||
a shared library / dynamic library / DLL then it takes care of these links.
|
|
||||||
However, if you are using GLFW as a static library then your executable will
|
|
||||||
need to link against these libraries.
|
|
||||||
|
|
||||||
On Windows and macOS, the list of system libraries is static and can be
|
|
||||||
hard-coded into your build environment. See the section for your development
|
|
||||||
environment below. On Linux and other Unix-like operating systems, the list
|
|
||||||
varies but can be retrieved in various ways as described below.
|
|
||||||
|
|
||||||
A good general introduction to linking is
|
|
||||||
[Beginner's Guide to Linkers](https://www.lurklurk.org/linkers/linkers.html) by
|
|
||||||
David Drysdale.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_win32 With MinGW or Visual C++ on Windows
|
|
||||||
|
|
||||||
The static version of the GLFW library is named `glfw3`. When using this
|
|
||||||
version, it is also necessary to link with some libraries that GLFW uses.
|
|
||||||
|
|
||||||
When using MinGW to link an application with the static version of GLFW, you
|
|
||||||
must also explicitly link with `gdi32`. Other toolchains including MinGW-w64
|
|
||||||
include it in the set of default libraries along with other dependencies like
|
|
||||||
`user32` and `kernel32`.
|
|
||||||
|
|
||||||
The link library for the GLFW DLL is named `glfw3dll`. When compiling an
|
|
||||||
application that uses the DLL version of GLFW, you need to define the @ref
|
|
||||||
GLFW_DLL macro _before_ any inclusion of the GLFW header. This can be done
|
|
||||||
either with a compiler switch or by defining it in your source code.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_cmake_source With CMake and GLFW source
|
|
||||||
|
|
||||||
This section is about using CMake to compile and link GLFW along with your
|
|
||||||
application. If you want to use an installed binary instead, see @ref
|
|
||||||
build_link_cmake_package.
|
|
||||||
|
|
||||||
With a few changes to your `CMakeLists.txt` you can have the GLFW source tree
|
|
||||||
built along with your application.
|
|
||||||
|
|
||||||
When including GLFW as part of your build, you probably don't want to build the
|
|
||||||
GLFW tests, examples and documentation. To disable these, set the corresponding
|
|
||||||
cache variables before adding the GLFW source tree.
|
|
||||||
|
|
||||||
@code
|
|
||||||
set(GLFW_BUILD_DOCS OFF CACHE BOOL "" FORCE)
|
|
||||||
set(GLFW_BUILD_TESTS OFF CACHE BOOL "" FORCE)
|
|
||||||
set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Add the root directory of the GLFW source tree to your project. This will add
|
|
||||||
the `glfw` target to your project.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
add_subdirectory(path/to/glfw)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Once GLFW has been added, link your application against the `glfw` target.
|
|
||||||
This adds the GLFW library and its link-time dependencies as it is currently
|
|
||||||
configured, the include directory for the GLFW header and, when applicable, the
|
|
||||||
@ref GLFW_DLL macro.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
target_link_libraries(myapp glfw)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Note that the `glfw` target does not depend on OpenGL, as GLFW loads any OpenGL,
|
|
||||||
OpenGL ES or Vulkan libraries it needs at runtime. If your application calls
|
|
||||||
OpenGL directly, instead of using a modern
|
|
||||||
[extension loader library](@ref context_glext_auto), use the OpenGL CMake
|
|
||||||
package.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
find_package(OpenGL REQUIRED)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
If OpenGL is found, the `OpenGL::GL` target is added to your project, containing
|
|
||||||
library and include directory paths. Link against this like any other library.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
target_link_libraries(myapp OpenGL::GL)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
For a minimal example of a program and GLFW sources built with CMake, see the
|
|
||||||
[GLFW CMake Starter](https://github.com/juliettef/GLFW-CMake-starter) on GitHub.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_cmake_package With CMake and installed GLFW binaries
|
|
||||||
|
|
||||||
This section is about using CMake to link GLFW after it has been built and
|
|
||||||
installed. If you want to build it along with your application instead, see
|
|
||||||
@ref build_link_cmake_source.
|
|
||||||
|
|
||||||
With a few changes to your `CMakeLists.txt` you can locate the package and
|
|
||||||
target files generated when GLFW is installed.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
find_package(glfw3 3.3 REQUIRED)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Once GLFW has been added to the project, link against it with the `glfw` target.
|
|
||||||
This adds the GLFW library and its link-time dependencies, the include directory
|
|
||||||
for the GLFW header and, when applicable, the @ref GLFW_DLL macro.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
target_link_libraries(myapp glfw)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Note that the `glfw` target does not depend on OpenGL, as GLFW loads any OpenGL,
|
|
||||||
OpenGL ES or Vulkan libraries it needs at runtime. If your application calls
|
|
||||||
OpenGL directly, instead of using a modern
|
|
||||||
[extension loader library](@ref context_glext_auto), use the OpenGL CMake
|
|
||||||
package.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
find_package(OpenGL REQUIRED)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
If OpenGL is found, the `OpenGL::GL` target is added to your project, containing
|
|
||||||
library and include directory paths. Link against this like any other library.
|
|
||||||
|
|
||||||
@code{.cmake}
|
|
||||||
target_link_libraries(myapp OpenGL::GL)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_pkgconfig With makefiles and pkg-config on Unix
|
|
||||||
|
|
||||||
GLFW supports [pkg-config](https://www.freedesktop.org/wiki/Software/pkg-config/),
|
|
||||||
and the `glfw3.pc` pkg-config file is generated when the GLFW library is built
|
|
||||||
and is installed along with it. A pkg-config file describes all necessary
|
|
||||||
compile-time and link-time flags and dependencies needed to use a library. When
|
|
||||||
they are updated or if they differ between systems, you will get the correct
|
|
||||||
ones automatically.
|
|
||||||
|
|
||||||
A typical compile and link command-line when using the static version of the
|
|
||||||
GLFW library may look like this:
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --static --libs glfw3)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
If you are using the shared version of the GLFW library, omit the `--static`
|
|
||||||
flag.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --libs glfw3)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
You can also use the `glfw3.pc` file without installing it first, by using the
|
|
||||||
`PKG_CONFIG_PATH` environment variable.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
env PKG_CONFIG_PATH=path/to/glfw/src cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --libs glfw3)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The dependencies do not include OpenGL, as GLFW loads any OpenGL, OpenGL ES or
|
|
||||||
Vulkan libraries it needs at runtime. If your application calls OpenGL
|
|
||||||
directly, instead of using a modern
|
|
||||||
[extension loader library](@ref context_glext_auto), you should add the `gl`
|
|
||||||
pkg-config package.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cc $(pkg-config --cflags glfw3 gl) -o myprog myprog.c $(pkg-config --libs glfw3 gl)
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_xcode With Xcode on macOS
|
|
||||||
|
|
||||||
If you are using the dynamic library version of GLFW, add it to the project
|
|
||||||
dependencies.
|
|
||||||
|
|
||||||
If you are using the static library version of GLFW, add it and the Cocoa,
|
|
||||||
OpenGL and IOKit frameworks to the project as dependencies. They can all be
|
|
||||||
found in `/System/Library/Frameworks`.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection build_link_osx With command-line on macOS
|
|
||||||
|
|
||||||
It is recommended that you use [pkg-config](@ref build_link_pkgconfig) when
|
|
||||||
building from the command line on macOS. That way you will get any new
|
|
||||||
dependencies added automatically. If you still wish to build manually, you need
|
|
||||||
to add the required frameworks and libraries to your command-line yourself using
|
|
||||||
the `-l` and `-framework` switches.
|
|
||||||
|
|
||||||
If you are using the dynamic GLFW library, which is named `libglfw.3.dylib`, do:
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cc -o myprog myprog.c -lglfw -framework Cocoa -framework OpenGL -framework IOKit
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
If you are using the static library, named `libglfw3.a`, substitute `-lglfw3`
|
|
||||||
for `-lglfw`.
|
|
||||||
|
|
||||||
Note that you do not add the `.framework` extension to a framework when linking
|
|
||||||
against it from the command-line.
|
|
||||||
|
|
||||||
@note Your machine may have `libGL.*.dylib` style OpenGL library, but that is
|
|
||||||
for the X Window System and will not work with the macOS native version of GLFW.
|
|
||||||
|
|
||||||
*/
|
|
@ -1,285 +0,0 @@
|
|||||||
/*!
|
|
||||||
|
|
||||||
@page compat_guide Standards conformance
|
|
||||||
|
|
||||||
@tableofcontents
|
|
||||||
|
|
||||||
This guide describes the various API extensions used by this version of GLFW.
|
|
||||||
It lists what are essentially implementation details, but which are nonetheless
|
|
||||||
vital knowledge for developers intending to deploy their applications on a wide
|
|
||||||
range of machines.
|
|
||||||
|
|
||||||
The information in this guide is not a part of GLFW API, but merely
|
|
||||||
preconditions for some parts of the library to function on a given machine. Any
|
|
||||||
part of this information may change in future versions of GLFW and that will not
|
|
||||||
be considered a breaking API change.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_x11 X11 extensions, protocols and IPC standards
|
|
||||||
|
|
||||||
As GLFW uses Xlib directly, without any intervening toolkit
|
|
||||||
library, it has sole responsibility for interacting well with the many and
|
|
||||||
varied window managers in use on Unix-like systems. In order for applications
|
|
||||||
and window managers to work well together, a number of standards and
|
|
||||||
conventions have been developed that regulate behavior outside the scope of the
|
|
||||||
X11 API; most importantly the
|
|
||||||
[Inter-Client Communication Conventions Manual](https://www.tronche.com/gui/x/icccm/)
|
|
||||||
(ICCCM) and
|
|
||||||
[Extended Window Manager Hints](https://standards.freedesktop.org/wm-spec/wm-spec-latest.html)
|
|
||||||
(EWMH) standards.
|
|
||||||
|
|
||||||
GLFW uses the `_MOTIF_WM_HINTS` window property to support borderless windows.
|
|
||||||
If the running window manager does not support this property, the
|
|
||||||
`GLFW_DECORATED` hint will have no effect.
|
|
||||||
|
|
||||||
GLFW uses the ICCCM `WM_DELETE_WINDOW` protocol to intercept the user
|
|
||||||
attempting to close the GLFW window. If the running window manager does not
|
|
||||||
support this protocol, the close callback will never be called.
|
|
||||||
|
|
||||||
GLFW uses the EWMH `_NET_WM_PING` protocol, allowing the window manager notify
|
|
||||||
the user when the application has stopped responding, i.e. when it has ceased to
|
|
||||||
process events. If the running window manager does not support this protocol,
|
|
||||||
the user will not be notified if the application locks up.
|
|
||||||
|
|
||||||
GLFW uses the EWMH `_NET_WM_STATE_FULLSCREEN` window state to tell the window
|
|
||||||
manager to make the GLFW window full screen. If the running window manager does
|
|
||||||
not support this state, full screen windows may not work properly. GLFW has
|
|
||||||
a fallback code path in case this state is unavailable, but every window manager
|
|
||||||
behaves slightly differently in this regard.
|
|
||||||
|
|
||||||
GLFW uses the EWMH `_NET_WM_BYPASS_COMPOSITOR` window property to tell a
|
|
||||||
compositing window manager to un-redirect full screen GLFW windows. If the
|
|
||||||
running window manager uses compositing but does not support this property then
|
|
||||||
additional copying may be performed for each buffer swap of full screen windows.
|
|
||||||
|
|
||||||
GLFW uses the
|
|
||||||
[clipboard manager protocol](https://www.freedesktop.org/wiki/ClipboardManager/)
|
|
||||||
to push a clipboard string (i.e. selection) owned by a GLFW window about to be
|
|
||||||
destroyed to the clipboard manager. If there is no running clipboard manager,
|
|
||||||
the clipboard string will be unavailable once the window has been destroyed.
|
|
||||||
|
|
||||||
GLFW uses the
|
|
||||||
[X drag-and-drop protocol](https://www.freedesktop.org/wiki/Specifications/XDND/)
|
|
||||||
to provide file drop events. If the application originating the drag does not
|
|
||||||
support this protocol, drag and drop will not work.
|
|
||||||
|
|
||||||
GLFW uses the XRandR 1.3 extension to provide multi-monitor support. If the
|
|
||||||
running X server does not support this version of this extension, multi-monitor
|
|
||||||
support will not function and only a single, desktop-spanning monitor will be
|
|
||||||
reported.
|
|
||||||
|
|
||||||
GLFW uses the XRandR 1.3 and Xf86vidmode extensions to provide gamma ramp
|
|
||||||
support. If the running X server does not support either or both of these
|
|
||||||
extensions, gamma ramp support will not function.
|
|
||||||
|
|
||||||
GLFW uses the Xkb extension and detectable auto-repeat to provide keyboard
|
|
||||||
input. If the running X server does not support this extension, a non-Xkb
|
|
||||||
fallback path is used.
|
|
||||||
|
|
||||||
GLFW uses the XInput2 extension to provide raw, non-accelerated mouse motion
|
|
||||||
when the cursor is disabled. If the running X server does not support this
|
|
||||||
extension, regular accelerated mouse motion will be used.
|
|
||||||
|
|
||||||
GLFW uses both the XRender extension and the compositing manager to support
|
|
||||||
transparent window framebuffers. If the running X server does not support this
|
|
||||||
extension or there is no running compositing manager, the
|
|
||||||
`GLFW_TRANSPARENT_FRAMEBUFFER` framebuffer hint will have no effect.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_wayland Wayland protocols and IPC standards
|
|
||||||
|
|
||||||
As GLFW uses libwayland directly, without any intervening toolkit library, it
|
|
||||||
has sole responsibility for interacting well with every compositor in use on
|
|
||||||
Unix-like systems. Most of the features are provided by the core protocol,
|
|
||||||
while cursor support is provided by the libwayland-cursor helper library, EGL
|
|
||||||
integration by libwayland-egl, and keyboard handling by
|
|
||||||
[libxkbcommon](https://xkbcommon.org/). In addition, GLFW uses some protocols
|
|
||||||
from wayland-protocols to provide additional features if the compositor
|
|
||||||
supports them.
|
|
||||||
|
|
||||||
GLFW uses xkbcommon 0.5.0 to provide compose key support. When it has been
|
|
||||||
built against an older xkbcommon, the compose key will be disabled even if it
|
|
||||||
has been configured in the compositor.
|
|
||||||
|
|
||||||
GLFW uses the [xdg-shell
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/stable/xdg-shell/xdg-shell.xml)
|
|
||||||
to provide better window management. This protocol is part of
|
|
||||||
wayland-protocols 1.12, and mandatory at build time. If the running compositor
|
|
||||||
does not support this protocol, the older [wl_shell
|
|
||||||
interface](https://cgit.freedesktop.org/wayland/wayland/tree/protocol/wayland.xml#n972)
|
|
||||||
will be used instead. This will result in a worse integration with the
|
|
||||||
desktop, especially on tiling compositors.
|
|
||||||
|
|
||||||
GLFW uses the [relative pointer
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/relative-pointer/relative-pointer-unstable-v1.xml)
|
|
||||||
alongside the [pointer constraints
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/pointer-constraints/pointer-constraints-unstable-v1.xml)
|
|
||||||
to implement disabled cursor. These two protocols are part of
|
|
||||||
wayland-protocols 1.1, and mandatory at build time. If the running compositor
|
|
||||||
does not support both of these protocols, disabling the cursor will have no
|
|
||||||
effect.
|
|
||||||
|
|
||||||
GLFW uses the [idle inhibit
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/idle-inhibit/idle-inhibit-unstable-v1.xml)
|
|
||||||
to prohibit the screensaver from starting. This protocol is part of
|
|
||||||
wayland-protocols 1.6, and mandatory at build time. If the running compositor
|
|
||||||
does not support this protocol, the screensaver may start even for full screen
|
|
||||||
windows.
|
|
||||||
|
|
||||||
GLFW uses the [xdg-decoration
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/xdg-decoration/xdg-decoration-unstable-v1.xml)
|
|
||||||
to request decorations to be drawn around its windows. This protocol is part
|
|
||||||
of wayland-protocols 1.15, and mandatory at build time. If the running
|
|
||||||
compositor does not support this protocol, a very simple frame will be drawn by
|
|
||||||
GLFW itself, using the [viewporter
|
|
||||||
protocol](https://cgit.freedesktop.org/wayland/wayland-protocols/tree/stable/viewporter/viewporter.xml)
|
|
||||||
alongside
|
|
||||||
[subsurfaces](https://cgit.freedesktop.org/wayland/wayland/tree/protocol/wayland.xml#n2598).
|
|
||||||
This protocol is part of wayland-protocols 1.4, and mandatory at build time.
|
|
||||||
If the running compositor does not support this protocol either, no decorations
|
|
||||||
will be drawn around windows.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_glx GLX extensions
|
|
||||||
|
|
||||||
The GLX API is the default API used to create OpenGL contexts on Unix-like
|
|
||||||
systems using the X Window System.
|
|
||||||
|
|
||||||
GLFW uses the GLX 1.3 `GLXFBConfig` functions to enumerate and select framebuffer pixel
|
|
||||||
formats. If GLX 1.3 is not supported, @ref glfwInit will fail.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_MESA_swap_control,` `GLX_EXT_swap_control` and
|
|
||||||
`GLX_SGI_swap_control` extensions to provide vertical retrace synchronization
|
|
||||||
(or _vsync_), in that order of preference. Where none of these extension are
|
|
||||||
available, calling @ref glfwSwapInterval will have no effect.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_ARB_multisample` extension to create contexts with
|
|
||||||
multisampling anti-aliasing. Where this extension is unavailable, the
|
|
||||||
`GLFW_SAMPLES` hint will have no effect.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_ARB_create_context` extension when available, even when
|
|
||||||
creating OpenGL contexts of version 2.1 and below. Where this extension is
|
|
||||||
unavailable, the `GLFW_CONTEXT_VERSION_MAJOR` and `GLFW_CONTEXT_VERSION_MINOR`
|
|
||||||
hints will only be partially supported, the `GLFW_OPENGL_DEBUG_CONTEXT` hint
|
|
||||||
will have no effect, and setting the `GLFW_OPENGL_PROFILE` or
|
|
||||||
`GLFW_OPENGL_FORWARD_COMPAT` hints to `GLFW_TRUE` will cause @ref
|
|
||||||
glfwCreateWindow to fail.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_ARB_create_context_profile` extension to provide support for
|
|
||||||
context profiles. Where this extension is unavailable, setting the
|
|
||||||
`GLFW_OPENGL_PROFILE` hint to anything but `GLFW_OPENGL_ANY_PROFILE`, or setting
|
|
||||||
`GLFW_CLIENT_API` to anything but `GLFW_OPENGL_API` or `GLFW_NO_API` will cause
|
|
||||||
@ref glfwCreateWindow to fail.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_ARB_context_flush_control` extension to provide control over
|
|
||||||
whether a context is flushed when it is released (made non-current). Where this
|
|
||||||
extension is unavailable, the `GLFW_CONTEXT_RELEASE_BEHAVIOR` hint will have no
|
|
||||||
effect and the context will always be flushed when released.
|
|
||||||
|
|
||||||
GLFW uses the `GLX_ARB_framebuffer_sRGB` and `GLX_EXT_framebuffer_sRGB`
|
|
||||||
extensions to provide support for sRGB framebuffers. Where both of these
|
|
||||||
extensions are unavailable, the `GLFW_SRGB_CAPABLE` hint will have no effect.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_wgl WGL extensions
|
|
||||||
|
|
||||||
The WGL API is used to create OpenGL contexts on Microsoft Windows and other
|
|
||||||
implementations of the Win32 API, such as Wine.
|
|
||||||
|
|
||||||
GLFW uses either the `WGL_EXT_extension_string` or the
|
|
||||||
`WGL_ARB_extension_string` extension to check for the presence of all other WGL
|
|
||||||
extensions listed below. If both are available, the EXT one is preferred. If
|
|
||||||
neither is available, no other extensions are used and many GLFW features
|
|
||||||
related to context creation will have no effect or cause errors when used.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_EXT_swap_control` extension to provide vertical retrace
|
|
||||||
synchronization (or _vsync_). Where this extension is unavailable, calling @ref
|
|
||||||
glfwSwapInterval will have no effect.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_ARB_pixel_format` and `WGL_ARB_multisample` extensions to
|
|
||||||
create contexts with multisampling anti-aliasing. Where these extensions are
|
|
||||||
unavailable, the `GLFW_SAMPLES` hint will have no effect.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_ARB_create_context` extension when available, even when
|
|
||||||
creating OpenGL contexts of version 2.1 and below. Where this extension is
|
|
||||||
unavailable, the `GLFW_CONTEXT_VERSION_MAJOR` and `GLFW_CONTEXT_VERSION_MINOR`
|
|
||||||
hints will only be partially supported, the `GLFW_OPENGL_DEBUG_CONTEXT` hint
|
|
||||||
will have no effect, and setting the `GLFW_OPENGL_PROFILE` or
|
|
||||||
`GLFW_OPENGL_FORWARD_COMPAT` hints to `GLFW_TRUE` will cause @ref
|
|
||||||
glfwCreateWindow to fail.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_ARB_create_context_profile` extension to provide support for
|
|
||||||
context profiles. Where this extension is unavailable, setting the
|
|
||||||
`GLFW_OPENGL_PROFILE` hint to anything but `GLFW_OPENGL_ANY_PROFILE` will cause
|
|
||||||
@ref glfwCreateWindow to fail.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_ARB_context_flush_control` extension to provide control over
|
|
||||||
whether a context is flushed when it is released (made non-current). Where this
|
|
||||||
extension is unavailable, the `GLFW_CONTEXT_RELEASE_BEHAVIOR` hint will have no
|
|
||||||
effect and the context will always be flushed when released.
|
|
||||||
|
|
||||||
GLFW uses the `WGL_ARB_framebuffer_sRGB` and `WGL_EXT_framebuffer_sRGB`
|
|
||||||
extensions to provide support for sRGB framebuffers. Where both of these
|
|
||||||
extension are unavailable, the `GLFW_SRGB_CAPABLE` hint will have no effect.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_osx OpenGL on macOS
|
|
||||||
|
|
||||||
Support for OpenGL 3.2 and above was introduced with OS X 10.7 and even then
|
|
||||||
only forward-compatible, core profile contexts are supported. Support for
|
|
||||||
OpenGL 4.1 was introduced with OS X 10.9, also limited to forward-compatible,
|
|
||||||
core profile contexts. There is also still no mechanism for requesting debug
|
|
||||||
contexts or no-error contexts. Versions of Mac OS X earlier than 10.7 support
|
|
||||||
at most OpenGL version 2.1.
|
|
||||||
|
|
||||||
Because of this, on OS X 10.7 and later, the `GLFW_CONTEXT_VERSION_MAJOR` and
|
|
||||||
`GLFW_CONTEXT_VERSION_MINOR` hints will cause @ref glfwCreateWindow to fail if
|
|
||||||
given version 3.0 or 3.1. The `GLFW_OPENGL_FORWARD_COMPAT` hint must be set to
|
|
||||||
`GLFW_TRUE` and the `GLFW_OPENGL_PROFILE` hint must be set to
|
|
||||||
`GLFW_OPENGL_CORE_PROFILE` when creating OpenGL 3.2 and later contexts. The
|
|
||||||
`GLFW_OPENGL_DEBUG_CONTEXT` and `GLFW_CONTEXT_NO_ERROR` hints are ignored.
|
|
||||||
|
|
||||||
Also, on Mac OS X 10.6 and below, the `GLFW_CONTEXT_VERSION_MAJOR` and
|
|
||||||
`GLFW_CONTEXT_VERSION_MINOR` hints will fail if given a version above 2.1,
|
|
||||||
setting the `GLFW_OPENGL_PROFILE` or `GLFW_OPENGL_FORWARD_COMPAT` hints to
|
|
||||||
a non-default value will cause @ref glfwCreateWindow to fail and the
|
|
||||||
`GLFW_OPENGL_DEBUG_CONTEXT` hint is ignored.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_vulkan Vulkan loader and API
|
|
||||||
|
|
||||||
By default, GLFW uses the standard system-wide Vulkan loader to access the
|
|
||||||
Vulkan API on all platforms except macOS. This is installed by both graphics
|
|
||||||
drivers and Vulkan SDKs. If either the loader or at least one minimally
|
|
||||||
functional ICD is missing, @ref glfwVulkanSupported will return `GLFW_FALSE` and
|
|
||||||
all other Vulkan-related functions will fail with an @ref GLFW_API_UNAVAILABLE
|
|
||||||
error.
|
|
||||||
|
|
||||||
|
|
||||||
@section compat_wsi Vulkan WSI extensions
|
|
||||||
|
|
||||||
The Vulkan WSI extensions are used to create Vulkan surfaces for GLFW windows on
|
|
||||||
all supported platforms.
|
|
||||||
|
|
||||||
GLFW uses the `VK_KHR_surface` and `VK_KHR_win32_surface` extensions to create
|
|
||||||
surfaces on Microsoft Windows. If any of these extensions are not available,
|
|
||||||
@ref glfwGetRequiredInstanceExtensions will return an empty list and window
|
|
||||||
surface creation will fail.
|
|
||||||
|
|
||||||
GLFW uses the `VK_KHR_surface` and either the `VK_MVK_macos_surface` or
|
|
||||||
`VK_EXT_metal_surface` extensions to create surfaces on macOS. If any of these
|
|
||||||
extensions are not available, @ref glfwGetRequiredInstanceExtensions will
|
|
||||||
return an empty list and window surface creation will fail.
|
|
||||||
|
|
||||||
GLFW uses the `VK_KHR_surface` and either the `VK_KHR_xlib_surface` or
|
|
||||||
`VK_KHR_xcb_surface` extensions to create surfaces on X11. If `VK_KHR_surface`
|
|
||||||
or both `VK_KHR_xlib_surface` and `VK_KHR_xcb_surface` are not available, @ref
|
|
||||||
glfwGetRequiredInstanceExtensions will return an empty list and window surface
|
|
||||||
creation will fail.
|
|
||||||
|
|
||||||
GLFW uses the `VK_KHR_surface` and `VK_KHR_wayland_surface` extensions to create
|
|
||||||
surfaces on Wayland. If any of these extensions are not available, @ref
|
|
||||||
glfwGetRequiredInstanceExtensions will return an empty list and window surface
|
|
||||||
creation will fail.
|
|
||||||
|
|
||||||
*/
|
|
@ -1,365 +0,0 @@
|
|||||||
/*!
|
|
||||||
|
|
||||||
@page compile_guide Compiling GLFW
|
|
||||||
|
|
||||||
@tableofcontents
|
|
||||||
|
|
||||||
This is about compiling the GLFW library itself. For information on how to
|
|
||||||
build applications that use GLFW, see @ref build_guide.
|
|
||||||
|
|
||||||
|
|
||||||
@section compile_cmake Using CMake
|
|
||||||
|
|
||||||
@note GLFW behaves like most other libraries that use CMake so this guide mostly
|
|
||||||
describes the basic configure/generate/compile sequence. If you are already
|
|
||||||
familiar with this from other projects, you may want to focus on the @ref
|
|
||||||
compile_deps and @ref compile_options sections for GLFW-specific information.
|
|
||||||
|
|
||||||
GLFW uses [CMake](https://cmake.org/) to generate project files or makefiles
|
|
||||||
for your chosen development environment. To compile GLFW, first generate these
|
|
||||||
files with CMake and then use them to compile the GLFW library.
|
|
||||||
|
|
||||||
If you are on Windows and macOS you can
|
|
||||||
[download CMake](https://cmake.org/download/) from their site.
|
|
||||||
|
|
||||||
If you are on a Unix-like system such as Linux, FreeBSD or Cygwin or have
|
|
||||||
a package system like Fink, MacPorts or Homebrew, you can install its CMake
|
|
||||||
package.
|
|
||||||
|
|
||||||
CMake is a complex tool and this guide will only show a few of the possible ways
|
|
||||||
to set up and compile GLFW. The CMake project has their own much more detailed
|
|
||||||
[CMake user guide](https://cmake.org/cmake/help/latest/guide/user-interaction/)
|
|
||||||
that includes everything in this guide not specific to GLFW. It may be a useful
|
|
||||||
companion to this one.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_deps Installing dependencies
|
|
||||||
|
|
||||||
The C/C++ development environments in Visual Studio, Xcode and MinGW come with
|
|
||||||
all necessary dependencies for compiling GLFW, but on Unix-like systems like
|
|
||||||
Linux and FreeBSD you will need a few extra packages.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection compile_deps_x11 Dependencies for X11 on Unix-like systems
|
|
||||||
|
|
||||||
To compile GLFW for X11, you need to have the X11 development packages
|
|
||||||
installed. They are not needed to build or run programs that use GLFW.
|
|
||||||
|
|
||||||
On Debian and derivates like Ubuntu and Linux Mint the `xorg-dev` meta-package
|
|
||||||
pulls in the development packages for all of X11.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
sudo apt install xorg-dev
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On Fedora and derivatives like Red Hat the X11 extension packages
|
|
||||||
`libXcursor-devel`, `libXi-devel`, `libXinerama-devel` and `libXrandr-devel`
|
|
||||||
required by GLFW pull in all its other dependencies.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
sudo dnf install libXcursor-devel libXi-devel libXinerama-devel libXrandr-devel
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On FreeBSD the X11 headers are installed along the end-user X11 packages, so if
|
|
||||||
you have an X server running you should have the headers as well. If not,
|
|
||||||
install the `xorgproto` package.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
pkg install xorgproto
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On Cygwin the `xorgproto` package in the Devel section of the GUI installer will
|
|
||||||
install the headers and other development related files for all of X11.
|
|
||||||
|
|
||||||
Once you have the required depdendencies, move on to @ref compile_generate.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection compile_deps_wayland Dependencies for Wayland on Unix-like systems
|
|
||||||
|
|
||||||
To compile GLFW for Wayland, you need to have the Wayland and xkbcommon
|
|
||||||
development packages installed. They are not needed to build or run programs
|
|
||||||
that use GLFW.
|
|
||||||
|
|
||||||
On Debian and derivates like Ubuntu and Linux Mint you will need the `libwayland-dev`,
|
|
||||||
`libxkbcommon-dev`, `wayland-protocols` and `extra-cmake-modules` packages.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
sudo apt install libwayland-dev libxkbcommon-dev wayland-protocols extra-cmake-modules
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On Fedora and derivatives like Red Hat you will need the `wayland-devel`,
|
|
||||||
`libxkbcommon-devel`, `wayland-protocols-devel` and `extra-cmake-modules` packages.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
sudo dnf install wayland-devel libxkbcommon-devel wayland-protocols-devel extra-cmake-modules
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
On FreeBSD you will need the `wayland`, `libxkbcommon`, `wayland-protocols` and
|
|
||||||
`kf5-extra-cmake-modules` packages.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
pkg install wayland libxkbcommon wayland-protocols kf5-extra-cmake-modules
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Once you have the required depdendencies, move on to @ref compile_generate.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_generate Generating build files with CMake
|
|
||||||
|
|
||||||
Once you have all necessary dependencies it is time to generate the project
|
|
||||||
files or makefiles for your development environment. CMake needs two paths for
|
|
||||||
this:
|
|
||||||
|
|
||||||
- the path to the root directory of the GLFW source tree (not its `src`
|
|
||||||
subdirectory)
|
|
||||||
- the path to the directory where the generated build files and compiled
|
|
||||||
binaries will be placed
|
|
||||||
|
|
||||||
If these are the same, it is called an in-tree build, otherwise it is called an
|
|
||||||
out-of-tree build.
|
|
||||||
|
|
||||||
Out-of-tree builds are recommended as they avoid cluttering up the source tree.
|
|
||||||
They also allow you to have several build directories for different
|
|
||||||
configurations all using the same source tree.
|
|
||||||
|
|
||||||
A common pattern when building a single configuration is to have a build
|
|
||||||
directory named `build` in the root of the source tree.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection compile_generate_gui Generating files with the CMake GUI
|
|
||||||
|
|
||||||
Start the CMake GUI and set the paths to the source and build directories
|
|
||||||
described above. Then press _Configure_ and _Generate_.
|
|
||||||
|
|
||||||
If you wish change any CMake variables in the list, press _Configure_ and then
|
|
||||||
_Generate_ to have the new values take effect. The variable list will be
|
|
||||||
populated after the first configure step.
|
|
||||||
|
|
||||||
By default GLFW will use X11 on Linux and other Unix-like systems other
|
|
||||||
than macOS. To use Wayland instead, set the `GLFW_USE_WAYLAND` option in the
|
|
||||||
GLFW section of the variable list, then apply the new value as described above.
|
|
||||||
|
|
||||||
Once you have generated the project files or makefiles for your chosen
|
|
||||||
development environment, move on to @ref compile_compile.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection compile_generate_cli Generating files with the CMake command-line tool
|
|
||||||
|
|
||||||
To make a build directory, pass the source and build directories to the `cmake`
|
|
||||||
command. These can be relative or absolute paths. The build directory is
|
|
||||||
created if it doesn't already exist.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
It is common to name the build directory `build` and place it in the root of the
|
|
||||||
source tree when only planning to build a single configuration.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cd path/to/glfw
|
|
||||||
cmake -S . -B build
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Without other flags these will generate Visual Studio project files on Windows
|
|
||||||
and makefiles on other platforms. You can choose other targets using the `-G`
|
|
||||||
flag.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build -G Xcode
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
By default GLFW will use X11 on Linux and other Unix-like systems other
|
|
||||||
than macOS. To use Wayland instead, set the `GLFW_USE_WAYLAND` CMake option.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build -D GLFW_USE_WAYLAND=1
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Once you have generated the project files or makefiles for your chosen
|
|
||||||
development environment, move on to @ref compile_compile.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_compile Compiling the library
|
|
||||||
|
|
||||||
You should now have all required dependencies and the project files or makefiles
|
|
||||||
necessary to compile GLFW. Go ahead and compile the actual GLFW library with
|
|
||||||
these files as you would with any other project.
|
|
||||||
|
|
||||||
With Visual Studio open `GLFW.sln` and use the Build menu. With Xcode open
|
|
||||||
`GLFW.xcodeproj` and use the Project menu.
|
|
||||||
|
|
||||||
With Linux, macOS and other forms of Unix, run `make`.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cd path/to/build
|
|
||||||
make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
With MinGW, it is `mingw32-make`.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cd path/to/build
|
|
||||||
mingw32-make
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Any CMake build directory can also be built with the `cmake` command and the
|
|
||||||
`--build` flag.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake --build path/to/build
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
This will run the platform specific build tool the directory was generated for.
|
|
||||||
|
|
||||||
Once the GLFW library is compiled you are ready to build your application,
|
|
||||||
linking it to the GLFW library. See @ref build_guide for more information.
|
|
||||||
|
|
||||||
|
|
||||||
@section compile_options CMake options
|
|
||||||
|
|
||||||
The CMake files for GLFW provide a number of options, although not all are
|
|
||||||
available on all supported platforms. Some of these are de facto standards
|
|
||||||
among projects using CMake and so have no `GLFW_` prefix.
|
|
||||||
|
|
||||||
If you are using the GUI version of CMake, these are listed and can be changed
|
|
||||||
from there. If you are using the command-line version of CMake you can use the
|
|
||||||
`ccmake` ncurses GUI to set options. Some package systems like Ubuntu and other
|
|
||||||
distributions based on Debian GNU/Linux have this tool in a separate
|
|
||||||
`cmake-curses-gui` package.
|
|
||||||
|
|
||||||
Finally, if you don't want to use any GUI, you can set options from the `cmake`
|
|
||||||
command-line with the `-D` flag.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build -D BUILD_SHARED_LIBS=ON
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_options_shared Shared CMake options
|
|
||||||
|
|
||||||
@anchor BUILD_SHARED_LIBS
|
|
||||||
__BUILD_SHARED_LIBS__ determines whether GLFW is built as a static
|
|
||||||
library or as a DLL / shared library / dynamic library. This is disabled by
|
|
||||||
default, producing a static GLFW library.
|
|
||||||
|
|
||||||
@anchor GLFW_BUILD_EXAMPLES
|
|
||||||
__GLFW_BUILD_EXAMPLES__ determines whether the GLFW examples are built
|
|
||||||
along with the library.
|
|
||||||
|
|
||||||
@anchor GLFW_BUILD_TESTS
|
|
||||||
__GLFW_BUILD_TESTS__ determines whether the GLFW test programs are
|
|
||||||
built along with the library.
|
|
||||||
|
|
||||||
@anchor GLFW_BUILD_DOCS
|
|
||||||
__GLFW_BUILD_DOCS__ determines whether the GLFW documentation is built along
|
|
||||||
with the library. This is enabled by default if
|
|
||||||
[Doxygen](https://www.doxygen.nl/) is found by CMake during configuration.
|
|
||||||
|
|
||||||
@anchor GLFW_VULKAN_STATIC
|
|
||||||
__GLFW_VULKAN_STATIC__ determines whether to use the Vulkan loader linked
|
|
||||||
directly with the application. This is disabled by default.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_options_win32 Windows specific CMake options
|
|
||||||
|
|
||||||
@anchor USE_MSVC_RUNTIME_LIBRARY_DLL
|
|
||||||
__USE_MSVC_RUNTIME_LIBRARY_DLL__ determines whether to use the DLL version or the
|
|
||||||
static library version of the Visual C++ runtime library. When enabled, the
|
|
||||||
DLL version of the Visual C++ library is used. This is enabled by default.
|
|
||||||
|
|
||||||
On CMake 3.15 and later you can set the standard CMake
|
|
||||||
[CMAKE_MSVC_RUNTIME_LIBRARY](https://cmake.org/cmake/help/latest/variable/CMAKE_MSVC_RUNTIME_LIBRARY.html)
|
|
||||||
variable instead of this GLFW-specific option.
|
|
||||||
|
|
||||||
@anchor GLFW_USE_HYBRID_HPG
|
|
||||||
__GLFW_USE_HYBRID_HPG__ determines whether to export the `NvOptimusEnablement` and
|
|
||||||
`AmdPowerXpressRequestHighPerformance` symbols, which force the use of the
|
|
||||||
high-performance GPU on Nvidia Optimus and AMD PowerXpress systems. These symbols
|
|
||||||
need to be exported by the EXE to be detected by the driver, so the override
|
|
||||||
will not work if GLFW is built as a DLL. This is disabled by default, letting
|
|
||||||
the operating system and driver decide.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection compile_options_wayland Wayland specific CMake options
|
|
||||||
|
|
||||||
@anchor GLFW_USE_WAYLAND
|
|
||||||
__GLFW_USE_WAYLAND__ determines whether to compile the library for Wayland.
|
|
||||||
This option is only available on Linux and other Unix-like systems other than
|
|
||||||
macOS. This is disabled by default.
|
|
||||||
|
|
||||||
|
|
||||||
@section compile_mingw_cross Cross-compilation with CMake and MinGW
|
|
||||||
|
|
||||||
Both Cygwin and many Linux distributions have MinGW or MinGW-w64 packages. For
|
|
||||||
example, Cygwin has the `mingw64-i686-gcc` and `mingw64-x86_64-gcc` packages
|
|
||||||
for 32- and 64-bit version of MinGW-w64, while Debian GNU/Linux and derivatives
|
|
||||||
like Ubuntu have the `mingw-w64` package for both.
|
|
||||||
|
|
||||||
GLFW has CMake toolchain files in the `CMake` subdirectory that set up
|
|
||||||
cross-compilation of Windows binaries. To use these files you set the
|
|
||||||
`CMAKE_TOOLCHAIN_FILE` CMake variable with the `-D` flag add an option when
|
|
||||||
configuring and generating the build files.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build -D CMAKE_TOOLCHAIN_FILE=path/to/file
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The exact toolchain file to use depends on the prefix used by the MinGW or
|
|
||||||
MinGW-w64 binaries on your system. You can usually see this in the /usr
|
|
||||||
directory. For example, both the Ubuntu and Cygwin MinGW-w64 packages have
|
|
||||||
`/usr/x86_64-w64-mingw32` for the 64-bit compilers, so the correct invocation
|
|
||||||
would be:
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
cmake -S path/to/glfw -B path/to/build -D CMAKE_TOOLCHAIN_FILE=CMake/x86_64-w64-mingw32.cmake
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The path to the toolchain file is relative to the path to the GLFW source tree
|
|
||||||
passed to the `-S` flag, not to the current directory.
|
|
||||||
|
|
||||||
For more details see the
|
|
||||||
[CMake toolchain guide](https://cmake.org/cmake/help/latest/manual/cmake-toolchains.7.html).
|
|
||||||
|
|
||||||
|
|
||||||
@section compile_manual Compiling GLFW manually
|
|
||||||
|
|
||||||
If you wish to compile GLFW without its CMake build environment then you will
|
|
||||||
have to do at least some of the platform detection yourself. GLFW needs
|
|
||||||
a configuration macro to be defined in order to know what window system it is
|
|
||||||
being compiled for and also has optional, platform-specific ones for various
|
|
||||||
features.
|
|
||||||
|
|
||||||
When building with CMake, the `glfw_config.h` configuration header is generated
|
|
||||||
based on the current platform and CMake options. The GLFW CMake environment
|
|
||||||
defines @b GLFW_USE_CONFIG_H, which causes this header to be included by
|
|
||||||
`internal.h`. Without this macro, GLFW will expect the necessary configuration
|
|
||||||
macros to be defined on the command-line.
|
|
||||||
|
|
||||||
The window creation API is used to create windows, handle input, monitors, gamma
|
|
||||||
ramps and clipboard. The options are:
|
|
||||||
|
|
||||||
- @b _GLFW_COCOA to use the Cocoa frameworks
|
|
||||||
- @b _GLFW_WIN32 to use the Win32 API
|
|
||||||
- @b _GLFW_X11 to use the X Window System
|
|
||||||
- @b _GLFW_WAYLAND to use the Wayland API (experimental and incomplete)
|
|
||||||
- @b _GLFW_OSMESA to use the OSMesa API (headless and non-interactive)
|
|
||||||
|
|
||||||
If you are building GLFW as a shared library / dynamic library / DLL then you
|
|
||||||
must also define @b _GLFW_BUILD_DLL. Otherwise, you must not define it.
|
|
||||||
|
|
||||||
If you are linking the Vulkan loader directly with your application then you
|
|
||||||
must also define @b _GLFW_VULKAN_STATIC. Otherwise, GLFW will attempt to use the
|
|
||||||
external version.
|
|
||||||
|
|
||||||
If you are using a custom name for the Vulkan, EGL, GLX, OSMesa, OpenGL, GLESv1
|
|
||||||
or GLESv2 library, you can override the default names by defining those you need
|
|
||||||
of @b _GLFW_VULKAN_LIBRARY, @b _GLFW_EGL_LIBRARY, @b _GLFW_GLX_LIBRARY, @b
|
|
||||||
_GLFW_OSMESA_LIBRARY, @b _GLFW_OPENGL_LIBRARY, @b _GLFW_GLESV1_LIBRARY and @b
|
|
||||||
_GLFW_GLESV2_LIBRARY. Otherwise, GLFW will use the built-in default names.
|
|
||||||
|
|
||||||
@note None of the @ref build_macros may be defined during the compilation of
|
|
||||||
GLFW. If you define any of these in your build files, make sure they are not
|
|
||||||
applied to the GLFW sources.
|
|
||||||
|
|
||||||
*/
|
|
@ -1,346 +0,0 @@
|
|||||||
/*!
|
|
||||||
|
|
||||||
@page context_guide Context guide
|
|
||||||
|
|
||||||
@tableofcontents
|
|
||||||
|
|
||||||
This guide introduces the OpenGL and OpenGL ES context related functions of
|
|
||||||
GLFW. For details on a specific function in this category, see the @ref
|
|
||||||
context. There are also guides for the other areas of the GLFW API.
|
|
||||||
|
|
||||||
- @ref intro_guide
|
|
||||||
- @ref window_guide
|
|
||||||
- @ref vulkan_guide
|
|
||||||
- @ref monitor_guide
|
|
||||||
- @ref input_guide
|
|
||||||
|
|
||||||
|
|
||||||
@section context_object Context objects
|
|
||||||
|
|
||||||
A window object encapsulates both a top-level window and an OpenGL or OpenGL ES
|
|
||||||
context. It is created with @ref glfwCreateWindow and destroyed with @ref
|
|
||||||
glfwDestroyWindow or @ref glfwTerminate. See @ref window_creation for more
|
|
||||||
information.
|
|
||||||
|
|
||||||
As the window and context are inseparably linked, the window object also serves
|
|
||||||
as the context handle.
|
|
||||||
|
|
||||||
To test the creation of various kinds of contexts and see their properties, run
|
|
||||||
the `glfwinfo` test program.
|
|
||||||
|
|
||||||
@note Vulkan does not have a context and the Vulkan instance is created via the
|
|
||||||
Vulkan API itself. If you will be using Vulkan to render to a window, disable
|
|
||||||
context creation by setting the [GLFW_CLIENT_API](@ref GLFW_CLIENT_API_hint)
|
|
||||||
hint to `GLFW_NO_API`. For more information, see the @ref vulkan_guide.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_hints Context creation hints
|
|
||||||
|
|
||||||
There are a number of hints, specified using @ref glfwWindowHint, related to
|
|
||||||
what kind of context is created. See
|
|
||||||
[context related hints](@ref window_hints_ctx) in the window guide.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_sharing Context object sharing
|
|
||||||
|
|
||||||
When creating a window and its OpenGL or OpenGL ES context with @ref
|
|
||||||
glfwCreateWindow, you can specify another window whose context the new one
|
|
||||||
should share its objects (textures, vertex and element buffers, etc.) with.
|
|
||||||
|
|
||||||
@code
|
|
||||||
GLFWwindow* second_window = glfwCreateWindow(640, 480, "Second Window", NULL, first_window);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Object sharing is implemented by the operating system and graphics driver. On
|
|
||||||
platforms where it is possible to choose which types of objects are shared, GLFW
|
|
||||||
requests that all types are shared.
|
|
||||||
|
|
||||||
See the relevant chapter of the [OpenGL](https://www.opengl.org/registry/) or
|
|
||||||
[OpenGL ES](https://www.khronos.org/opengles/) reference documents for more
|
|
||||||
information. The name and number of this chapter unfortunately varies between
|
|
||||||
versions and APIs, but has at times been named _Shared Objects and Multiple
|
|
||||||
Contexts_.
|
|
||||||
|
|
||||||
GLFW comes with a barebones object sharing example program called `sharing`.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_offscreen Offscreen contexts
|
|
||||||
|
|
||||||
GLFW doesn't support creating contexts without an associated window. However,
|
|
||||||
contexts with hidden windows can be created with the
|
|
||||||
[GLFW_VISIBLE](@ref GLFW_VISIBLE_hint) window hint.
|
|
||||||
|
|
||||||
@code
|
|
||||||
glfwWindowHint(GLFW_VISIBLE, GLFW_FALSE);
|
|
||||||
|
|
||||||
GLFWwindow* offscreen_context = glfwCreateWindow(640, 480, "", NULL, NULL);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The window never needs to be shown and its context can be used as a plain
|
|
||||||
offscreen context. Depending on the window manager, the size of a hidden
|
|
||||||
window's framebuffer may not be usable or modifiable, so framebuffer
|
|
||||||
objects are recommended for rendering with such contexts.
|
|
||||||
|
|
||||||
You should still [process events](@ref events) as long as you have at least one
|
|
||||||
window, even if none of them are visible.
|
|
||||||
|
|
||||||
@macos The first time a window is created the menu bar is created. This is not
|
|
||||||
desirable for example when writing a command-line only application. Menu bar
|
|
||||||
creation can be disabled with the @ref GLFW_COCOA_MENUBAR init hint.
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_less Windows without contexts
|
|
||||||
|
|
||||||
You can disable context creation by setting the
|
|
||||||
[GLFW_CLIENT_API](@ref GLFW_CLIENT_API_hint) hint to `GLFW_NO_API`. Windows
|
|
||||||
without contexts must not be passed to @ref glfwMakeContextCurrent or @ref
|
|
||||||
glfwSwapBuffers.
|
|
||||||
|
|
||||||
|
|
||||||
@section context_current Current context
|
|
||||||
|
|
||||||
Before you can make OpenGL or OpenGL ES calls, you need to have a current
|
|
||||||
context of the correct type. A context can only be current for a single thread
|
|
||||||
at a time, and a thread can only have a single context current at a time.
|
|
||||||
|
|
||||||
When moving a context between threads, you must make it non-current on the old
|
|
||||||
thread before making it current on the new one.
|
|
||||||
|
|
||||||
The context of a window is made current with @ref glfwMakeContextCurrent.
|
|
||||||
|
|
||||||
@code
|
|
||||||
glfwMakeContextCurrent(window);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The window of the current context is returned by @ref glfwGetCurrentContext.
|
|
||||||
|
|
||||||
@code
|
|
||||||
GLFWwindow* window = glfwGetCurrentContext();
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The following GLFW functions require a context to be current. Calling any these
|
|
||||||
functions without a current context will generate a @ref GLFW_NO_CURRENT_CONTEXT
|
|
||||||
error.
|
|
||||||
|
|
||||||
- @ref glfwSwapInterval
|
|
||||||
- @ref glfwExtensionSupported
|
|
||||||
- @ref glfwGetProcAddress
|
|
||||||
|
|
||||||
|
|
||||||
@section context_swap Buffer swapping
|
|
||||||
|
|
||||||
See @ref buffer_swap in the window guide.
|
|
||||||
|
|
||||||
|
|
||||||
@section context_glext OpenGL and OpenGL ES extensions
|
|
||||||
|
|
||||||
One of the benefits of OpenGL and OpenGL ES is their extensibility.
|
|
||||||
Hardware vendors may include extensions in their implementations that extend the
|
|
||||||
API before that functionality is included in a new version of the OpenGL or
|
|
||||||
OpenGL ES specification, and some extensions are never included and remain
|
|
||||||
as extensions until they become obsolete.
|
|
||||||
|
|
||||||
An extension is defined by:
|
|
||||||
|
|
||||||
- An extension name (e.g. `GL_ARB_gl_spirv`)
|
|
||||||
- New OpenGL tokens (e.g. `GL_SPIR_V_BINARY_ARB`)
|
|
||||||
- New OpenGL functions (e.g. `glSpecializeShaderARB`)
|
|
||||||
|
|
||||||
Note the `ARB` affix, which stands for Architecture Review Board and is used
|
|
||||||
for official extensions. The extension above was created by the ARB, but there
|
|
||||||
are many different affixes, like `NV` for Nvidia and `AMD` for, well, AMD. Any
|
|
||||||
group may also use the generic `EXT` affix. Lists of extensions, together with
|
|
||||||
their specifications, can be found at the
|
|
||||||
[OpenGL Registry](https://www.opengl.org/registry/) and
|
|
||||||
[OpenGL ES Registry](https://www.khronos.org/registry/gles/).
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_glext_auto Loading extension with a loader library
|
|
||||||
|
|
||||||
An extension loader library is the easiest and best way to access both OpenGL and
|
|
||||||
OpenGL ES extensions and modern versions of the core OpenGL or OpenGL ES APIs.
|
|
||||||
They will take care of all the details of declaring and loading everything you
|
|
||||||
need. One such library is [glad](https://github.com/Dav1dde/glad) and there are
|
|
||||||
several others.
|
|
||||||
|
|
||||||
The following example will use glad but all extension loader libraries work
|
|
||||||
similarly.
|
|
||||||
|
|
||||||
First you need to generate the source files using the glad Python script. This
|
|
||||||
example generates a loader for any version of OpenGL, which is the default for
|
|
||||||
both GLFW and glad, but loaders for OpenGL ES, as well as loaders for specific
|
|
||||||
API versions and extension sets can be generated. The generated files are
|
|
||||||
written to the `output` directory.
|
|
||||||
|
|
||||||
@code{.sh}
|
|
||||||
python main.py --generator c --no-loader --out-path output
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The `--no-loader` option is added because GLFW already provides a function for
|
|
||||||
loading OpenGL and OpenGL ES function pointers, one that automatically uses the
|
|
||||||
selected context creation API, and glad can call this instead of having to
|
|
||||||
implement its own. There are several other command-line options as well. See
|
|
||||||
the glad documentation for details.
|
|
||||||
|
|
||||||
Add the generated `output/src/glad.c`, `output/include/glad/glad.h` and
|
|
||||||
`output/include/KHR/khrplatform.h` files to your build. Then you need to
|
|
||||||
include the glad header file, which will replace the OpenGL header of your
|
|
||||||
development environment. By including the glad header before the GLFW header,
|
|
||||||
it suppresses the development environment's OpenGL or OpenGL ES header.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#include <glad/glad.h>
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Finally you need to initialize glad once you have a suitable current context.
|
|
||||||
|
|
||||||
@code
|
|
||||||
window = glfwCreateWindow(640, 480, "My Window", NULL, NULL);
|
|
||||||
if (!window)
|
|
||||||
{
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
glfwMakeContextCurrent(window);
|
|
||||||
|
|
||||||
gladLoadGLLoader((GLADloadproc) glfwGetProcAddress);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
Once glad has been loaded, you have access to all OpenGL core and extension
|
|
||||||
functions supported by both the context you created and the glad loader you
|
|
||||||
generated and you are ready to start rendering.
|
|
||||||
|
|
||||||
You can specify a minimum required OpenGL or OpenGL ES version with
|
|
||||||
[context hints](@ref window_hints_ctx). If your needs are more complex, you can
|
|
||||||
check the actual OpenGL or OpenGL ES version with
|
|
||||||
[context attributes](@ref window_attribs_ctx), or you can check whether
|
|
||||||
a specific version is supported by the current context with the
|
|
||||||
`GLAD_GL_VERSION_x_x` booleans.
|
|
||||||
|
|
||||||
@code
|
|
||||||
if (GLAD_GL_VERSION_3_2)
|
|
||||||
{
|
|
||||||
// Call OpenGL 3.2+ specific code
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
To check whether a specific extension is supported, use the `GLAD_GL_xxx`
|
|
||||||
booleans.
|
|
||||||
|
|
||||||
@code
|
|
||||||
if (GLAD_GL_ARB_gl_spirv)
|
|
||||||
{
|
|
||||||
// Use GL_ARB_gl_spirv
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsection context_glext_manual Loading extensions manually
|
|
||||||
|
|
||||||
__Do not use this technique__ unless it is absolutely necessary. An
|
|
||||||
[extension loader library](@ref context_glext_auto) will save you a ton of
|
|
||||||
tedious, repetitive, error prone work.
|
|
||||||
|
|
||||||
To use a certain extension, you must first check whether the context supports
|
|
||||||
that extension and then, if it introduces new functions, retrieve the pointers
|
|
||||||
to those functions. GLFW provides @ref glfwExtensionSupported and @ref
|
|
||||||
glfwGetProcAddress for manual loading of extensions and new API functions.
|
|
||||||
|
|
||||||
This section will demonstrate manual loading of OpenGL extensions. The loading
|
|
||||||
of OpenGL ES extensions is identical except for the name of the extension header.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection context_glext_header The glext.h header
|
|
||||||
|
|
||||||
The `glext.h` extension header is a continually updated file that defines the
|
|
||||||
interfaces for all OpenGL extensions. The latest version of this can always be
|
|
||||||
found at the [OpenGL Registry](https://www.opengl.org/registry/). There are also
|
|
||||||
extension headers for the various versions of OpenGL ES at the
|
|
||||||
[OpenGL ES Registry](https://www.khronos.org/registry/gles/). It it strongly
|
|
||||||
recommended that you use your own copy of the extension header, as the one
|
|
||||||
included in your development environment may be several years out of date and
|
|
||||||
may not include the extensions you wish to use.
|
|
||||||
|
|
||||||
The header defines function pointer types for all functions of all extensions it
|
|
||||||
supports. These have names like `PFNGLSPECIALIZESHADERARBPROC` (for
|
|
||||||
`glSpecializeShaderARB`), i.e. the name is made uppercase and `PFN` (pointer
|
|
||||||
to function) and `PROC` (procedure) are added to the ends.
|
|
||||||
|
|
||||||
To include the extension header, define @ref GLFW_INCLUDE_GLEXT before including
|
|
||||||
the GLFW header.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#define GLFW_INCLUDE_GLEXT
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection context_glext_string Checking for extensions
|
|
||||||
|
|
||||||
A given machine may not actually support the extension (it may have older
|
|
||||||
drivers or a graphics card that lacks the necessary hardware features), so it
|
|
||||||
is necessary to check at run-time whether the context supports the extension.
|
|
||||||
This is done with @ref glfwExtensionSupported.
|
|
||||||
|
|
||||||
@code
|
|
||||||
if (glfwExtensionSupported("GL_ARB_gl_spirv"))
|
|
||||||
{
|
|
||||||
// The extension is supported by the current context
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The argument is a null terminated ASCII string with the extension name. If the
|
|
||||||
extension is supported, @ref glfwExtensionSupported returns `GLFW_TRUE`,
|
|
||||||
otherwise it returns `GLFW_FALSE`.
|
|
||||||
|
|
||||||
|
|
||||||
@subsubsection context_glext_proc Fetching function pointers
|
|
||||||
|
|
||||||
Many extensions, though not all, require the use of new OpenGL functions.
|
|
||||||
These functions often do not have entry points in the client API libraries of
|
|
||||||
your operating system, making it necessary to fetch them at run time. You can
|
|
||||||
retrieve pointers to these functions with @ref glfwGetProcAddress.
|
|
||||||
|
|
||||||
@code
|
|
||||||
PFNGLSPECIALIZESHADERARBPROC pfnSpecializeShaderARB = glfwGetProcAddress("glSpecializeShaderARB");
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
In general, you should avoid giving the function pointer variables the (exact)
|
|
||||||
same name as the function, as this may confuse your linker. Instead, you can
|
|
||||||
use a different prefix, like above, or some other naming scheme.
|
|
||||||
|
|
||||||
Now that all the pieces have been introduced, here is what they might look like
|
|
||||||
when used together.
|
|
||||||
|
|
||||||
@code
|
|
||||||
#define GLFW_INCLUDE_GLEXT
|
|
||||||
#include <GLFW/glfw3.h>
|
|
||||||
|
|
||||||
#define glSpecializeShaderARB pfnSpecializeShaderARB
|
|
||||||
PFNGLSPECIALIZESHADERARBPROC pfnSpecializeShaderARB;
|
|
||||||
|
|
||||||
// Flag indicating whether the extension is supported
|
|
||||||
int has_ARB_gl_spirv = 0;
|
|
||||||
|
|
||||||
void load_extensions(void)
|
|
||||||
{
|
|
||||||
if (glfwExtensionSupported("GL_ARB_gl_spirv"))
|
|
||||||
{
|
|
||||||
pfnSpecializeShaderARB = (PFNGLSPECIALIZESHADERARBPROC)
|
|
||||||
glfwGetProcAddress("glSpecializeShaderARB");
|
|
||||||
has_ARB_gl_spirv = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void some_function(void)
|
|
||||||
{
|
|
||||||
if (has_ARB_gl_spirv)
|
|
||||||
{
|
|
||||||
// Now the extension function can be called as usual
|
|
||||||
glSpecializeShaderARB(...);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
*/
|
|
@ -1 +0,0 @@
|
|||||||
{"version":3,"sourceRoot":"","sources":["extra.scss"],"names":[],"mappings":"AA8EA,4GACI,gBACA,iBAGJ,yBACC,yDAGD,6HACC,sDAGD,yIACC,sDAGD,mBACI,WA9EuB,KA+EvB,iBAGJ,uBACC,MAzFoB,QA0FjB,iBAGJ,6UACC,gBAGD,mJACC,YAGD,yHACC,iBAGD,sBACC,gBAGD,4LACC,UAGD,yCACC,aAGD,kMACC,WAnHgC,QAsHjC,KACC,MA1HoB,QA6HrB,sDACC,MA/Ge,QAgHf,mBAGD,GACE,iBACA,eAGF,GACE,iBACA,gBACA,eAGF,GACE,iBACA,gBACA,eAGF,YACC,eACA,gBACA,gBACA,eACA,cAEA,aACA,mBACA,eACA,2BACA,mBACA,sBAGD,UACC,iBACA,mBACA,MA/J0B,KAgK1B,gBACA,qEAGD,YACC,qBACA,kBACA,YAGD,yBACC,WAGD,oCACC,iBACA,gBACA,cACA,MAlL0B,KAqL3B,YACC,eAGD,8CACC,qBAGD,mBACC,MA9L0B,KAiM3B,eACC,kBACA,YACA,eAGD,KACC,WAxM0B,KA2M3B,UACC,gBACA,cACA,eAGD,WACC,gBACA,cACA,eAGD,UACI,aAGJ,mBACI,iBACA,iBAGJ,WACC,gBACA,aACA,mBACA,eACA,2BACA,mBACA,sBAGD,mEACC,MA9OgC,QAiPjC,gCACC,MArPoB,QAwPrB,sCACC,MAjOoB,KAoOrB,yBACC,kBAGD,UACC,iBAGD,wBACC,gBACA,cACA,eACA,qBAGD,uDACC,gEACA,+BACA,+BACA,gBACA,MArPgB,KAwPjB,mBACC,MA5PoB,KA6PpB,aACA,kBACA,yBAGD,QACC,WACA,WAGD,WACC,iBAGD,WACC,mBAGD,WACC,cACA,eACA,qBAGD,oCACC,gEACA,kCACA,2BACA,MAlSe,QAmSf,yBACA,kBAGD,WACC,MA3QuB,QA8QxB,cACC,sBACA,2BACA,4BACA,mBAGD,cACC,sBACA,+BACA,8BACA,gBAGD,mCACC,wBACA,iBACA,sBACA,kBAGD,gIACC,MAxToB,KAyTpB,qBAGD,cACC,wBACA,iBACA,sBACA,kBAGD,iBACC,WACA,4EAGD,oCApSC,gEACA,kCACA,cACA,yBAqSD,wBAxSC,gEACA,kCACA,cACA,yBAySD,qBA5SC,gEACA,kCACA,cACA,yBA6SD,gBAhTC,gEACA,kCACA,cACA,yBAiTD,iGACC,kBACA,YACA,2BACA,aAGD,kRACC,cAGD,SACC,oBAGD,0BACC,mBACA,kBACA,YACA,YACA,cACA,2BACA,aAGD,+CACC,MA1YoB,QA6YrB,+BACC,cAGD,sBACC,cAGD,+CACC,cACA,iBAGD,mBACC,cAGD,KACC,aACA","file":"extra.css"}
|
|
@ -1,430 +0,0 @@
|
|||||||
// NOTE: Please use this file to perform modifications on default style sheets.
|
|
||||||
//
|
|
||||||
// You need to install the official Sass CLI tool:
|
|
||||||
// npm install -g sass
|
|
||||||
//
|
|
||||||
// Run this command to regenerate extra.css after you're finished with changes:
|
|
||||||
// sass --style=compressed extra.scss extra.css
|
|
||||||
//
|
|
||||||
// Alternatively you can use online services to regenerate extra.css.
|
|
||||||
|
|
||||||
|
|
||||||
// Default text color for page contents
|
|
||||||
$default-text-color: hsl(0,0%,30%);
|
|
||||||
|
|
||||||
// Page header, footer, table rows, inline codes and definition lists
|
|
||||||
$header-footer-background-color: hsl(0,0%,95%);
|
|
||||||
|
|
||||||
// Page header, footer links and navigation bar background
|
|
||||||
$header-footer-link-color: hsl(0,0%,40%);
|
|
||||||
|
|
||||||
// Doxygen navigation bar links
|
|
||||||
$navbar-link-color: $header-footer-background-color;
|
|
||||||
|
|
||||||
// Page content background color
|
|
||||||
$content-background-color: hsl(0,0%,100%);
|
|
||||||
|
|
||||||
// Bold, italic, h1, h2, ... and table of contents
|
|
||||||
$heading-color: hsl(0,0%,10%);
|
|
||||||
|
|
||||||
// Function, enum and macro definition separator
|
|
||||||
$def-separator-color: $header-footer-background-color;
|
|
||||||
|
|
||||||
// Base color hue
|
|
||||||
$base-hue: 24;
|
|
||||||
|
|
||||||
// Default color used for links
|
|
||||||
$default-link-color: hsl($base-hue,100%,50%);
|
|
||||||
|
|
||||||
// Doxygen navigation bar active tab
|
|
||||||
$tab-text-color: hsl(0,0%,100%);
|
|
||||||
$tab-background-color1: $default-link-color;
|
|
||||||
$tab-background-color2: lighten(adjust-hue($tab-background-color1, 10), 10%);
|
|
||||||
|
|
||||||
// Table borders
|
|
||||||
$default-border-color: $default-link-color;
|
|
||||||
|
|
||||||
// Table header
|
|
||||||
$table-text-color: $tab-text-color;
|
|
||||||
$table-background-color1: $tab-background-color1;
|
|
||||||
$table-background-color2: $tab-background-color2;
|
|
||||||
|
|
||||||
// Table of contents, data structure index and prototypes
|
|
||||||
$toc-background-color1: hsl(0,0%,90%);
|
|
||||||
$toc-background-color2: lighten($toc-background-color1, 5%);
|
|
||||||
|
|
||||||
// Function prototype parameters color
|
|
||||||
$prototype-param-color: darken($default-link-color, 25%);
|
|
||||||
|
|
||||||
// Message box color: note, pre, post and invariant
|
|
||||||
$box-note-color: hsl(103,80%,85%);
|
|
||||||
|
|
||||||
// Message box color: warning and attention
|
|
||||||
$box-warning-color: hsl(34,80%,85%);
|
|
||||||
|
|
||||||
// Message box color: deprecated and bug
|
|
||||||
$box-bug-color: hsl(333,80%,85%);
|
|
||||||
|
|
||||||
// Message box color: todo and test
|
|
||||||
$box-todo-color: hsl(200,80%,85%);
|
|
||||||
|
|
||||||
// Message box helper function
|
|
||||||
@mixin message-box($base-color){
|
|
||||||
background:linear-gradient(to bottom,lighten($base-color, 5%) 0%,$base-color 100%);
|
|
||||||
box-shadow:inset 0 0 32px darken($base-color, 5%);
|
|
||||||
color:darken($base-color, 67%);
|
|
||||||
border:2px solid desaturate(darken($base-color, 10%), 20%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox,.sm-dox a,.sm-dox a:focus,.sm-dox a:active,.sm-dox a:hover,.sm-dox a.highlighted,.sm-dox ul a:hover {
|
|
||||||
background:none;
|
|
||||||
text-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox a span.sub-arrow {
|
|
||||||
border-color:$navbar-link-color transparent transparent transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox a span.sub-arrow:active,.sm-dox a span.sub-arrow:focus,.sm-dox a span.sub-arrow:hover,.sm-dox a:hover span.sub-arrow {
|
|
||||||
border-color:$default-link-color transparent transparent transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox ul a span.sub-arrow:active,.sm-dox ul a span.sub-arrow:focus,.sm-dox ul a span.sub-arrow:hover,.sm-dox ul a:hover span.sub-arrow {
|
|
||||||
border-color:transparent transparent transparent $default-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox ul a:hover {
|
|
||||||
background:$header-footer-link-color;
|
|
||||||
text-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sm-dox ul.sm-nowrap a {
|
|
||||||
color:$default-text-color;
|
|
||||||
text-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-nav,#main-menu,#main-menu a,#main-menu a:visited,#main-menu a:hover,#main-menu li,.memdoc,dl.reflist dd,div.toc li,.ah,span.lineno,span.lineno a,span.lineno a:hover,.note code,.pre code,.post code,.invariant code,.warning code,.attention code,.deprecated code,.bug code,.todo code,.test code,.doxtable code,.markdownTable code {
|
|
||||||
background:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#titlearea,.footer,.contents,div.header,.memdoc,table.doxtable td,table.doxtable th,table.markdownTable td,table.markdownTable th,hr,.memSeparator {
|
|
||||||
border:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu a,#main-menu a:visited,#main-menu a:hover,#main-menu li,.reflist dt a.el,.levels span,.directory .levels span {
|
|
||||||
text-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.memdoc,dl.reflist dd {
|
|
||||||
box-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.headertitle,.note code,.pre code,.post code,.invariant code,.warning code,.attention code,.deprecated code,.bug code,.todo code,.test code,table.doxtable code,table.markdownTable code {
|
|
||||||
padding:0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#nav-path,.directory .levels,span.lineno {
|
|
||||||
display:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
html,#titlearea,.footer,tr.even,.directory tr.even,.doxtable tr:nth-child(even),tr.markdownTableBody:nth-child(even),.mdescLeft,.mdescRight,.memItemLeft,.memItemRight,code,.markdownTableRowEven {
|
|
||||||
background:$header-footer-background-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
color:$default-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1,h2,h2.groupheader,h3,div.toc h3,h4,h5,h6,strong,em {
|
|
||||||
color:$heading-color;
|
|
||||||
border-bottom:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
padding-top:0.5em;
|
|
||||||
font-size:180%;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
padding-top:0.5em;
|
|
||||||
margin-bottom:0;
|
|
||||||
font-size:140%;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
padding-top:0.5em;
|
|
||||||
margin-bottom:0;
|
|
||||||
font-size:110%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.glfwheader {
|
|
||||||
font-size:16px;
|
|
||||||
min-height:64px;
|
|
||||||
max-width:920px;
|
|
||||||
padding:0 32px;
|
|
||||||
margin:0 auto;
|
|
||||||
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
justify-content: flex-start;
|
|
||||||
align-items: center;
|
|
||||||
align-content: stretch;
|
|
||||||
}
|
|
||||||
|
|
||||||
#glfwhome {
|
|
||||||
line-height:64px;
|
|
||||||
padding-right:48px;
|
|
||||||
color:$header-footer-link-color;
|
|
||||||
font-size:2.5em;
|
|
||||||
background:url("https://www.glfw.org/css/arrow.png") no-repeat right;
|
|
||||||
}
|
|
||||||
|
|
||||||
.glfwnavbar {
|
|
||||||
list-style-type:none;
|
|
||||||
margin:0 0 0 auto;
|
|
||||||
float:right;
|
|
||||||
}
|
|
||||||
|
|
||||||
#glfwhome,.glfwnavbar li {
|
|
||||||
float:left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.glfwnavbar a,.glfwnavbar a:visited {
|
|
||||||
line-height:64px;
|
|
||||||
margin-left:2em;
|
|
||||||
display:block;
|
|
||||||
color:$header-footer-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.glfwnavbar {
|
|
||||||
padding-left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#glfwhome,.glfwnavbar a,.glfwnavbar a:visited {
|
|
||||||
transition:.35s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
#titlearea,.footer {
|
|
||||||
color:$header-footer-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
address.footer {
|
|
||||||
text-align:center;
|
|
||||||
padding:2em;
|
|
||||||
margin-top:3em;
|
|
||||||
}
|
|
||||||
|
|
||||||
#top {
|
|
||||||
background:$header-footer-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-nav {
|
|
||||||
max-width:960px;
|
|
||||||
margin:0 auto;
|
|
||||||
font-size:13px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu {
|
|
||||||
max-width:920px;
|
|
||||||
margin:0 auto;
|
|
||||||
font-size:13px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.memtitle {
|
|
||||||
display:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.memproto,.memname {
|
|
||||||
font-weight:bold;
|
|
||||||
text-shadow:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu {
|
|
||||||
min-height:36px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
justify-content: flex-start;
|
|
||||||
align-items: center;
|
|
||||||
align-content: stretch;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu a,#main-menu a:visited,#main-menu a:hover,#main-menu li {
|
|
||||||
color:$navbar-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu li ul.sm-nowrap li a {
|
|
||||||
color:$default-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu li ul.sm-nowrap li a:hover {
|
|
||||||
color:$default-link-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
#main-menu > li:last-child {
|
|
||||||
margin: 0 0 0 auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.contents {
|
|
||||||
min-height:590px;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.contents,div.header {
|
|
||||||
max-width:920px;
|
|
||||||
margin:0 auto;
|
|
||||||
padding:0 32px;
|
|
||||||
background:$content-background-color none;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.doxtable th,table.markdownTable th,dl.reflist dt {
|
|
||||||
background:linear-gradient(to bottom,$table-background-color2 0%,$table-background-color1 100%);
|
|
||||||
box-shadow:inset 0 0 32px $table-background-color1;
|
|
||||||
text-shadow:0 -1px 1px darken($table-background-color1, 15%);
|
|
||||||
text-align:left;
|
|
||||||
color:$table-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.reflist dt a.el {
|
|
||||||
color:$default-link-color;
|
|
||||||
padding:.2em;
|
|
||||||
border-radius:4px;
|
|
||||||
background-color:lighten($default-link-color, 40%);
|
|
||||||
}
|
|
||||||
|
|
||||||
div.toc {
|
|
||||||
float:none;
|
|
||||||
width:auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.toc h3 {
|
|
||||||
font-size:1.17em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.toc ul {
|
|
||||||
padding-left:1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.toc li {
|
|
||||||
font-size:1em;
|
|
||||||
padding-left:0;
|
|
||||||
list-style-type:disc;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.toc,.memproto,div.qindex,div.ah {
|
|
||||||
background:linear-gradient(to bottom,$toc-background-color2 0%,$toc-background-color1 100%);
|
|
||||||
box-shadow:inset 0 0 32px $toc-background-color1;
|
|
||||||
text-shadow:0 1px 1px lighten($toc-background-color2, 10%);
|
|
||||||
color:$heading-color;
|
|
||||||
border:2px solid $toc-background-color1;
|
|
||||||
border-radius:4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.paramname {
|
|
||||||
color:$prototype-param-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.reflist dt {
|
|
||||||
border:2px solid $default-border-color;
|
|
||||||
border-top-left-radius:4px;
|
|
||||||
border-top-right-radius:4px;
|
|
||||||
border-bottom:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.reflist dd {
|
|
||||||
border:2px solid $default-border-color;
|
|
||||||
border-bottom-right-radius:4px;
|
|
||||||
border-bottom-left-radius:4px;
|
|
||||||
border-top:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
table.doxtable,table.markdownTable {
|
|
||||||
border-collapse:inherit;
|
|
||||||
border-spacing:0;
|
|
||||||
border:2px solid $default-border-color;
|
|
||||||
border-radius:4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
a,a:hover,a:visited,a:visited:hover,.contents a:visited,.el,a.el:visited,#glfwhome:hover,#main-menu a:hover,span.lineno a:hover {
|
|
||||||
color:$default-link-color;
|
|
||||||
text-decoration:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.directory {
|
|
||||||
border-collapse:inherit;
|
|
||||||
border-spacing:0;
|
|
||||||
border:2px solid $default-border-color;
|
|
||||||
border-radius:4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
hr,.memSeparator {
|
|
||||||
height:2px;
|
|
||||||
background:linear-gradient(to right,$def-separator-color 0%,darken($def-separator-color, 10%) 50%,$def-separator-color 100%);
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.note,dl.pre,dl.post,dl.invariant {
|
|
||||||
@include message-box($box-note-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.warning,dl.attention {
|
|
||||||
@include message-box($box-warning-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.deprecated,dl.bug {
|
|
||||||
@include message-box($box-bug-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.todo,dl.test {
|
|
||||||
@include message-box($box-todo-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
dl.note,dl.pre,dl.post,dl.invariant,dl.warning,dl.attention,dl.deprecated,dl.bug,dl.todo,dl.test {
|
|
||||||
border-radius:4px;
|
|
||||||
padding:1em;
|
|
||||||
text-shadow:0 1px 1px hsl(0,0%,100%);
|
|
||||||
margin:1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.note a,.pre a,.post a,.invariant a,.warning a,.attention a,.deprecated a,.bug a,.todo a,.test a,.note a:visited,.pre a:visited,.post a:visited,.invariant a:visited,.warning a:visited,.attention a:visited,.deprecated a:visited,.bug a:visited,.todo a:visited,.test a:visited {
|
|
||||||
color:inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.line {
|
|
||||||
line-height:inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
div.fragment,pre.fragment {
|
|
||||||
background:hsl(0,0%,95%);
|
|
||||||
border-radius:4px;
|
|
||||||
border:none;
|
|
||||||
padding:1em;
|
|
||||||
overflow:auto;
|
|
||||||
border-left:4px solid hsl(0,0%,80%);
|
|
||||||
margin:1em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.lineno a,.lineno a:visited,.line,pre.fragment {
|
|
||||||
color:$default-text-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.preprocessor,span.comment {
|
|
||||||
color:hsl(193,100%,30%);
|
|
||||||
}
|
|
||||||
|
|
||||||
a.code,a.code:visited {
|
|
||||||
color:hsl(18,100%,45%);
|
|
||||||
}
|
|
||||||
|
|
||||||
span.keyword,span.keywordtype,span.keywordflow {
|
|
||||||
color:darken($default-text-color, 5%);
|
|
||||||
font-weight:bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
span.stringliteral {
|
|
||||||
color:hsl(261,100%,30%);
|
|
||||||
}
|
|
||||||
|
|
||||||
code {
|
|
||||||
padding:.1em;
|
|
||||||
border-radius:4px;
|
|
||||||
}
|
|
@ -1,7 +0,0 @@
|
|||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on $date for $projectname $projectnumber
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,34 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen $doxygenversion"/>
|
|
||||||
<!--BEGIN PROJECT_NAME--><title>$projectname: $title</title><!--END PROJECT_NAME-->
|
|
||||||
<!--BEGIN !PROJECT_NAME--><title>$title</title><!--END !PROJECT_NAME-->
|
|
||||||
<link href="$relpath^tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="$relpath^jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="$relpath^dynsections.js"></script>
|
|
||||||
$treeview
|
|
||||||
$search
|
|
||||||
$mathjax
|
|
||||||
<link href="$relpath^$stylesheet" rel="stylesheet" type="text/css" />
|
|
||||||
$extrastylesheet
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
|
|
||||||
<!--BEGIN TITLEAREA-->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!--END TITLEAREA-->
|
|
||||||
<!-- end header part -->
|
|
Before Width: | Height: | Size: 676 B |
Before Width: | Height: | Size: 147 B |
@ -1,74 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: build.dox File Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">build.dox File Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,192 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Building applications</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div><div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Building applications </div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="toc"><h3>Table of Contents</h3>
|
|
||||||
<ul><li class="level1"><a href="#build_include">Including the GLFW header file</a><ul><li class="level2"><a href="#build_macros">GLFW header option macros</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level1"><a href="#build_link">Link with the right libraries</a><ul><li class="level2"><a href="#build_link_win32">With MinGW or Visual C++ on Windows</a></li>
|
|
||||||
<li class="level2"><a href="#build_link_cmake_source">With CMake and GLFW source</a></li>
|
|
||||||
<li class="level2"><a href="#build_link_cmake_package">With CMake and installed GLFW binaries</a></li>
|
|
||||||
<li class="level2"><a href="#build_link_pkgconfig">With makefiles and pkg-config on Unix</a></li>
|
|
||||||
<li class="level2"><a href="#build_link_xcode">With Xcode on macOS</a></li>
|
|
||||||
<li class="level2"><a href="#build_link_osx">With command-line on macOS</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="textblock"><p >This is about compiling and linking applications that use GLFW. For information on how to write such applications, start with the <a class="el" href="quick_guide.html">introductory tutorial</a>. For information on how to compile the GLFW library itself, see <a class="el" href="compile_guide.html">Compiling GLFW</a>.</p>
|
|
||||||
<p >This is not a tutorial on compilation or linking. It assumes basic understanding of how to compile and link a C program as well as how to use the specific compiler of your chosen development environment. The compilation and linking process should be explained in your C programming material and in the documentation for your development environment.</p>
|
|
||||||
<h1><a class="anchor" id="build_include"></a>
|
|
||||||
Including the GLFW header file</h1>
|
|
||||||
<p >You should include the GLFW header in the source files where you use OpenGL or GLFW.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#include <<a class="code" href="glfw3_8h.html">GLFW/glfw3.h</a>></span></div>
|
|
||||||
<div class="ttc" id="aglfw3_8h_html"><div class="ttname"><a href="glfw3_8h.html">glfw3.h</a></div><div class="ttdoc">The header of the GLFW 3 API.</div></div>
|
|
||||||
</div><!-- fragment --><p >This header defines all the constants and declares all the types and function prototypes of the GLFW API. By default it also includes the OpenGL header from your development environment. See <a class="el" href="build_guide.html#build_macros">option macros</a> below for how to select OpenGL ES headers and more.</p>
|
|
||||||
<p >The GLFW header also defines any platform-specific macros needed by your OpenGL header, so that it can be included without needing any window system headers.</p>
|
|
||||||
<p >It does this only when needed, so if window system headers are included, the GLFW header does not try to redefine those symbols. The reverse is not true, i.e. <code>windows.h</code> cannot cope if any Win32 symbols have already been defined.</p>
|
|
||||||
<p >In other words:</p>
|
|
||||||
<ul>
|
|
||||||
<li>Use the GLFW header to include OpenGL or OpenGL ES headers portably</li>
|
|
||||||
<li>Do not include window system headers unless you will use those APIs directly</li>
|
|
||||||
<li>If you do need such headers, include them before the GLFW header</li>
|
|
||||||
</ul>
|
|
||||||
<p >If you are using an OpenGL extension loading library such as <a href="https://github.com/Dav1dde/glad">glad</a>, the extension loader header should be included before the GLFW one. GLFW attempts to detect any OpenGL or OpenGL ES header or extension loader header included before it and will then disable the inclusion of the default OpenGL header. Most extension loaders also define macros that disable similar headers below it.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#include <glad/gl.h></span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <<a class="code" href="glfw3_8h.html">GLFW/glfw3.h</a>></span></div>
|
|
||||||
</div><!-- fragment --><p >Both of these mechanisms depend on the extension loader header defining a known macro. If yours doesn't or you don't know which one your users will pick, the <a class="el" href="build_guide.html#GLFW_INCLUDE_NONE">GLFW_INCLUDE_NONE</a> macro will explicitly to prevent the GLFW header from including the OpenGL header. This will also allow you to include the two headers in any order.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#define GLFW_INCLUDE_NONE</span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <<a class="code" href="glfw3_8h.html">GLFW/glfw3.h</a>></span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <glad/gl.h></span></div>
|
|
||||||
</div><!-- fragment --><h2><a class="anchor" id="build_macros"></a>
|
|
||||||
GLFW header option macros</h2>
|
|
||||||
<p >These macros may be defined before the inclusion of the GLFW header and affect its behavior.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_DLL"></a><b>GLFW_DLL</b> is required on Windows when using the GLFW DLL, to tell the compiler that the GLFW functions are defined in a DLL.</p>
|
|
||||||
<p >The following macros control which OpenGL or OpenGL ES API header is included. Only one of these may be defined at a time.</p>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>GLFW does not provide any of the API headers mentioned below. They are provided by your development environment or your OpenGL, OpenGL ES or Vulkan SDK, and most of them can be downloaded from the <a href="https://www.khronos.org/registry/">Khronos Registry</a>.</dd></dl>
|
|
||||||
<p><a class="anchor" id="GLFW_INCLUDE_GLCOREARB"></a><b>GLFW_INCLUDE_GLCOREARB</b> makes the GLFW header include the modern <code>GL/glcorearb.h</code> header (<code>OpenGL/gl3.h</code> on macOS) instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_ES1"></a><b>GLFW_INCLUDE_ES1</b> makes the GLFW header include the OpenGL ES 1.x <code>GLES/gl.h</code> header instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_ES2"></a><b>GLFW_INCLUDE_ES2</b> makes the GLFW header include the OpenGL ES 2.0 <code>GLES2/gl2.h</code> header instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_ES3"></a><b>GLFW_INCLUDE_ES3</b> makes the GLFW header include the OpenGL ES 3.0 <code>GLES3/gl3.h</code> header instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_ES31"></a><b>GLFW_INCLUDE_ES31</b> makes the GLFW header include the OpenGL ES 3.1 <code>GLES3/gl31.h</code> header instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_ES32"></a><b>GLFW_INCLUDE_ES32</b> makes the GLFW header include the OpenGL ES 3.2 <code>GLES3/gl32.h</code> header instead of the regular OpenGL header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_NONE"></a><b>GLFW_INCLUDE_NONE</b> makes the GLFW header not include any OpenGL or OpenGL ES API header. This is useful in combination with an extension loading library.</p>
|
|
||||||
<p >If none of the above inclusion macros are defined, the standard OpenGL <code>GL/gl.h</code> header (<code>OpenGL/gl.h</code> on macOS) is included, unless GLFW detects the inclusion guards of any OpenGL, OpenGL ES or extension loader header it knows about.</p>
|
|
||||||
<p >The following macros control the inclusion of additional API headers. Any number of these may be defined simultaneously, and/or together with one of the above macros.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_VULKAN"></a><b>GLFW_INCLUDE_VULKAN</b> makes the GLFW header include the Vulkan <code>vulkan/vulkan.h</code> header in addition to any selected OpenGL or OpenGL ES header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_GLEXT"></a><b>GLFW_INCLUDE_GLEXT</b> makes the GLFW header include the appropriate extension header for the OpenGL or OpenGL ES header selected above after and in addition to that header.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_INCLUDE_GLU"></a><b>GLFW_INCLUDE_GLU</b> makes the header include the GLU header in addition to the header selected above. This should only be used with the standard OpenGL header and only for compatibility with legacy code. GLU has been deprecated and should not be used in new code.</p>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>None of these macros may be defined during the compilation of GLFW itself. If your build includes GLFW and you define any these in your build files, make sure they are not applied to the GLFW sources.</dd></dl>
|
|
||||||
<h1><a class="anchor" id="build_link"></a>
|
|
||||||
Link with the right libraries</h1>
|
|
||||||
<p >GLFW is essentially a wrapper of various platform-specific APIs and therefore needs to link against many different system libraries. If you are using GLFW as a shared library / dynamic library / DLL then it takes care of these links. However, if you are using GLFW as a static library then your executable will need to link against these libraries.</p>
|
|
||||||
<p >On Windows and macOS, the list of system libraries is static and can be hard-coded into your build environment. See the section for your development environment below. On Linux and other Unix-like operating systems, the list varies but can be retrieved in various ways as described below.</p>
|
|
||||||
<p >A good general introduction to linking is <a href="https://www.lurklurk.org/linkers/linkers.html">Beginner's Guide to Linkers</a> by David Drysdale.</p>
|
|
||||||
<h2><a class="anchor" id="build_link_win32"></a>
|
|
||||||
With MinGW or Visual C++ on Windows</h2>
|
|
||||||
<p >The static version of the GLFW library is named <code>glfw3</code>. When using this version, it is also necessary to link with some libraries that GLFW uses.</p>
|
|
||||||
<p >When using MinGW to link an application with the static version of GLFW, you must also explicitly link with <code>gdi32</code>. Other toolchains including MinGW-w64 include it in the set of default libraries along with other dependencies like <code>user32</code> and <code>kernel32</code>.</p>
|
|
||||||
<p >The link library for the GLFW DLL is named <code>glfw3dll</code>. When compiling an application that uses the DLL version of GLFW, you need to define the <a class="el" href="build_guide.html#GLFW_DLL">GLFW_DLL</a> macro <em>before</em> any inclusion of the GLFW header. This can be done either with a compiler switch or by defining it in your source code.</p>
|
|
||||||
<h2><a class="anchor" id="build_link_cmake_source"></a>
|
|
||||||
With CMake and GLFW source</h2>
|
|
||||||
<p >This section is about using CMake to compile and link GLFW along with your application. If you want to use an installed binary instead, see <a class="el" href="build_guide.html#build_link_cmake_package">With CMake and installed GLFW binaries</a>.</p>
|
|
||||||
<p >With a few changes to your <code>CMakeLists.txt</code> you can have the GLFW source tree built along with your application.</p>
|
|
||||||
<p >When including GLFW as part of your build, you probably don't want to build the GLFW tests, examples and documentation. To disable these, set the corresponding cache variables before adding the GLFW source tree.</p>
|
|
||||||
<div class="fragment"><div class="line">set(GLFW_BUILD_DOCS OFF CACHE BOOL <span class="stringliteral">""</span> FORCE)</div>
|
|
||||||
<div class="line">set(GLFW_BUILD_TESTS OFF CACHE BOOL <span class="stringliteral">""</span> FORCE)</div>
|
|
||||||
<div class="line">set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL <span class="stringliteral">""</span> FORCE)</div>
|
|
||||||
</div><!-- fragment --><p >Add the root directory of the GLFW source tree to your project. This will add the <code>glfw</code> target to your project.</p>
|
|
||||||
<div class="fragment"><div class="line">add_subdirectory(path/to/glfw)</div>
|
|
||||||
</div><!-- fragment --><p >Once GLFW has been added, link your application against the <code>glfw</code> target. This adds the GLFW library and its link-time dependencies as it is currently configured, the include directory for the GLFW header and, when applicable, the <a class="el" href="build_guide.html#GLFW_DLL">GLFW_DLL</a> macro.</p>
|
|
||||||
<div class="fragment"><div class="line">target_link_libraries(myapp glfw)</div>
|
|
||||||
</div><!-- fragment --><p >Note that the <code>glfw</code> target does not depend on OpenGL, as GLFW loads any OpenGL, OpenGL ES or Vulkan libraries it needs at runtime. If your application calls OpenGL directly, instead of using a modern <a class="el" href="context_guide.html#context_glext_auto">extension loader library</a>, use the OpenGL CMake package.</p>
|
|
||||||
<div class="fragment"><div class="line">find_package(OpenGL REQUIRED)</div>
|
|
||||||
</div><!-- fragment --><p >If OpenGL is found, the <code>OpenGL::GL</code> target is added to your project, containing library and include directory paths. Link against this like any other library.</p>
|
|
||||||
<div class="fragment"><div class="line">target_link_libraries(myapp OpenGL::GL)</div>
|
|
||||||
</div><!-- fragment --><p >For a minimal example of a program and GLFW sources built with CMake, see the <a href="https://github.com/juliettef/GLFW-CMake-starter">GLFW CMake Starter</a> on GitHub.</p>
|
|
||||||
<h2><a class="anchor" id="build_link_cmake_package"></a>
|
|
||||||
With CMake and installed GLFW binaries</h2>
|
|
||||||
<p >This section is about using CMake to link GLFW after it has been built and installed. If you want to build it along with your application instead, see <a class="el" href="build_guide.html#build_link_cmake_source">With CMake and GLFW source</a>.</p>
|
|
||||||
<p >With a few changes to your <code>CMakeLists.txt</code> you can locate the package and target files generated when GLFW is installed.</p>
|
|
||||||
<div class="fragment"><div class="line">find_package(glfw3 3.3 REQUIRED)</div>
|
|
||||||
</div><!-- fragment --><p >Once GLFW has been added to the project, link against it with the <code>glfw</code> target. This adds the GLFW library and its link-time dependencies, the include directory for the GLFW header and, when applicable, the <a class="el" href="build_guide.html#GLFW_DLL">GLFW_DLL</a> macro.</p>
|
|
||||||
<div class="fragment"><div class="line">target_link_libraries(myapp glfw)</div>
|
|
||||||
</div><!-- fragment --><p >Note that the <code>glfw</code> target does not depend on OpenGL, as GLFW loads any OpenGL, OpenGL ES or Vulkan libraries it needs at runtime. If your application calls OpenGL directly, instead of using a modern <a class="el" href="context_guide.html#context_glext_auto">extension loader library</a>, use the OpenGL CMake package.</p>
|
|
||||||
<div class="fragment"><div class="line">find_package(OpenGL REQUIRED)</div>
|
|
||||||
</div><!-- fragment --><p >If OpenGL is found, the <code>OpenGL::GL</code> target is added to your project, containing library and include directory paths. Link against this like any other library.</p>
|
|
||||||
<div class="fragment"><div class="line">target_link_libraries(myapp OpenGL::GL)</div>
|
|
||||||
</div><!-- fragment --><h2><a class="anchor" id="build_link_pkgconfig"></a>
|
|
||||||
With makefiles and pkg-config on Unix</h2>
|
|
||||||
<p >GLFW supports <a href="https://www.freedesktop.org/wiki/Software/pkg-config/">pkg-config</a>, and the <code>glfw3.pc</code> pkg-config file is generated when the GLFW library is built and is installed along with it. A pkg-config file describes all necessary compile-time and link-time flags and dependencies needed to use a library. When they are updated or if they differ between systems, you will get the correct ones automatically.</p>
|
|
||||||
<p >A typical compile and link command-line when using the static version of the GLFW library may look like this:</p>
|
|
||||||
<div class="fragment"><div class="line">cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --static --libs glfw3)</div>
|
|
||||||
</div><!-- fragment --><p >If you are using the shared version of the GLFW library, omit the <code>--static</code> flag.</p>
|
|
||||||
<div class="fragment"><div class="line">cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --libs glfw3)</div>
|
|
||||||
</div><!-- fragment --><p >You can also use the <code>glfw3.pc</code> file without installing it first, by using the <code>PKG_CONFIG_PATH</code> environment variable.</p>
|
|
||||||
<div class="fragment"><div class="line">env PKG_CONFIG_PATH=path/to/glfw/src cc $(pkg-config --cflags glfw3) -o myprog myprog.c $(pkg-config --libs glfw3)</div>
|
|
||||||
</div><!-- fragment --><p >The dependencies do not include OpenGL, as GLFW loads any OpenGL, OpenGL ES or Vulkan libraries it needs at runtime. If your application calls OpenGL directly, instead of using a modern <a class="el" href="context_guide.html#context_glext_auto">extension loader library</a>, you should add the <code>gl</code> pkg-config package.</p>
|
|
||||||
<div class="fragment"><div class="line">cc $(pkg-config --cflags glfw3 gl) -o myprog myprog.c $(pkg-config --libs glfw3 gl)</div>
|
|
||||||
</div><!-- fragment --><h2><a class="anchor" id="build_link_xcode"></a>
|
|
||||||
With Xcode on macOS</h2>
|
|
||||||
<p >If you are using the dynamic library version of GLFW, add it to the project dependencies.</p>
|
|
||||||
<p >If you are using the static library version of GLFW, add it and the Cocoa, OpenGL and IOKit frameworks to the project as dependencies. They can all be found in <code>/System/Library/Frameworks</code>.</p>
|
|
||||||
<h2><a class="anchor" id="build_link_osx"></a>
|
|
||||||
With command-line on macOS</h2>
|
|
||||||
<p >It is recommended that you use <a class="el" href="build_guide.html#build_link_pkgconfig">pkg-config</a> when building from the command line on macOS. That way you will get any new dependencies added automatically. If you still wish to build manually, you need to add the required frameworks and libraries to your command-line yourself using the <code>-l</code> and <code>-framework</code> switches.</p>
|
|
||||||
<p >If you are using the dynamic GLFW library, which is named <code>libglfw.3.dylib</code>, do:</p>
|
|
||||||
<div class="fragment"><div class="line">cc -o myprog myprog.c -lglfw -framework Cocoa -framework OpenGL -framework IOKit</div>
|
|
||||||
</div><!-- fragment --><p >If you are using the static library, named <code>libglfw3.a</code>, substitute <code>-lglfw3</code> for <code>-lglfw</code>.</p>
|
|
||||||
<p >Note that you do not add the <code>.framework</code> extension to a framework when linking against it from the command-line.</p>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>Your machine may have <code>libGL.*.dylib</code> style OpenGL library, but that is for the X Window System and will not work with the macOS native version of GLFW. </dd></dl>
|
|
||||||
</div></div><!-- contents -->
|
|
||||||
</div><!-- PageDoc -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Before Width: | Height: | Size: 132 B |
@ -1,74 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: compat.dox File Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">compat.dox File Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,145 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Standards conformance</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div><div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Standards conformance </div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="toc"><h3>Table of Contents</h3>
|
|
||||||
<ul><li class="level1"><a href="#compat_x11">X11 extensions, protocols and IPC standards</a></li>
|
|
||||||
<li class="level1"><a href="#compat_wayland">Wayland protocols and IPC standards</a></li>
|
|
||||||
<li class="level1"><a href="#compat_glx">GLX extensions</a></li>
|
|
||||||
<li class="level1"><a href="#compat_wgl">WGL extensions</a></li>
|
|
||||||
<li class="level1"><a href="#compat_osx">OpenGL on macOS</a></li>
|
|
||||||
<li class="level1"><a href="#compat_vulkan">Vulkan loader and API</a></li>
|
|
||||||
<li class="level1"><a href="#compat_wsi">Vulkan WSI extensions</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="textblock"><p >This guide describes the various API extensions used by this version of GLFW. It lists what are essentially implementation details, but which are nonetheless vital knowledge for developers intending to deploy their applications on a wide range of machines.</p>
|
|
||||||
<p >The information in this guide is not a part of GLFW API, but merely preconditions for some parts of the library to function on a given machine. Any part of this information may change in future versions of GLFW and that will not be considered a breaking API change.</p>
|
|
||||||
<h1><a class="anchor" id="compat_x11"></a>
|
|
||||||
X11 extensions, protocols and IPC standards</h1>
|
|
||||||
<p >As GLFW uses Xlib directly, without any intervening toolkit library, it has sole responsibility for interacting well with the many and varied window managers in use on Unix-like systems. In order for applications and window managers to work well together, a number of standards and conventions have been developed that regulate behavior outside the scope of the X11 API; most importantly the <a href="https://www.tronche.com/gui/x/icccm/">Inter-Client Communication Conventions Manual</a> (ICCCM) and <a href="https://standards.freedesktop.org/wm-spec/wm-spec-latest.html">Extended Window Manager Hints</a> (EWMH) standards.</p>
|
|
||||||
<p >GLFW uses the <code>_MOTIF_WM_HINTS</code> window property to support borderless windows. If the running window manager does not support this property, the <code>GLFW_DECORATED</code> hint will have no effect.</p>
|
|
||||||
<p >GLFW uses the ICCCM <code>WM_DELETE_WINDOW</code> protocol to intercept the user attempting to close the GLFW window. If the running window manager does not support this protocol, the close callback will never be called.</p>
|
|
||||||
<p >GLFW uses the EWMH <code>_NET_WM_PING</code> protocol, allowing the window manager notify the user when the application has stopped responding, i.e. when it has ceased to process events. If the running window manager does not support this protocol, the user will not be notified if the application locks up.</p>
|
|
||||||
<p >GLFW uses the EWMH <code>_NET_WM_STATE_FULLSCREEN</code> window state to tell the window manager to make the GLFW window full screen. If the running window manager does not support this state, full screen windows may not work properly. GLFW has a fallback code path in case this state is unavailable, but every window manager behaves slightly differently in this regard.</p>
|
|
||||||
<p >GLFW uses the EWMH <code>_NET_WM_BYPASS_COMPOSITOR</code> window property to tell a compositing window manager to un-redirect full screen GLFW windows. If the running window manager uses compositing but does not support this property then additional copying may be performed for each buffer swap of full screen windows.</p>
|
|
||||||
<p >GLFW uses the <a href="https://www.freedesktop.org/wiki/ClipboardManager/">clipboard manager protocol</a> to push a clipboard string (i.e. selection) owned by a GLFW window about to be destroyed to the clipboard manager. If there is no running clipboard manager, the clipboard string will be unavailable once the window has been destroyed.</p>
|
|
||||||
<p >GLFW uses the <a href="https://www.freedesktop.org/wiki/Specifications/XDND/">X drag-and-drop protocol</a> to provide file drop events. If the application originating the drag does not support this protocol, drag and drop will not work.</p>
|
|
||||||
<p >GLFW uses the XRandR 1.3 extension to provide multi-monitor support. If the running X server does not support this version of this extension, multi-monitor support will not function and only a single, desktop-spanning monitor will be reported.</p>
|
|
||||||
<p >GLFW uses the XRandR 1.3 and Xf86vidmode extensions to provide gamma ramp support. If the running X server does not support either or both of these extensions, gamma ramp support will not function.</p>
|
|
||||||
<p >GLFW uses the Xkb extension and detectable auto-repeat to provide keyboard input. If the running X server does not support this extension, a non-Xkb fallback path is used.</p>
|
|
||||||
<p >GLFW uses the XInput2 extension to provide raw, non-accelerated mouse motion when the cursor is disabled. If the running X server does not support this extension, regular accelerated mouse motion will be used.</p>
|
|
||||||
<p >GLFW uses both the XRender extension and the compositing manager to support transparent window framebuffers. If the running X server does not support this extension or there is no running compositing manager, the <code>GLFW_TRANSPARENT_FRAMEBUFFER</code> framebuffer hint will have no effect.</p>
|
|
||||||
<h1><a class="anchor" id="compat_wayland"></a>
|
|
||||||
Wayland protocols and IPC standards</h1>
|
|
||||||
<p >As GLFW uses libwayland directly, without any intervening toolkit library, it has sole responsibility for interacting well with every compositor in use on Unix-like systems. Most of the features are provided by the core protocol, while cursor support is provided by the libwayland-cursor helper library, EGL integration by libwayland-egl, and keyboard handling by <a href="https://xkbcommon.org/">libxkbcommon</a>. In addition, GLFW uses some protocols from wayland-protocols to provide additional features if the compositor supports them.</p>
|
|
||||||
<p >GLFW uses xkbcommon 0.5.0 to provide compose key support. When it has been built against an older xkbcommon, the compose key will be disabled even if it has been configured in the compositor.</p>
|
|
||||||
<p >GLFW uses the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/stable/xdg-shell/xdg-shell.xml">xdg-shell protocol</a> to provide better window management. This protocol is part of wayland-protocols 1.12, and mandatory at build time. If the running compositor does not support this protocol, the older <a href="https://cgit.freedesktop.org/wayland/wayland/tree/protocol/wayland.xml#n972">wl_shell interface</a> will be used instead. This will result in a worse integration with the desktop, especially on tiling compositors.</p>
|
|
||||||
<p >GLFW uses the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/relative-pointer/relative-pointer-unstable-v1.xml">relative pointer protocol</a> alongside the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/pointer-constraints/pointer-constraints-unstable-v1.xml">pointer constraints protocol</a> to implement disabled cursor. These two protocols are part of wayland-protocols 1.1, and mandatory at build time. If the running compositor does not support both of these protocols, disabling the cursor will have no effect.</p>
|
|
||||||
<p >GLFW uses the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/idle-inhibit/idle-inhibit-unstable-v1.xml">idle inhibit protocol</a> to prohibit the screensaver from starting. This protocol is part of wayland-protocols 1.6, and mandatory at build time. If the running compositor does not support this protocol, the screensaver may start even for full screen windows.</p>
|
|
||||||
<p >GLFW uses the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/unstable/xdg-decoration/xdg-decoration-unstable-v1.xml">xdg-decoration protocol</a> to request decorations to be drawn around its windows. This protocol is part of wayland-protocols 1.15, and mandatory at build time. If the running compositor does not support this protocol, a very simple frame will be drawn by GLFW itself, using the <a href="https://cgit.freedesktop.org/wayland/wayland-protocols/tree/stable/viewporter/viewporter.xml">viewporter protocol</a> alongside <a href="https://cgit.freedesktop.org/wayland/wayland/tree/protocol/wayland.xml#n2598">subsurfaces</a>. This protocol is part of wayland-protocols 1.4, and mandatory at build time. If the running compositor does not support this protocol either, no decorations will be drawn around windows.</p>
|
|
||||||
<h1><a class="anchor" id="compat_glx"></a>
|
|
||||||
GLX extensions</h1>
|
|
||||||
<p >The GLX API is the default API used to create OpenGL contexts on Unix-like systems using the X Window System.</p>
|
|
||||||
<p >GLFW uses the GLX 1.3 <code>GLXFBConfig</code> functions to enumerate and select framebuffer pixel formats. If GLX 1.3 is not supported, <a class="el" href="group__init.html#ga317aac130a235ab08c6db0834907d85e">glfwInit</a> will fail.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_MESA_swap_control,</code> <code>GLX_EXT_swap_control</code> and <code>GLX_SGI_swap_control</code> extensions to provide vertical retrace synchronization (or <em>vsync</em>), in that order of preference. Where none of these extension are available, calling <a class="el" href="group__context.html#ga6d4e0cdf151b5e579bd67f13202994ed">glfwSwapInterval</a> will have no effect.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_ARB_multisample</code> extension to create contexts with multisampling anti-aliasing. Where this extension is unavailable, the <code>GLFW_SAMPLES</code> hint will have no effect.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_ARB_create_context</code> extension when available, even when creating OpenGL contexts of version 2.1 and below. Where this extension is unavailable, the <code>GLFW_CONTEXT_VERSION_MAJOR</code> and <code>GLFW_CONTEXT_VERSION_MINOR</code> hints will only be partially supported, the <code>GLFW_OPENGL_DEBUG_CONTEXT</code> hint will have no effect, and setting the <code>GLFW_OPENGL_PROFILE</code> or <code>GLFW_OPENGL_FORWARD_COMPAT</code> hints to <code>GLFW_TRUE</code> will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_ARB_create_context_profile</code> extension to provide support for context profiles. Where this extension is unavailable, setting the <code>GLFW_OPENGL_PROFILE</code> hint to anything but <code>GLFW_OPENGL_ANY_PROFILE</code>, or setting <code>GLFW_CLIENT_API</code> to anything but <code>GLFW_OPENGL_API</code> or <code>GLFW_NO_API</code> will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_ARB_context_flush_control</code> extension to provide control over whether a context is flushed when it is released (made non-current). Where this extension is unavailable, the <code>GLFW_CONTEXT_RELEASE_BEHAVIOR</code> hint will have no effect and the context will always be flushed when released.</p>
|
|
||||||
<p >GLFW uses the <code>GLX_ARB_framebuffer_sRGB</code> and <code>GLX_EXT_framebuffer_sRGB</code> extensions to provide support for sRGB framebuffers. Where both of these extensions are unavailable, the <code>GLFW_SRGB_CAPABLE</code> hint will have no effect.</p>
|
|
||||||
<h1><a class="anchor" id="compat_wgl"></a>
|
|
||||||
WGL extensions</h1>
|
|
||||||
<p >The WGL API is used to create OpenGL contexts on Microsoft Windows and other implementations of the Win32 API, such as Wine.</p>
|
|
||||||
<p >GLFW uses either the <code>WGL_EXT_extension_string</code> or the <code>WGL_ARB_extension_string</code> extension to check for the presence of all other WGL extensions listed below. If both are available, the EXT one is preferred. If neither is available, no other extensions are used and many GLFW features related to context creation will have no effect or cause errors when used.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_EXT_swap_control</code> extension to provide vertical retrace synchronization (or <em>vsync</em>). Where this extension is unavailable, calling <a class="el" href="group__context.html#ga6d4e0cdf151b5e579bd67f13202994ed">glfwSwapInterval</a> will have no effect.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_ARB_pixel_format</code> and <code>WGL_ARB_multisample</code> extensions to create contexts with multisampling anti-aliasing. Where these extensions are unavailable, the <code>GLFW_SAMPLES</code> hint will have no effect.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_ARB_create_context</code> extension when available, even when creating OpenGL contexts of version 2.1 and below. Where this extension is unavailable, the <code>GLFW_CONTEXT_VERSION_MAJOR</code> and <code>GLFW_CONTEXT_VERSION_MINOR</code> hints will only be partially supported, the <code>GLFW_OPENGL_DEBUG_CONTEXT</code> hint will have no effect, and setting the <code>GLFW_OPENGL_PROFILE</code> or <code>GLFW_OPENGL_FORWARD_COMPAT</code> hints to <code>GLFW_TRUE</code> will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_ARB_create_context_profile</code> extension to provide support for context profiles. Where this extension is unavailable, setting the <code>GLFW_OPENGL_PROFILE</code> hint to anything but <code>GLFW_OPENGL_ANY_PROFILE</code> will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_ARB_context_flush_control</code> extension to provide control over whether a context is flushed when it is released (made non-current). Where this extension is unavailable, the <code>GLFW_CONTEXT_RELEASE_BEHAVIOR</code> hint will have no effect and the context will always be flushed when released.</p>
|
|
||||||
<p >GLFW uses the <code>WGL_ARB_framebuffer_sRGB</code> and <code>WGL_EXT_framebuffer_sRGB</code> extensions to provide support for sRGB framebuffers. Where both of these extension are unavailable, the <code>GLFW_SRGB_CAPABLE</code> hint will have no effect.</p>
|
|
||||||
<h1><a class="anchor" id="compat_osx"></a>
|
|
||||||
OpenGL on macOS</h1>
|
|
||||||
<p >Support for OpenGL 3.2 and above was introduced with OS X 10.7 and even then only forward-compatible, core profile contexts are supported. Support for OpenGL 4.1 was introduced with OS X 10.9, also limited to forward-compatible, core profile contexts. There is also still no mechanism for requesting debug contexts or no-error contexts. Versions of Mac OS X earlier than 10.7 support at most OpenGL version 2.1.</p>
|
|
||||||
<p >Because of this, on OS X 10.7 and later, the <code>GLFW_CONTEXT_VERSION_MAJOR</code> and <code>GLFW_CONTEXT_VERSION_MINOR</code> hints will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail if given version 3.0 or 3.1. The <code>GLFW_OPENGL_FORWARD_COMPAT</code> hint must be set to <code>GLFW_TRUE</code> and the <code>GLFW_OPENGL_PROFILE</code> hint must be set to <code>GLFW_OPENGL_CORE_PROFILE</code> when creating OpenGL 3.2 and later contexts. The <code>GLFW_OPENGL_DEBUG_CONTEXT</code> and <code>GLFW_CONTEXT_NO_ERROR</code> hints are ignored.</p>
|
|
||||||
<p >Also, on Mac OS X 10.6 and below, the <code>GLFW_CONTEXT_VERSION_MAJOR</code> and <code>GLFW_CONTEXT_VERSION_MINOR</code> hints will fail if given a version above 2.1, setting the <code>GLFW_OPENGL_PROFILE</code> or <code>GLFW_OPENGL_FORWARD_COMPAT</code> hints to a non-default value will cause <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> to fail and the <code>GLFW_OPENGL_DEBUG_CONTEXT</code> hint is ignored.</p>
|
|
||||||
<h1><a class="anchor" id="compat_vulkan"></a>
|
|
||||||
Vulkan loader and API</h1>
|
|
||||||
<p >By default, GLFW uses the standard system-wide Vulkan loader to access the Vulkan API on all platforms except macOS. This is installed by both graphics drivers and Vulkan SDKs. If either the loader or at least one minimally functional ICD is missing, <a class="el" href="group__vulkan.html#ga2e7f30931e02464b5bc8d0d4b6f9fe2b">glfwVulkanSupported</a> will return <code>GLFW_FALSE</code> and all other Vulkan-related functions will fail with an <a class="el" href="group__errors.html#ga56882b290db23261cc6c053c40c2d08e">GLFW_API_UNAVAILABLE</a> error.</p>
|
|
||||||
<h1><a class="anchor" id="compat_wsi"></a>
|
|
||||||
Vulkan WSI extensions</h1>
|
|
||||||
<p >The Vulkan WSI extensions are used to create Vulkan surfaces for GLFW windows on all supported platforms.</p>
|
|
||||||
<p >GLFW uses the <code>VK_KHR_surface</code> and <code>VK_KHR_win32_surface</code> extensions to create surfaces on Microsoft Windows. If any of these extensions are not available, <a class="el" href="group__vulkan.html#ga99ad342d82f4a3421e2864978cb6d1d6">glfwGetRequiredInstanceExtensions</a> will return an empty list and window surface creation will fail.</p>
|
|
||||||
<p >GLFW uses the <code>VK_KHR_surface</code> and either the <code>VK_MVK_macos_surface</code> or <code>VK_EXT_metal_surface</code> extensions to create surfaces on macOS. If any of these extensions are not available, <a class="el" href="group__vulkan.html#ga99ad342d82f4a3421e2864978cb6d1d6">glfwGetRequiredInstanceExtensions</a> will return an empty list and window surface creation will fail.</p>
|
|
||||||
<p >GLFW uses the <code>VK_KHR_surface</code> and either the <code>VK_KHR_xlib_surface</code> or <code>VK_KHR_xcb_surface</code> extensions to create surfaces on X11. If <code>VK_KHR_surface</code> or both <code>VK_KHR_xlib_surface</code> and <code>VK_KHR_xcb_surface</code> are not available, <a class="el" href="group__vulkan.html#ga99ad342d82f4a3421e2864978cb6d1d6">glfwGetRequiredInstanceExtensions</a> will return an empty list and window surface creation will fail.</p>
|
|
||||||
<p >GLFW uses the <code>VK_KHR_surface</code> and <code>VK_KHR_wayland_surface</code> extensions to create surfaces on Wayland. If any of these extensions are not available, <a class="el" href="group__vulkan.html#ga99ad342d82f4a3421e2864978cb6d1d6">glfwGetRequiredInstanceExtensions</a> will return an empty list and window surface creation will fail. </p>
|
|
||||||
</div></div><!-- contents -->
|
|
||||||
</div><!-- PageDoc -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,74 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: compile.dox File Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">compile.dox File Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,216 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Compiling GLFW</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div><div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Compiling GLFW </div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="toc"><h3>Table of Contents</h3>
|
|
||||||
<ul><li class="level1"><a href="#compile_cmake">Using CMake</a><ul><li class="level2"><a href="#compile_deps">Installing dependencies</a><ul><li class="level3"><a href="#compile_deps_x11">Dependencies for X11 on Unix-like systems</a></li>
|
|
||||||
<li class="level3"><a href="#compile_deps_wayland">Dependencies for Wayland on Unix-like systems</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level2"><a href="#compile_generate">Generating build files with CMake</a><ul><li class="level3"><a href="#compile_generate_gui">Generating files with the CMake GUI</a></li>
|
|
||||||
<li class="level3"><a href="#compile_generate_cli">Generating files with the CMake command-line tool</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level2"><a href="#compile_compile">Compiling the library</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level1"><a href="#compile_options">CMake options</a><ul><li class="level2"><a href="#compile_options_shared">Shared CMake options</a></li>
|
|
||||||
<li class="level2"><a href="#compile_options_win32">Windows specific CMake options</a></li>
|
|
||||||
<li class="level2"><a href="#compile_options_wayland">Wayland specific CMake options</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level1"><a href="#compile_mingw_cross">Cross-compilation with CMake and MinGW</a></li>
|
|
||||||
<li class="level1"><a href="#compile_manual">Compiling GLFW manually</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="textblock"><p >This is about compiling the GLFW library itself. For information on how to build applications that use GLFW, see <a class="el" href="build_guide.html">Building applications</a>.</p>
|
|
||||||
<h1><a class="anchor" id="compile_cmake"></a>
|
|
||||||
Using CMake</h1>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>GLFW behaves like most other libraries that use CMake so this guide mostly describes the basic configure/generate/compile sequence. If you are already familiar with this from other projects, you may want to focus on the <a class="el" href="compile_guide.html#compile_deps">Installing dependencies</a> and <a class="el" href="compile_guide.html#compile_options">CMake options</a> sections for GLFW-specific information.</dd></dl>
|
|
||||||
<p>GLFW uses <a href="https://cmake.org/">CMake</a> to generate project files or makefiles for your chosen development environment. To compile GLFW, first generate these files with CMake and then use them to compile the GLFW library.</p>
|
|
||||||
<p >If you are on Windows and macOS you can <a href="https://cmake.org/download/">download CMake</a> from their site.</p>
|
|
||||||
<p >If you are on a Unix-like system such as Linux, FreeBSD or Cygwin or have a package system like Fink, MacPorts or Homebrew, you can install its CMake package.</p>
|
|
||||||
<p >CMake is a complex tool and this guide will only show a few of the possible ways to set up and compile GLFW. The CMake project has their own much more detailed <a href="https://cmake.org/cmake/help/latest/guide/user-interaction/">CMake user guide</a> that includes everything in this guide not specific to GLFW. It may be a useful companion to this one.</p>
|
|
||||||
<h2><a class="anchor" id="compile_deps"></a>
|
|
||||||
Installing dependencies</h2>
|
|
||||||
<p >The C/C++ development environments in Visual Studio, Xcode and MinGW come with all necessary dependencies for compiling GLFW, but on Unix-like systems like Linux and FreeBSD you will need a few extra packages.</p>
|
|
||||||
<h3><a class="anchor" id="compile_deps_x11"></a>
|
|
||||||
Dependencies for X11 on Unix-like systems</h3>
|
|
||||||
<p >To compile GLFW for X11, you need to have the X11 development packages installed. They are not needed to build or run programs that use GLFW.</p>
|
|
||||||
<p >On Debian and derivates like Ubuntu and Linux Mint the <code>xorg-dev</code> meta-package pulls in the development packages for all of X11.</p>
|
|
||||||
<div class="fragment"><div class="line">sudo apt install xorg-dev</div>
|
|
||||||
</div><!-- fragment --><p >On Fedora and derivatives like Red Hat the X11 extension packages <code>libXcursor-devel</code>, <code>libXi-devel</code>, <code>libXinerama-devel</code> and <code>libXrandr-devel</code> required by GLFW pull in all its other dependencies.</p>
|
|
||||||
<div class="fragment"><div class="line">sudo dnf install libXcursor-devel libXi-devel libXinerama-devel libXrandr-devel</div>
|
|
||||||
</div><!-- fragment --><p >On FreeBSD the X11 headers are installed along the end-user X11 packages, so if you have an X server running you should have the headers as well. If not, install the <code>xorgproto</code> package.</p>
|
|
||||||
<div class="fragment"><div class="line">pkg install xorgproto</div>
|
|
||||||
</div><!-- fragment --><p >On Cygwin the <code>xorgproto</code> package in the Devel section of the GUI installer will install the headers and other development related files for all of X11.</p>
|
|
||||||
<p >Once you have the required depdendencies, move on to <a class="el" href="compile_guide.html#compile_generate">Generating build files with CMake</a>.</p>
|
|
||||||
<h3><a class="anchor" id="compile_deps_wayland"></a>
|
|
||||||
Dependencies for Wayland on Unix-like systems</h3>
|
|
||||||
<p >To compile GLFW for Wayland, you need to have the Wayland and xkbcommon development packages installed. They are not needed to build or run programs that use GLFW.</p>
|
|
||||||
<p >On Debian and derivates like Ubuntu and Linux Mint you will need the <code>libwayland-dev</code>, <code>libxkbcommon-dev</code>, <code>wayland-protocols</code> and <code>extra-cmake-modules</code> packages.</p>
|
|
||||||
<div class="fragment"><div class="line">sudo apt install libwayland-dev libxkbcommon-dev wayland-protocols extra-cmake-modules</div>
|
|
||||||
</div><!-- fragment --><p >On Fedora and derivatives like Red Hat you will need the <code>wayland-devel</code>, <code>libxkbcommon-devel</code>, <code>wayland-protocols-devel</code> and <code>extra-cmake-modules</code> packages.</p>
|
|
||||||
<div class="fragment"><div class="line">sudo dnf install wayland-devel libxkbcommon-devel wayland-protocols-devel extra-cmake-modules</div>
|
|
||||||
</div><!-- fragment --><p >On FreeBSD you will need the <code>wayland</code>, <code>libxkbcommon</code>, <code>wayland-protocols</code> and <code>kf5-extra-cmake-modules</code> packages.</p>
|
|
||||||
<div class="fragment"><div class="line">pkg install wayland libxkbcommon wayland-protocols kf5-extra-cmake-modules</div>
|
|
||||||
</div><!-- fragment --><p >Once you have the required depdendencies, move on to <a class="el" href="compile_guide.html#compile_generate">Generating build files with CMake</a>.</p>
|
|
||||||
<h2><a class="anchor" id="compile_generate"></a>
|
|
||||||
Generating build files with CMake</h2>
|
|
||||||
<p >Once you have all necessary dependencies it is time to generate the project files or makefiles for your development environment. CMake needs two paths for this:</p>
|
|
||||||
<ul>
|
|
||||||
<li>the path to the root directory of the GLFW source tree (not its <code>src</code> subdirectory)</li>
|
|
||||||
<li>the path to the directory where the generated build files and compiled binaries will be placed</li>
|
|
||||||
</ul>
|
|
||||||
<p >If these are the same, it is called an in-tree build, otherwise it is called an out-of-tree build.</p>
|
|
||||||
<p >Out-of-tree builds are recommended as they avoid cluttering up the source tree. They also allow you to have several build directories for different configurations all using the same source tree.</p>
|
|
||||||
<p >A common pattern when building a single configuration is to have a build directory named <code>build</code> in the root of the source tree.</p>
|
|
||||||
<h3><a class="anchor" id="compile_generate_gui"></a>
|
|
||||||
Generating files with the CMake GUI</h3>
|
|
||||||
<p >Start the CMake GUI and set the paths to the source and build directories described above. Then press <em>Configure</em> and <em>Generate</em>.</p>
|
|
||||||
<p >If you wish change any CMake variables in the list, press <em>Configure</em> and then <em>Generate</em> to have the new values take effect. The variable list will be populated after the first configure step.</p>
|
|
||||||
<p >By default GLFW will use X11 on Linux and other Unix-like systems other than macOS. To use Wayland instead, set the <code>GLFW_USE_WAYLAND</code> option in the GLFW section of the variable list, then apply the new value as described above.</p>
|
|
||||||
<p >Once you have generated the project files or makefiles for your chosen development environment, move on to <a class="el" href="compile_guide.html#compile_compile">Compiling the library</a>.</p>
|
|
||||||
<h3><a class="anchor" id="compile_generate_cli"></a>
|
|
||||||
Generating files with the CMake command-line tool</h3>
|
|
||||||
<p >To make a build directory, pass the source and build directories to the <code>cmake</code> command. These can be relative or absolute paths. The build directory is created if it doesn't already exist.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build</div>
|
|
||||||
</div><!-- fragment --><p >It is common to name the build directory <code>build</code> and place it in the root of the source tree when only planning to build a single configuration.</p>
|
|
||||||
<div class="fragment"><div class="line">cd path/to/glfw</div>
|
|
||||||
<div class="line">cmake -S . -B build</div>
|
|
||||||
</div><!-- fragment --><p >Without other flags these will generate Visual Studio project files on Windows and makefiles on other platforms. You can choose other targets using the <code>-G</code> flag.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build -G Xcode</div>
|
|
||||||
</div><!-- fragment --><p >By default GLFW will use X11 on Linux and other Unix-like systems other than macOS. To use Wayland instead, set the <code>GLFW_USE_WAYLAND</code> CMake option.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build -D GLFW_USE_WAYLAND=1</div>
|
|
||||||
</div><!-- fragment --><p >Once you have generated the project files or makefiles for your chosen development environment, move on to <a class="el" href="compile_guide.html#compile_compile">Compiling the library</a>.</p>
|
|
||||||
<h2><a class="anchor" id="compile_compile"></a>
|
|
||||||
Compiling the library</h2>
|
|
||||||
<p >You should now have all required dependencies and the project files or makefiles necessary to compile GLFW. Go ahead and compile the actual GLFW library with these files as you would with any other project.</p>
|
|
||||||
<p >With Visual Studio open <code>GLFW.sln</code> and use the Build menu. With Xcode open <code>GLFW.xcodeproj</code> and use the Project menu.</p>
|
|
||||||
<p >With Linux, macOS and other forms of Unix, run <code>make</code>.</p>
|
|
||||||
<div class="fragment"><div class="line">cd path/to/build</div>
|
|
||||||
<div class="line">make</div>
|
|
||||||
</div><!-- fragment --><p >With MinGW, it is <code>mingw32-make</code>.</p>
|
|
||||||
<div class="fragment"><div class="line">cd path/to/build</div>
|
|
||||||
<div class="line">mingw32-make</div>
|
|
||||||
</div><!-- fragment --><p >Any CMake build directory can also be built with the <code>cmake</code> command and the <code>--build</code> flag.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake --build path/to/build</div>
|
|
||||||
</div><!-- fragment --><p >This will run the platform specific build tool the directory was generated for.</p>
|
|
||||||
<p >Once the GLFW library is compiled you are ready to build your application, linking it to the GLFW library. See <a class="el" href="build_guide.html">Building applications</a> for more information.</p>
|
|
||||||
<h1><a class="anchor" id="compile_options"></a>
|
|
||||||
CMake options</h1>
|
|
||||||
<p >The CMake files for GLFW provide a number of options, although not all are available on all supported platforms. Some of these are de facto standards among projects using CMake and so have no <code>GLFW_</code> prefix.</p>
|
|
||||||
<p >If you are using the GUI version of CMake, these are listed and can be changed from there. If you are using the command-line version of CMake you can use the <code>ccmake</code> ncurses GUI to set options. Some package systems like Ubuntu and other distributions based on Debian GNU/Linux have this tool in a separate <code>cmake-curses-gui</code> package.</p>
|
|
||||||
<p >Finally, if you don't want to use any GUI, you can set options from the <code>cmake</code> command-line with the <code>-D</code> flag.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build -D BUILD_SHARED_LIBS=ON</div>
|
|
||||||
</div><!-- fragment --><h2><a class="anchor" id="compile_options_shared"></a>
|
|
||||||
Shared CMake options</h2>
|
|
||||||
<p ><a class="anchor" id="BUILD_SHARED_LIBS"></a><b>BUILD_SHARED_LIBS</b> determines whether GLFW is built as a static library or as a DLL / shared library / dynamic library. This is disabled by default, producing a static GLFW library.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_BUILD_EXAMPLES"></a><b>GLFW_BUILD_EXAMPLES</b> determines whether the GLFW examples are built along with the library.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_BUILD_TESTS"></a><b>GLFW_BUILD_TESTS</b> determines whether the GLFW test programs are built along with the library.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_BUILD_DOCS"></a><b>GLFW_BUILD_DOCS</b> determines whether the GLFW documentation is built along with the library. This is enabled by default if <a href="https://www.doxygen.nl/">Doxygen</a> is found by CMake during configuration.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_VULKAN_STATIC"></a><b>GLFW_VULKAN_STATIC</b> determines whether to use the Vulkan loader linked directly with the application. This is disabled by default.</p>
|
|
||||||
<h2><a class="anchor" id="compile_options_win32"></a>
|
|
||||||
Windows specific CMake options</h2>
|
|
||||||
<p ><a class="anchor" id="USE_MSVC_RUNTIME_LIBRARY_DLL"></a><b>USE_MSVC_RUNTIME_LIBRARY_DLL</b> determines whether to use the DLL version or the static library version of the Visual C++ runtime library. When enabled, the DLL version of the Visual C++ library is used. This is enabled by default.</p>
|
|
||||||
<p >On CMake 3.15 and later you can set the standard CMake <a href="https://cmake.org/cmake/help/latest/variable/CMAKE_MSVC_RUNTIME_LIBRARY.html">CMAKE_MSVC_RUNTIME_LIBRARY</a> variable instead of this GLFW-specific option.</p>
|
|
||||||
<p ><a class="anchor" id="GLFW_USE_HYBRID_HPG"></a><b>GLFW_USE_HYBRID_HPG</b> determines whether to export the <code>NvOptimusEnablement</code> and <code>AmdPowerXpressRequestHighPerformance</code> symbols, which force the use of the high-performance GPU on Nvidia Optimus and AMD PowerXpress systems. These symbols need to be exported by the EXE to be detected by the driver, so the override will not work if GLFW is built as a DLL. This is disabled by default, letting the operating system and driver decide.</p>
|
|
||||||
<h2><a class="anchor" id="compile_options_wayland"></a>
|
|
||||||
Wayland specific CMake options</h2>
|
|
||||||
<p ><a class="anchor" id="GLFW_USE_WAYLAND"></a><b>GLFW_USE_WAYLAND</b> determines whether to compile the library for Wayland. This option is only available on Linux and other Unix-like systems other than macOS. This is disabled by default.</p>
|
|
||||||
<h1><a class="anchor" id="compile_mingw_cross"></a>
|
|
||||||
Cross-compilation with CMake and MinGW</h1>
|
|
||||||
<p >Both Cygwin and many Linux distributions have MinGW or MinGW-w64 packages. For example, Cygwin has the <code>mingw64-i686-gcc</code> and <code>mingw64-x86_64-gcc</code> packages for 32- and 64-bit version of MinGW-w64, while Debian GNU/Linux and derivatives like Ubuntu have the <code>mingw-w64</code> package for both.</p>
|
|
||||||
<p >GLFW has CMake toolchain files in the <code>CMake</code> subdirectory that set up cross-compilation of Windows binaries. To use these files you set the <code>CMAKE_TOOLCHAIN_FILE</code> CMake variable with the <code>-D</code> flag add an option when configuring and generating the build files.</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build -D CMAKE_TOOLCHAIN_FILE=path/to/file</div>
|
|
||||||
</div><!-- fragment --><p >The exact toolchain file to use depends on the prefix used by the MinGW or MinGW-w64 binaries on your system. You can usually see this in the /usr directory. For example, both the Ubuntu and Cygwin MinGW-w64 packages have <code>/usr/x86_64-w64-mingw32</code> for the 64-bit compilers, so the correct invocation would be:</p>
|
|
||||||
<div class="fragment"><div class="line">cmake -S path/to/glfw -B path/to/build -D CMAKE_TOOLCHAIN_FILE=CMake/x86_64-w64-mingw32.cmake</div>
|
|
||||||
</div><!-- fragment --><p >The path to the toolchain file is relative to the path to the GLFW source tree passed to the <code>-S</code> flag, not to the current directory.</p>
|
|
||||||
<p >For more details see the <a href="https://cmake.org/cmake/help/latest/manual/cmake-toolchains.7.html">CMake toolchain guide</a>.</p>
|
|
||||||
<h1><a class="anchor" id="compile_manual"></a>
|
|
||||||
Compiling GLFW manually</h1>
|
|
||||||
<p >If you wish to compile GLFW without its CMake build environment then you will have to do at least some of the platform detection yourself. GLFW needs a configuration macro to be defined in order to know what window system it is being compiled for and also has optional, platform-specific ones for various features.</p>
|
|
||||||
<p >When building with CMake, the <code>glfw_config.h</code> configuration header is generated based on the current platform and CMake options. The GLFW CMake environment defines <b>GLFW_USE_CONFIG_H</b>, which causes this header to be included by <code>internal.h</code>. Without this macro, GLFW will expect the necessary configuration macros to be defined on the command-line.</p>
|
|
||||||
<p >The window creation API is used to create windows, handle input, monitors, gamma ramps and clipboard. The options are:</p>
|
|
||||||
<ul>
|
|
||||||
<li><b>_GLFW_COCOA</b> to use the Cocoa frameworks</li>
|
|
||||||
<li><b>_GLFW_WIN32</b> to use the Win32 API</li>
|
|
||||||
<li><b>_GLFW_X11</b> to use the X Window System</li>
|
|
||||||
<li><b>_GLFW_WAYLAND</b> to use the Wayland API (experimental and incomplete)</li>
|
|
||||||
<li><b>_GLFW_OSMESA</b> to use the OSMesa API (headless and non-interactive)</li>
|
|
||||||
</ul>
|
|
||||||
<p >If you are building GLFW as a shared library / dynamic library / DLL then you must also define <b>_GLFW_BUILD_DLL</b>. Otherwise, you must not define it.</p>
|
|
||||||
<p >If you are linking the Vulkan loader directly with your application then you must also define <b>_GLFW_VULKAN_STATIC</b>. Otherwise, GLFW will attempt to use the external version.</p>
|
|
||||||
<p >If you are using a custom name for the Vulkan, EGL, GLX, OSMesa, OpenGL, GLESv1 or GLESv2 library, you can override the default names by defining those you need of <b>_GLFW_VULKAN_LIBRARY</b>, <b>_GLFW_EGL_LIBRARY</b>, <b>_GLFW_GLX_LIBRARY</b>, <b>_GLFW_OSMESA_LIBRARY</b>, <b>_GLFW_OPENGL_LIBRARY</b>, <b>_GLFW_GLESV1_LIBRARY</b> and <b>_GLFW_GLESV2_LIBRARY</b>. Otherwise, GLFW will use the built-in default names.</p>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>None of the <a class="el" href="build_guide.html#build_macros">GLFW header option macros</a> may be defined during the compilation of GLFW. If you define any of these in your build files, make sure they are not applied to the GLFW sources. </dd></dl>
|
|
||||||
</div></div><!-- contents -->
|
|
||||||
</div><!-- PageDoc -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,74 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: context.dox File Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">context.dox File Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,251 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Context guide</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div><div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Context guide </div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="toc"><h3>Table of Contents</h3>
|
|
||||||
<ul><li class="level1"><a href="#context_object">Context objects</a><ul><li class="level2"><a href="#context_hints">Context creation hints</a></li>
|
|
||||||
<li class="level2"><a href="#context_sharing">Context object sharing</a></li>
|
|
||||||
<li class="level2"><a href="#context_offscreen">Offscreen contexts</a></li>
|
|
||||||
<li class="level2"><a href="#context_less">Windows without contexts</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
<li class="level1"><a href="#context_current">Current context</a></li>
|
|
||||||
<li class="level1"><a href="#context_swap">Buffer swapping</a></li>
|
|
||||||
<li class="level1"><a href="#context_glext">OpenGL and OpenGL ES extensions</a><ul><li class="level2"><a href="#context_glext_auto">Loading extension with a loader library</a></li>
|
|
||||||
<li class="level2"><a href="#context_glext_manual">Loading extensions manually</a><ul><li class="level3"><a href="#context_glext_header">The glext.h header</a></li>
|
|
||||||
<li class="level3"><a href="#context_glext_string">Checking for extensions</a></li>
|
|
||||||
<li class="level3"><a href="#context_glext_proc">Fetching function pointers</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<div class="textblock"><p >This guide introduces the OpenGL and OpenGL ES context related functions of GLFW. For details on a specific function in this category, see the <a class="el" href="group__context.html">Context reference</a>. There are also guides for the other areas of the GLFW API.</p>
|
|
||||||
<ul>
|
|
||||||
<li><a class="el" href="intro_guide.html">Introduction to the API</a></li>
|
|
||||||
<li><a class="el" href="window_guide.html">Window guide</a></li>
|
|
||||||
<li><a class="el" href="vulkan_guide.html">Vulkan guide</a></li>
|
|
||||||
<li><a class="el" href="monitor_guide.html">Monitor guide</a></li>
|
|
||||||
<li><a class="el" href="input_guide.html">Input guide</a></li>
|
|
||||||
</ul>
|
|
||||||
<h1><a class="anchor" id="context_object"></a>
|
|
||||||
Context objects</h1>
|
|
||||||
<p >A window object encapsulates both a top-level window and an OpenGL or OpenGL ES context. It is created with <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a> and destroyed with <a class="el" href="group__window.html#gacdf43e51376051d2c091662e9fe3d7b2">glfwDestroyWindow</a> or <a class="el" href="group__init.html#gaaae48c0a18607ea4a4ba951d939f0901">glfwTerminate</a>. See <a class="el" href="window_guide.html#window_creation">Window creation</a> for more information.</p>
|
|
||||||
<p >As the window and context are inseparably linked, the window object also serves as the context handle.</p>
|
|
||||||
<p >To test the creation of various kinds of contexts and see their properties, run the <code>glfwinfo</code> test program.</p>
|
|
||||||
<dl class="section note"><dt>Note</dt><dd>Vulkan does not have a context and the Vulkan instance is created via the Vulkan API itself. If you will be using Vulkan to render to a window, disable context creation by setting the <a class="el" href="window_guide.html#GLFW_CLIENT_API_hint">GLFW_CLIENT_API</a> hint to <code>GLFW_NO_API</code>. For more information, see the <a class="el" href="vulkan_guide.html">Vulkan guide</a>.</dd></dl>
|
|
||||||
<h2><a class="anchor" id="context_hints"></a>
|
|
||||||
Context creation hints</h2>
|
|
||||||
<p >There are a number of hints, specified using <a class="el" href="group__window.html#ga7d9c8c62384b1e2821c4dc48952d2033">glfwWindowHint</a>, related to what kind of context is created. See <a class="el" href="window_guide.html#window_hints_ctx">context related hints</a> in the window guide.</p>
|
|
||||||
<h2><a class="anchor" id="context_sharing"></a>
|
|
||||||
Context object sharing</h2>
|
|
||||||
<p >When creating a window and its OpenGL or OpenGL ES context with <a class="el" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a>, you can specify another window whose context the new one should share its objects (textures, vertex and element buffers, etc.) with.</p>
|
|
||||||
<div class="fragment"><div class="line"><a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* second_window = <a class="code hl_function" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a>(640, 480, <span class="stringliteral">"Second Window"</span>, NULL, first_window);</div>
|
|
||||||
<div class="ttc" id="agroup__window_html_ga3555a418df92ad53f917597fe2f64aeb"><div class="ttname"><a href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a></div><div class="ttdeci">GLFWwindow * glfwCreateWindow(int width, int height, const char *title, GLFWmonitor *monitor, GLFWwindow *share)</div><div class="ttdoc">Creates a window and its associated context.</div></div>
|
|
||||||
<div class="ttc" id="agroup__window_html_ga3c96d80d363e67d13a41b5d1821f3242"><div class="ttname"><a href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a></div><div class="ttdeci">struct GLFWwindow GLFWwindow</div><div class="ttdoc">Opaque window object.</div><div class="ttdef"><b>Definition:</b> glfw3.h:1186</div></div>
|
|
||||||
</div><!-- fragment --><p >Object sharing is implemented by the operating system and graphics driver. On platforms where it is possible to choose which types of objects are shared, GLFW requests that all types are shared.</p>
|
|
||||||
<p >See the relevant chapter of the <a href="https://www.opengl.org/registry/">OpenGL</a> or <a href="https://www.khronos.org/opengles/">OpenGL ES</a> reference documents for more information. The name and number of this chapter unfortunately varies between versions and APIs, but has at times been named <em>Shared Objects and Multiple Contexts</em>.</p>
|
|
||||||
<p >GLFW comes with a barebones object sharing example program called <code>sharing</code>.</p>
|
|
||||||
<h2><a class="anchor" id="context_offscreen"></a>
|
|
||||||
Offscreen contexts</h2>
|
|
||||||
<p >GLFW doesn't support creating contexts without an associated window. However, contexts with hidden windows can be created with the <a class="el" href="window_guide.html#GLFW_VISIBLE_hint">GLFW_VISIBLE</a> window hint.</p>
|
|
||||||
<div class="fragment"><div class="line"><a class="code hl_function" href="group__window.html#ga7d9c8c62384b1e2821c4dc48952d2033">glfwWindowHint</a>(<a class="code hl_define" href="group__window.html#gafb3cdc45297e06d8f1eb13adc69ca6c4">GLFW_VISIBLE</a>, <a class="code hl_define" href="group__init.html#gac877fe3b627d21ef3a0a23e0a73ba8c5">GLFW_FALSE</a>);</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* offscreen_context = <a class="code hl_function" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a>(640, 480, <span class="stringliteral">""</span>, NULL, NULL);</div>
|
|
||||||
<div class="ttc" id="agroup__init_html_gac877fe3b627d21ef3a0a23e0a73ba8c5"><div class="ttname"><a href="group__init.html#gac877fe3b627d21ef3a0a23e0a73ba8c5">GLFW_FALSE</a></div><div class="ttdeci">#define GLFW_FALSE</div><div class="ttdoc">Zero.</div><div class="ttdef"><b>Definition:</b> glfw3.h:322</div></div>
|
|
||||||
<div class="ttc" id="agroup__window_html_ga7d9c8c62384b1e2821c4dc48952d2033"><div class="ttname"><a href="group__window.html#ga7d9c8c62384b1e2821c4dc48952d2033">glfwWindowHint</a></div><div class="ttdeci">void glfwWindowHint(int hint, int value)</div><div class="ttdoc">Sets the specified window hint to the desired value.</div></div>
|
|
||||||
<div class="ttc" id="agroup__window_html_gafb3cdc45297e06d8f1eb13adc69ca6c4"><div class="ttname"><a href="group__window.html#gafb3cdc45297e06d8f1eb13adc69ca6c4">GLFW_VISIBLE</a></div><div class="ttdeci">#define GLFW_VISIBLE</div><div class="ttdoc">Window visibility window hint and attribute.</div><div class="ttdef"><b>Definition:</b> glfw3.h:815</div></div>
|
|
||||||
</div><!-- fragment --><p >The window never needs to be shown and its context can be used as a plain offscreen context. Depending on the window manager, the size of a hidden window's framebuffer may not be usable or modifiable, so framebuffer objects are recommended for rendering with such contexts.</p>
|
|
||||||
<p >You should still <a class="el" href="input_guide.html#events">process events</a> as long as you have at least one window, even if none of them are visible.</p>
|
|
||||||
<p ><b>macOS:</b> The first time a window is created the menu bar is created. This is not desirable for example when writing a command-line only application. Menu bar creation can be disabled with the <a class="el" href="group__init.html#ga71e0b4ce2f2696a84a9b8c5e12dc70cf">GLFW_COCOA_MENUBAR</a> init hint.</p>
|
|
||||||
<h2><a class="anchor" id="context_less"></a>
|
|
||||||
Windows without contexts</h2>
|
|
||||||
<p >You can disable context creation by setting the <a class="el" href="window_guide.html#GLFW_CLIENT_API_hint">GLFW_CLIENT_API</a> hint to <code>GLFW_NO_API</code>. Windows without contexts must not be passed to <a class="el" href="group__context.html#ga1c04dc242268f827290fe40aa1c91157">glfwMakeContextCurrent</a> or <a class="el" href="group__window.html#ga15a5a1ee5b3c2ca6b15ca209a12efd14">glfwSwapBuffers</a>.</p>
|
|
||||||
<h1><a class="anchor" id="context_current"></a>
|
|
||||||
Current context</h1>
|
|
||||||
<p >Before you can make OpenGL or OpenGL ES calls, you need to have a current context of the correct type. A context can only be current for a single thread at a time, and a thread can only have a single context current at a time.</p>
|
|
||||||
<p >When moving a context between threads, you must make it non-current on the old thread before making it current on the new one.</p>
|
|
||||||
<p >The context of a window is made current with <a class="el" href="group__context.html#ga1c04dc242268f827290fe40aa1c91157">glfwMakeContextCurrent</a>.</p>
|
|
||||||
<div class="fragment"><div class="line"><a class="code hl_function" href="group__context.html#ga1c04dc242268f827290fe40aa1c91157">glfwMakeContextCurrent</a>(window);</div>
|
|
||||||
<div class="ttc" id="agroup__context_html_ga1c04dc242268f827290fe40aa1c91157"><div class="ttname"><a href="group__context.html#ga1c04dc242268f827290fe40aa1c91157">glfwMakeContextCurrent</a></div><div class="ttdeci">void glfwMakeContextCurrent(GLFWwindow *window)</div><div class="ttdoc">Makes the context of the specified window current for the calling thread.</div></div>
|
|
||||||
</div><!-- fragment --><p >The window of the current context is returned by <a class="el" href="group__context.html#gad94e80185397a6cf5fe2ab30567af71c">glfwGetCurrentContext</a>.</p>
|
|
||||||
<div class="fragment"><div class="line"><a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window = <a class="code hl_function" href="group__context.html#gad94e80185397a6cf5fe2ab30567af71c">glfwGetCurrentContext</a>();</div>
|
|
||||||
<div class="ttc" id="agroup__context_html_gad94e80185397a6cf5fe2ab30567af71c"><div class="ttname"><a href="group__context.html#gad94e80185397a6cf5fe2ab30567af71c">glfwGetCurrentContext</a></div><div class="ttdeci">GLFWwindow * glfwGetCurrentContext(void)</div><div class="ttdoc">Returns the window whose context is current on the calling thread.</div></div>
|
|
||||||
</div><!-- fragment --><p >The following GLFW functions require a context to be current. Calling any these functions without a current context will generate a <a class="el" href="group__errors.html#gaa8290386e9528ccb9e42a3a4e16fc0d0">GLFW_NO_CURRENT_CONTEXT</a> error.</p>
|
|
||||||
<ul>
|
|
||||||
<li><a class="el" href="group__context.html#ga6d4e0cdf151b5e579bd67f13202994ed">glfwSwapInterval</a></li>
|
|
||||||
<li><a class="el" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a></li>
|
|
||||||
<li><a class="el" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a></li>
|
|
||||||
</ul>
|
|
||||||
<h1><a class="anchor" id="context_swap"></a>
|
|
||||||
Buffer swapping</h1>
|
|
||||||
<p >See <a class="el" href="window_guide.html#buffer_swap">Buffer swapping</a> in the window guide.</p>
|
|
||||||
<h1><a class="anchor" id="context_glext"></a>
|
|
||||||
OpenGL and OpenGL ES extensions</h1>
|
|
||||||
<p >One of the benefits of OpenGL and OpenGL ES is their extensibility. Hardware vendors may include extensions in their implementations that extend the API before that functionality is included in a new version of the OpenGL or OpenGL ES specification, and some extensions are never included and remain as extensions until they become obsolete.</p>
|
|
||||||
<p >An extension is defined by:</p>
|
|
||||||
<ul>
|
|
||||||
<li>An extension name (e.g. <code>GL_ARB_gl_spirv</code>)</li>
|
|
||||||
<li>New OpenGL tokens (e.g. <code>GL_SPIR_V_BINARY_ARB</code>)</li>
|
|
||||||
<li>New OpenGL functions (e.g. <code>glSpecializeShaderARB</code>)</li>
|
|
||||||
</ul>
|
|
||||||
<p >Note the <code>ARB</code> affix, which stands for Architecture Review Board and is used for official extensions. The extension above was created by the ARB, but there are many different affixes, like <code>NV</code> for Nvidia and <code>AMD</code> for, well, AMD. Any group may also use the generic <code>EXT</code> affix. Lists of extensions, together with their specifications, can be found at the <a href="https://www.opengl.org/registry/">OpenGL Registry</a> and <a href="https://www.khronos.org/registry/gles/">OpenGL ES Registry</a>.</p>
|
|
||||||
<h2><a class="anchor" id="context_glext_auto"></a>
|
|
||||||
Loading extension with a loader library</h2>
|
|
||||||
<p >An extension loader library is the easiest and best way to access both OpenGL and OpenGL ES extensions and modern versions of the core OpenGL or OpenGL ES APIs. They will take care of all the details of declaring and loading everything you need. One such library is <a href="https://github.com/Dav1dde/glad">glad</a> and there are several others.</p>
|
|
||||||
<p >The following example will use glad but all extension loader libraries work similarly.</p>
|
|
||||||
<p >First you need to generate the source files using the glad Python script. This example generates a loader for any version of OpenGL, which is the default for both GLFW and glad, but loaders for OpenGL ES, as well as loaders for specific API versions and extension sets can be generated. The generated files are written to the <code>output</code> directory.</p>
|
|
||||||
<div class="fragment"><div class="line">python main.py --generator c --no-loader --out-path output</div>
|
|
||||||
</div><!-- fragment --><p >The <code>--no-loader</code> option is added because GLFW already provides a function for loading OpenGL and OpenGL ES function pointers, one that automatically uses the selected context creation API, and glad can call this instead of having to implement its own. There are several other command-line options as well. See the glad documentation for details.</p>
|
|
||||||
<p >Add the generated <code>output/src/glad.c</code>, <code>output/include/glad/glad.h</code> and <code>output/include/KHR/khrplatform.h</code> files to your build. Then you need to include the glad header file, which will replace the OpenGL header of your development environment. By including the glad header before the GLFW header, it suppresses the development environment's OpenGL or OpenGL ES header.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#include <glad/glad.h></span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <<a class="code" href="glfw3_8h.html">GLFW/glfw3.h</a>></span></div>
|
|
||||||
<div class="ttc" id="aglfw3_8h_html"><div class="ttname"><a href="glfw3_8h.html">glfw3.h</a></div><div class="ttdoc">The header of the GLFW 3 API.</div></div>
|
|
||||||
</div><!-- fragment --><p >Finally you need to initialize glad once you have a suitable current context.</p>
|
|
||||||
<div class="fragment"><div class="line">window = <a class="code hl_function" href="group__window.html#ga3555a418df92ad53f917597fe2f64aeb">glfwCreateWindow</a>(640, 480, <span class="stringliteral">"My Window"</span>, NULL, NULL);</div>
|
|
||||||
<div class="line"><span class="keywordflow">if</span> (!window)</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> ...</div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><a class="code hl_function" href="group__context.html#ga1c04dc242268f827290fe40aa1c91157">glfwMakeContextCurrent</a>(window);</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line">gladLoadGLLoader((GLADloadproc) <a class="code hl_function" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a>);</div>
|
|
||||||
<div class="ttc" id="agroup__context_html_ga35f1837e6f666781842483937612f163"><div class="ttname"><a href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a></div><div class="ttdeci">GLFWglproc glfwGetProcAddress(const char *procname)</div><div class="ttdoc">Returns the address of the specified function for the current context.</div></div>
|
|
||||||
</div><!-- fragment --><p >Once glad has been loaded, you have access to all OpenGL core and extension functions supported by both the context you created and the glad loader you generated and you are ready to start rendering.</p>
|
|
||||||
<p >You can specify a minimum required OpenGL or OpenGL ES version with <a class="el" href="window_guide.html#window_hints_ctx">context hints</a>. If your needs are more complex, you can check the actual OpenGL or OpenGL ES version with <a class="el" href="window_guide.html#window_attribs_ctx">context attributes</a>, or you can check whether a specific version is supported by the current context with the <code>GLAD_GL_VERSION_x_x</code> booleans.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="keywordflow">if</span> (GLAD_GL_VERSION_3_2)</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> <span class="comment">// Call OpenGL 3.2+ specific code</span></div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
</div><!-- fragment --><p >To check whether a specific extension is supported, use the <code>GLAD_GL_xxx</code> booleans.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="keywordflow">if</span> (GLAD_GL_ARB_gl_spirv)</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> <span class="comment">// Use GL_ARB_gl_spirv</span></div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
</div><!-- fragment --><h2><a class="anchor" id="context_glext_manual"></a>
|
|
||||||
Loading extensions manually</h2>
|
|
||||||
<p ><b>Do not use this technique</b> unless it is absolutely necessary. An <a class="el" href="context_guide.html#context_glext_auto">extension loader library</a> will save you a ton of tedious, repetitive, error prone work.</p>
|
|
||||||
<p >To use a certain extension, you must first check whether the context supports that extension and then, if it introduces new functions, retrieve the pointers to those functions. GLFW provides <a class="el" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a> and <a class="el" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a> for manual loading of extensions and new API functions.</p>
|
|
||||||
<p >This section will demonstrate manual loading of OpenGL extensions. The loading of OpenGL ES extensions is identical except for the name of the extension header.</p>
|
|
||||||
<h3><a class="anchor" id="context_glext_header"></a>
|
|
||||||
The glext.h header</h3>
|
|
||||||
<p >The <code>glext.h</code> extension header is a continually updated file that defines the interfaces for all OpenGL extensions. The latest version of this can always be found at the <a href="https://www.opengl.org/registry/">OpenGL Registry</a>. There are also extension headers for the various versions of OpenGL ES at the <a href="https://www.khronos.org/registry/gles/">OpenGL ES Registry</a>. It it strongly recommended that you use your own copy of the extension header, as the one included in your development environment may be several years out of date and may not include the extensions you wish to use.</p>
|
|
||||||
<p >The header defines function pointer types for all functions of all extensions it supports. These have names like <code>PFNGLSPECIALIZESHADERARBPROC</code> (for <code>glSpecializeShaderARB</code>), i.e. the name is made uppercase and <code>PFN</code> (pointer to function) and <code>PROC</code> (procedure) are added to the ends.</p>
|
|
||||||
<p >To include the extension header, define <a class="el" href="build_guide.html#GLFW_INCLUDE_GLEXT">GLFW_INCLUDE_GLEXT</a> before including the GLFW header.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#define GLFW_INCLUDE_GLEXT</span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <GLFW/glfw3.h></span></div>
|
|
||||||
</div><!-- fragment --><h3><a class="anchor" id="context_glext_string"></a>
|
|
||||||
Checking for extensions</h3>
|
|
||||||
<p >A given machine may not actually support the extension (it may have older drivers or a graphics card that lacks the necessary hardware features), so it is necessary to check at run-time whether the context supports the extension. This is done with <a class="el" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a>.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="keywordflow">if</span> (<a class="code hl_function" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a>(<span class="stringliteral">"GL_ARB_gl_spirv"</span>))</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> <span class="comment">// The extension is supported by the current context</span></div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
<div class="ttc" id="agroup__context_html_ga87425065c011cef1ebd6aac75e059dfa"><div class="ttname"><a href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a></div><div class="ttdeci">int glfwExtensionSupported(const char *extension)</div><div class="ttdoc">Returns whether the specified extension is available.</div></div>
|
|
||||||
</div><!-- fragment --><p >The argument is a null terminated ASCII string with the extension name. If the extension is supported, <a class="el" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a> returns <code>GLFW_TRUE</code>, otherwise it returns <code>GLFW_FALSE</code>.</p>
|
|
||||||
<h3><a class="anchor" id="context_glext_proc"></a>
|
|
||||||
Fetching function pointers</h3>
|
|
||||||
<p >Many extensions, though not all, require the use of new OpenGL functions. These functions often do not have entry points in the client API libraries of your operating system, making it necessary to fetch them at run time. You can retrieve pointers to these functions with <a class="el" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a>.</p>
|
|
||||||
<div class="fragment"><div class="line">PFNGLSPECIALIZESHADERARBPROC pfnSpecializeShaderARB = <a class="code hl_function" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a>(<span class="stringliteral">"glSpecializeShaderARB"</span>);</div>
|
|
||||||
</div><!-- fragment --><p >In general, you should avoid giving the function pointer variables the (exact) same name as the function, as this may confuse your linker. Instead, you can use a different prefix, like above, or some other naming scheme.</p>
|
|
||||||
<p >Now that all the pieces have been introduced, here is what they might look like when used together.</p>
|
|
||||||
<div class="fragment"><div class="line"><span class="preprocessor">#define GLFW_INCLUDE_GLEXT</span></div>
|
|
||||||
<div class="line"><span class="preprocessor">#include <<a class="code" href="glfw3_8h.html">GLFW/glfw3.h</a>></span></div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><span class="preprocessor">#define glSpecializeShaderARB pfnSpecializeShaderARB</span></div>
|
|
||||||
<div class="line">PFNGLSPECIALIZESHADERARBPROC pfnSpecializeShaderARB;</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><span class="comment">// Flag indicating whether the extension is supported</span></div>
|
|
||||||
<div class="line"><span class="keywordtype">int</span> has_ARB_gl_spirv = 0;</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><span class="keywordtype">void</span> load_extensions(<span class="keywordtype">void</span>)</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> <span class="keywordflow">if</span> (<a class="code hl_function" href="group__context.html#ga87425065c011cef1ebd6aac75e059dfa">glfwExtensionSupported</a>(<span class="stringliteral">"GL_ARB_gl_spirv"</span>))</div>
|
|
||||||
<div class="line"> {</div>
|
|
||||||
<div class="line"> pfnSpecializeShaderARB = (PFNGLSPECIALIZESHADERARBPROC)</div>
|
|
||||||
<div class="line"> <a class="code hl_function" href="group__context.html#ga35f1837e6f666781842483937612f163">glfwGetProcAddress</a>(<span class="stringliteral">"glSpecializeShaderARB"</span>);</div>
|
|
||||||
<div class="line"> has_ARB_gl_spirv = 1;</div>
|
|
||||||
<div class="line"> }</div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
<div class="line"> </div>
|
|
||||||
<div class="line"><span class="keywordtype">void</span> some_function(<span class="keywordtype">void</span>)</div>
|
|
||||||
<div class="line">{</div>
|
|
||||||
<div class="line"> <span class="keywordflow">if</span> (has_ARB_gl_spirv)</div>
|
|
||||||
<div class="line"> {</div>
|
|
||||||
<div class="line"> <span class="comment">// Now the extension function can be called as usual</span></div>
|
|
||||||
<div class="line"> glSpecializeShaderARB(...);</div>
|
|
||||||
<div class="line"> }</div>
|
|
||||||
<div class="line">}</div>
|
|
||||||
</div><!-- fragment --> </div></div><!-- contents -->
|
|
||||||
</div><!-- PageDoc -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,81 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Deprecated List</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div><!-- top -->
|
|
||||||
<div><div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Deprecated List </div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="textblock"><dl class="reflist">
|
|
||||||
<dt>Global <a class="el" href="group__input.html#gac3cf64f90b6219c05ac7b7822d5a4b8f">GLFWcharmodsfun</a> )(GLFWwindow *window, unsigned int codepoint, int mods)</dt>
|
|
||||||
<dd><a class="anchor" id="_deprecated000001"></a>Scheduled for removal in version 4.0. </dd>
|
|
||||||
<dt>Global <a class="el" href="group__input.html#ga0b7f4ad13c2b17435ff13b6dcfb4e43c">glfwSetCharModsCallback</a> (GLFWwindow *window, GLFWcharmodsfun callback)</dt>
|
|
||||||
<dd><a class="anchor" id="_deprecated000002"></a>Scheduled for removal in version 4.0.</dd>
|
|
||||||
</dl>
|
|
||||||
</div></div><!-- contents -->
|
|
||||||
</div><!-- PageDoc -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,88 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: GLFW Directory Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li><li class="navelem"><a class="el" href="dir_ba478fc71671afc03f16a7df0eff1823.html">include</a></li><li class="navelem"><a class="el" href="dir_95e305b1bfdd4b95b22076c452f17802.html">GLFW</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">GLFW Directory Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<table class="memberdecls">
|
|
||||||
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a>
|
|
||||||
Files</h2></td></tr>
|
|
||||||
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="glfw3_8h.html">glfw3.h</a> <a href="glfw3_8h_source.html">[code]</a></td></tr>
|
|
||||||
<tr class="memdesc:glfw3_8h"><td class="mdescLeft"> </td><td class="mdescRight">The header of the GLFW 3 API. <br /></td></tr>
|
|
||||||
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="glfw3native_8h.html">glfw3native.h</a> <a href="glfw3native_8h_source.html">[code]</a></td></tr>
|
|
||||||
<tr class="memdesc:glfw3native_8h"><td class="mdescLeft"> </td><td class="mdescRight">The header of the native access functions. <br /></td></tr>
|
|
||||||
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
</table>
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,86 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: glfw-3.3.5 Directory Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">glfw-3.3.5 Directory Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<table class="memberdecls">
|
|
||||||
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a>
|
|
||||||
Directories</h2></td></tr>
|
|
||||||
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">directory  </td><td class="memItemRight" valign="bottom"><a class="el" href="dir_af88d45d38f632316cb7d639530d38c2.html">docs</a></td></tr>
|
|
||||||
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">directory  </td><td class="memItemRight" valign="bottom"><a class="el" href="dir_ba478fc71671afc03f16a7df0eff1823.html">include</a></td></tr>
|
|
||||||
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
</table>
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,78 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: docs Directory Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li><li class="navelem"><a class="el" href="dir_af88d45d38f632316cb7d639530d38c2.html">docs</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">docs Directory Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,84 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: include Directory Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li><li class="navelem"><a class="el" href="dir_ba478fc71671afc03f16a7df0eff1823.html">include</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">include Directory Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<table class="memberdecls">
|
|
||||||
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a>
|
|
||||||
Directories</h2></td></tr>
|
|
||||||
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">directory  </td><td class="memItemRight" valign="bottom"><a class="el" href="dir_95e305b1bfdd4b95b22076c452f17802.html">GLFW</a></td></tr>
|
|
||||||
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
</table>
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Before Width: | Height: | Size: 746 B |
Before Width: | Height: | Size: 15 KiB |
@ -1,121 +0,0 @@
|
|||||||
/*
|
|
||||||
@licstart The following is the entire license notice for the JavaScript code in this file.
|
|
||||||
|
|
||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (C) 1997-2020 by Dimitri van Heesch
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software
|
|
||||||
and associated documentation files (the "Software"), to deal in the Software without restriction,
|
|
||||||
including without limitation the rights to use, copy, modify, merge, publish, distribute,
|
|
||||||
sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or
|
|
||||||
substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
|
|
||||||
BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
||||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
||||||
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
@licend The above is the entire license notice for the JavaScript code in this file
|
|
||||||
*/
|
|
||||||
function toggleVisibility(linkObj)
|
|
||||||
{
|
|
||||||
var base = $(linkObj).attr('id');
|
|
||||||
var summary = $('#'+base+'-summary');
|
|
||||||
var content = $('#'+base+'-content');
|
|
||||||
var trigger = $('#'+base+'-trigger');
|
|
||||||
var src=$(trigger).attr('src');
|
|
||||||
if (content.is(':visible')===true) {
|
|
||||||
content.hide();
|
|
||||||
summary.show();
|
|
||||||
$(linkObj).addClass('closed').removeClass('opened');
|
|
||||||
$(trigger).attr('src',src.substring(0,src.length-8)+'closed.png');
|
|
||||||
} else {
|
|
||||||
content.show();
|
|
||||||
summary.hide();
|
|
||||||
$(linkObj).removeClass('closed').addClass('opened');
|
|
||||||
$(trigger).attr('src',src.substring(0,src.length-10)+'open.png');
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateStripes()
|
|
||||||
{
|
|
||||||
$('table.directory tr').
|
|
||||||
removeClass('even').filter(':visible:even').addClass('even');
|
|
||||||
}
|
|
||||||
|
|
||||||
function toggleLevel(level)
|
|
||||||
{
|
|
||||||
$('table.directory tr').each(function() {
|
|
||||||
var l = this.id.split('_').length-1;
|
|
||||||
var i = $('#img'+this.id.substring(3));
|
|
||||||
var a = $('#arr'+this.id.substring(3));
|
|
||||||
if (l<level+1) {
|
|
||||||
i.removeClass('iconfopen iconfclosed').addClass('iconfopen');
|
|
||||||
a.html('▼');
|
|
||||||
$(this).show();
|
|
||||||
} else if (l==level+1) {
|
|
||||||
i.removeClass('iconfclosed iconfopen').addClass('iconfclosed');
|
|
||||||
a.html('►');
|
|
||||||
$(this).show();
|
|
||||||
} else {
|
|
||||||
$(this).hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
updateStripes();
|
|
||||||
}
|
|
||||||
|
|
||||||
function toggleFolder(id)
|
|
||||||
{
|
|
||||||
// the clicked row
|
|
||||||
var currentRow = $('#row_'+id);
|
|
||||||
|
|
||||||
// all rows after the clicked row
|
|
||||||
var rows = currentRow.nextAll("tr");
|
|
||||||
|
|
||||||
var re = new RegExp('^row_'+id+'\\d+_$', "i"); //only one sub
|
|
||||||
|
|
||||||
// only match elements AFTER this one (can't hide elements before)
|
|
||||||
var childRows = rows.filter(function() { return this.id.match(re); });
|
|
||||||
|
|
||||||
// first row is visible we are HIDING
|
|
||||||
if (childRows.filter(':first').is(':visible')===true) {
|
|
||||||
// replace down arrow by right arrow for current row
|
|
||||||
var currentRowSpans = currentRow.find("span");
|
|
||||||
currentRowSpans.filter(".iconfopen").removeClass("iconfopen").addClass("iconfclosed");
|
|
||||||
currentRowSpans.filter(".arrow").html('►');
|
|
||||||
rows.filter("[id^=row_"+id+"]").hide(); // hide all children
|
|
||||||
} else { // we are SHOWING
|
|
||||||
// replace right arrow by down arrow for current row
|
|
||||||
var currentRowSpans = currentRow.find("span");
|
|
||||||
currentRowSpans.filter(".iconfclosed").removeClass("iconfclosed").addClass("iconfopen");
|
|
||||||
currentRowSpans.filter(".arrow").html('▼');
|
|
||||||
// replace down arrows by right arrows for child rows
|
|
||||||
var childRowsSpans = childRows.find("span");
|
|
||||||
childRowsSpans.filter(".iconfopen").removeClass("iconfopen").addClass("iconfclosed");
|
|
||||||
childRowsSpans.filter(".arrow").html('►');
|
|
||||||
childRows.show(); //show all children
|
|
||||||
}
|
|
||||||
updateStripes();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function toggleInherit(id)
|
|
||||||
{
|
|
||||||
var rows = $('tr.inherit.'+id);
|
|
||||||
var img = $('tr.inherit_header.'+id+' img');
|
|
||||||
var src = $(img).attr('src');
|
|
||||||
if (rows.filter(':first').is(':visible')===true) {
|
|
||||||
rows.css('display','none');
|
|
||||||
$(img).attr('src',src.substring(0,src.length-8)+'closed.png');
|
|
||||||
} else {
|
|
||||||
rows.css('display','table-row'); // using show() causes jump in firefox
|
|
||||||
$(img).attr('src',src.substring(0,src.length-10)+'open.png');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* @license-end */
|
|
@ -1,80 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: Files</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">Files</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<div class="textblock">Here is a list of all files with brief descriptions:</div><div class="directory">
|
|
||||||
<table class="directory">
|
|
||||||
<tr id="row_0_" class="even"><td class="entry"><span style="width:16px;display:inline-block;"> </span><a href="glfw3_8h_source.html"><span class="icondoc"></span></a><a class="el" href="glfw3_8h.html" target="_self">glfw3.h</a></td><td class="desc">The header of the GLFW 3 API </td></tr>
|
|
||||||
<tr id="row_1_"><td class="entry"><span style="width:16px;display:inline-block;"> </span><a href="glfw3native_8h_source.html"><span class="icondoc"></span></a><a class="el" href="glfw3native_8h.html" target="_self">glfw3native.h</a></td><td class="desc">The header of the native access functions </td></tr>
|
|
||||||
</table>
|
|
||||||
</div><!-- directory -->
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Before Width: | Height: | Size: 616 B |
Before Width: | Height: | Size: 597 B |
@ -1,160 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: glfw3native.h File Reference</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li><li class="navelem"><a class="el" href="dir_ba478fc71671afc03f16a7df0eff1823.html">include</a></li><li class="navelem"><a class="el" href="dir_95e305b1bfdd4b95b22076c452f17802.html">GLFW</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="summary">
|
|
||||||
<a href="#func-members">Functions</a> </div>
|
|
||||||
<div class="headertitle"><div class="title">glfw3native.h File Reference</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<a name="details" id="details"></a><h2 class="groupheader">Description</h2>
|
|
||||||
<div class="textblock"><p >This is the header file of the native access functions. See <a class="el" href="group__native.html">Native access</a> for more information. </p>
|
|
||||||
</div>
|
|
||||||
<p><a href="glfw3native_8h_source.html">Go to the source code of this file.</a></p>
|
|
||||||
<table class="memberdecls">
|
|
||||||
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
|
|
||||||
Functions</h2></td></tr>
|
|
||||||
<tr class="memitem:gad4d3e9242536c0ba6be88a98f4c73a41"><td class="memItemLeft" align="right" valign="top">const char * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gad4d3e9242536c0ba6be88a98f4c73a41">glfwGetWin32Adapter</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:gad4d3e9242536c0ba6be88a98f4c73a41"><td class="mdescLeft"> </td><td class="mdescRight">Returns the adapter device name of the specified monitor. <a href="group__native.html#gad4d3e9242536c0ba6be88a98f4c73a41">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gad4d3e9242536c0ba6be88a98f4c73a41"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gac845f7dbe4c1d7fdd682a3c6fdae6766"><td class="memItemLeft" align="right" valign="top">const char * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gac845f7dbe4c1d7fdd682a3c6fdae6766">glfwGetWin32Monitor</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:gac845f7dbe4c1d7fdd682a3c6fdae6766"><td class="mdescLeft"> </td><td class="mdescRight">Returns the display device name of the specified monitor. <a href="group__native.html#gac845f7dbe4c1d7fdd682a3c6fdae6766">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gac845f7dbe4c1d7fdd682a3c6fdae6766"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gafe5079aa79038b0079fc09d5f0a8e667"><td class="memItemLeft" align="right" valign="top">HWND </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gafe5079aa79038b0079fc09d5f0a8e667">glfwGetWin32Window</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:gafe5079aa79038b0079fc09d5f0a8e667"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>HWND</code> of the specified window. <a href="group__native.html#gafe5079aa79038b0079fc09d5f0a8e667">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gafe5079aa79038b0079fc09d5f0a8e667"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gadc4010d91d9cc1134d040eeb1202a143"><td class="memItemLeft" align="right" valign="top">HGLRC </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gadc4010d91d9cc1134d040eeb1202a143">glfwGetWGLContext</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:gadc4010d91d9cc1134d040eeb1202a143"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>HGLRC</code> of the specified window. <a href="group__native.html#gadc4010d91d9cc1134d040eeb1202a143">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gadc4010d91d9cc1134d040eeb1202a143"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gaf22f429aec4b1aab316142d66d9be3e6"><td class="memItemLeft" align="right" valign="top">CGDirectDisplayID </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gaf22f429aec4b1aab316142d66d9be3e6">glfwGetCocoaMonitor</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:gaf22f429aec4b1aab316142d66d9be3e6"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>CGDirectDisplayID</code> of the specified monitor. <a href="group__native.html#gaf22f429aec4b1aab316142d66d9be3e6">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gaf22f429aec4b1aab316142d66d9be3e6"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gac3ed9d495d0c2bb9652de5a50c648715"><td class="memItemLeft" align="right" valign="top">id </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gac3ed9d495d0c2bb9652de5a50c648715">glfwGetCocoaWindow</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:gac3ed9d495d0c2bb9652de5a50c648715"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>NSWindow</code> of the specified window. <a href="group__native.html#gac3ed9d495d0c2bb9652de5a50c648715">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gac3ed9d495d0c2bb9652de5a50c648715"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga559e002e3cd63c979881770cd4dc63bc"><td class="memItemLeft" align="right" valign="top">id </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga559e002e3cd63c979881770cd4dc63bc">glfwGetNSGLContext</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga559e002e3cd63c979881770cd4dc63bc"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>NSOpenGLContext</code> of the specified window. <a href="group__native.html#ga559e002e3cd63c979881770cd4dc63bc">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga559e002e3cd63c979881770cd4dc63bc"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga6e7822385cc8a1cc3b18f60352830189"><td class="memItemLeft" align="right" valign="top">Display * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga6e7822385cc8a1cc3b18f60352830189">glfwGetX11Display</a> (void)</td></tr>
|
|
||||||
<tr class="memdesc:ga6e7822385cc8a1cc3b18f60352830189"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>Display</code> used by GLFW. <a href="group__native.html#ga6e7822385cc8a1cc3b18f60352830189">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga6e7822385cc8a1cc3b18f60352830189"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga088fbfa80f50569402b41be71ad66e40"><td class="memItemLeft" align="right" valign="top">RRCrtc </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga088fbfa80f50569402b41be71ad66e40">glfwGetX11Adapter</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:ga088fbfa80f50569402b41be71ad66e40"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>RRCrtc</code> of the specified monitor. <a href="group__native.html#ga088fbfa80f50569402b41be71ad66e40">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga088fbfa80f50569402b41be71ad66e40"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gab2f8cc043905e9fa9b12bfdbbcfe874c"><td class="memItemLeft" align="right" valign="top">RROutput </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gab2f8cc043905e9fa9b12bfdbbcfe874c">glfwGetX11Monitor</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:gab2f8cc043905e9fa9b12bfdbbcfe874c"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>RROutput</code> of the specified monitor. <a href="group__native.html#gab2f8cc043905e9fa9b12bfdbbcfe874c">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gab2f8cc043905e9fa9b12bfdbbcfe874c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga90ca676322740842db446999a1b1f21d"><td class="memItemLeft" align="right" valign="top">Window </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga90ca676322740842db446999a1b1f21d">glfwGetX11Window</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga90ca676322740842db446999a1b1f21d"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>Window</code> of the specified window. <a href="group__native.html#ga90ca676322740842db446999a1b1f21d">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga90ca676322740842db446999a1b1f21d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga55f879ab02d93367f966186b6f0133f7"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga55f879ab02d93367f966186b6f0133f7">glfwSetX11SelectionString</a> (const char *string)</td></tr>
|
|
||||||
<tr class="memdesc:ga55f879ab02d93367f966186b6f0133f7"><td class="mdescLeft"> </td><td class="mdescRight">Sets the current primary selection to the specified string. <a href="group__native.html#ga55f879ab02d93367f966186b6f0133f7">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga55f879ab02d93367f966186b6f0133f7"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gae084ef64dc0db140b455b1427256d3f7"><td class="memItemLeft" align="right" valign="top">const char * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gae084ef64dc0db140b455b1427256d3f7">glfwGetX11SelectionString</a> (void)</td></tr>
|
|
||||||
<tr class="memdesc:gae084ef64dc0db140b455b1427256d3f7"><td class="mdescLeft"> </td><td class="mdescRight">Returns the contents of the current primary selection as a string. <a href="group__native.html#gae084ef64dc0db140b455b1427256d3f7">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gae084ef64dc0db140b455b1427256d3f7"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga62d884114b0abfcdc2930e89f20867e2"><td class="memItemLeft" align="right" valign="top">GLXContext </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga62d884114b0abfcdc2930e89f20867e2">glfwGetGLXContext</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga62d884114b0abfcdc2930e89f20867e2"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>GLXContext</code> of the specified window. <a href="group__native.html#ga62d884114b0abfcdc2930e89f20867e2">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga62d884114b0abfcdc2930e89f20867e2"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga1ed27b8766e859a21381e8f8ce18d049"><td class="memItemLeft" align="right" valign="top">GLXWindow </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga1ed27b8766e859a21381e8f8ce18d049">glfwGetGLXWindow</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga1ed27b8766e859a21381e8f8ce18d049"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>GLXWindow</code> of the specified window. <a href="group__native.html#ga1ed27b8766e859a21381e8f8ce18d049">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga1ed27b8766e859a21381e8f8ce18d049"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:gacbe11f93ce20621de82989bbba94e62a"><td class="memItemLeft" align="right" valign="top">struct wl_display * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#gacbe11f93ce20621de82989bbba94e62a">glfwGetWaylandDisplay</a> (void)</td></tr>
|
|
||||||
<tr class="memdesc:gacbe11f93ce20621de82989bbba94e62a"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>struct wl_display*</code> used by GLFW. <a href="group__native.html#gacbe11f93ce20621de82989bbba94e62a">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:gacbe11f93ce20621de82989bbba94e62a"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga4f16066bd4c59e2f99418adfcb43dd16"><td class="memItemLeft" align="right" valign="top">struct wl_output * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga4f16066bd4c59e2f99418adfcb43dd16">glfwGetWaylandMonitor</a> (<a class="el" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a> *monitor)</td></tr>
|
|
||||||
<tr class="memdesc:ga4f16066bd4c59e2f99418adfcb43dd16"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>struct wl_output*</code> of the specified monitor. <a href="group__native.html#ga4f16066bd4c59e2f99418adfcb43dd16">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga4f16066bd4c59e2f99418adfcb43dd16"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga5c597f2841229d9626f0811cca41ceb3"><td class="memItemLeft" align="right" valign="top">struct wl_surface * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga5c597f2841229d9626f0811cca41ceb3">glfwGetWaylandWindow</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga5c597f2841229d9626f0811cca41ceb3"><td class="mdescLeft"> </td><td class="mdescRight">Returns the main <code>struct wl_surface*</code> of the specified window. <a href="group__native.html#ga5c597f2841229d9626f0811cca41ceb3">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga5c597f2841229d9626f0811cca41ceb3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga1cd8d973f47aacb5532d368147cc3138"><td class="memItemLeft" align="right" valign="top">EGLDisplay </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga1cd8d973f47aacb5532d368147cc3138">glfwGetEGLDisplay</a> (void)</td></tr>
|
|
||||||
<tr class="memdesc:ga1cd8d973f47aacb5532d368147cc3138"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>EGLDisplay</code> used by GLFW. <a href="group__native.html#ga1cd8d973f47aacb5532d368147cc3138">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga1cd8d973f47aacb5532d368147cc3138"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga671c5072becd085f4ab5771a9c8efcf1"><td class="memItemLeft" align="right" valign="top">EGLContext </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga671c5072becd085f4ab5771a9c8efcf1">glfwGetEGLContext</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga671c5072becd085f4ab5771a9c8efcf1"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>EGLContext</code> of the specified window. <a href="group__native.html#ga671c5072becd085f4ab5771a9c8efcf1">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga671c5072becd085f4ab5771a9c8efcf1"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga2199b36117a6a695fec8441d8052eee6"><td class="memItemLeft" align="right" valign="top">EGLSurface </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga2199b36117a6a695fec8441d8052eee6">glfwGetEGLSurface</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga2199b36117a6a695fec8441d8052eee6"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>EGLSurface</code> of the specified window. <a href="group__native.html#ga2199b36117a6a695fec8441d8052eee6">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga2199b36117a6a695fec8441d8052eee6"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga3b36e3e3dcf308b776427b6bd73cc132"><td class="memItemLeft" align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga3b36e3e3dcf308b776427b6bd73cc132">glfwGetOSMesaColorBuffer</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window, int *width, int *height, int *format, void **buffer)</td></tr>
|
|
||||||
<tr class="memdesc:ga3b36e3e3dcf308b776427b6bd73cc132"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves the color buffer associated with the specified window. <a href="group__native.html#ga3b36e3e3dcf308b776427b6bd73cc132">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga3b36e3e3dcf308b776427b6bd73cc132"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga6b64039ffc88a7a2f57f0956c0c75d53"><td class="memItemLeft" align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga6b64039ffc88a7a2f57f0956c0c75d53">glfwGetOSMesaDepthBuffer</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window, int *width, int *height, int *bytesPerValue, void **buffer)</td></tr>
|
|
||||||
<tr class="memdesc:ga6b64039ffc88a7a2f57f0956c0c75d53"><td class="mdescLeft"> </td><td class="mdescRight">Retrieves the depth buffer associated with the specified window. <a href="group__native.html#ga6b64039ffc88a7a2f57f0956c0c75d53">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga6b64039ffc88a7a2f57f0956c0c75d53"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
<tr class="memitem:ga9e47700080094eb569cb053afaa88773"><td class="memItemLeft" align="right" valign="top">OSMesaContext </td><td class="memItemRight" valign="bottom"><a class="el" href="group__native.html#ga9e47700080094eb569cb053afaa88773">glfwGetOSMesaContext</a> (<a class="el" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a> *window)</td></tr>
|
|
||||||
<tr class="memdesc:ga9e47700080094eb569cb053afaa88773"><td class="mdescLeft"> </td><td class="mdescRight">Returns the <code>OSMesaContext</code> of the specified window. <a href="group__native.html#ga9e47700080094eb569cb053afaa88773">More...</a><br /></td></tr>
|
|
||||||
<tr class="separator:ga9e47700080094eb569cb053afaa88773"><td class="memSeparator" colspan="2"> </td></tr>
|
|
||||||
</table>
|
|
||||||
</div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,264 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
||||||
<meta name="generator" content="Doxygen 1.9.2"/>
|
|
||||||
<title>GLFW: glfw3native.h Source File</title>
|
|
||||||
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="jquery.js"></script>
|
|
||||||
<script type="text/javascript" src="dynsections.js"></script>
|
|
||||||
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
||||||
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
||||||
<script type="text/javascript" src="search/search.js"></script>
|
|
||||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
||||||
<link href="extra.css" rel="stylesheet" type="text/css"/>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
||||||
<div id="titlearea">
|
|
||||||
<div class="glfwheader">
|
|
||||||
<a href="https://www.glfw.org/" id="glfwhome">GLFW</a>
|
|
||||||
<ul class="glfwnavbar">
|
|
||||||
<li><a href="https://www.glfw.org/documentation.html">Documentation</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/download.html">Download</a></li>
|
|
||||||
<li><a href="https://www.glfw.org/community.html">Community</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- end header part -->
|
|
||||||
<!-- Generated by Doxygen 1.9.2 -->
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="menudata.js"></script>
|
|
||||||
<script type="text/javascript" src="menu.js"></script>
|
|
||||||
<script type="text/javascript">
|
|
||||||
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
||||||
$(function() {
|
|
||||||
initMenu('',true,false,'search.php','Search');
|
|
||||||
$(document).ready(function() { init_search(); });
|
|
||||||
});
|
|
||||||
/* @license-end */
|
|
||||||
</script>
|
|
||||||
<div id="main-nav"></div>
|
|
||||||
<!-- window showing the filter options -->
|
|
||||||
<div id="MSearchSelectWindow"
|
|
||||||
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
||||||
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
||||||
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- iframe showing the search results (closed by default) -->
|
|
||||||
<div id="MSearchResultsWindow">
|
|
||||||
<iframe src="javascript:void(0)" frameborder="0"
|
|
||||||
name="MSearchResults" id="MSearchResults">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="nav-path" class="navpath">
|
|
||||||
<ul>
|
|
||||||
<li class="navelem"><a class="el" href="dir_a2f8ccc4e596c8744057ab6c4a040d5c.html">glfw-3.3.5</a></li><li class="navelem"><a class="el" href="dir_ba478fc71671afc03f16a7df0eff1823.html">include</a></li><li class="navelem"><a class="el" href="dir_95e305b1bfdd4b95b22076c452f17802.html">GLFW</a></li> </ul>
|
|
||||||
</div>
|
|
||||||
</div><!-- top -->
|
|
||||||
<div class="header">
|
|
||||||
<div class="headertitle"><div class="title">glfw3native.h</div></div>
|
|
||||||
</div><!--header-->
|
|
||||||
<div class="contents">
|
|
||||||
<a href="glfw3native_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">/*************************************************************************</span></div>
|
|
||||||
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment"> * GLFW 3.3 - www.glfw.org</span></div>
|
|
||||||
<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment"> * A library for OpenGL, window and input</span></div>
|
|
||||||
<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment"> *------------------------------------------------------------------------</span></div>
|
|
||||||
<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment"> * Copyright (c) 2002-2006 Marcus Geelnard</span></div>
|
|
||||||
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment"> * Copyright (c) 2006-2018 Camilla Löwy <elmindreda@glfw.org></span></div>
|
|
||||||
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="comment"> * This software is provided 'as-is', without any express or implied</span></div>
|
|
||||||
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="comment"> * warranty. In no event will the authors be held liable for any damages</span></div>
|
|
||||||
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment"> * arising from the use of this software.</span></div>
|
|
||||||
<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="comment"> * Permission is granted to anyone to use this software for any purpose,</span></div>
|
|
||||||
<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="comment"> * including commercial applications, and to alter it and redistribute it</span></div>
|
|
||||||
<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="comment"> * freely, subject to the following restrictions:</span></div>
|
|
||||||
<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="comment"> * 1. The origin of this software must not be misrepresented; you must not</span></div>
|
|
||||||
<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment"> * claim that you wrote the original software. If you use this software</span></div>
|
|
||||||
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment"> * in a product, an acknowledgment in the product documentation would</span></div>
|
|
||||||
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="comment"> * be appreciated but is not required.</span></div>
|
|
||||||
<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment"> * 2. Altered source versions must be plainly marked as such, and must not</span></div>
|
|
||||||
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment"> * be misrepresented as being the original software.</span></div>
|
|
||||||
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment"> * 3. This notice may not be removed or altered from any source</span></div>
|
|
||||||
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment"> * distribution.</span></div>
|
|
||||||
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment"> *</span></div>
|
|
||||||
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment"> *************************************************************************/</span></div>
|
|
||||||
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span> </div>
|
|
||||||
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="preprocessor">#ifndef _glfw3_native_h_</span></div>
|
|
||||||
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="preprocessor">#define _glfw3_native_h_</span></div>
|
|
||||||
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> </div>
|
|
||||||
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="preprocessor">#ifdef __cplusplus</span></div>
|
|
||||||
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="keyword">extern</span> <span class="stringliteral">"C"</span> {</div>
|
|
||||||
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div>
|
|
||||||
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div>
|
|
||||||
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="comment">/*************************************************************************</span></div>
|
|
||||||
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="comment"> * Doxygen documentation</span></div>
|
|
||||||
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment"> *************************************************************************/</span></div>
|
|
||||||
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> </div>
|
|
||||||
<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span><span class="comment">/*************************************************************************</span></div>
|
|
||||||
<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span><span class="comment"> * System headers and types</span></div>
|
|
||||||
<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="comment"> *************************************************************************/</span></div>
|
|
||||||
<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> </div>
|
|
||||||
<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_WIN32) || defined(GLFW_EXPOSE_NATIVE_WGL)</span></div>
|
|
||||||
<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> <span class="comment">// This is a workaround for the fact that glfw3.h needs to export APIENTRY (for</span></div>
|
|
||||||
<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> <span class="comment">// example to allow applications to correctly declare a GL_KHR_debug callback)</span></div>
|
|
||||||
<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> <span class="comment">// but windows.h assumes no one will define APIENTRY before it does</span></div>
|
|
||||||
<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="preprocessor"> #if defined(GLFW_APIENTRY_DEFINED)</span></div>
|
|
||||||
<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="preprocessor"> #undef APIENTRY</span></div>
|
|
||||||
<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span><span class="preprocessor"> #undef GLFW_APIENTRY_DEFINED</span></div>
|
|
||||||
<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="preprocessor"> #endif</span></div>
|
|
||||||
<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span><span class="preprocessor"> #include <windows.h></span></div>
|
|
||||||
<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="preprocessor">#elif defined(GLFW_EXPOSE_NATIVE_COCOA) || defined(GLFW_EXPOSE_NATIVE_NSGL)</span></div>
|
|
||||||
<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span><span class="preprocessor"> #if defined(__OBJC__)</span></div>
|
|
||||||
<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="preprocessor"> #import <Cocoa/Cocoa.h></span></div>
|
|
||||||
<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="preprocessor"> #else</span></div>
|
|
||||||
<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="preprocessor"> #include <ApplicationServices/ApplicationServices.h></span></div>
|
|
||||||
<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> <span class="keyword">typedef</span> <span class="keywordtype">void</span>* id;</div>
|
|
||||||
<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span><span class="preprocessor"> #endif</span></div>
|
|
||||||
<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span><span class="preprocessor">#elif defined(GLFW_EXPOSE_NATIVE_X11) || defined(GLFW_EXPOSE_NATIVE_GLX)</span></div>
|
|
||||||
<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span><span class="preprocessor"> #include <X11/Xlib.h></span></div>
|
|
||||||
<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span><span class="preprocessor"> #include <X11/extensions/Xrandr.h></span></div>
|
|
||||||
<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span><span class="preprocessor">#elif defined(GLFW_EXPOSE_NATIVE_WAYLAND)</span></div>
|
|
||||||
<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span><span class="preprocessor"> #include <wayland-client.h></span></div>
|
|
||||||
<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> </div>
|
|
||||||
<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_WGL)</span></div>
|
|
||||||
<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> <span class="comment">/* WGL is declared by windows.h */</span></div>
|
|
||||||
<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_NSGL)</span></div>
|
|
||||||
<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span> <span class="comment">/* NSGL is declared by Cocoa.h */</span></div>
|
|
||||||
<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_GLX)</span></div>
|
|
||||||
<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span><span class="preprocessor"> #include <GL/glx.h></span></div>
|
|
||||||
<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_EGL)</span></div>
|
|
||||||
<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span><span class="preprocessor"> #include <EGL/egl.h></span></div>
|
|
||||||
<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_OSMESA)</span></div>
|
|
||||||
<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span><span class="preprocessor"> #include <GL/osmesa.h></span></div>
|
|
||||||
<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span> </div>
|
|
||||||
<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span> </div>
|
|
||||||
<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span><span class="comment">/*************************************************************************</span></div>
|
|
||||||
<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span><span class="comment"> * Functions</span></div>
|
|
||||||
<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span><span class="comment"> *************************************************************************/</span></div>
|
|
||||||
<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> </div>
|
|
||||||
<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_WIN32)</span></div>
|
|
||||||
<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"><a class="line" href="group__native.html#gad4d3e9242536c0ba6be88a98f4c73a41"> 144</a></span>GLFWAPI <span class="keyword">const</span> <span class="keywordtype">char</span>* <a class="code hl_function" href="group__native.html#gad4d3e9242536c0ba6be88a98f4c73a41">glfwGetWin32Adapter</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span> </div>
|
|
||||||
<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"><a class="line" href="group__native.html#gac845f7dbe4c1d7fdd682a3c6fdae6766"> 161</a></span>GLFWAPI <span class="keyword">const</span> <span class="keywordtype">char</span>* <a class="code hl_function" href="group__native.html#gac845f7dbe4c1d7fdd682a3c6fdae6766">glfwGetWin32Monitor</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span> </div>
|
|
||||||
<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"><a class="line" href="group__native.html#gafe5079aa79038b0079fc09d5f0a8e667"> 185</a></span>GLFWAPI HWND <a class="code hl_function" href="group__native.html#gafe5079aa79038b0079fc09d5f0a8e667">glfwGetWin32Window</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"> 187</span> </div>
|
|
||||||
<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"> 188</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_WGL)</span></div>
|
|
||||||
<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"><a class="line" href="group__native.html#gadc4010d91d9cc1134d040eeb1202a143"> 212</a></span>GLFWAPI HGLRC <a class="code hl_function" href="group__native.html#gadc4010d91d9cc1134d040eeb1202a143">glfwGetWGLContext</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> </div>
|
|
||||||
<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_COCOA)</span></div>
|
|
||||||
<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"><a class="line" href="group__native.html#gaf22f429aec4b1aab316142d66d9be3e6"> 230</a></span>GLFWAPI CGDirectDisplayID <a class="code hl_function" href="group__native.html#gaf22f429aec4b1aab316142d66d9be3e6">glfwGetCocoaMonitor</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span> </div>
|
|
||||||
<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"><a class="line" href="group__native.html#gac3ed9d495d0c2bb9652de5a50c648715"> 246</a></span>GLFWAPI <span class="keywordtype">id</span> <a class="code hl_function" href="group__native.html#gac3ed9d495d0c2bb9652de5a50c648715">glfwGetCocoaWindow</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span> </div>
|
|
||||||
<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_NSGL)</span></div>
|
|
||||||
<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"><a class="line" href="group__native.html#ga559e002e3cd63c979881770cd4dc63bc"> 265</a></span>GLFWAPI <span class="keywordtype">id</span> <a class="code hl_function" href="group__native.html#ga559e002e3cd63c979881770cd4dc63bc">glfwGetNSGLContext</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span> </div>
|
|
||||||
<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_X11)</span></div>
|
|
||||||
<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"><a class="line" href="group__native.html#ga6e7822385cc8a1cc3b18f60352830189"> 283</a></span>GLFWAPI Display* <a class="code hl_function" href="group__native.html#ga6e7822385cc8a1cc3b18f60352830189">glfwGetX11Display</a>(<span class="keywordtype">void</span>);</div>
|
|
||||||
<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span> </div>
|
|
||||||
<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"><a class="line" href="group__native.html#ga088fbfa80f50569402b41be71ad66e40"> 299</a></span>GLFWAPI RRCrtc <a class="code hl_function" href="group__native.html#ga088fbfa80f50569402b41be71ad66e40">glfwGetX11Adapter</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span> </div>
|
|
||||||
<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"><a class="line" href="group__native.html#gab2f8cc043905e9fa9b12bfdbbcfe874c"> 315</a></span>GLFWAPI RROutput <a class="code hl_function" href="group__native.html#gab2f8cc043905e9fa9b12bfdbbcfe874c">glfwGetX11Monitor</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"> 316</span> </div>
|
|
||||||
<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"><a class="line" href="group__native.html#ga90ca676322740842db446999a1b1f21d"> 331</a></span>GLFWAPI Window <a class="code hl_function" href="group__native.html#ga90ca676322740842db446999a1b1f21d">glfwGetX11Window</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span> </div>
|
|
||||||
<div class="line"><a id="l00353" name="l00353"></a><span class="lineno"><a class="line" href="group__native.html#ga55f879ab02d93367f966186b6f0133f7"> 353</a></span>GLFWAPI <span class="keywordtype">void</span> <a class="code hl_function" href="group__native.html#ga55f879ab02d93367f966186b6f0133f7">glfwSetX11SelectionString</a>(<span class="keyword">const</span> <span class="keywordtype">char</span>* <span class="keywordtype">string</span>);</div>
|
|
||||||
<div class="line"><a id="l00354" name="l00354"></a><span class="lineno"> 354</span> </div>
|
|
||||||
<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"><a class="line" href="group__native.html#gae084ef64dc0db140b455b1427256d3f7"> 381</a></span>GLFWAPI <span class="keyword">const</span> <span class="keywordtype">char</span>* <a class="code hl_function" href="group__native.html#gae084ef64dc0db140b455b1427256d3f7">glfwGetX11SelectionString</a>(<span class="keywordtype">void</span>);</div>
|
|
||||||
<div class="line"><a id="l00382" name="l00382"></a><span class="lineno"> 382</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00383" name="l00383"></a><span class="lineno"> 383</span> </div>
|
|
||||||
<div class="line"><a id="l00384" name="l00384"></a><span class="lineno"> 384</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_GLX)</span></div>
|
|
||||||
<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"><a class="line" href="group__native.html#ga62d884114b0abfcdc2930e89f20867e2"> 400</a></span>GLFWAPI GLXContext <a class="code hl_function" href="group__native.html#ga62d884114b0abfcdc2930e89f20867e2">glfwGetGLXContext</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"> 401</span> </div>
|
|
||||||
<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"><a class="line" href="group__native.html#ga1ed27b8766e859a21381e8f8ce18d049"> 417</a></span>GLFWAPI GLXWindow <a class="code hl_function" href="group__native.html#ga1ed27b8766e859a21381e8f8ce18d049">glfwGetGLXWindow</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"> 418</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00419" name="l00419"></a><span class="lineno"> 419</span> </div>
|
|
||||||
<div class="line"><a id="l00420" name="l00420"></a><span class="lineno"> 420</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_WAYLAND)</span></div>
|
|
||||||
<div class="line"><a id="l00435" name="l00435"></a><span class="lineno"><a class="line" href="group__native.html#gacbe11f93ce20621de82989bbba94e62a"> 435</a></span>GLFWAPI <span class="keyword">struct </span>wl_display* <a class="code hl_function" href="group__native.html#gacbe11f93ce20621de82989bbba94e62a">glfwGetWaylandDisplay</a>(<span class="keywordtype">void</span>);</div>
|
|
||||||
<div class="line"><a id="l00436" name="l00436"></a><span class="lineno"> 436</span> </div>
|
|
||||||
<div class="line"><a id="l00451" name="l00451"></a><span class="lineno"><a class="line" href="group__native.html#ga4f16066bd4c59e2f99418adfcb43dd16"> 451</a></span>GLFWAPI <span class="keyword">struct </span>wl_output* <a class="code hl_function" href="group__native.html#ga4f16066bd4c59e2f99418adfcb43dd16">glfwGetWaylandMonitor</a>(<a class="code hl_typedef" href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a>* monitor);</div>
|
|
||||||
<div class="line"><a id="l00452" name="l00452"></a><span class="lineno"> 452</span> </div>
|
|
||||||
<div class="line"><a id="l00467" name="l00467"></a><span class="lineno"><a class="line" href="group__native.html#ga5c597f2841229d9626f0811cca41ceb3"> 467</a></span>GLFWAPI <span class="keyword">struct </span>wl_surface* <a class="code hl_function" href="group__native.html#ga5c597f2841229d9626f0811cca41ceb3">glfwGetWaylandWindow</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00468" name="l00468"></a><span class="lineno"> 468</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00469" name="l00469"></a><span class="lineno"> 469</span> </div>
|
|
||||||
<div class="line"><a id="l00470" name="l00470"></a><span class="lineno"> 470</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_EGL)</span></div>
|
|
||||||
<div class="line"><a id="l00485" name="l00485"></a><span class="lineno"><a class="line" href="group__native.html#ga1cd8d973f47aacb5532d368147cc3138"> 485</a></span>GLFWAPI EGLDisplay <a class="code hl_function" href="group__native.html#ga1cd8d973f47aacb5532d368147cc3138">glfwGetEGLDisplay</a>(<span class="keywordtype">void</span>);</div>
|
|
||||||
<div class="line"><a id="l00486" name="l00486"></a><span class="lineno"> 486</span> </div>
|
|
||||||
<div class="line"><a id="l00502" name="l00502"></a><span class="lineno"><a class="line" href="group__native.html#ga671c5072becd085f4ab5771a9c8efcf1"> 502</a></span>GLFWAPI EGLContext <a class="code hl_function" href="group__native.html#ga671c5072becd085f4ab5771a9c8efcf1">glfwGetEGLContext</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00503" name="l00503"></a><span class="lineno"> 503</span> </div>
|
|
||||||
<div class="line"><a id="l00519" name="l00519"></a><span class="lineno"><a class="line" href="group__native.html#ga2199b36117a6a695fec8441d8052eee6"> 519</a></span>GLFWAPI EGLSurface <a class="code hl_function" href="group__native.html#ga2199b36117a6a695fec8441d8052eee6">glfwGetEGLSurface</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00520" name="l00520"></a><span class="lineno"> 520</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00521" name="l00521"></a><span class="lineno"> 521</span> </div>
|
|
||||||
<div class="line"><a id="l00522" name="l00522"></a><span class="lineno"> 522</span><span class="preprocessor">#if defined(GLFW_EXPOSE_NATIVE_OSMESA)</span></div>
|
|
||||||
<div class="line"><a id="l00545" name="l00545"></a><span class="lineno"><a class="line" href="group__native.html#ga3b36e3e3dcf308b776427b6bd73cc132"> 545</a></span>GLFWAPI <span class="keywordtype">int</span> <a class="code hl_function" href="group__native.html#ga3b36e3e3dcf308b776427b6bd73cc132">glfwGetOSMesaColorBuffer</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window, <span class="keywordtype">int</span>* width, <span class="keywordtype">int</span>* height, <span class="keywordtype">int</span>* format, <span class="keywordtype">void</span>** buffer);</div>
|
|
||||||
<div class="line"><a id="l00546" name="l00546"></a><span class="lineno"> 546</span> </div>
|
|
||||||
<div class="line"><a id="l00569" name="l00569"></a><span class="lineno"><a class="line" href="group__native.html#ga6b64039ffc88a7a2f57f0956c0c75d53"> 569</a></span>GLFWAPI <span class="keywordtype">int</span> <a class="code hl_function" href="group__native.html#ga6b64039ffc88a7a2f57f0956c0c75d53">glfwGetOSMesaDepthBuffer</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window, <span class="keywordtype">int</span>* width, <span class="keywordtype">int</span>* height, <span class="keywordtype">int</span>* bytesPerValue, <span class="keywordtype">void</span>** buffer);</div>
|
|
||||||
<div class="line"><a id="l00570" name="l00570"></a><span class="lineno"> 570</span> </div>
|
|
||||||
<div class="line"><a id="l00586" name="l00586"></a><span class="lineno"><a class="line" href="group__native.html#ga9e47700080094eb569cb053afaa88773"> 586</a></span>GLFWAPI OSMesaContext <a class="code hl_function" href="group__native.html#ga9e47700080094eb569cb053afaa88773">glfwGetOSMesaContext</a>(<a class="code hl_typedef" href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a>* window);</div>
|
|
||||||
<div class="line"><a id="l00587" name="l00587"></a><span class="lineno"> 587</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00588" name="l00588"></a><span class="lineno"> 588</span> </div>
|
|
||||||
<div class="line"><a id="l00589" name="l00589"></a><span class="lineno"> 589</span><span class="preprocessor">#ifdef __cplusplus</span></div>
|
|
||||||
<div class="line"><a id="l00590" name="l00590"></a><span class="lineno"> 590</span>}</div>
|
|
||||||
<div class="line"><a id="l00591" name="l00591"></a><span class="lineno"> 591</span><span class="preprocessor">#endif</span></div>
|
|
||||||
<div class="line"><a id="l00592" name="l00592"></a><span class="lineno"> 592</span> </div>
|
|
||||||
<div class="line"><a id="l00593" name="l00593"></a><span class="lineno"> 593</span><span class="preprocessor">#endif </span><span class="comment">/* _glfw3_native_h_ */</span><span class="preprocessor"></span></div>
|
|
||||||
<div class="line"><a id="l00594" name="l00594"></a><span class="lineno"> 594</span> </div>
|
|
||||||
<div class="ttc" id="agroup__monitor_html_ga8d9efd1cde9426692c73fe40437d0ae3"><div class="ttname"><a href="group__monitor.html#ga8d9efd1cde9426692c73fe40437d0ae3">GLFWmonitor</a></div><div class="ttdeci">struct GLFWmonitor GLFWmonitor</div><div class="ttdoc">Opaque monitor object.</div><div class="ttdef"><b>Definition:</b> glfw3.h:1174</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga088fbfa80f50569402b41be71ad66e40"><div class="ttname"><a href="group__native.html#ga088fbfa80f50569402b41be71ad66e40">glfwGetX11Adapter</a></div><div class="ttdeci">RRCrtc glfwGetX11Adapter(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the RRCrtc of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga1cd8d973f47aacb5532d368147cc3138"><div class="ttname"><a href="group__native.html#ga1cd8d973f47aacb5532d368147cc3138">glfwGetEGLDisplay</a></div><div class="ttdeci">EGLDisplay glfwGetEGLDisplay(void)</div><div class="ttdoc">Returns the EGLDisplay used by GLFW.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga1ed27b8766e859a21381e8f8ce18d049"><div class="ttname"><a href="group__native.html#ga1ed27b8766e859a21381e8f8ce18d049">glfwGetGLXWindow</a></div><div class="ttdeci">GLXWindow glfwGetGLXWindow(GLFWwindow *window)</div><div class="ttdoc">Returns the GLXWindow of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga2199b36117a6a695fec8441d8052eee6"><div class="ttname"><a href="group__native.html#ga2199b36117a6a695fec8441d8052eee6">glfwGetEGLSurface</a></div><div class="ttdeci">EGLSurface glfwGetEGLSurface(GLFWwindow *window)</div><div class="ttdoc">Returns the EGLSurface of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga3b36e3e3dcf308b776427b6bd73cc132"><div class="ttname"><a href="group__native.html#ga3b36e3e3dcf308b776427b6bd73cc132">glfwGetOSMesaColorBuffer</a></div><div class="ttdeci">int glfwGetOSMesaColorBuffer(GLFWwindow *window, int *width, int *height, int *format, void **buffer)</div><div class="ttdoc">Retrieves the color buffer associated with the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga4f16066bd4c59e2f99418adfcb43dd16"><div class="ttname"><a href="group__native.html#ga4f16066bd4c59e2f99418adfcb43dd16">glfwGetWaylandMonitor</a></div><div class="ttdeci">struct wl_output * glfwGetWaylandMonitor(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the struct wl_output* of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga559e002e3cd63c979881770cd4dc63bc"><div class="ttname"><a href="group__native.html#ga559e002e3cd63c979881770cd4dc63bc">glfwGetNSGLContext</a></div><div class="ttdeci">id glfwGetNSGLContext(GLFWwindow *window)</div><div class="ttdoc">Returns the NSOpenGLContext of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga55f879ab02d93367f966186b6f0133f7"><div class="ttname"><a href="group__native.html#ga55f879ab02d93367f966186b6f0133f7">glfwSetX11SelectionString</a></div><div class="ttdeci">void glfwSetX11SelectionString(const char *string)</div><div class="ttdoc">Sets the current primary selection to the specified string.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga5c597f2841229d9626f0811cca41ceb3"><div class="ttname"><a href="group__native.html#ga5c597f2841229d9626f0811cca41ceb3">glfwGetWaylandWindow</a></div><div class="ttdeci">struct wl_surface * glfwGetWaylandWindow(GLFWwindow *window)</div><div class="ttdoc">Returns the main struct wl_surface* of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga62d884114b0abfcdc2930e89f20867e2"><div class="ttname"><a href="group__native.html#ga62d884114b0abfcdc2930e89f20867e2">glfwGetGLXContext</a></div><div class="ttdeci">GLXContext glfwGetGLXContext(GLFWwindow *window)</div><div class="ttdoc">Returns the GLXContext of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga671c5072becd085f4ab5771a9c8efcf1"><div class="ttname"><a href="group__native.html#ga671c5072becd085f4ab5771a9c8efcf1">glfwGetEGLContext</a></div><div class="ttdeci">EGLContext glfwGetEGLContext(GLFWwindow *window)</div><div class="ttdoc">Returns the EGLContext of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga6b64039ffc88a7a2f57f0956c0c75d53"><div class="ttname"><a href="group__native.html#ga6b64039ffc88a7a2f57f0956c0c75d53">glfwGetOSMesaDepthBuffer</a></div><div class="ttdeci">int glfwGetOSMesaDepthBuffer(GLFWwindow *window, int *width, int *height, int *bytesPerValue, void **buffer)</div><div class="ttdoc">Retrieves the depth buffer associated with the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga6e7822385cc8a1cc3b18f60352830189"><div class="ttname"><a href="group__native.html#ga6e7822385cc8a1cc3b18f60352830189">glfwGetX11Display</a></div><div class="ttdeci">Display * glfwGetX11Display(void)</div><div class="ttdoc">Returns the Display used by GLFW.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga90ca676322740842db446999a1b1f21d"><div class="ttname"><a href="group__native.html#ga90ca676322740842db446999a1b1f21d">glfwGetX11Window</a></div><div class="ttdeci">Window glfwGetX11Window(GLFWwindow *window)</div><div class="ttdoc">Returns the Window of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_ga9e47700080094eb569cb053afaa88773"><div class="ttname"><a href="group__native.html#ga9e47700080094eb569cb053afaa88773">glfwGetOSMesaContext</a></div><div class="ttdeci">OSMesaContext glfwGetOSMesaContext(GLFWwindow *window)</div><div class="ttdoc">Returns the OSMesaContext of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gab2f8cc043905e9fa9b12bfdbbcfe874c"><div class="ttname"><a href="group__native.html#gab2f8cc043905e9fa9b12bfdbbcfe874c">glfwGetX11Monitor</a></div><div class="ttdeci">RROutput glfwGetX11Monitor(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the RROutput of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gac3ed9d495d0c2bb9652de5a50c648715"><div class="ttname"><a href="group__native.html#gac3ed9d495d0c2bb9652de5a50c648715">glfwGetCocoaWindow</a></div><div class="ttdeci">id glfwGetCocoaWindow(GLFWwindow *window)</div><div class="ttdoc">Returns the NSWindow of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gac845f7dbe4c1d7fdd682a3c6fdae6766"><div class="ttname"><a href="group__native.html#gac845f7dbe4c1d7fdd682a3c6fdae6766">glfwGetWin32Monitor</a></div><div class="ttdeci">const char * glfwGetWin32Monitor(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the display device name of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gacbe11f93ce20621de82989bbba94e62a"><div class="ttname"><a href="group__native.html#gacbe11f93ce20621de82989bbba94e62a">glfwGetWaylandDisplay</a></div><div class="ttdeci">struct wl_display * glfwGetWaylandDisplay(void)</div><div class="ttdoc">Returns the struct wl_display* used by GLFW.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gad4d3e9242536c0ba6be88a98f4c73a41"><div class="ttname"><a href="group__native.html#gad4d3e9242536c0ba6be88a98f4c73a41">glfwGetWin32Adapter</a></div><div class="ttdeci">const char * glfwGetWin32Adapter(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the adapter device name of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gadc4010d91d9cc1134d040eeb1202a143"><div class="ttname"><a href="group__native.html#gadc4010d91d9cc1134d040eeb1202a143">glfwGetWGLContext</a></div><div class="ttdeci">HGLRC glfwGetWGLContext(GLFWwindow *window)</div><div class="ttdoc">Returns the HGLRC of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gae084ef64dc0db140b455b1427256d3f7"><div class="ttname"><a href="group__native.html#gae084ef64dc0db140b455b1427256d3f7">glfwGetX11SelectionString</a></div><div class="ttdeci">const char * glfwGetX11SelectionString(void)</div><div class="ttdoc">Returns the contents of the current primary selection as a string.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gaf22f429aec4b1aab316142d66d9be3e6"><div class="ttname"><a href="group__native.html#gaf22f429aec4b1aab316142d66d9be3e6">glfwGetCocoaMonitor</a></div><div class="ttdeci">CGDirectDisplayID glfwGetCocoaMonitor(GLFWmonitor *monitor)</div><div class="ttdoc">Returns the CGDirectDisplayID of the specified monitor.</div></div>
|
|
||||||
<div class="ttc" id="agroup__native_html_gafe5079aa79038b0079fc09d5f0a8e667"><div class="ttname"><a href="group__native.html#gafe5079aa79038b0079fc09d5f0a8e667">glfwGetWin32Window</a></div><div class="ttdeci">HWND glfwGetWin32Window(GLFWwindow *window)</div><div class="ttdoc">Returns the HWND of the specified window.</div></div>
|
|
||||||
<div class="ttc" id="agroup__window_html_ga3c96d80d363e67d13a41b5d1821f3242"><div class="ttname"><a href="group__window.html#ga3c96d80d363e67d13a41b5d1821f3242">GLFWwindow</a></div><div class="ttdeci">struct GLFWwindow GLFWwindow</div><div class="ttdoc">Opaque window object.</div><div class="ttdef"><b>Definition:</b> glfw3.h:1186</div></div>
|
|
||||||
</div><!-- fragment --></div><!-- contents -->
|
|
||||||
<address class="footer">
|
|
||||||
<p>
|
|
||||||
Last update on Thu Oct 28 2021 for GLFW 3.3.5
|
|
||||||
</p>
|
|
||||||
</address>
|
|
||||||
</body>
|
|
||||||
</html>
|
|