Commit 62d27b7a authored by Ian Barber's avatar Ian Barber

Merge pull request #273 from BoresExpress/wm5

Add WinCE support.
parents f9674308 318ba883
#if defined WINCE
//#include "..\..\include\zmq.h"
#include "..\..\src\err.hpp"
int errno;
int _doserrno;
int _sys_nerr;
char* error_desc_buff = NULL;
char* strerror(int errno)
{
if (NULL != error_desc_buff)
{
LocalFree(error_desc_buff);
error_desc_buff = NULL;
}
FormatMessage(
FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS | FORMAT_MESSAGE_ALLOCATE_BUFFER,
NULL,
errno,
0,
(LPTSTR)&error_desc_buff,
1024,
NULL
);
return error_desc_buff;
}
#endif
\ No newline at end of file
#ifndef ERRNO_H
#define ERRNO_H 1
//#define EPERM 1
//#define ENOENT 2
//#define ESRCH 3
#define EINTR 4
//#define EIO 5
//#define ENXIO 6
//#define E2BIG 7
//#define ENOEXEC 8
#define EBADF 9
//#define ECHILD 10
#define EAGAIN 11
//#define ENOMEM 12
//#define EACCES 13
#define EFAULT 14
//#define EOSERR 15 // rk
//#define EBUSY 16
//#define EEXIST 17
//#define EXDEV 18
//#define ENODEV 19
//#define ENOTDIR 20
//#define EISDIR 21
#define EINVAL 22
//#define ENFILE 23
#define EMFILE 24
//#define ENOTTY 25
//#define EFBIG 27
//#define ENOSPC 28
//#define ESPIPE 29
//#define EROFS 30
//#define EMLINK 31
//#define EPIPE 32
//#define EDOM 33
//#define ERANGE 34
//#define EDEADLK 36
//#define ENOSYS 37
#ifdef __cplusplus
extern "C" {
#endif
extern int errno;
extern int _doserrno;
extern int _sys_nerr;
char* strerror(int errno);
#define sys_nerr _sys_nerr
#ifdef __cplusplus
};
#endif
#endif
\ No newline at end of file
...@@ -282,6 +282,10 @@ ...@@ -282,6 +282,10 @@
RelativePath="..\..\..\src\err.cpp" RelativePath="..\..\..\src\err.cpp"
> >
</File> </File>
<File
RelativePath="..\errno.cpp"
>
</File>
<File <File
RelativePath="..\..\..\src\fq.cpp" RelativePath="..\..\..\src\fq.cpp"
> >
...@@ -528,6 +532,10 @@ ...@@ -528,6 +532,10 @@
RelativePath="..\..\..\src\err.hpp" RelativePath="..\..\..\src\err.hpp"
> >
</File> </File>
<File
RelativePath="..\errno.hpp"
>
</File>
<File <File
RelativePath="..\..\..\src\fd.hpp" RelativePath="..\..\..\src\fd.hpp"
> >
......
...@@ -27,7 +27,9 @@ ...@@ -27,7 +27,9 @@
extern "C" { extern "C" {
#endif #endif
#if !defined WINCE
#include <errno.h> #include <errno.h>
#endif
#include <stddef.h> #include <stddef.h>
#include <stdio.h> #include <stdio.h>
#if defined _WIN32 #if defined _WIN32
......
...@@ -27,8 +27,12 @@ ...@@ -27,8 +27,12 @@
#include <stddef.h> #include <stddef.h>
#if defined _MSC_VER #if defined _MSC_VER
#if defined WINCE
#include <cmnintrin.h>
#else
#include <intrin.h> #include <intrin.h>
#endif #endif
#endif
#if !defined ZMQ_HAVE_WINDOWS #if !defined ZMQ_HAVE_WINDOWS
#include <sys/time.h> #include <sys/time.h>
......
...@@ -202,9 +202,15 @@ const char *zmq::wsa_error_no (int no_) ...@@ -202,9 +202,15 @@ const char *zmq::wsa_error_no (int no_)
void zmq::win_error (char *buffer_, size_t buffer_size_) void zmq::win_error (char *buffer_, size_t buffer_size_)
{ {
DWORD errcode = GetLastError (); DWORD errcode = GetLastError ();
#if defined WINCE
DWORD rc = FormatMessage (FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS, NULL, errcode, MAKELANGID(LANG_NEUTRAL,
SUBLANG_DEFAULT), (LPWSTR)buffer_, buffer_size_ / sizeof(wchar_t), NULL );
#else
DWORD rc = FormatMessageA (FORMAT_MESSAGE_FROM_SYSTEM | DWORD rc = FormatMessageA (FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS, NULL, errcode, MAKELANGID(LANG_NEUTRAL, FORMAT_MESSAGE_IGNORE_INSERTS, NULL, errcode, MAKELANGID(LANG_NEUTRAL,
SUBLANG_DEFAULT), buffer_, (DWORD) buffer_size_, NULL ); SUBLANG_DEFAULT), buffer_, (DWORD) buffer_size_, NULL );
#endif
zmq_assert (rc); zmq_assert (rc);
} }
......
...@@ -26,7 +26,11 @@ ...@@ -26,7 +26,11 @@
#include "../include/zmq.h" #include "../include/zmq.h"
#include <assert.h> #include <assert.h>
#if defined WINCE
#include "..\builds\msvc\errno.hpp"
#else
#include <errno.h> #include <errno.h>
#endif
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
......
...@@ -23,7 +23,6 @@ ...@@ -23,7 +23,6 @@
#include "../include/zmq.h" #include "../include/zmq.h"
#include <string.h> #include <string.h>
#include <errno.h>
#include <stdlib.h> #include <stdlib.h>
#include <new> #include <new>
......
...@@ -238,7 +238,7 @@ int zmq::signaler_t::make_fdpair (fd_t *r_, fd_t *w_) ...@@ -238,7 +238,7 @@ int zmq::signaler_t::make_fdpair (fd_t *r_, fd_t *w_)
// two instances of the library don't accidentally create signaler // two instances of the library don't accidentally create signaler
// crossing the process boundary. // crossing the process boundary.
// We'll use named event object to implement the critical section. // We'll use named event object to implement the critical section.
HANDLE sync = CreateEvent (NULL, FALSE, TRUE, "zmq-signaler-port-sync"); HANDLE sync = CreateEvent (NULL, FALSE, TRUE, TEXT("zmq-signaler-port-sync"));
win_assert (sync != NULL); win_assert (sync != NULL);
// Enter the critical section. // Enter the critical section.
......
...@@ -29,8 +29,12 @@ ...@@ -29,8 +29,12 @@
#if defined ZMQ_HAVE_WINDOWS #if defined ZMQ_HAVE_WINDOWS
#include "windows.hpp" #include "windows.hpp"
#if defined _MSC_VER #if defined _MSC_VER
#if defined WINCE
#include <cmnintrin.h>
#else
#include <intrin.h> #include <intrin.h>
#endif #endif
#endif
#else #else
#include <unistd.h> #include <unistd.h>
#endif #endif
......
...@@ -27,7 +27,11 @@ ...@@ -27,7 +27,11 @@
extern "C" extern "C"
{ {
#if defined _WIN32_WCE
static DWORD thread_routine (LPVOID arg_)
#else
static unsigned int __stdcall thread_routine (void *arg_) static unsigned int __stdcall thread_routine (void *arg_)
#endif
{ {
zmq::thread_t *self = (zmq::thread_t*) arg_; zmq::thread_t *self = (zmq::thread_t*) arg_;
self->tfn (self->arg); self->tfn (self->arg);
...@@ -39,8 +43,13 @@ void zmq::thread_t::start (thread_fn *tfn_, void *arg_) ...@@ -39,8 +43,13 @@ void zmq::thread_t::start (thread_fn *tfn_, void *arg_)
{ {
tfn = tfn_; tfn = tfn_;
arg =arg_; arg =arg_;
#if defined WINCE
descriptor = (HANDLE) CreateThread (NULL, 0,
&::thread_routine, this, 0 , NULL);
#else
descriptor = (HANDLE) _beginthreadex (NULL, 0, descriptor = (HANDLE) _beginthreadex (NULL, 0,
&::thread_routine, this, 0 , NULL); &::thread_routine, this, 0 , NULL);
#endif
win_assert (descriptor != NULL); win_assert (descriptor != NULL);
} }
......
...@@ -170,7 +170,9 @@ ...@@ -170,7 +170,9 @@
#include <ws2tcpip.h> #include <ws2tcpip.h>
#include <ipexport.h> #include <ipexport.h>
#if !defined WINCE
#include <process.h> #include <process.h>
#endif
// In MinGW environment AI_NUMERICSERV is not defined. // In MinGW environment AI_NUMERICSERV is not defined.
#ifndef AI_NUMERICSERV #ifndef AI_NUMERICSERV
......
...@@ -65,7 +65,6 @@ struct iovec { ...@@ -65,7 +65,6 @@ struct iovec {
#include <string.h> #include <string.h>
#include <errno.h>
#include <stdlib.h> #include <stdlib.h>
#include <new> #include <new>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment