4 # Generic mechanism to deal with WITH and WITHOUT options and turn
5 # them into MK_ options.
7 # For each option FOO in __DEFUALT_YES_OPTIONS, MK_FOO is set to
8 # "yes", unless WITHOUT_FOO is defined, in which case it is set to
11 # For each option FOO in __DEFUALT_NO_OPTIONS, MK_FOO is set to "no",
12 # unless WITH_FOO is defined, in which case it is set to "yes".
14 # If both WITH_FOO and WITHOUT_FOO are defined, WITHOUT_FOO wins and
15 # MK_FOO is set to "no" regardless of which list it was in.
17 # Both __DEFAULT_YES_OPTIONS and __DEFAULT_NO_OPTIONS are undef'd
18 # after all this processing, allowing this file to be included
19 # multiple times with different lists.
21 # Users should generally define WITH_FOO or WITHOUT_FOO, but the build
22 # system should use MK_FOO={yes,no} when it needs to override the
23 # user's desires or default behavior.
27 # MK_* options which default to "yes".
29 .for var in ${__DEFAULT_YES_OPTIONS}
30 .if !defined(MK_${var})
31 .if defined(WITHOUT_${var}) # WITHOUT always wins
38 .undef __DEFAULT_YES_OPTIONS
41 # MK_* options which default to "no".
43 .for var in ${__DEFAULT_NO_OPTIONS}
44 .if !defined(MK_${var})
45 .if defined(WITH_${var}) && !defined(WITHOUT_${var}) # WITHOUT always wins
52 .undef __DEFAULT_NO_OPTIONS