summaryrefslogtreecommitdiff
path: root/ACE/ace/OS_NS_stdlib.cpp
diff options
context:
space:
mode:
authorOssama Othman <ossama-othman@users.noreply.github.com>2007-02-15 20:10:26 +0000
committerOssama Othman <ossama-othman@users.noreply.github.com>2007-02-15 20:10:26 +0000
commit7517131e44bad6c3682f92d26473d554bd7bd202 (patch)
tree33eae6ec3e5b611d7ec67d385c0aa097680d0ba2 /ACE/ace/OS_NS_stdlib.cpp
parent57d4693816bf895897367503d82dd1499f9b1379 (diff)
downloadATCD-7517131e44bad6c3682f92d26473d554bd7bd202.tar.gz
ChangeLogTag:Thu Feb 15 20:04:01 UTC 2007 Ossama Othman <ossama_othman at symantec dot com>
Diffstat (limited to 'ACE/ace/OS_NS_stdlib.cpp')
-rw-r--r--ACE/ace/OS_NS_stdlib.cpp14
1 files changed, 11 insertions, 3 deletions
diff --git a/ACE/ace/OS_NS_stdlib.cpp b/ACE/ace/OS_NS_stdlib.cpp
index cd2005eb041..2874bb2f337 100644
--- a/ACE/ace/OS_NS_stdlib.cpp
+++ b/ACE/ace/OS_NS_stdlib.cpp
@@ -27,6 +27,7 @@ ACE_RCSID (ace,
# include "ace/OS_NS_fcntl.h"
# include "ace/OS_NS_ctype.h"
# include "ace/OS_NS_sys_time.h"
+# include "ace/OS_NS_Thread.h"
# include "ace/Numeric_Limits.h"
#endif /* ACE_LACKS_MKSTEMP */
@@ -686,7 +687,9 @@ ACE_OS::mkstemp_emulation (ACE_TCHAR * s)
static unsigned int const NUM_CHARS = 6; // Do not change!
ACE_RANDR_TYPE seed =
- static_cast<ACE_RANDR_TYPE> (ACE_OS::gettimeofday ().msec ());
+ static_cast<ACE_RANDR_TYPE> (ACE_OS::gettimeofday ().msec ())
+ + static_cast<ACE_RANDR_TYPE> (ACE_OS::getpid ())
+ + static_cast<ACE_RANDR_TYPE> (ACE_OS::thr_self ());
// We only care about UTF-8 / ASCII characters in generated
// filenames. A UTF-16 or UTF-32 character could potentially cause
@@ -694,7 +697,12 @@ ACE_OS::mkstemp_emulation (ACE_TCHAR * s)
// greatly slowing down this mkstemp() implementation. It is more
// practical to limit the search space to UTF-8 / ASCII characters
// (i.e. 127 characters).
- static float const MAX_VAL =
+ //
+ // Note that we can't make this constant static since the compiler
+ // may not inline the return value of ACE_Numeric_Limits::max(),
+ // meaning multiple threads could potentially initialize this value
+ // in parallel.
+ float const MAX_VAL =
static_cast<float> (ACE_Numeric_Limits<char>::max ());
// Use high-order bits rather than low-order ones (e.g. rand() %
@@ -706,7 +714,7 @@ ACE_OS::mkstemp_emulation (ACE_TCHAR * s)
// e.g.: MAX_VAL * rand() / (RAND_MAX + 1.0)
// Factor out the constant coefficient.
- static float const coefficient =
+ float const coefficient =
static_cast<float> (MAX_VAL / (RAND_MAX + 1.0f));
// @@ These nested loops may be ineffecient. Improvements are