~ctwm/ctwm/trunk

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
#
# Compiler/stdlib feature checks for ctwm
#


# Expect and try to enforce a C99 capable compiler.  There doesn't seem
# an obvious way to be sure in a fully portable way, but we probably
# don't work well in places that compile with something other than a
# program called like 'cc', and a cc that supports C99 should accept -std
# calls, so that's good enough.  Lacking it is not (yet) a fatal error,
# but is a sign that it's a compiler or platform we're moving further
# away from.
#
# Known alternate spellings:
#   -xc99  (Sun C 5.10 SunOS_i386, sunstudio12.1, OpenIndiana)
include(CheckCCompilerFlag)
set(c99_flag_options -std=c99 -xc99)
foreach(_C99_FLAG ${c99_flag_options})
	# CheckCCompilerFlag calls into CheckCSourceCompiles, which won't do
	# anything if the result var is already set in the cache, so we have
	# to unset it.  Otherwise, the second and later invocations don't
	# actually do anything, and it'll never check any flag after the
	# first.
	unset(COMPILER_C99_FLAG CACHE)
	check_c_compiler_flag(${_C99_FLAG} COMPILER_C99_FLAG)
	if(COMPILER_C99_FLAG)
		set(C99_FLAG ${_C99_FLAG})
		break()
	endif(COMPILER_C99_FLAG)
endforeach(_C99_FLAG)
if(C99_FLAG)
	message(STATUS "Enabling C99 flag: ${C99_FLAG}")
	add_definitions(${C99_FLAG})
else()
	message(WARNING "Compiler doesn't support known C99 flag, "
			"building without it.")
endif(C99_FLAG)


# With -std=c99, GNU libc's includes get strict about what they export.
# Particularly, a lot of POSIX stuff doesn't get defined unless we
# explicitly ask for it.  Do our best at checking for what's there...
check_include_files(features.h HAS_FEATURES_H)
if(HAS_FEATURES_H)
	# Check if including it with our args sets __USE_ISOC99; that's a
	# sign it's what we're looking for here.
	check_symbol_exists(__USE_ISOC99 features.h SETS_USE_ISOC99)
	if(SETS_USE_ISOC99)
		# OK, it does.  Assume that's a good enough test that things are
		# acting as we expect.
		set(GLIBC_FEATURE_FLAGS
			"-D_POSIX_C_SOURCE=200809L"
			"-D_XOPEN_SOURCE=700"
			)
		# asprintf() seems to need _GNU_SOURCE; no other way to expose it
		# I can find.
		check_symbol_exists(__GNU_LIBRARY__ features.h SETS_GNU_LIBRARY)
		if(SETS_GNU_LIBRARY)
			list(APPEND GLIBC_FEATURE_FLAGS "-D_GNU_SOURCE")
		endif(SETS_GNU_LIBRARY)

		message(STATUS "Enabling glibc feature macros: ${GLIBC_FEATURE_FLAGS}")
		add_definitions(${GLIBC_FEATURE_FLAGS})
	endif()
endif(HAS_FEATURES_H)


# Some compilers (like Sun's) don't take -W flags for warnings.  Do a
# quick check with -Wall.  They're mostly for devs, so we don't care THAT
# much, I guess...  maybe we should be more thorough about checking the
# flags we use too, but worry about what when it becomes an issue.
check_c_compiler_flag("-Wall" COMPILER_TAKES_WALL)
if(NOT COMPILER_TAKES_WALL)
	message(STATUS "Compiler doesn't like -Wall, disabling warnings.")
	set(NO_WARNS 1)
endif(NOT COMPILER_TAKES_WALL)

if(NOT NO_WARNS)
	add_definitions(${STD_WARNS})
	message(STATUS "Enabling standard warnings.")
endif(NOT NO_WARNS)