blob: 30c8a921d2bab24a8b8c051019f2a02b89fc1d8a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
# This option allows deactivating FreeRDP supplied platform defauts to replace these with
# user supplied values.
#
# Compilation will fail without a replacement defining the symbols, but that can be
# done by supplying a TOOLCHAIN_FILE defining these.
option(USE_PLATFORM_DEFAULT "Use this configuration file for platform defaults. Supply -DCMAKE_TOOLCHAIN_FILE=<yourfile>." ON)
if (USE_PLATFORM_DEFAULT)
# default defines or other required preferences per platform
if((CMAKE_SYSTEM_NAME MATCHES "WindowsStore") AND (CMAKE_SYSTEM_VERSION MATCHES "10.0"))
set(UWP 1 CACHE BOOL "platform default")
add_definitions("-D_UWP")
set(CMAKE_WINDOWS_VERSION "WIN10" CACHE STRING "platform default")
endif()
if("${CMAKE_SYSTEM_NAME}" MATCHES "Linux")
# Linux already does define _POSIX_C_SOURCE by default, nothing to do
add_definitions("-D_FILE_OFFSET_BITS=64")
set(WINPR_TIMEZONE_FILE "/etc/timezone")
endif()
if("${CMAKE_SYSTEM_NAME}" MATCHES "FreeBSD")
set(BSD TRUE CACHE INTERNAL "platform default")
set(FREEBSD TRUE CACHE INTERNAL "platform default")
# we want POSIX 2008. FreeBSD 14 does only support 2001 fully, but the subset we require from 2008
# is implemented, so ignore _POSIX_VERSION from unistd.h
add_definitions("-D_POSIX_C_SOURCE=200809L")
# TODO: FreeBSD allows mixing POSIX and BSD API calls if we do not set
# _POSIX_C_SOURCE but lack a macro to reenable the BSD calls...
add_definitions("-D__BSD_VISIBLE")
# There are some symbols only visible for XOpen standard
add_definitions("-D_XOPEN_SOURCE=700")
add_definitions("-D_FILE_OFFSET_BITS=64")
set(WINPR_TIMEZONE_FILE "/var/db/zoneinfo")
endif()
if("${CMAKE_SYSTEM_NAME}" MATCHES "SunOS")
# TODO: Does somebody still use this? please show yourself and
# tell us if this still works.
add_definitions("-D_POSIX_PTHREAD_SEMANTICS")
list(APPEND CMAKE_STANDARD_LIBRARIES rt)
set(CMAKE_STANDARD_LIBRARIES ${CMAKE_STANDARD_LIBRARIES} CACHE STRING "platform default")
set(WITH_SUN true CACHE BOOL "platform default")
endif()
if("${CMAKE_SYSTEM_NAME}" MATCHES "Darwin")
# we want POSIX 2008. MacOS does only support 2001 fully, but the subset we require from 2008
# is implemented, so ignore _POSIX_VERSION from unistd.h
add_definitions("-D_POSIX_C_SOURCE=200809L")
# as _POSIX_C_SOURCE sets a fully POSIX confirmant environment reenable
# MacOS API visibility by defining the following feature test macro
add_definitions("-D_DARWIN_C_SOURCE")
endif()
if(${CMAKE_SYSTEM_NAME} MATCHES "kFreeBSD")
set(BSD TRUE CACHE INTERNAL "platform default")
set(KFREEBSD TRUE CACHE INTERNAL "platform default")
add_definitions(-DKFREEBSD)
add_definitions("-D_GNU_SOURCE")
endif()
if(${CMAKE_SYSTEM_NAME} MATCHES "OpenBSD")
set(BSD TRUE CACHE INTERNAL "platform default")
set(OPENBSD TRUE CACHE INTERNAL "platform default")
endif()
if(${CMAKE_SYSTEM_NAME} MATCHES "DragonFly")
set(BSD TRUE CACHE INTERNAL "platform default")
set(FREEBSD TRUE CACHE INTERNAL "platform default")
# we want POSIX 2008. FreeBSD 14 does only support 2001 fully, but the subset we require from 2008
# is implemented, so ignore _POSIX_VERSION from unistd.h
add_definitions("-D_POSIX_C_SOURCE=200809L")
# TODO: FreeBSD allows mixing POSIX and BSD API calls if we do not set
# _POSIX_C_SOURCE but lack a macro to reenable the BSD calls...
add_definitions("-D__BSD_VISIBLE")
# There are some symbols only visible for XOpen standard
add_definitions("-D_XOPEN_SOURCE=700")
add_definitions("-D_FILE_OFFSET_BITS=64")
set(WINPR_TIMEZONE_FILE "/var/db/zoneinfo")
endif()
if(BSD)
if(IS_DIRECTORY /usr/local/include)
include_directories(/usr/local/include)
link_directories(/usr/local/lib)
endif()
if(OPENBSD)
if(IS_DIRECTORY /usr/X11R6/include)
include_directories(/usr/X11R6/include)
endif()
endif()
endif()
# define a fallback for systems that do not support a timezone file or we did not yet test.
# since most of these are BSD try a sensible default
if (NOT WINPR_TIMEZONE_FILE)
set(WINPR_TIMEZONE_FILE "/var/db/zoneinfo")
endif()
add_definitions("-DWINPR_TIMEZONE_FILE=\"${WINPR_TIMEZONE_FILE}\"")
endif()
|