diff options
author | Jose <jose@zeroc.com> | 2012-07-17 16:53:05 +0200 |
---|---|---|
committer | Jose <jose@zeroc.com> | 2012-07-17 16:53:05 +0200 |
commit | 9e833a51504b14ac852863dcad59a51e6025ce79 (patch) | |
tree | 6ca0297b6e6575fe4c6b2d48b606fef8132b9e5a /cpp/src/IceUtil/UUID.cpp | |
parent | implementing optional params in Java (diff) | |
parent | WinRT support (diff) | |
download | ice-9e833a51504b14ac852863dcad59a51e6025ce79.tar.bz2 ice-9e833a51504b14ac852863dcad59a51e6025ce79.tar.xz ice-9e833a51504b14ac852863dcad59a51e6025ce79.zip |
Merge branch 'master' into encoding11
Conflicts:
CHANGES
cpp/src/Ice/EndpointI.cpp
cpp/src/Ice/TcpConnector.cpp
cpp/src/Ice/TcpConnector.h
cpp/src/Ice/UdpConnector.cpp
cpp/src/Ice/UdpConnector.h
Diffstat (limited to 'cpp/src/IceUtil/UUID.cpp')
-rw-r--r-- | cpp/src/IceUtil/UUID.cpp | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/cpp/src/IceUtil/UUID.cpp b/cpp/src/IceUtil/UUID.cpp index 9fe8f703498..cb2d77a1992 100644 --- a/cpp/src/IceUtil/UUID.cpp +++ b/cpp/src/IceUtil/UUID.cpp @@ -14,17 +14,18 @@ // (/dev/random) to generate "version 4" UUIDs, as described in // http://www.ietf.org/internet-drafts/draft-mealling-uuid-urn-00.txt +#include <IceUtil/Random.h> + #ifdef _WIN32 # include <rpc.h> #else -# include <IceUtil/Random.h> # include <sys/types.h> # include <unistd.h> #endif using namespace std; -#ifndef _WIN32 +#if defined(ICE_OS_WINRT) || !defined(_WIN32) namespace { @@ -45,7 +46,11 @@ public: PidInitializer() { +#ifndef _WIN32 pid_t p = getpid(); +#else + int p = GetCurrentProcessId(); +#endif myPid[0] = (p >> 8) & 0x7F; myPid[1] = p & 0xFF; } @@ -87,15 +92,22 @@ inline void bytesToHex(unsigned char* bytes, size_t len, char*& hexBuffer) string IceUtil::generateUUID() { -#ifdef _WIN32 +#if defined(_WIN32) && !defined(ICE_OS_WINRT) UUID uuid; - UuidCreate(&uuid); + RPC_STATUS ret = UuidCreate(&uuid); + if(ret != RPC_S_OK && ret != RPC_S_UUID_LOCAL_ONLY && ret != RPC_S_UUID_NO_ADDRESS) + { + throw new SyscallException(__FILE__, __LINE__, GetLastError()); + } unsigned char* str; - UuidToString(&uuid, &str); - + ret = UuidToString(&uuid, &str); + if(ret != RPC_S_OK) + { + throw new SyscallException(__FILE__, __LINE__, GetLastError()); + } string result = reinterpret_cast<char*>(str); RpcStringFree(&str); |