os_winphone8.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /*
  2. * Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
  3. * Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. */
  19. #ifndef __PJ_COMPAT_OS_WINPHONE8_H__
  20. #define __PJ_COMPAT_OS_WINPHONE8_H__
  21. /**
  22. * @file os_winphone8.h
  23. * @brief Describes Windows Phone 8 operating system family specifics.
  24. */
  25. #define PJ_OS_NAME "winphone8"
  26. #define WIN32_LEAN_AND_MEAN
  27. #define RPC_NO_WINDOWS_H
  28. #define PJ_WIN32_WINNT 0x0602 /*_WIN32_WINNT_WIN8*/
  29. #ifdef _WIN32_WINNT
  30. #undef _WIN32_WINNT
  31. #define _WIN32_WINNT PJ_WIN32_WINNT
  32. #endif
  33. #define PJ_HAS_ARPA_INET_H 0
  34. #define PJ_HAS_ASSERT_H 1
  35. #define PJ_HAS_CTYPE_H 1
  36. #define PJ_HAS_ERRNO_H 0 /* Must be zero, otherwise errno_test() fails. */
  37. #define PJ_HAS_LINUX_SOCKET_H 0
  38. #define PJ_HAS_MALLOC_H 1
  39. #define PJ_HAS_NETDB_H 0
  40. #define PJ_HAS_NETINET_IN_H 0
  41. #define PJ_HAS_NETINET_TCP_H 0
  42. #define PJ_HAS_SETJMP_H 1
  43. #define PJ_HAS_STDARG_H 1
  44. #define PJ_HAS_STDDEF_H 1
  45. #define PJ_HAS_STDIO_H 1
  46. #define PJ_HAS_STDLIB_H 1
  47. #define PJ_HAS_STRING_H 1
  48. #define PJ_HAS_SYS_IOCTL_H 0
  49. #define PJ_HAS_SYS_SELECT_H 0
  50. #define PJ_HAS_SYS_SOCKET_H 0
  51. #define PJ_HAS_SYS_TIME_H 0
  52. #define PJ_HAS_SYS_TIMEB_H 0 /* Doesn't have sys/timeb.h */
  53. #define PJ_HAS_SYS_TYPES_H 0 /* Doesn't have sys/types.h */
  54. #define PJ_HAS_TIME_H 1
  55. #define PJ_HAS_UNISTD_H 0
  56. #define PJ_HAS_MSWSOCK_H 1
  57. #define PJ_HAS_WINSOCK_H 0
  58. #define PJ_HAS_WINSOCK2_H 1
  59. #define PJ_SOCK_HAS_INET_ATON 0
  60. /* Set 1 if native sockaddr_in has sin_len member.
  61. * Default: 0
  62. */
  63. #define PJ_SOCKADDR_HAS_LEN 0
  64. /* Is errno a good way to retrieve OS errors? (no)
  65. */
  66. #define PJ_HAS_ERRNO_VAR 0
  67. /* When this macro is set, getsockopt(SOL_SOCKET, SO_ERROR) will return
  68. * the status of non-blocking connect() operation.
  69. */
  70. #define PJ_HAS_SO_ERROR 0
  71. /* This value specifies the value set in errno by the OS when a non-blocking
  72. * socket recv() or send() can not return immediately.
  73. */
  74. #define PJ_BLOCKING_ERROR_VAL WSAEWOULDBLOCK
  75. /* This value specifies the value set in errno by the OS when a non-blocking
  76. * socket connect() can not get connected immediately.
  77. */
  78. #define PJ_BLOCKING_CONNECT_ERROR_VAL WSAEWOULDBLOCK
  79. /**
  80. * If this macro is set, it tells select I/O Queue that select() needs to
  81. * be given correct value of nfds (i.e. largest fd + 1). This requires
  82. * select ioqueue to re-scan the descriptors on each registration and
  83. * unregistration.
  84. * If this macro is not set, then ioqueue will always give FD_SETSIZE for
  85. * nfds argument when calling select().
  86. *
  87. * Default: 0
  88. */
  89. #define PJ_SELECT_NEEDS_NFDS 0
  90. /* Endianness */
  91. #ifndef PJ_IS_LITTLE_ENDIAN
  92. # define PJ_IS_LITTLE_ENDIAN 1
  93. # define PJ_IS_BIG_ENDIAN 0
  94. #endif
  95. /* Default threading is enabled, unless it's overridden. */
  96. #ifndef PJ_HAS_THREADS
  97. # define PJ_HAS_THREADS (1)
  98. #endif
  99. #define PJ_HAS_HIGH_RES_TIMER 1
  100. #define PJ_HAS_MALLOC 1
  101. #define PJ_OS_HAS_CHECK_STACK 1
  102. #define PJ_ATOMIC_VALUE_TYPE long
  103. /* No console. */
  104. #define PJ_TERM_HAS_COLOR 0
  105. /* TlsAlloc() error value. */
  106. #ifndef TLS_OUT_OF_INDEXES
  107. #define TLS_OUT_OF_INDEXES 0xFFFFFFFF
  108. #endif
  109. /* No rdtsc */
  110. #define PJ_TIMESTAMP_USE_RDTSC 0
  111. /* Native string is Unicode. */
  112. #define PJ_NATIVE_STRING_IS_UNICODE 1
  113. /* If 1, use Read/Write mutex emulation for platforms that don't support it */
  114. #define PJ_EMULATE_RWMUTEX 1
  115. /* If 1, pj_thread_create() should enforce the stack size when creating
  116. * threads.
  117. * Default: 0 (let OS decide the thread's stack size).
  118. */
  119. #define PJ_THREAD_SET_STACK_SIZE 0
  120. /* If 1, pj_thread_create() should allocate stack from the pool supplied.
  121. * Default: 0 (let OS allocate memory for thread's stack).
  122. */
  123. #define PJ_THREAD_ALLOCATE_STACK 0
  124. #endif /* __PJ_COMPAT_OS_WINPHONE8_H__ */