Config.FreeBSD.pp 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. //
  2. // Config.FreeBSD.pp
  3. //
  4. // This file defines some custom config variables for the FreeBSD
  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. // What additional flags should we pass to interrogate?
  21. #define SYSTEM_IGATE_FLAGS -D__i386__ -D__const=const -D__LITTLE_ENDIAN__ -D__inline__=inline -D__GNUC__
  22. // Is the platform big-endian (like an SGI workstation) or
  23. // little-endian (like a PC)? Define this to the empty string to
  24. // indicate little-endian, or nonempty to indicate big-endian.
  25. #define WORDS_BIGENDIAN
  26. // Does the C++ compiler support namespaces?
  27. #define HAVE_NAMESPACE 1
  28. // Does the C++ compiler support ios::binary?
  29. #define HAVE_IOS_BINARY 1
  30. // How about the typename keyword?
  31. #define HAVE_TYPENAME 1
  32. // Will the compiler avoid inserting extra bytes in structs between a
  33. // base struct and its derived structs? It is safe to define this
  34. // false if you don't know, but if you know that you can get away with
  35. // this you may gain a tiny performance gain by defining this true.
  36. // If you define this true incorrectly, you will get lots of
  37. // assertion failures on execution.
  38. #define SIMPLE_STRUCT_POINTERS
  39. // Do we have a gettimeofday() function?
  40. #define HAVE_GETTIMEOFDAY 1
  41. // Does gettimeofday() take only one parameter?
  42. #define GETTIMEOFDAY_ONE_PARAM
  43. // Do we have getopt() and/or getopt_long_only() built into the
  44. // system?
  45. #define HAVE_GETOPT 1
  46. #define HAVE_GETOPT_LONG_ONLY
  47. // Are the above getopt() functions defined in getopt.h, or somewhere else?
  48. #define HAVE_GETOPT_H 1
  49. // Can we determine the terminal width by making an ioctl(TIOCGWINSZ) call?
  50. #define IOCTL_TERMINAL_WIDTH 1
  51. // Do the system headers define a "streamsize" typedef? How about the
  52. // ios::binary enumerated value? And other ios typedef symbols like
  53. // ios::openmode and ios::fmtflags?
  54. #define HAVE_STREAMSIZE 1
  55. #define HAVE_IOS_BINARY 1
  56. #define HAVE_IOS_TYPEDEFS 1
  57. // Can we safely call getenv() at static init time?
  58. #define STATIC_INIT_GETENV 1
  59. // Can we read the file /proc/self/environ to determine our
  60. // environment variables at static init time?
  61. #define HAVE_PROC_SELF_ENVIRON
  62. // Do we have a global pair of argc/argv variables that we can read at
  63. // static init time? Should we prototype them? What are they called?
  64. #define HAVE_GLOBAL_ARGV
  65. #define PROTOTYPE_GLOBAL_ARGV
  66. #define GLOBAL_ARGV
  67. #define GLOBAL_ARGC
  68. // Can we read the file /proc/self/cmdline to determine our
  69. // command-line arguments at static init time?
  70. #define HAVE_PROC_SELF_CMDLINE
  71. // Should we include <iostream> or <iostream.h>? Define HAVE_IOSTREAM
  72. // to nonempty if we should use <iostream>, or empty if we should use
  73. // <iostream.h>.
  74. #define HAVE_IOSTREAM 1
  75. // Do we have a true stringstream class defined in <sstream>?
  76. #define HAVE_SSTREAM 1
  77. // Does fstream::open() require a third parameter, specifying the
  78. // umask? Versions of gcc prior to 3.2 had this.
  79. #define HAVE_OPEN_MASK
  80. // Do the compiler or system libraries define wchar_t for you?
  81. #define HAVE_WCHAR_T 1
  82. // Does <string> define the typedef wstring? Most do, but for some
  83. // reason, versions of gcc before 3.0 didn't do this.
  84. #define HAVE_WSTRING 1
  85. // Do we have <new>?
  86. #define HAVE_NEW 1
  87. // Do we have <io.h>?
  88. #define HAVE_IO_H
  89. // Do we have <malloc.h>?
  90. //#define HAVE_MALLOC_H
  91. #define HAVE_SYS_MALLOC_H 1
  92. // Do we have <alloca.h>?
  93. #define HAVE_ALLOCA_H
  94. // Do we have <locale.h>?
  95. #define HAVE_LOCALE_H 1
  96. // Do we have <minmax.h>?
  97. #define HAVE_MINMAX_H
  98. // Do we have <sys/types.h>?
  99. #define HAVE_SYS_TYPES_H 1
  100. #define HAVE_SYS_TIME_H 1
  101. // Do we have <unistd.h>?
  102. #define HAVE_UNISTD_H 1
  103. // Do we have <utime.h>?
  104. #define HAVE_UTIME_H 1
  105. // Do we have <dirent.h>?
  106. #define HAVE_DIRENT_H 1
  107. // Do we have <glob.h> (and do we want to use it instead of dirent.h)?
  108. #define HAVE_GLOB_H 1
  109. // Do we have <sys/soundcard.h> (and presumably a Linux-style audio
  110. // interface)?
  111. #define HAVE_SYS_SOUNDCARD_H 1
  112. // Do we have RTTI (and <typeinfo>)?
  113. #define HAVE_RTTI 1
  114. #define HAVE_POSIX_THREADS 1
  115. // Must global operator new and delete functions throw exceptions?
  116. #define GLOBAL_OPERATOR_NEW_EXCEPTIONS 1
  117. // Modern versions of gcc do support the latest STL allocator
  118. // definitions.
  119. #define USE_STL_ALLOCATOR 1
  120. // The dynamic library file extension (usually .so .dll or .dylib):
  121. #define DYNAMIC_LIB_EXT .so
  122. #define PYTHON_IPATH /usr/local/include/python2.4
  123. #define PYTHON_LPATH /usr/local/lib/python2.4
  124. #define SSL_IPATH /usr/local/openssl
  125. //#define SSL_097 1
  126. #define JPEG_IPATH /usr/local/include
  127. #define JPEG_LPATH /usr/local/lib
  128. #define PNG_IPATH /usr/local/include
  129. #define PNG_LPATH /usr/local/lib
  130. #define TIFF_IPATH /usr/local/include
  131. #define TIFF_LPATH /usr/local/lib
  132. #define CC ccache cc
  133. #define CXX ccache c++
  134. //#define LOCAL_INCS /usr/local/include
  135. //#define LOCAL_LIBS /usr/local/lib
  136. //#defer ipath $[ipath] /usr/local/include
  137. //#defer lpath $[lpath] /usr/local/lib
  138. #defer EXTRA_IPATH $[EXTRA_IPATH] /usr/local/include
  139. #defer EXTRA_LPATH $[EXTRA_LPATH] /usr/local/lib
  140. //#defer alt_ipath $[alt_ipath] /usr/local/include
  141. //#defer alt_lpath $[alt_lpath] /usr/local/lib