Config.Win32.pp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. //
  2. // Config.Win32.pp
  3. //
  4. // This file defines some custom config variables for the Windows
  5. // platform, using MS VC++. It makes some initial guesses about
  6. // compiler features, 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 -longlong __int64 -D_X86_ -DWIN32_VC -D"_declspec(param)=" -D"__declspec(param)=" -D_near -D_far -D__near -D__far -D_WIN32 -D__stdcall -Dvolatile=
  22. // Additional flags to pass to the Tau instrumentor.
  23. #define TAU_INSTRUMENTOR_FLAGS -DTAU_USE_C_API -DPROFILING_ON -DWIN32_VC -D_WIN32 -D__cdecl= -D__stdcall= -D__fastcall= -D__i386 -D_MSC_VER=1310 -D_W64= -D_INTEGRAL_MAX_BITS=64 --exceptions --late_tiebreaker --no_class_name_injection --no_warnings --restrict --microsoft --new_for_init
  24. // Is the platform big-endian (like an SGI workstation) or
  25. // little-endian (like a PC)? Define this to the empty string to
  26. // indicate little-endian, or nonempty to indicate big-endian.
  27. #define WORDS_BIGENDIAN
  28. // Does the C++ compiler support namespaces?
  29. #define HAVE_NAMESPACE 1
  30. // Does the C++ compiler support ios::binary?
  31. #define HAVE_IOS_BINARY 1
  32. // How about the typename keyword?
  33. #define HAVE_TYPENAME 1
  34. // Will the compiler avoid inserting extra bytes in structs between a
  35. // base struct and its derived structs? It is safe to define this
  36. // false if you don't know, but if you know that you can get away with
  37. // this you may gain a tiny performance gain by defining this true.
  38. // If you define this true incorrectly, you will get lots of
  39. // assertion failures on execution.
  40. #define SIMPLE_STRUCT_POINTERS 1
  41. // Do we have a gettimeofday() function?
  42. #define HAVE_GETTIMEOFDAY
  43. // Does gettimeofday() take only one parameter?
  44. #define GETTIMEOFDAY_ONE_PARAM
  45. // Do we have getopt() and/or getopt_long_only() built into the
  46. // system?
  47. #define HAVE_GETOPT
  48. #define HAVE_GETOPT_LONG_ONLY
  49. // Are the above getopt() functions defined in getopt.h, or somewhere else?
  50. #define HAVE_GETOPT_H
  51. // Can we determine the terminal width by making an ioctl(TIOCGWINSZ) call?
  52. #define IOCTL_TERMINAL_WIDTH
  53. // Do the system headers define a "streamsize" typedef? How about the
  54. // ios::binary enumerated value? And other ios typedef symbols like
  55. // ios::openmode and ios::fmtflags?
  56. #define HAVE_STREAMSIZE 1
  57. #define HAVE_IOS_BINARY 1
  58. #define HAVE_IOS_TYPEDEFS 1
  59. // Can we safely call getenv() at static init time?
  60. #define STATIC_INIT_GETENV 1
  61. // Can we read the file /proc/self/environ to determine our
  62. // environment variables at static init time?
  63. #define HAVE_PROC_SELF_ENVIRON
  64. // Do we have a global pair of argc/argv variables that we can read at
  65. // static init time? Should we prototype them? What are they called?
  66. #define HAVE_GLOBAL_ARGV 1
  67. #define PROTOTYPE_GLOBAL_ARGV
  68. #define GLOBAL_ARGV __argv
  69. #define GLOBAL_ARGC __argc
  70. // Can we read the file /proc/self/cmdline to determine our
  71. // command-line arguments at static init time?
  72. #define HAVE_PROC_SELF_CMDLINE
  73. // Should we include <iostream> or <iostream.h>? Define HAVE_IOSTREAM
  74. // to nonempty if we should use <iostream>, or empty if we should use
  75. // <iostream.h>.
  76. #define HAVE_IOSTREAM 1
  77. // Do we have a true stringstream class defined in <sstream>?
  78. #define HAVE_SSTREAM 1
  79. // Does fstream::open() require a third parameter, specifying the
  80. // umask?
  81. #define HAVE_OPEN_MASK
  82. // Do the compiler or system libraries define wchar_t for you?
  83. #define HAVE_WCHAR_T 1
  84. // Does <string> define the typedef wstring? Most do, but for some
  85. // reason, versions of gcc before 3.0 didn't do this.
  86. #define HAVE_WSTRING 1
  87. // Do we have <new>?
  88. #define HAVE_NEW 1
  89. // Do we have <io.h>?
  90. #define HAVE_IO_H 1
  91. // Do we have <malloc.h>?
  92. #define HAVE_MALLOC_H 1
  93. // Do we have <alloca.h>?
  94. #define HAVE_ALLOCA_H
  95. // Do we have <locale.h>?
  96. #define HAVE_LOCALE_H
  97. // Do we have <minmax.h>?
  98. #define HAVE_MINMAX_H 1
  99. // Do we have <sys/types.h>?
  100. #define HAVE_SYS_TYPES_H 1
  101. #define HAVE_SYS_TIME_H
  102. // Do we have <unistd.h>?
  103. #define HAVE_UNISTD_H
  104. // Do we have <utime.h>?
  105. #define HAVE_UTIME_H
  106. // Do we have <dirent.h>?
  107. #define HAVE_DIRENT_H
  108. // Do we have <sys/soundcard.h> (and presumably a Linux-style audio
  109. // interface)?
  110. #define HAVE_SYS_SOUNDCARD_H
  111. // Do we have RTTI (and <typeinfo>)?
  112. #define HAVE_RTTI 1
  113. // Must global operator new and delete functions throw exceptions?
  114. #define GLOBAL_OPERATOR_NEW_EXCEPTIONS
  115. // MSVC7 does support the latest STL allocator definitions.
  116. #define USE_STL_ALLOCATOR 1
  117. // can Intel C++ build this directory successfully (if not, change CC to msvc)
  118. #define NOT_INTEL_BUILDABLE false
  119. // The dynamic library file extension (usually .so .dll or .dylib):
  120. #define DYNAMIC_LIB_EXT .dll
  121. #define BUNDLE_EXT