Config.Linux.pp 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. //
  2. // Config.Linux.pp
  3. //
  4. // This file defines some custom config variables for the Linux
  5. // platform. It makes some initial guesses about compiler features,
  6. // etc.
  7. //
  8. // *******************************************************************
  9. // NOTE: you should not attempt to copy this file verbatim as your own
  10. // personal Config.pp file. Instead, you should start with an empty
  11. // Config.pp file, and add lines to it when you wish to override
  12. // settings given in here. In the normal ppremake system, this file
  13. // will always be read first, and then your personal Config.pp file
  14. // will be read later, which gives you a chance to override the
  15. // default settings found in this file. However, if you start by
  16. // copying the entire file, it will be difficult to tell which
  17. // settings you have customized, and it will be difficult to upgrade
  18. // to a subsequent version of Panda.
  19. // *******************************************************************
  20. #define IS_LINUX 1
  21. // What additional flags should we pass to interrogate?
  22. #if $[eq $[shell uname -m], x86_64] // if Linux is 64bit
  23. #define SYSTEM_IGATE_FLAGS -D_LP64
  24. #else
  25. #define SYSTEM_IGATE_FLAGS -D__i386__ -D__const=const -Dvolatile -Dmutable
  26. #endif
  27. // Is the platform big-endian (like an SGI workstation) or
  28. // little-endian (like a PC)? Define this to the empty string to
  29. // indicate little-endian, or nonempty to indicate big-endian.
  30. #define WORDS_BIGENDIAN
  31. // Does the C++ compiler support namespaces?
  32. #define HAVE_NAMESPACE 1
  33. // Does the C++ compiler support ios::binary?
  34. #define HAVE_IOS_BINARY 1
  35. // How about the typename keyword?
  36. #define HAVE_TYPENAME 1
  37. // Will the compiler avoid inserting extra bytes in structs between a
  38. // base struct and its derived structs? It is safe to define this
  39. // false if you don't know, but if you know that you can get away with
  40. // this you may gain a tiny performance gain by defining this true.
  41. // If you define this true incorrectly, you will get lots of
  42. // assertion failures on execution.
  43. #define SIMPLE_STRUCT_POINTERS
  44. // Do we have a gettimeofday() function?
  45. #define HAVE_GETTIMEOFDAY 1
  46. // Does gettimeofday() take only one parameter?
  47. #define GETTIMEOFDAY_ONE_PARAM
  48. // Do we have getopt() and/or getopt_long_only() built into the
  49. // system?
  50. #define HAVE_GETOPT 1
  51. #define HAVE_GETOPT_LONG_ONLY 1
  52. // Are the above getopt() functions defined in getopt.h, or somewhere else?
  53. #define HAVE_GETOPT_H 1
  54. // Can we determine the terminal width by making an ioctl(TIOCGWINSZ) call?
  55. #define IOCTL_TERMINAL_WIDTH 1
  56. // Do the system headers define a "streamsize" typedef? How about the
  57. // ios::binary enumerated value? And other ios typedef symbols like
  58. // ios::openmode and ios::fmtflags?
  59. #define HAVE_STREAMSIZE 1
  60. #define HAVE_IOS_BINARY 1
  61. #define HAVE_IOS_TYPEDEFS 1
  62. // Can we safely call getenv() at static init time?
  63. #define STATIC_INIT_GETENV 1
  64. // Can we read the file /proc/self/environ to determine our
  65. // environment variables at static init time?
  66. #define HAVE_PROC_SELF_ENVIRON 1
  67. // Do we have a global pair of argc/argv variables that we can read at
  68. // static init time? Should we prototype them? What are they called?
  69. #define HAVE_GLOBAL_ARGV
  70. #define PROTOTYPE_GLOBAL_ARGV
  71. #define GLOBAL_ARGV
  72. #define GLOBAL_ARGC
  73. // Can we read the file /proc/self/cmdline to determine our
  74. // command-line arguments at static init time?
  75. #define HAVE_PROC_SELF_CMDLINE 1
  76. // Should we include <iostream> or <iostream.h>? Define HAVE_IOSTREAM
  77. // to nonempty if we should use <iostream>, or empty if we should use
  78. // <iostream.h>.
  79. #define HAVE_IOSTREAM 1
  80. // Do we have a true stringstream class defined in <sstream>?
  81. #define HAVE_SSTREAM 1
  82. // Does fstream::open() require a third parameter, specifying the
  83. // umask? Versions of gcc prior to 3.2 had this.
  84. #define HAVE_OPEN_MASK
  85. // Do the compiler or system libraries define wchar_t for you?
  86. #define HAVE_WCHAR_T 1
  87. // Does <string> define the typedef wstring? Most do, but for some
  88. // reason, versions of gcc before 3.0 didn't do this.
  89. #define HAVE_WSTRING 1
  90. // Do we have <new>?
  91. #define HAVE_NEW 1
  92. // Do we have <io.h>?
  93. #define HAVE_IO_H
  94. // Do we have <malloc.h>?
  95. #define HAVE_MALLOC_H 1
  96. // Do we have <alloca.h>?
  97. #define HAVE_ALLOCA_H 1
  98. // Do we have <locale.h>?
  99. #define HAVE_LOCALE_H 1
  100. // Do we have <string.h>?
  101. #define HAVE_STRING_H 1
  102. // Do we have <stdlib.h>?
  103. #define HAVE_STDLIB_H 1
  104. // Do we have <limits.h>?
  105. #define HAVE_LIMITS_H 1
  106. // Do we have <minmax.h>?
  107. #define HAVE_MINMAX_H
  108. // Do we have <sys/types.h>?
  109. #define HAVE_SYS_TYPES_H 1
  110. #define HAVE_SYS_TIME_H 1
  111. // Do we have <unistd.h>?
  112. #define HAVE_UNISTD_H 1
  113. // Do we have <utime.h>?
  114. #define HAVE_UTIME_H 1
  115. // Do we have <dirent.h>?
  116. #define HAVE_DIRENT_H 1
  117. // Do we have <glob.h> (and do we want to use it instead of dirent.h)?
  118. #define HAVE_GLOB_H 1
  119. // Do we have <sys/soundcard.h> (and presumably a Linux-style audio
  120. // interface)?
  121. #define HAVE_SYS_SOUNDCARD_H 1
  122. // Do we have <ucontext.h> (and therefore makecontext() / swapcontext())?
  123. #define HAVE_UCONTEXT_H 1
  124. // Do we have RTTI (and <typeinfo>)?
  125. #define HAVE_RTTI 1
  126. // We need 64-bit file i/o
  127. #define __USE_LARGEFILE64 1
  128. // Modern versions of gcc do support the latest STL allocator
  129. // definitions.
  130. #define USE_STL_ALLOCATOR 1
  131. // The dynamic library file extension (usually .so .dll or .dylib):
  132. #define DYNAMIC_LIB_EXT .so
  133. #define BUNDLE_EXT