Introduce platform_libs which is used for bmake
[ACE_TAO.git] / ACE / NEWS
blob02982c59a57f71ad7f4910ed8d6e64218f31a961
1 USER VISIBLE CHANGES BETWEEN ACE-7.1.4 and ACE-7.2.0
2 ====================================================
4 . ACE/TAO now require C++17 or newer
6 . Add support for Embarcadero C++ Builder bcc64x compiler
8 . Removed ace/Auto_Ptr.*, with C++17 std::auto_ptr is not
9   available anymore
11 USER VISIBLE CHANGES BETWEEN ACE-7.1.3 and ACE-7.1.4
12 ====================================================
14 . With g++ versions < 11 we default to C++17 as
15   minimum C++ standards level
17 USER VISIBLE CHANGES BETWEEN ACE-7.1.2 and ACE-7.1.3
18 ====================================================
20 . Fixed possible race conditions in extreme use case
21   in the barrier and future implementations
23 . Improve support for QNX 7.1 and FreeBSD
25 . Integrated debian packaging changes
27 USER VISIBLE CHANGES BETWEEN ACE-7.1.1 and ACE-7.1.2
28 ====================================================
30 . C++17 removed std::auto_ptr, updated ACE/TAO to not
31   use std::auto_ptr anymore and also not provide our
32   own auto_ptr. With C++17 ACE doesn't provide ACE_Auto_Ptr,
33   ACE_Auto_Basic_Ptr, ACE_Auto_Basic_Array_Ptr, ACE_Auto_Array_Ptr,
34   and ACE_auto_ptr_reset anymore, just use std::unique_ptr
36 . Add c++std which can be used in the platform_macros.GNU
37   to set the C++ revision to be used (results in -std= flag)
39 . Improve support for QNX 7.1
41 . Embarcadero C++ Builder enhancements
43 USER VISIBLE CHANGES BETWEEN ACE-7.1.0 and ACE-7.1.1
44 ====================================================
46 . Fixed shared memory leak by ACE_Shared_Memory_Pool
48 . Fixed ACE_INET_Addr::set when ACE_LACKS_GETSERVBYNAME has
49   been defined
51 USER VISIBLE CHANGES BETWEEN ACE-7.0.11 and ACE-7.1.0
52 =====================================================
54 . Removed support for Windows CE, OpenVMS, HPUX, AIX, RTEMS,
55   Pharlap, Solaris, and Visual Studio 2015
57 . ACE/TAO now require C++14 or newer
59 USER VISIBLE CHANGES BETWEEN ACE-7.0.10 and ACE-7.0.11
60 ======================================================
62 . Fixed some compiler warnings given by newer compilers
64 . Make use of noexcept instead of throw()
66 . Fixed a bug in ACE_Configuration_Heap with uses_wchar=1 builds
68 USER VISIBLE CHANGES BETWEEN ACE-7.0.9 and ACE-7.0.10
69 =====================================================
71 . Add missing resource files for several DLLs on Windows
73 . VxWorks runtime fixes
75 . Various cleanup and using more C++11 features
77 . Embarcadero C++ Builder 11.2 fixes
79 USER VISIBLE CHANGES BETWEEN ACE-7.0.8 and ACE-7.0.9
80 ====================================================
82 . Compile fixes for VxWorks 22.03
84 . Various cleanup
86 . Minor fixes
88 USER VISIBLE CHANGES BETWEEN ACE-7.0.7 and ACE-7.0.8
89 ====================================================
91 . Minor changes
93 USER VISIBLE CHANGES BETWEEN ACE-7.0.6 and ACE-7.0.7
94 ====================================================
96 . Minor changes
98 USER VISIBLE CHANGES BETWEEN ACE-7.0.5 and ACE-7.0.6
99 ====================================================
101 . Various cleanup and using more C++11 features
103 . Various packaging related fixes
105 USER VISIBLE CHANGES BETWEEN ACE-7.0.4 and ACE-7.0.5
106 ====================================================
108 . Initial not tested support for Visual Studio 2022
110 . Fixed compile errors when using Visual Studio 2019 with C++17
111   or C++20 support enabled
113 . Various cleanup and using more C++11 features
115 USER VISIBLE CHANGES BETWEEN ACE-7.0.3 and ACE-7.0.4
116 ====================================================
118 . Add support for Embarcadero C++ Builder 11.0 Alexandria using
119   the bcc32c compiler
121 . Allow ACE_Module and ACE_SOCK_Dgram_Mcast to be sub-classed
123 . Add ACE_SWAP_LONG_LONG byte swap macro for ACE_UINT64
125 . Improved ACE_Atomic implementation for g++
127 . Various cleanup and using more C++11 features
129 USER VISIBLE CHANGES BETWEEN ACE-7.0.2 and ACE-7.0.3
130 ====================================================
132 . The macro ACE_HAS_WIN32_STRUCTURAL_EXCEPTIONS has been renamed
133   to ACE_HAS_WIN32_STRUCTURED_EXCEPTIONS, update your code accordingly
135 . MinGW 2 has been deprecated
137 . ACE CDR supports (u)int8
139 . Use more C++11 features including using std alternatives
141 . Various cleanup
143 . Fix SocketConnect::ip_check() Concurrency and Too-Early Request Issues for Windows
145 . Make install: use relative links in prefix/share
147 USER VISIBLE CHANGES BETWEEN ACE-7.0.1 and ACE-7.0.2
148 ====================================================
150 . Fixed various warnings given by newer compilers
152 . Use more C++11 features
154 . Various cleanup
156 USER VISIBLE CHANGES BETWEEN ACE-7.0.0 and ACE-7.0.1
157 ====================================================
159 . Cleanup of ACE_* macros which are not used anymore
161 . Removed support for LynxOS 4 which has gcc3
163 . Make sure C++11 is enabled on MacOSX
165 USER VISIBLE CHANGES BETWEEN ACE-6.5.12 and ACE-7.0.0
166 =====================================================
168 . C++11 is now a mandatory compiler feature which is
169   required for ACE. Cleaned up part of the support for compilers
170   that lack C++11 support
172 . When valgrind is enabled we don't disable dlclose anymore,
173   this reduces the amount of leaks reported related to dlclose.
174   When you unload your shared libraries before the end of your program
175   you can use `--keep-debuginfo=yes` as valgrind options as alternative
176   or you can disable dlclose yourself by adding
177   `#define ACE_LACKS_DLCLOSE` to your ace/config.h file
179 . Removed `ACE_OS::readdir_r`. `readdir_r` was marked as depracated in glibc
180   and FreeBSD libc. Also removed `ACE_Dirent::read (ACE_DIRENT *, ACE_DIRENT **)`
181   which used it. `ACE_LACKS_READDIR_R` will now always be defined.
183 . Modernized part of the code using clang-type, added override, use nullptr,
184   use unique_ptr, remove redundant void, use bool, simplify boolean expressions,
185   make use of std::atomic, use using
187 . New Latest_ACE7TAO3_ branches which can be used to always checkout the
188   latest ACE7/TAO3 micro/minor release
190 . Android Support:
192   . `gnuace` no longer supports Android NDKs before r18. This means only clang
193     is now supported when building for Android.
195   . Support for building with the Android NDK r19 or later directly instead of
196     having to use a generated standalone toolchain. See `ACE-INSTALL.html` for
197     details. Using a standalone toolchain is still supported.
199   . Made it easier to use `gnuace`-built libraries in as imported libraries in
200     CMake-based Android Studio native projects.
202   . Removed support for old `ANDROID_ARCH` make variable. Replaced
203     `ANDROID_ABI` with `android_abi`, but kept the former as an alias of the
204     later for compatibility. Also will no longer default to 32-bit ARM, so
205     `android_abi` or `ANDROID_ABI` must be defined.
207   . As recommend by Google, building with neon support is now the default when
208     `android_abi` is `armeabi-v7a`. If support for these processors without
209     NEON extensions is needed, put `androind_neon := 0` in
210     `platform_macros.GNU`.
212   . As recommend by Google, `gnuace` will start using LLD, the LLVM linker,
213     instead of the default GNU linkers. If the NDK being used doesn't default
214     to LLD and you want to use the GNU linkers, put `androind_set_lld := 0` in
215     `platform_macros.GNU`.
217 . Removed support for the Alpha CPU
219 USER VISIBLE CHANGES BETWEEN ACE-6.5.11 and ACE-6.5.12
220 ======================================================
222 . Fixed some C++11 warnings
224 . Fixed compile problem on AIX
226 . Removed c++0x and c++1y as GNU make variables, use c++11 and c++14 as
227   alternatives
229 . Moved all CI builds to github actions
231 . Added ACE_GCC_NO_RETURN to fix fall through warnings
233 . Fix ACE_Thread_Manager::join memory leak and potential deadlock
235 USER VISIBLE CHANGES BETWEEN ACE-6.5.10 and ACE-6.5.11
236 ======================================================
238 . Latest_{Major,Minor,Micro,Beta} tags have been replaced with
239   branches because tags are not intended to move where branches are
241 . Removed emulated operations in ACE_OS which are not used anymore
243 . Resolved some compile warnings when using C++11 or newer
245 . Integrated debian packaging changes
247 . Visual Studio 2015 solutions are not part of the release
248   packaging anymore. When you require these you need to generate
249   them locally using MPC
251 . Improve multicast join by interface name on Windows
253 . Fixed ACE_INT64_FORMAT_SPECIFIER (and similar) preprocessor macros
254   on macOS (Apple-clang) with -std=c++11 or higher
256 . On Windows, use unnamed kernel objects (Events and Semaphores)
257   for thread-scoped reader-write mutexes in ACE_OS::rwlock_init
259 USER VISIBLE CHANGES BETWEEN ACE-6.5.9 and ACE-6.5.10
260 =====================================================
262 . Add support for Embarcadero C++ Builder 10.4 Sydney using the
263   classic compiler. ACE/TAO compile with the new 32/64 bit clang
264   compilers but runtime tests show several runtime problems which
265   makes them not safe to use
267 . Make a change in the ACE Process Manager to resolve an internal
268   compiler error with Visual Studio 2019 16.5.x compilers
270 . Android enhancements for if_nameindex
272 USER VISIBLE CHANGES BETWEEN ACE-6.5.8 and ACE-6.5.9
273 ====================================================
275 . On Windows, ACE no longer defines _WIN32_WINNT.  ACE wrappers for
276   if_nametoindex and if_indextoname are available if the version of the
277   Windows SDK supports them.
279 . IPv6 extended datagram receive info now supported on macOS.
281 . ACE_(U)INT8/16/32/64 map to (u)int8/16/32/64_t when C++11 has been
282   enabled.
284 . CDR_Base uses ACE_INT64 for LongLong, all old emulated support
285   has been removed
287 . Updated debian and rpm packaging support
289 USER VISIBLE CHANGES BETWEEN ACE-6.5.7 and ACE-6.5.8
290 ====================================================
292 . Added instructions to ACE-INSTALL.html for building ACE/TAO for Android on
293   Windows.
295 . Embarcadero C++ Builder Rio fixes
297 . Renamed `VERSION` file to `VERSION.txt` to avoid conflicting with the
298   `version` standard header.
300 USER VISIBLE CHANGES BETWEEN ACE-6.5.6 and ACE-6.5.7
301 ====================================================
303 . Fixed compile problem with glibc 2.30 and newer
305 . gnuace makefiles: Updated handling of generated files and
306   use requires/avoids to make postbuild steps conditional
308 . Removed references to the ACE_LACKS_MONOTONIC_TIME preprocessor macro because
309   it was equivalent to ACE_LACKS_CLOCK_MONOTONIC.
311 . Exposed support status of monotonic times features using preprocessor macros.
312   See "Testing for Monotonic Time Support" in docs/ACE-monotonic-timer.html for
313   details.
315 . Added support for ARM and ARM64 stack traces with Microsoft Visual C++.
317 . The "optional argument for the receive address in ACE_SOCK_Dgram::recv"
318   feature from ACE-6.5.5 is now supported on Windows.  This includes enhanced
319   support for sendmsg/recvmsg on Windows.
321 USER VISIBLE CHANGES BETWEEN ACE-6.5.5 and ACE-6.5.6
322 ====================================================
324 . On Linux, the ACE_Log_Msg format specifier `%t` is now replaced with the
325   system thread id provided by gettid(), instead of the much longer pthread id.
327 . Added support for MQX
329 . Enhanced Android support
331 USER VISIBLE CHANGES BETWEEN ACE-6.5.4 and ACE-6.5.5
332 ====================================================
334 . Fixed several broken links due to the removal of
335   Douglas Schmidt website at WashU
337 . On Android:
339   . ACE_Log_Msg (and therefore ACE_DEBUG and ACE_ERROR) now uses
340     Android's logging system (aka Logcat) by default in addition to stderr
341     because stdout and stderr are discarded under normal circumstances.
342     To disable this at runtime, run:
343       ACE_LOG_MSG->clr_flags (ACE_Log_Msg::SYSLOG)
344     To disable this at compile time include these lines in config.h:
345       #define ACE_DEFAULT_LOG_FLAGS ACE_Log_Msg::STDERR
346       #define ACE_DEFAULT_LOG_BACKEND_FLAGS 0
348   . When statically linking to OpenSSL, prevent usage of the preloaded and
349     unpredictable system SSL library when using ace_openssl.
351 . minizip has been moved from ACE to DANCE
353 . Add initial support for Visual Studio 2019
355 . Validated ACE for usage SLES15.0 x86_64 using 32bit g++ compiler
357 . Add optional argument for the receive address in ACE_SOCK_Dgram::recv
359 USER VISIBLE CHANGES BETWEEN ACE-6.5.3 and ACE-6.5.4
360 ====================================================
362 . Fix ACE_Vector::end(), which now correctly
363   represents the end of the elements of the vector
364   instead of the end of the base array.
366 USER VISIBLE CHANGES BETWEEN ACE-6.5.2 and ACE-6.5.3
367 ====================================================
369 . Enhance Android support
371 . Fix AIX and Solaris linking rpath errors
373 . Add support for SSL_INCDIR/SSL_LIBDIR and XERCESC_INCDIR/XERCESC_LIBDIR
374   to specify a custom include/lib dir as required for vcpkg versions of
375   openssl/xercesc
377 USER VISIBLE CHANGES BETWEEN ACE-6.5.1 and ACE-6.5.2
378 ====================================================
380 . Enhanced C++Builder XE2 support
382 . ACE_QtReactor can be built with Qt version 5 using the qt5 MPC feature
384 USER VISIBLE CHANGES BETWEEN ACE-6.5.0 and ACE-6.5.1
385 ====================================================
387 . At the moment C++11 or newer is enabled ACE_Strong_Bound_Ptr
388   doesn't provide the convenience functions to use a
389   std::auto_ptr anymore
391 . Optimized CDR std::(w)string insertion and extraction
392   when C++11 or newer is enabled
394 . Solved Visual Studio 2017 solution loading due to duplicate
395   files generated in a project file
397 USER VISIBLE CHANGES BETWEEN ACE-6.4.8 and ACE-6.5.0
398 ====================================================
400 . The ACE core libraries now use std::unique_ptr instead
401   of std::auto_ptr when C++11 or newer is enabled
403 USER VISIBLE CHANGES BETWEEN ACE-6.4.7 and ACE-6.4.8
404 ====================================================
406 . Enhanced Embarcadero C++ Builder support
408 . ACE XML_Utils enhancements
410 . Debian packaging enhancements
412 . Support for clang6 and gcc8
414 . Enhanced Android support
416 . Remove addr_any restriction from ipv6_only UDP
418 USER VISIBLE CHANGES BETWEEN ACE-6.4.6 and ACE-6.4.7
419 ====================================================
421 . Added a new, optional argument named ipv6_only to:
422     ACE_Acceptor::ACE_Acceptor
423     ACE_Acceptor::open
424     ACE_SOCK_Dgram::ACE_SOCK_Dgram
425     ACE_SOCK_Dgram::open
426   If ipv6_only is 0/false (the default) the socket will accept
427   both IPv6 and IPv4 connections/datagrams. If ipv6_only is
428   1/true the socket will only accept IPv6.
429   This behavior only applies when ACE_HAS_IPV6 is true and the
430   local-side IP address is the generic localhost IP address.
432 . Integrated some changes from XSC into XML Utils
434 . Enable ACE_HAS_CPP11 when we have clang with C++11 enabled
436 . Added support for cross compiling using MinGW on a Linux host
438 . Added support for FreeBSD 11
440 . Fixed issue ACE_Singleton was broken after ACE::fini, ACE::init (GitHub #554)
442 USER VISIBLE CHANGES BETWEEN ACE-6.4.5 and ACE-6.4.6
443 ====================================================
445 . Fixed some Codacy and C++ Core guidelines reported issues
447 . VxWorks 7 (SR0510) support
449 . Support make install on newer Apple MacOS versions
451 USER VISIBLE CHANGES BETWEEN ACE-6.4.4 and ACE-6.4.5
452 ====================================================
454 . Add support for OpenSSL 1.1. ACE users on Windows have
455   to add openssl11=1 to their default.features file so
456   that the correct OpenSSL library names are used.
458 USER VISIBLE CHANGES BETWEEN ACE-6.4.3 and ACE-6.4.4
459 ====================================================
461 . Enhanced support for Embarcadero C++ Builder 10.2 (Tokyo).
462   Support for bcc32/bcc64/bcc32c has been enhanced and by
463   default the clang based versions are used. When the old
464   bcc32 has to be used set the CLASSIC environment variable
465   to 1. At this moment runtime test results for bcc64/bcc32c
466   show some structural problems
468 . Add support for Oracle Studio 12.5
470 . Removed usage of ACE_REGISTER and register keyword because
471   they trigger deprecated warnings with newer gcc and clang
472   versions
474 . Add support for gcc 7
476 . Enhanced Android support
478 . Fix ACE_INET_Addr::set(domain_name, AF_UNSPEC) to be set to IPv4 address
479   when IPv6 is enabled and the domain_name could be resolved to IPv4 address.
481 USER VISIBLE CHANGES BETWEEN ACE-6.4.2 and ACE-6.4.3
482 ====================================================
484 . Enhancements for Visual Studio 2017
486 . Enhancements for Android
488 USER VISIBLE CHANGES BETWEEN ACE-6.4.1 and ACE-6.4.2
489 ====================================================
491 . Added support for Mac OS X on x86_64 to get the network adapter
492   address in ACE_OS::getmacaddress().
494 . Added support for the December 2016 updates to VxWorks 7.
496 USER VISIBLE CHANGES BETWEEN ACE-6.4.0 and ACE-6.4.1
497 ====================================================
499 . The ACE_DEBUG environment variable can again be used to set the
500   internal debug flag.  This used to work but was mistakenly changed
501   in an earlier release.
503 . Corrected usage of ACE_Singleton and template instantation to be
504   valid C++ (GCC cross-compiler arm-linux-gnueabihf-g++ requires it).
506 . Added support for detecting the Mac OS X version when configured with
507   ace/config-macosx.h and include/makeinclude/platform_macosx.GNU.
508   Also on 10.11 El Capitan, use rpath to avoid a problem with SIP.
510 . Added support for Android NDK r12b (Platform API 24) and improved
511   cross compilation support
513 USER VISIBLE CHANGES BETWEEN ACE-6.3.4 and ACE-6.4.0
514 ====================================================
516 . Added support for obtaining the micro version number
518 . Reduced include of ace/Auto_Ptr.h in header files
520 USER VISIBLE CHANGES BETWEEN ACE-6.3.3 and ACE-6.3.4
521 ====================================================
523 . ACE_SSL_Context::set_mode() can no longer be used to select a specific
524   SSL/TLS protocol version, use ACE_SSL_Context::filter_versions() for that.
525   This follows general advice by the OpenSSL project to go through
526   SSL_CTX_set_options() to limit the list of protocols available. The purpose
527   of ACE_SSL_Context::set_mode() is now limited to explicitly restricting
528   behaviour to client or server (defaults to both).
530 . Improve Oracle Studio support
532 . CIAO and DAnCE are forked to their own github repositories
533   and are not part anymore of the ACE+TAO release packages
535 . Fixed several Coverity reported issues
537 . Added ACE configuration for FACE safety profiles (see config-face-safety.h).
538   FACE, or Future Airborne Capability Environment http://www.opengroup.org/face,
539   specifies a restricted subset of OS functions and rules for controlling
540   dynamic memory allocation.  When built in this configuration on a platform
541   that supports it, ACE conforms to the FACE requirements.
543 . ACE uses new netdb.h functions (getaddrinfo/getnameinfo) if they are
544   available, in place of deprecated functions (gethostbyname/addr).
546 USER VISIBLE CHANGES BETWEEN ACE-6.3.2 and ACE-6.3.3
547 ====================================================
549 . Visual Studio 2015 has adequate C++11 support, because of this
550   ACE_HAS_CPP11 is now defined with this compiler. A large amount
551   of warnings given by this new compiler have been fixed
553 . As part of the release script we generate vc12 and vc14
554   solution files which are packaged as part of the release
556 . Added support for VxWorks 7 (kernel mode and RTP).
557   See the comments in include/makeinclude/platform_vxworks7.0.GNU for details.
559 . Ended daily maintenance for OpenVMS
561 . Fixed a defect in ACE_INET_Addr when there is a non-empty interface
562   address list and set_port_number() is called.
564 USER VISIBLE CHANGES BETWEEN ACE-6.3.1 and ACE-6.3.2
565 ====================================================
567 . Added support for std::chrono to ACE_Time_Value. It's
568   now possible to construct an ACE_Time_Value with a
569   std::duration. Also streaming, adding and substracting
570   an ACE_Time_Value to and from a std::duration is
571   supported. Please see tests/Chrono_Test.cpp for more
572   details.
574 . Allow ACE_INET_Addr to hold all addresses associated with a hostname. The
575   set of addresses always has a "current" address which is accessed by the
576   usual "get"-type methods on the class. Two new methods are added to deal
577   with multiple addresses:
578     - bool next (void): makes the next available address the "current" one.
579       Returns false if there are no more addresses.
580     - void reset (void): resets the iteration mechanism to be able to examine
581       all of the addresses again.
582   ACE_Multihomed_INET_Addr has also been enhanced so that the get_addresses()
583   methods copy all available addresses related to each name.
585 . The ACE_Addr::set_addr (void*, int) signature was changed to
586   ACE_Addr::set_addr (const void*, int). All classes that inherit from
587   ACE_Addr also have the same change. This affects ACE_ATM_Addr, ACE_Addr,
588   ACE_INET_Addr, ACE_MEM_Addr, ACE_Netlink_Addr, ACE_SPIPE_Addr, ACE_UNIX_Addr.
589   Any user-written classes derived from ACE_Addr will also need to change to
590   match the new signature for virtual method dispatch to continue working
591   properly in all cases.
593 . Added the class ACE_CDR::Fixed (CDR_Base.h) for CDR's fixed-point decimal
594   data type which stores up to 31 decimal digits and a sign bit.
596 USER VISIBLE CHANGES BETWEEN ACE-6.3.0 and ACE-6.3.1
597 ====================================================
599 . ACE is now hosted on github (https://github.com/DOCGroup/ATCD).
600   As part of the release process we now generate a ChangeLog
601   for each release which is stored in the ChangeLogs directory
603 . ACE has been ported to OpenBSD 5.6. Old versions of
604   OpenBSD are no longer supported.
606 USER VISIBLE CHANGES BETWEEN ACE-6.2.8 and ACE-6.3.0
607 ====================================================
609 . ACE now supports Oracle Solaris Studio 12.4 on Solaris.
611 . New config macros were added:
612   ACE_DISABLE_MKTEMP:  Disables the availability of ACE_OS::mktemp().
613   ACE_DISABLE_TEMPNAM: Disables the availability of ACE_OS::tempnam().
614   These can be added to your $ACE_ROOT/ace/config.h to disable these
615   wrappers which are considered to be a potential security risk. Disabling
616   one or both will also disable the following:
617     - ACE_FILE_Addr::set () with the 'any' address specified.
618     - ACE_MMAP_Memory_Pool use of the 'unique' option.
620 . Reduced size of all doxygen documentation by changing the
621   type of diagrams shown
623 . Removed Windows specific workarounds from ACE_OS::setsockopt, as a
624   result SO_REUSEPORT is not defined anymore on Windows and SO_REUSEADDR
625   is passed directly to the OS
627 . By adding a 'specific' section to a MPC (base) project it is now possible
628   to have object file output directories per project for GNUACE projects.
629   The following should be added to MPC projects (bugzilla #3868):
630   specific(gnuace) {
631     build_dir_per_project=1
632   }
634 . ACE_Asynch_Write_File will now correctly accept non-socket (file, TTY ..)
635   handles (bugzilla #3762 and #3992)
637 . Fixes for VxWorks 6.9
639 USER VISIBLE CHANGES BETWEEN ACE-6.2.7 and ACE-6.2.8
640 ====================================================
642 . Add new ACE::make_event_handler<T>() which is similar
643   to std::make_shared but than for allocation of ACE
644   event handlers. This template method is only enabled
645   when ACE_HAS_CPP11 has been defined, which is set
646   automatically when a C++ compiler with adequate
647   C++11 support is used. Also ACE_Event_Handler_var is
648   extended with some C++11 specific operations
650 . For all reactor types calling cancel_timer with a
651   nullptr is now allowed, will result in a return of 0
653 . ACE_DLL and ACE_DLL_Manager have been extended with
654   the support to retrieve any dynamic loader errors
656 USER VISIBLE CHANGES BETWEEN ACE-6.2.6 and ACE-6.2.7
657 ====================================================
659 . Added configuration files for Microsoft Visual Studio 2014
661 . Added configuration files for MacOSX Yosemite
663 . Added configuration files for IBM AIX XL C++ 12.1
665 USER VISIBLE CHANGES BETWEEN ACE-6.2.5 and ACE-6.2.6
666 ====================================================
668 . Resolved several data races reported by Intel Inspector XE
670 . Added optional socket connection optimization for Windows
672 . Improve functionality and stability of running tests on
673   Android Virtual Device (AVD).
675 USER VISIBLE CHANGES BETWEEN ACE-6.2.4 and ACE-6.2.5
676 ====================================================
678 . Added the ability to build RPMs for just ACE, using an ACE-src tarball.
679   To do this add "--without tao" to the rpmbuild command line.
681 . Added support for Embarcadero C++Builder XE5 using
682   bcc32 in debug and release mode
684 . Added support for Embarcadero C++Builder XE6 using
685   bcc32 in debug and release mode
687 . When Intel C++ 2013 SP1 Update 2 is used with C++11 enabled
688   as compiler feature now also ACE_HAS_CPP11 will be defined,
689   this compiler is now able to compile all our C++11 feature
690   tests
692 . Fixed several boundary bugs in the ACE RLE Compressor
694 USER VISIBLE CHANGES BETWEEN ACE-6.2.3 and ACE-6.2.4
695 ====================================================
697 . Added support for FC20 and ended maintenance for FC19
699 . Extended C++11 feature test suite
701 . Improved support for MingW64
703 . Improvements to IPv6 support on Windows
705 USER VISIBLE CHANGES BETWEEN ACE-6.2.2 and ACE-6.2.3
706 ====================================================
708 . The ACE_OS::thr_join() method will detect if the thread to be waited on is
709   the calling thread and avert that deadlock. The support needed for this
710   method is available at Vista/Windows Server 2003 and higher; to enable
711   the deadlock prevention, compile ACE with _WIN32_WINNT=0x0502 or higher.
713 . Ended maintenance and support for FC12 CEEL
715 . Further improvements of the Android port: Added new define
716   ACE_HAS_EXPLICIT_TEMPLATE_CLASS_INSTANTIATION and related macros
717   ACE_SINGLETON_TEMPLATE_INSTANTIATION and ACE_SINGLETON_TEMPLATE_INSTANTIATE
718   providing a cleaner way to support explicit template (static member or class)
719   instantiation.
721 ' Improvements of the test framework for running tests in a mixed environment
722   where different targets run on different physiscal devices (possibly having
723   different OS).
725 USER VISIBLE CHANGES BETWEEN ACE-6.2.1 and ACE-6.2.2
726 ====================================================
728 . The max_len argument to ACE_Process::command_line_buf changed from int*
729   to size_t*. This corrects a mismatch between the argument type and the
730   data member in ACE_Process from which the value comes.
732 . Removed some include files from ACE.h. These were not required for ACE.
733   The removed includes are OS_NS_math, Flag_Manip, Handle_Ops, Lib_Find,
734   Init_ACE, Sock_Connect.h. You may have to explicitly add one of these
735   in your own code to restore compiling.
737 . Further improvements of the Android port, still work in progress.
739 USER VISIBLE CHANGES BETWEEN ACE-6.2.0 and ACE-6.2.1
740 ====================================================
742 . Added support for Fedora 19, ended daily maintenance
743   for Fedora 17 and 18
745 . Added support for Embarcadero C++BuilderXE4 using
746   bcc32 in debug and release mode
748 . Improved support for Android
750 USER VISIBLE CHANGES BETWEEN ACE-6.1.9 and ACE-6.2.0
751 ====================================================
753 . None
755 USER VISIBLE CHANGES BETWEEN ACE-6.1.8 and ACE-6.1.9
756 ====================================================
758 . Added MinGW64 as supported platform
760 . Added support for GCC 4.8.0
762 USER VISIBLE CHANGES BETWEEN ACE-6.1.7 and ACE-6.1.8
763 ====================================================
765 . Small bug fixes
767 USER VISIBLE CHANGES BETWEEN ACE-6.1.6 and ACE-6.1.7
768 ====================================================
770 . Integrated several patches to simplify Debian/Ubuntu
771   packaging
773 USER VISIBLE CHANGES BETWEEN ACE-6.1.5 and ACE-6.1.6
774 ====================================================
776 . Added new event and sema initialization methods to OS_NS_Thread
777   to allow passing pre-initialized condition attributes providing
778   basic support for using time policies in ACE Event classes.
780 . Added TIME_POLICY support to ACE_Event classes to allow for
781   monotonic timer support for ACE Events.
783 . Added new regression test:
784   Monotonic_Manual_Event_Test
786 USER VISIBLE CHANGES BETWEEN ACE-6.1.4 and ACE-6.1.5
787 ====================================================
789 . When a ACE_Event_Handler registered for signals is unregistered,
790   whether by unregistering, returning -1 from handle_signal(), or by
791   the reactor closing, the ACE_Event_Handler::handle_close() hook will
792   be called. The close_mask passed will be ACE_Event_Handler::SIGNAL_MASK.
793   In previous versions, handle_close() would only be called when the
794   handle_signal() callback returned -1. This resolves Bugzilla #2368.
796 . Some initial ACE unit tests to validate the C++11 support of various
797   compilers
799 . Added support for OpenSuSE 12.2
801 USER VISIBLE CHANGES BETWEEN ACE-6.1.3 and ACE-6.1.4
802 ====================================================
804 . Added a new ACE_Time_Value derived template class (Time_Value_T.h):
806   template <class TIME_POLICY> class ACE_Time_Value_T
808   This template class overloads 4 new virtual methods from
809   the ACE_Time_Value base class to provide time policy aware
810   time values:
811   to_relative_time ()
812   to_absolute_time ()
813   now ()
814   duplicate ()
816 . Updated time policy classes to return ACE_Time_Value_T<> instantiations
817   for the corresponding time policy instead of 'common' time values.
819 . Added new ACE_Monotonic_Time_Policy (Monotonic_Time_Policy.h).
820   This class provides a monotonic time source for supported
821   platforms (Windows and POSIX platforms providing the required
822   clock_gettime() time source; currently verified for Windows and
823   Linux)
825 . Updated OS_NS_Thread to use the new time policy support in ACE_Time_Value
826   for (relative) time calculations and added new ACE_OS::condattr_setclock ()
827   method.
829 . Added TIME_POLICY support to ACE_Condition_Attributes to allow for
830   monotonic timer support for ACE_Condition.
832 . Added TIME_POLICY support to ACE_Message_Queue-s, ACE_Task-s and
833   related classes to enable support for monotonic timers in the timed
834   wait methods (ACE_Condition based). See docs/ACE-monotonic-timer.html
835   for how to use this.
837 . Added two new regression tests:
838   Monotonic_Task_Test
839   Monotonic_Message_Queue_Test
840   and updated the Bug_4055_Regression_Test to a fixed state.
842 USER VISIBLE CHANGES BETWEEN ACE-6.1.2 and ACE-6.1.3
843 ====================================================
845 . Added support for Oracle Solaris Studio 12 Update 3 (SunCC 5.12)
847 . Added new XML_Utils library which comes from DAnCE but is now also used
848   by OpenDDS
850 USER VISIBLE CHANGES BETWEEN ACE-6.1.1 and ACE-6.1.2
851 ====================================================
853 . Added compile time support for Windows CE 7, no runtime testing has
854   been performed
856 . The High Res Timer global scale factor on Windows is now 64bit, see bugzilla
857   3703 for the background of this. If you use the gsf in your code, use the
858   new ACE_High_Res_Timer::global_scale_factor_type type trait to not get
859   any conversion warnings
861 . Removed Tandem NSK v2/v3 support which resulted in cleanup throughout all
862   code. The emulations for ACE_INT64/ACE_UINT64 have been removed because no
863   platform is using them anymore
865 USER VISIBLE CHANGES BETWEEN ACE-6.1.0 and ACE-6.1.1
866 ====================================================
868 . Minor bug fixes
870 USER VISIBLE CHANGES BETWEEN ACE-6.0.8 and ACE-6.1.0
871 ====================================================
873 . Added compilation support for VxWorks 6.9, no runtime
874   testing has been performed
876 . Added ACE Run-length encoding compressor
878 . Fixed several Coverity reported issues
880 USER VISIBLE CHANGES BETWEEN ACE-6.0.7 and ACE-6.0.8
881 ====================================================
883 . Added support for MPC's new feature that creates dependency files for IDL
884   files when generating '-type gnuace' projects. Turned off by default, it
885   can be enabled in a features file or on the command line with
886   '-features ace_idl_dependencies=1'.
888 USER VISIBLE CHANGES BETWEEN ACE-6.0.6 and ACE-6.0.7
889 ====================================================
891 . Added a new method to ACE_Atomic_Op<LOCK, TYPE>, TYPE exchange (TYPE newval)
892   which does an atomic exchange of the new value with ACE_Atomic_Op's value
893   and returns the old value. The tests/Atomic_Op_Test.cpp test program has a
894   test case that exemplifies its usage; see the Exchange_Tester class.
896 . Added a new feature to timer queue templates classes: TIME_POLICY.
897   This feature is specified through a new template argument and provides the
898   timer queue with a policy for a timer (time of day) value. This feature is
899   intended to replace (in time) the gettimeofday setter method which has been
900   marked @deprecated. For now backwards compatibility is guaranteed.
901   The TIME_POLICY feature provides flexibility with regards to providing a timer
902   source to the timer queues as well as the possibility for a fully optimized
903   calling path.
904   A number of standard time policies are provided in ace/Time_Policy.h.
905   The tests/Timer_Queue_Test.cpp has been updated to reflect and exemplify these
906   changes.
908 . Added the TIME_POLICY feature also to countdown time class which has now
909   become a template (ace/Countdown_Time_T.h)
911 . Initial support for Microsoft Visual Studio 11
913 . Increased overall code quality by using Coverity and Klocwork
915 USER VISIBLE CHANGES BETWEEN ACE-6.0.5 and ACE-6.0.6
916 ====================================================
918 . Removed autoconf support, only traditional way of
919   compilation is shipped from now
921 . Add support for RHEL 6.1 64bit
923 USER VISIBLE CHANGES BETWEEN ACE-6.0.4 and ACE-6.0.5
924 ====================================================
926 . Improved support for Android and added the ability to run all ACE/TAO tests
927   automatically using the Android emulator
929 USER VISIBLE CHANGES BETWEEN ACE-6.0.3 and ACE-6.0.4
930 ====================================================
932 . Removed support for C++ Builder
934 . Added support for building with the Android NDK, at least r5c. This
935   is currently available for linux host platforms.
937 USER VISIBLE CHANGES BETWEEN ACE-6.0.2 and ACE-6.0.3
938 ====================================================
940 . Added support for GCC 4.6
942 USER VISIBLE CHANGES BETWEEN ACE-6.0.1 and ACE-6.0.2
943 ====================================================
945 . The ACE_wrappers/ace/OS.h file has been restored in order to ensure
946   build-time compatibility with older ACE versions. Its use will still
947   cause your build to incur more processing time than using the needed
948   ace/OS_NS_*.h files; however, you should be able to build OS.h-including
949   code without needing to replace it with OS_NS_* includes.
951 . Improved and simplified QNX support
953 . Changed rand_r() and getpwnam_r() to conform Single UNIX Specification.
955 . Fixed performance of send_v on windows when individual iovec elements
956   are particularly large.
958 USER VISIBLE CHANGES BETWEEN ACE-6.0.0 and ACE-6.0.1
959 ====================================================
961 . Added support for MinGW with GCC 4.5
963 USER VISIBLE CHANGES BETWEEN ACE-5.8.3 and ACE-6.0.0
964 ====================================================
966 . Changed the string format produced by ACE::timestamp() from the ctime
967   format "Day Mon dd hh:mm:ss yyyy" to ISO-8601 yyyy-mm-dd hh:mm:ss.mmmmmm.
968   This makes the time easier to collate and removes any dependence on locale.
969   The change affects the output from ACE_Log_Msg's %D format and both VERBOSE
970   and VERBOSE_LIGHT timestamps in addition to application-made direct calls
971   to ACE::timestamp().
973 . Removed GCC < 3 support
975 . A new build system hook was added for users to include site-private rules
976   in a build. If a file named "rules.private.GNU" in located in any build
977   directory it will get included from
978   $ACE_ROOT/include/makeinclude/rules.local.GNU. The "private_rules_file"
979   make variable can be set to override the name and/or location of the file.
980   If no such rules file exists, its absence is silently ignored. This
981   facility can be used, for example, to integrate a specialized code checker
982   into the build process.
984 USER VISIBLE CHANGES BETWEEN ACE-5.8.2 and ACE-5.8.3
985 ====================================================
987 . Two new methods were added to ACE_Pipe: close_read() and close_write().
988   These methods can be used to close individual pipe handles.
990 . The ACE::handle_ready() family of methods was changed to prefer using
991   poll() over select() on platforms where poll() is available. This
992   preference was previously only used if ACE_HAS_LIMITED_SELECT was set.
993   The ACE_HAS_LIMITED_SELECT choice is removed, making ACE_HAS_POLL the
994   setting that switches this preference. The driving reason for this
995   is that if select() is called to detect changes on a handle whose
996   values falls outside that which can safely be stored in an fdset,
997   the handle-setting macros/functions will set/clear bits outside
998   of the fdset. This results in very weird memory changes, often in
999   the stack, which are very hard to diagnose. poll()'s operation
1000   does not suffer from this affect. With the growing use of large
1001   numbers of handles and use of ACE_Dev_Poll_Reactor on Linux,
1002   the rate at which this problem was cropping up was increasing.
1004 . Added a simple helper ACE::is_equal() which compares equality of two
1005   objects without using operator==. This is useful for comparing floating
1006   point values.
1008 . Removed all deprecated methods, arguments, files, classes, macros and
1009   anything else we kept for years.
1011 . Removed Irix/Tru64/SCO/Uniware/Cray support
1013 . ACE_Pair has been removed. Users should now use std::pair.
1015 . This is the last micro release that will work with GCC < 3, after x.8.3
1016   support for GCC < 3 will be removed
1018 USER VISIBLE CHANGES BETWEEN ACE-5.8.1 and ACE-5.8.2
1019 ====================================================
1021 . Added support for the Microsoft Visual Studio 2010 IDE (vc10)
1023 . Removed complete support for emulated C++ exceptions
1025 USER VISIBLE CHANGES BETWEEN ACE-5.8.0 and ACE-5.8.1
1026 ====================================================
1028 . Added support for Microsoft Visual Studio 2010 using nmake
1030 . Reduced the amount of doxygen pages generated, the original settings caused
1031   a doxygen generated html package of 1.4GB which was way too large
1033 . Extended ACE INet addon library with:
1034   * HTTP Basic Authentication
1035   * SSL/HTTPS support.
1036   * Proxy CONNECT tunneling.
1038 USER VISIBLE CHANGES BETWEEN ACE-5.7.9 and ACE-5.8.0
1039 ====================================================
1041 . There are two new ACE_Time_Value methods for getting and setting millisecond
1042   values to/from ACE_UINT64 values:
1044       ACE_UINT64 ACE_Time_Value::get_msec () const
1045       void ACE_Time_Value::set_msec (const ACE_UINT64 &ms)
1047   The former is a replacement for the existing msec(ACE_UINT64&) methods that
1048   are "getter" methods whose signatures look confusingly like "setters". See
1049   Bugzilla #3336 for the history behind this change.
1051   The latter is for consistency and clarity.
1053 . Added ACE INet addon library for Inet protocol clients (and possibly
1054   servers at some point) like http://, ftp:// etc.
1055   The library implements standard C++ iostream wrapper classes for
1056   ACE Svc_Handler and Reactor based input/output handling, URL classes
1057   and protocol handler classes.
1058   NOTE: This is work in progress! There is no guarentee that the API
1059   won't change in the next few releases.
1060   Protocol handling is currently restricted to client side download
1061   requests for HTTP and FTP.
1062   Handling for upload requests should be added in the near future as well
1063   as HTTP Basic Authentication.
1065 USER VISIBLE CHANGES BETWEEN ACE-5.7.8 and ACE-5.7.9
1066 ====================================================
1068 . ACE's default makefiles (traditional ACE/GNU, not autoconf/automake)
1069   now support installation with "make install".
1070   Please see the ACE-INSTALL.html file for instructions.
1072 . Support for the ARCH make variable has been enhanced to apply to executables
1073   (in addition to libraries and object files), and the ARCH feature has been
1074   integrated into the MPC-generated makefiles (to work with MPC's requires
1075   and avoids features).
1077 USER VISIBLE CHANGES BETWEEN ACE-5.7.7 and ACE-5.7.8
1078 ====================================================
1080 . ACE now uses GCC builtin Atomic instructions for short,
1081   unsigned short, long, unsigned long, int, unsigned int,
1082   and bool. This makes our Atomic_Op around 7 times faster
1084 . ACE Service Configuration Framework now process first service
1085   configuration files and then command-line directives. Thus if
1086   application uses both service configuration files and command-line
1087   directives then the command-line directives may override results of
1088   directives in the configuration files. At the same time if the
1089   application uses only the default svc.conf file and command-line
1090   directives then the directives from svc.conf can not override
1091   results of the user provided command-line directives.
1093 . ACE_Dev_Poll_Reactor now dispatches notifications in only one thread at
1094   a time. This brings notification handling more in line with behavior in
1095   other Reactor implementations.
1097 USER VISIBLE CHANGES BETWEEN ACE-5.7.6 and ACE-5.7.7
1098 ====================================================
1100 . Integrated fix for bug 3104 and regression test for
1101   interval timers.
1103 . Added support for GCC builtin Atomic instructions which
1104   are enabled with GCC >= 4.1 for PPC32/PPC64/IA64
1106 . Improved autoconf support for debian
1108 . Added support for -mcpu and -mtune. Add TCPU=.. to your
1109   environment/platform_macros.GNU to specify you cpu and
1110   than add cpumodelflag=1 and/or tunemodelflag=1. Using
1111   this with IBM Cell increased the performance significantly
1113 USER VISIBLE CHANGES BETWEEN ACE-5.7.5 and ACE-5.7.6
1114 ====================================================
1116 . Added support for iPhone/iPod Touch/iPad. The following
1117   environment variables are needed:
1119   IPHONE_TARGET, should be set to either SIMULATOR or
1120   HARDWARE. Set to HARDWARE if you want to deploy
1121   on the iPhone/iPod Touch/iPad device.
1123   IPHONE_VERSION, should be set to 3.1.2 or 3.2. One can
1124   set the version to any future or past versions, but
1125   only 3.1.2 and 3.2 have been tried.
1127   Note that one has to compile ACE/TAO statically as
1128   it is believed that the iPhone OS does not support
1129   dynamic loading of external libraries. The usual
1130   procedure of cross compiling ACE/TAO applies
1131   (such as setting HOST_ROOT environment variable).
1133 . Added support for Embarcadero C++ Builder 2010
1135 . Added option to print a given ACE_Time_Value in the log
1136   message instead of system supplied timestamp as in %T
1137   and %D.
1138   The option is implemented as a variant of the %D/%T
1139   options by using the '#' flag character like '%#D' or
1140   '%#T'. When using this flag an ACE_Time_Value pointer is
1141   expected in the argument list supplied with the log message.
1142   This fixed Bugzilla #3221.
1144 . Fixed problems with ACE_INET_Addr::is_multicast() on
1145   little endian platforms. This fixed bugzilla #3729.
1147 . Added compilation support for VxWorks 6.8, no runtime
1148   testing has been performed
1150 USER VISIBLE CHANGES BETWEEN ACE-5.7.4 and ACE-5.7.5
1151 ====================================================
1153 . Added MacOSX Snow Leopard support
1155 . Added strsignal() wrapper
1157 . Improved LynxOS support
1159 . Updated Interix port
1161 . Fixed MinGW compilation problems
1163 USER VISIBLE CHANGES BETWEEN ACE-5.7.3 and ACE-5.7.4
1164 ====================================================
1166 . ACE_CDR::consolidate now returns an int, 0 is ok, -1 is failure
1168 . Fixed a bug in the realclean feature of the GNU makefiles
1170 . Improved Sun Studio for Linux support
1172 . Improved OpenBSD support
1174 USER VISIBLE CHANGES BETWEEN ACE-5.7.2 and ACE-5.7.3
1175 ====================================================
1177 . C++ Builder 2009 Update 3 is the only C++Builder that is supported, older
1178   and newer compilers are not supported anymore
1180 . Made final changes for the CEGCC port
1182 . Added a set of tests to validate C++ compiler and the stl implementation
1183   they ship.
1185 . HP-UX PARISC aCC < 3.80 are deprecated and can't be used anymore. Upgrade
1186   to aCC 3.80 or newer
1188 USER VISIBLE CHANGES BETWEEN ACE-5.7.1 and ACE-5.7.2
1189 ====================================================
1191 . Borland C++ makefiles aren't shipped anymore as part of the release
1192   but have to be generated by the user
1194 . Refactored gperf to have its own shared library so that we can reuse
1195   that in TAO
1197 . Added support for SuSE Enterprise 10
1199 . ACE_Configuration_Heap::open() now returns -1 with errno EBUSY if it is
1200   called multiple times. Previous versions would allow multiple calls to
1201   open() but leak resources.
1203 USER VISIBLE CHANGES BETWEEN ACE-5.7.0 and ACE-5.7.1
1204 ====================================================
1206 . Added support for Sun Studio 12 Update Pack 1
1208 . Fixed compile problems when using Windows CE x86 release mode
1210 . Fixed compile problems for FreeBSD
1212 USER VISIBLE CHANGES BETWEEN ACE-5.6.9 and ACE-5.7.0
1213 ====================================================
1215 . Added support for the VxWorks vxAtomicLib which is available with VxWorks 6.6
1216   and newer. If you don't want to use this library undef ACE_HAS_VXATOMICLIB
1217   in your config.h file
1219 . Added support for C++ Builder 2009 Update 3
1221 . Added support for ACE/TAO using the CEGCC project
1223 . Added support for upcoming Fedora 11 and OpenSuSE Factory
1225 USER VISIBLE CHANGES BETWEEN ACE-5.6.8 and ACE-5.6.9
1226 ====================================================
1228 . Removed Borland/CodeGear C++ Builder 2007 support.  If you'd like to
1229   fund this support please let us know.
1231 . Removed VxWorks 5.5.x, 6.2, and 6.3 support.  If you'd like to fund
1232   this support please let us know.
1234 . Improved Unicode support.
1236 . Added support for the native Windows Vista and Windows Server 2008
1237   condition variables. These has to be enabled at compile time, and when
1238   enabled the application can only run on Vista or Server 2008.  Add
1239   ACE_HAS_WTHREADS_CONDITION_VARIABLE to your config.h file to enable
1240   these
1242 . Fixed a bug when trying to read a file of 1 byte when unicode is
1243   enabled
1245 . Improved the Windows CE port
1247 . Fixed several Klocwork reported issues
1249 . Added support for MinGW 3.15
1251 . Added support for Incredibuild, which is an MSVC++ feature that
1252   optimizes compiles via distributing builds.
1254 USER VISIBLE CHANGES BETWEEN ACE-5.6.7 and ACE-5.6.8
1255 ====================================================
1257 . Added a new function ACE::isdotdir() which determines if a specified
1258   pathname is "dot dir" (ie. "." or ".."). ACE::isdotdir() is significantly
1259   faster than pair of strcmp() calls.
1261 . Last micro release that is maintained for Borland/CodeGear C++
1262   Builder 2007 and Intel C++ on Windows.
1264 . Fixed crash when ACE thread tries to inherit the logging attributes
1265   from non ACE threads.
1267 . Fixed many small compile and test errors that occur on some platforms.
1269 . Fixed log output formatting on some platforms.
1271 . Bugs fixed:  2748, 3164, 3480, 3494, 3502, 3541, 3542, 3544, 3557.
1273 USER VISIBLE CHANGES BETWEEN ACE-5.6.6 and ACE-5.6.7
1274 ====================================================
1276 . Changed the automake build's feature test for a "usable" config
1277   to warn on failure instead of exiting with an error.  This should
1278   make it easier to diagnose configure failures, as the script will
1279   now generate a config.h file even when the test fails.
1281 . Removed borland MPC template, use the bmake template from now
1283 . Added Windows Mobile 6 support and improved the WinCE port
1285 . Removed BCB6 and BCB2006 support
1287 . Added BCB2009 MPC template
1289 . Updated stat struct on Windows CE to match the stat struct on other
1290   platforms so that application code can be written portable
1292 . Added new ACE_OS wrappers: raise, atof, atol, isblank, isascii,
1293   isctype, and iswctype
1295 . Added ACE_OS wrapper for narrow-char version of strtoll.
1297 . ACE_OS wrappers for wide-char versions of strtol, strtoul,
1298   strtoll, and strtoll.
1300 . Added Visual Studio 2010 (vc10) support
1302 . Added a new feature for the "Traditional Make" build facility to allow
1303   building for multiple architectures out of a single source directory.
1304   To use this facility, set the ARCH make variable. The ARCH value will be
1305   used to add a subdirectory layer below the source directory where the
1306   traditional .shobj, .obj, etc. directories will be placed.
1308 . Added support for HP-UX 11iv3 on Integrity using aC++
1310 . ACE (and TAO) can now be built using GNU make and the Microsoft Visual C++
1311   compiler and linker.  See include/makeinclude/platform_win32_msvc.GNU for
1312   more details.
1314 . Added support for FC10
1316 USER VISIBLE CHANGES BETWEEN ACE-5.6.5 and ACE-5.6.6
1317 ====================================================
1319 . Added an option to the ACE_Process_Options class to use a wchar_t
1320   environment buffer on Windows.
1322 . A new configure option, --enable-rcsid, was added to the autoconf build.
1323   This is used to embed RCS IDs in object files.
1325 . A new method was added: void ACE_Time_Value::msec (ACE_UINT64&)
1326   This method, like the existing msec(ACE_UINT64&)const method, obtains the
1327   time value in milliseconds and stores it in the passed ACE_UINT64 object.
1328   This method was added so that msec(ACE_UINT64&) can be called on both
1329   const and non-const ACE_Time_Value objects without triggering compile errors.
1330   Fixes Bugzilla #3336.
1332 . Added ACE_Stack_Trace class to allow users to obtain a stack trace
1333   within their application on supported platforms. A new conversion
1334   character, the question mark, was added to ACE_Log_Msg for stack
1335   trace logging.
1337 . Added iterator support to ACE_Message_Queue_Ex class. The resulted in
1338   the addition of ACE_Message_Queue_Ex_Iterator class and
1339   ACE_Message_Queue_Ex_Reverse_Iterator class.
1341 . Renamed gperf to ace_gperf to prevent clashes with the regular gperf
1342   tool that is available in linux distributions
1344 . Added support for FC9
1346 . Added support for OpenSuSE 11.0
1348 . Improved support for GCC 4.2 and 4.3
1350 . Added support for CodeGear C++ Builder 2009
1352 USER VISIBLE CHANGES BETWEEN ACE-5.6.4 and ACE-5.6.5
1353 ====================================================
1355 . Added new Monitoring lib that can be used to store and retrieve
1356   counters. This is disabled by default because it is not 100%
1357   finished yet, with the next release it will be enabled by default
1359 . Fixed bug in ACE_Service_Config when it was used from a thread
1360   not spawned by ACE
1362 . Add VxWorks 6.x kernel mode with shared library support to ACE
1364 . Extended the implementation of Unbounded_Set, which has been
1365   renamed Unbounded_Set_Ex, to accept a second parameter which is
1366   a comparator that implements operator() which returns true if
1367   the items are equivalent.  Unbounded_Set has been reimplemented
1368   in terms of Unbounded_Set_Ex using a comparator that uses operator==,
1369   which captures the previous behavior.
1371 . Added support for Intel C++ on MacOSX
1373 USER VISIBLE CHANGES BETWEEN ACE-5.6.3 and ACE-5.6.4
1374 ====================================================
1376 . Reworked the relationship between ACE_Service_Config and
1377   ACE_Service_Gestalt
1379 . Improved autoconf support
1381 . Improved AIX with gcc support
1383 . Improved OpenVMS support
1385 . Improved VxWorks support
1387 USER VISIBLE CHANGES BETWEEN ACE-5.6.2 and ACE-5.6.3
1388 ====================================================
1390 . Deprecated Visual Age 5 and older
1392 . Closed a rare race condition hole whereby ACE_Atomic_Op<> function
1393   pointers would not be fully initialized prior to use.  See bugzilla
1394   3185 for details.
1396 . Tweaks to support MacOS X Leopard (10.5 and 10.5.1) on Intel
1398 . Fixed compile problems with MinGW with GCC 4.2. Do note that we do see
1399   much more test failures then when using GCC 3.4.
1401 . Changed to use synchronous exception handling with msvc 8/9 which is the
1402   default. Asynchrous exception handling does catch access violations but
1403   it leads to lower performance and other problems. See also bugzilla 3169
1405 . Make ace_main extern C with VxWorks so that it doesn't get mangled
1407 . Fixed compile errors and warnings for VxWorks 6.6
1409 . Added an MPC generator for the WindRiver Workbench 2.6 which is shipped
1410   with VxWorks 6.4
1412 . Added support for CodeGear C++ Builder 2007 with December 2007 update
1413   installed
1415 . Added support for VxWorks 5.5.1
1417 . Implemented the const reverse iterator for ACE_Hash_Map_Manager_Ex
1419 . Increased support for using ACE_Hash_Map_Manager_Ex with STL <algorithm>
1420   functions based on latest standard C++ draft
1422 USER VISIBLE CHANGES BETWEEN ACE-5.6.1 and ACE-5.6.2
1423 ====================================================
1425 . ACE-ified the UUID class, which will change user applications slightly.
1427 . Added support for Sun Studio 12
1429 . Added support for Intel C++ 10.1
1431 . Fixed runtime problems with VxWorks 6.x in kernel mode, several improvements
1432   have been made to ACE, but also some problems in the VxWorks kernel have
1433   been found for which WindRiver has made patches.
1435 . Added support for VxWorks 6.5 kernel mode
1437 . Added support for MacOS 10.5
1439 . Support for MacOS 10.4 is now deprecated.
1441 . Added support for OpenSuSE 10.3
1443 . Added support for RedHat 5.1
1445 . Added support for Microsoft Visual Studio 2008
1447 . Added support for Fedora Core 8
1449 . Added support for Ubuntu 7.10
1451 . With Ubuntu 7.04 and 7.10 we can't use visibility, that results in
1452   unresolved externals when building some tests. With lsb_release we
1453   now detect Ubuntu 7.04 and 7.10 automatically and then we disable
1454   visibility
1456 . Removed deprecated (un)subscribe methods from ACE_SOCK_Dgram_Mcast
1458 . Added an additional replace() method to ACE_OuptutCDR for replacing a
1459   ACE_CDR::Short value. Also added write_long_placeholder() and
1460   write_short_placeholder() to properly align the stream's write pointer,
1461   write a placeholder value and return the placeholder's pointer. The pointer
1462   can later be used in a call to replace() to replace the placeholder with a
1463   different value.
1465 . Initial support for VxWorks 6.6
1467 . Removed support for pthread draft 4, 6, & 7. This makes the ACE threading
1468   code much cleaner
1470 . Improved autoconf support
1472 . Fixed TSS emulation problems
1474 . Changed ACE_thread_t and ACE_hthread_t to int for VxWorks kernel mode. All
1475   thread creation methods do have an additional const char* argument to
1476   specify the task name, this now also works with pthread support enabled
1478 . Use bool in much more interfaces where this is possible
1480 . Added support for Debian Etch
1482 . Fixed ACE CDR LongDouble support on VxWorks 6.x
1484 . Added Microsoft Visual Studio 2008 project files to the release packages
1486 . Fixed a few bugs in the ACE_Vector template
1488 USER VISIBLE CHANGES BETWEEN ACE-5.6 and ACE-5.6.1
1489 ====================================================
1491 . Added support for CodeGear RAD Studio 2007
1493 . Added support for CodeGear C++ Builder 2007 Update 3
1495 . Modified the definiton of ACE_DEFAULT_THREAD_KEYS on Windows so it
1496   is based on the version of the OS as defined by Microsoft in this web
1497   page: http://tinyurl.com/2jqcmd
1498   This fixes bugzilla #2753
1500 USER VISIBLE CHANGES BETWEEN ACE-5.5.10 and ACE-5.6
1501 ====================================================
1503 . OpenVMS 8.3 on IA64 port
1505 . Added autoconf support for Intel C++ 10.0
1507 . Improved autoconf support on Linux, Solaris, NetBSD and HPUX
1509 . CodeGear C++ Builder 2007 Update 2 support
1511 . The netsvcs's client logging daemon has a new configuration option,
1512   -llocal-ip[:local-port], which can be used to specify the local IP
1513   address and port number for the client logging daemon's connection to
1514   the server logging daemon. If the -l option is specified with an IP
1515   address but not a port number, an unused port number is selected.
1517 . A new ACE+TAO port to LabVIEW RT 8.2 with Pharlap ETS. The host build
1518   environment is Windows with Microsoft Visual Studio .NET 2003 (VC7.1).
1519   Please see the ACE-INSTALL.html file for build instructions.
1521 USER VISIBLE CHANGES BETWEEN ACE-5.5.9 and ACE-5.5.10
1522 ====================================================
1524 . The ACE_utsname struct, used in the ACE_OS::uname() function when the
1525   platform doesn't provide the standard utsname struct, was changed. It
1526   defines a number of text fields and their types were changed from
1527   ACE_TCHAR[] to char[] in order to be consistent with all other platforms.
1528   This removes the need to write different code for platforms where
1529   ACE_LACKS_UTSNAME_T is set and that have wide characters (most probably
1530   Windows). Fixes Bugzilla #2665.
1532 . The ACE::daemonize() "close_all_handles" parameter was changed from
1533   an "int" to a "bool" to better reflect how it is used.
1535 . VxWorks 6.5 support. Compilation of the core libraries has been validated
1536   but no runtime testing has been performed.
1538 . CodeGear C++ Builder 2007 support.
1540 . The FaCE utility was moved from the ACE_wrappers/apps directory to
1541   ACE_wrappers/contrib. It is used for testing ACE+TAO apps on WinCE.
1542   See the ACE_wrappers/contrib/FaCE/README file for more information.
1544 . ACE_INET_Addr::set (u_short port, char *host_name, ...) now favors IPv6
1545   addresses when compiled with ACE_HAS_IPV6 defined and the supplied address
1546   family is AF_UNSPEC. This means that if host_name has an IPv6 address in
1547   DNS or /etc/hosts, that will be used over an IPv4 address. If no IPv6
1548   address exists for host_name, then its IPv4 address will be used.
1550 . Intel C++ 10.0 support
1552 . Support for the version of vc8 for 64-bit (AMD64) shipped with the Microsoft
1553   Platform SDK.
1555 . Fixed ACE_Vector::swap() (bugzilla #2951).
1557 . Make use of the Atomic_Op optimizations on Intel EM64T processors. The
1558   Atomic_Op is now several times faster on EM64T then with previous versions
1559   of ACE
1561 USER VISIBLE CHANGES BETWEEN ACE-5.5.8 and ACE-5.5.9
1562 ====================================================
1564 . Use Intel C++ specific optimizations for Linux on IA64
1566 . Improved support for ACE_OS::fgetc. Added support for ACE_OS::fputc,
1567   ACE_OS::getc, ACE_OS::putc and ACE_OS::ungetc.
1569 . Added support for ACE_OS::log2(double) and improved support for
1570   ACE::log2(u_long).
1572 . Shared library builds on AIX now produce a libxxx.so file instead of the
1573   previous practice of producing libxxx.a(shr.o).
1575 . GCC 4.1.2 that comes with Fedora 7 seems to have a fix for the visibility
1576   attribute we use for the singletons. F7 users will therefore need to
1577   define the following in your config.h file.
1578   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1580 . Fixed (rare) problem in TP_Reactor where incorrect event handler was
1581   resumed.
1583 . Reduced footprint on some platforms, particularly those that use
1584   g++ >= 3.3.
1586 USER VISIBLE CHANGES BETWEEN ACE-5.5.7 and ACE-5.5.8
1587 ====================================================
1589 . Extended ACE_Event constructor with optional LPSECURITY_ATTRIBUTES
1590   argument
1592 . Added support for QT4
1594 . Added support to integrate with the FOX Toolkit (www.fox-toolkit.org)
1596 . Added support for Microsoft Visual Studio Code Name "Orcas", which is
1597   the msvc9 beta
1599 . Added ability to provide an optional priority when calling
1600   ACE_Message_Queue_Ex::enqueue_prio(). There was previously no way
1601   to specify a priority for queueing.
1603 . Removed support for Visual Age on Windows.
1605 . ACE will compile once again with ACE_LACKS_CDR_ALIGNMENT #defined.
1607 . ACE_Process_Manager::terminate() no longer removes the process from the
1608   process descriptor table; the pid remains available in order to call
1609   ACE_Process_Manager::wait().
1611 USER VISIBLE CHANGES BETWEEN ACE-5.5.6 and ACE-5.5.7
1612 ====================================================
1614 . ACE 5.5 contained a set of pragmas which prevented Visual Studio 2005 (VC8)
1615   from issuing warnings where C run-time functions are used but a more
1616   secure alternative is available. For more information on the C run-time
1617   issues and Microsoft's response, please see the following MSDN page:
1618   http://msdn2.microsoft.com/en-us/library/8ef0s5kh(VS.80).aspx.
1619   In this beta, the pragmas which prevented the warnings have been removed.
1620   The ACE library has been reviewed and most of the use of "unsafe" functions
1621   has been fixed where possible. Since not all of the warnings emanating from
1622   ACE are situations that can or should be fixed, the ACE VC8 projects will
1623   prevent the warnings while building the ACE kit and its contained examples,
1624   tests, etc. The warnings are disabled by adding Microsoft-specified macros
1625   to the compile line via MPC. If desired, the warnings can be re-enabled by
1626   regenerating the project files with different MPC features. Note, however,
1627   that while ACE without warnings caused by the new C run-time functions, your
1628   application builds may trigger these warnings either by use of the "unsafe"
1629   C run-time functions or via use of an inlined ACE_OS method which uses it.
1630   If the warning is caused by an ACE_OS method, there is a more safe alternate
1631   available, probably located by appending _r to the method name (e.g.,
1632   instead of using ACE_OS::ctime(), use ACE_OS::ctime_r()).
1633   There are other cases where the compiler may have issued warnings and ACE
1634   prevented this via a #pragma. These #pragmas have been removed as well.
1635   This may cause your application builds to trigger more warnings from VC8
1636   than past ACE versions. You should review your code and either correct
1637   the code or disable the warnings locally, as appropriate.
1639 . The "release" argument to a number of ACE_String_Base<> methods was changed
1640   from int to bool to more accurately reflect its purpose. The following
1641   methods were changed:
1643             ACE_String_Base (const CHAR *s,
1644                              ACE_Allocator *the_allocator = 0,
1645                              int release = 1);
1646           to
1647             ACE_String_Base (const CHAR *s,
1648                              ACE_Allocator *the_allocator = 0,
1649                              bool release = true);
1651             ACE_String_Base (const CHAR *s,
1652                              size_type len,
1653                              ACE_Allocator *the_allocator = 0,
1654                              int release = 1);
1655           to
1656             ACE_String_Base (const CHAR *s,
1657                              size_type len,
1658                              ACE_Allocator *the_allocator = 0,
1659                              bool release = true);
1661             void set (const CHAR * s, int release = 1);
1662           to
1663             void set (const CHAR * s, bool release = true);
1665             void set (const CHAR * s, size_type len, int release);
1666           to
1667             void set (const CHAR * s, size_type len, bool release);
1669             void clear (int release = 0);
1670           to
1671             void clear (bool release = false);
1673   Since ACE_String_Base forms the basis of the ACE_CString and ACE_TString
1674   classes, this may ripple out to user application code. If you encounter
1675   errors in this area while building your applications, replace the
1676   int argument you are passing to the method now with either true or false.
1678 . Solutions for the eVC3/4 platform have been removed from this
1679   release.  Note that we package WinCE projects/workspaces for use
1680   with VC8.
1682 . There were 3 new ACE_Log_Msg logging format specifiers added to make logging
1683   easier for types that may change sizes across platforms. These all take one
1684   argument, and the new formats are:
1685     %b - format a ssize_t value
1686     %B - format a size_t value
1687     %: - format a time_t value
1689 . The ace/Time_Request_Reply.h and ace/Time_Request_Reply.cpp files were
1690   moved from $ACE_ROOT/ace to $ACE_ROOT/netsvcs/lib. The time arguments in
1691   the public API to ACE_Time_Request were changed from ACE_UINT32 to time_t
1692   and the portions of the on-wire protocol that contains time was changed from
1693   ACE_UINT32 to ACE_UINT64. Thus, code that uses the ACE_Time_Request class
1694   to transfer time information will not interoperate properly with prior
1695   ACE versions. This will affect uses of the netsvcs time clerk/server.
1697 . The portion of the ACE_Name_Request class that carries the on-wire seconds
1698   portion of a timeout value was changed from ACE_UINT32 to ACE_UINT64. This
1699   means that Name server/clients at ACE 5.5.7 and higher will not interoperate
1700   properly with previous ACE versions' name servers/clients.
1702 . In the ACE_Log_Record (ACE_Log_Priority, long, long) constructor, the
1703   second argument, long time_stamp, was changed to be of type time_t. This
1704   aligns the type with the expected value, a time stamp such as that returned
1705   from ACE_OS::time().
1707 . Added support for VxWorks 6.x cross compilation using a Windows host
1708   system
1710 . Added support for VxWorks 6.x using the diab compiler
1712 . The destructor of ACE_Event_Handler no longer calls
1713   purge_pending_notifications().  Please see bugzilla #2845 for the full
1714   rationale.
1715   (http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2845)
1717 USER VISIBLE CHANGES BETWEEN ACE-5.5.5 and ACE-5.5.6
1718 ====================================================
1720 . The ACE_TYPENAME macro has been added to those that are not
1721   available when the ACE_LACKS_DEPRECATED_MACROS config option is set
1722   (it is not set by default). You are encouraged to replace the use of
1723   ACE_TYPENAME with the C++ typename keyword before the ACE_TYPENAME
1724   macros is removed from ACE in the future.
1726 . A new script, rm_exception_macros.pl, has been added to help users
1727   remove the use of the ACE exception macros from their own code.
1729 USER VISIBLE CHANGES BETWEEN ACE-5.5.4 and ACE-5.5.5
1730 ====================================================
1732 . The prebuild MPC keyword is now supported by the gnuace project type.
1733   This fixes Bugzilla #2713.
1735 . Support for Windows earlier than NT 4 SP2 was removed. ACE will not build
1736   for Windows 95, 98, Me, etc. out of the box any longer.
1738 . Reformat stringified IPv6 addresses to use [addr]:port when printing
1739   addresses that contain ':' such as "::1".
1741 . Added method to ACE_INET_Addr to determine if address is IPv6 or
1742   IPv4 multicast.
1744 . Fixed a bug in ACE_Async_Timer_Adapter_Timer_Queue_Adapter<TQ> where the
1745   gettimeofday function of the timer queue was ignored when setting the alarm.
1747 . Fixed a problem where, on Solaris 9 onwards, calling
1748   ACE_OS::thr_create(THR_NEW_LWP) more than 2^15 (65535) times in a
1749   process will fail.  See changelog entry from "Wed Jan 3 22:31:05 UTC
1750   2007 Chris Cleeland <cleeland_c@ociweb.com>" for more information.
1752 . Fixed a bug in ACE_QtReactor where the two select() calls in that function
1753   might select on different handler sets.
1755 . ACE_SOCK_IO::recvv(iovec[], size_t, const ACE_Time_Value* = 0) and
1756   ACE_SOCK_IO::sendv (const iovec[], size_t, const ACE_Time_Value* = 0) methods
1757   were changed to specify the iovec count argument as int instead of size_t
1758   since it gets reduced to int in the underlying OS calls (usually).
1760 . The following deprecated methods were removed:
1762     ssize_t ACE_SOCK_IO::recv (iovec iov[],
1763                                size_t n,
1764                                const ACE_Time_Value *timeout = 0) const;
1766     ssize_t ACE_SOCK_IO::recv (iovec *io_vec,
1767                                const ACE_Time_Value *timeout = 0) const;
1769     ssize_t ACE_SOCK_IO::send (const iovec iov[],
1770                                size_t n,
1771                                const ACE_Time_Value *timeout = 0) const;
1773     These were previously replaced with more specific recvv() and sendv()
1774     methods.
1776 . The ACE_Service_Repository::find(const ACE_TCHAR name[],
1777                                    const ACE_Service_Type **srp = 0,
1778                                    int ignore_suspended = true) const
1779   method's 'ignore_suspended' parameter was changed from int to bool to
1780   reflect it's purpose as a yes/no indicator.
1782 . Added --enable-ace-reactor-notification-queue configure script
1783   option to the autoconf build for enabling the Reactor's userspace
1784   notification queue (defines ACE_HAS_REACTOR_NOTIFICATION_QUEUE in
1785   config.h).
1787 . The int ACE_OutputCDR::consolidate(void) method was contributed by
1788   Howard Finer at Sonus Networks. This method consolidates any continuation
1789   blocks used by an ACE_OutputCDR object into a single block. It's useful for
1790   situations which require access to a single memory area containing the
1791   encoded stream, regardless of its length, when the length cannot be known
1792   in advance.
1794 . There are a number of new methods defined on ACE_String_Base<CHAR>:
1796         size_t capacity (void) const:  This method returns the number
1797             of allocated CHAR units in the string object.
1799         void fast_resize (size_t): This method manage the sizing/reallocating
1800             of the string, but doesn't do the memory setting of resize().
1802         bool operator!= (const CHAR *) const
1803         bool operator== (const CHAR *) const: These methods compare the
1804             string with a nul-terminated CHAR* string.
1806         nonmember functions operator== and operator!= where also added
1807             that compare const ACE_String_Base and const CHAR*; these make
1808             it possible to switch ACE_String and CHAR* on either side of
1809             the operator.
1811   Thank you to Kelly Hickel <kfh at mqsoftware dot com> for these additions.
1813 . There are 2 new build options on the traditional make command:
1814   dmalloc and mtrace. When specified at build time (e.g. make mtrace=1)
1815   the PLATFORM_DMALLOC_CPPFLAGS and/or PLATFORM_MTRACE_CPPFLAGS values
1816   are added to CPPFLAGS. For dmalloc, the PLATFORM_DMALLOC_LDFLAGS and
1817   PLATFORM_DMALLOC_LIBS are added to LDFLAGS and LIBS, respectively.
1818   Thank you to Howard Finer for supplying these additions.
1820 . Added the ability to specify additional purify and quantify command-line
1821   options by setting PLATFORM_PURIFY_OPTIONS and PLATFORM_QUANTIFY_OPTIONS,
1822   respectively. Thank you to Howard Finer for supplying these additions.
1824 . Added the ability to use trio (http://sourceforge.net/projects/ctrio/)
1825   if platform lacks decent support for vsnprintf. trio support is
1826   enabled by defining trio=1 in plaform_macros.GNU
1828 . Removed Irix 5, DGUX, and m88k support
1830 . Improved LynxOS 4.2 support
1832 . VxWorks 6.4 support
1834 . Added support for FC6. Because the GCC 4.1.1 version that gets shipped
1835   has a fix for the visibility attribute we use for the singletons
1836   you will need to define the following in your config.h file. This can't be
1837   done automatically because SuSE 10.2 gets shipped with GCC 4.1.2 but
1838   doesn't have the same fix
1839   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1841 . RTEMS port
1843 USER VISIBLE CHANGES BETWEEN ACE-5.5.3 and ACE-5.5.4
1844 ====================================================
1846 . Added appropriate intptr_t and uintptr_t typedefs on platforms that
1847   don't provide them (i.e. when ACE_LACKS_INTPTR_T is defined).
1849 . Added ability to explicitly choose support for 32 bit or 64 bit file
1850   offsets on all platforms.  Define the _FILE_OFFSET_BITS preprocessor
1851   symbol to either 32 or 64 to choose the desired number of file
1852   offset bits.  This preprocessor symbol is supported natively by most
1853   UNIX and UNIX-like operating systems, and supported by ACE on
1854   Windows.  Use the new ACE_OFF_T typedef to refer to file offsets
1855   across UNIX and Windows portably.
1857 . 64-bit file offsets are now enabled by default in Win64
1858   configurations.
1860 . Improved support for 64 bit platforms (64 bit addresses, etc).
1862 . Added STL-style traits, iterators and a swap() method to the
1863   ACE_Array_Base<> class template.
1865 . Added STL-style traits and iterator accessors to the
1866   ACE_Hash_Map_Manager_Ex<> class template, as well as new find() and
1867   unbind() methods that return (as an "out" parameter) and accept
1868   iterators, respectively.
1870 . Greatly improved event handler dispatch performance in
1871   select()-based reactors (e.g. ACE_Select_Reactor and ACE_TP_Reactor)
1872   for large handle sets on Windows. Previous event handler search
1873   were linear, and are now constant on average.
1875 . Addressed a number of Coverity errors (CHECKED_RETURN, DEADCODE,
1876   LOCK, USE_AFTER_FREE, RESOURCE_LEAK, FORWARD_NULL).
1878 . Added STL-style "element_type" trait to all ACE auto_ptr class
1879   templates.
1881 . Removed support for LynxOS 3.x.
1883 . Resolved Bugzilla #2701 to ensure fini() is called for all
1884   Service Objects upon calling ACE_Service_Config::close()
1886 . VxWorks 5.5.2 has been tested, for ACE the support is exactly
1887   the same as for VxWorks 5.5.1. No specific defines or flags have
1888   to be used.
1890 USER VISIBLE CHANGES BETWEEN ACE-5.5.2 and ACE-5.5.3
1891 ====================================================
1893 . Added the base projects for executionmanager_stub and plan_generator.
1895 . Added the ACE_Hash_MultiMap_Manager class and its test file.
1897 . Changed the ACE_Synch_Options::operator[] method to return bool rather than
1898   int. The value returned is a yes/no indication of whether or not the
1899   specified option(s) are set in the object.
1901 . Changed the prototype(s) for ACE::debug () to return (and take) a
1902   bool. This is consistent with the original intent for this
1903   feature. If you have been using it like 'ACE::debug () > 0' or
1904   'ACE::debug (1)', you may have to rebuild ACE. The value of the
1905   ACE_DEBUG environment variable can be used to specify the initial
1906   value for ACE::debug(), at the process start up.
1908 . An assembler (within a C source file) based implementation for SPARC
1909   of atomic operations suitable for use with the
1910   ACE_Atomic_Op<ACE_Thread_Mutex, long> and
1911   ACE_Atomic_Op<ACE_Thread_Mutex, unsigned long> specializations has
1912   been added.  Currently, it can only be enabled by setting the
1913   atomic_ops_sparc make macro to 1 when using the GNUACE build system with
1914   the Solaris SunCC compiler.  It should be noted that this requires the
1915   -xarch=v8plus (or higher) be added to the CFLAGS make macro or the
1916   assembler code will not compile.
1918 . The ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> class
1919   is new, contributed by Guy Peleg <guy dot peleg at amdocs dot com>.
1920   ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> is
1921   similar to ACE_Message_Queue_Ex in that the object queued is a
1922   template parameter. However, ACE_Message_Queue_Ex_N allows the
1923   enqueueing and dequeueing of multiple chained objects at once. This
1924   wasn't added to ACE_Message_Queue_Ex because the chained object
1925   functionality requires the ACE_MESSAGE_TYPE class to have a
1926   ACE_MESSAGE_TYPE *next (void) const method, analogous to
1927   ACE_Message_Block::next(), to follow the chain and this would
1928   probably break existing applications using ACE_Message_Queue_Ex.
1929   The ACE_wrappers/tests/Message_Queue_Test_Ex.cpp test has an example of
1930   how to use the new class.
1932 . The selector and comparator function pointer arguments to ACE_OS::scandir()
1933   and ACE_Dirent_Selector are now marked as extern "C" to enforce their
1934   use with a C RTL function. User code that defines functions which are
1935   passed as the selector or comparator arguments which are not declared
1936   extern "C" may generate compile warnings. To resolve this, add extern "C"
1937   to the function's signature. See ACE_wrappers/tests/Dirent_Test.cpp for
1938   an example.
1940 . To address a problem in the ACE string interface that prevented
1941   substring or character searches in very large strings (e.g. greater
1942   than the maximum value of an ssize_t type) from being correctly
1943   reported to the caller, the find(), rfind() and strstr() methods now
1944   return an unsigned integer (size_t) instead of a signed one
1945   (ssize_t). Affected classes include:
1947     * ACE_CString
1948     * ACE_WString
1949     * ACE_TString
1950     * ACE_NS_WString
1952   Unless you have been explicitly using -1 instead of npos when
1953   comparing the return value of find(), rfind() and strstr(), and/or
1954   assigning the return value to ssize_t you should not see any
1955   difference. A new size_type typedef has been added to the ACE string
1956   class to aid developers.  This typedef is analogous to the standard
1957   C++ string::size_type typedef.
1959   The ACE_String_Base<>::strstr() documentation and the default
1960   rfind() argument erroneously referred to -1 instead of npos. Those
1961   instances have been corrected.
1963   To summarize, a "no position" condition is denoted using the npos
1964   constant, not -1. It can be referred directly by scoping it with the
1965   appropriate string class (e.g. ACE_CString::npos, ACE_WString::npos,
1966   etc).
1968 . Changing the shared library extension for hpux ia64 to ".so". On
1969   HP-UX 11i Version 1.5 the naming scheme is lib*.sl for PA and
1970   lib*.so on IPF.
1972 . The ACE_Refcounted_Auto_Ptr reset() and release() methods were changed
1973   per Bugzilla #1925. They will both now detach from the underlying
1974   ACE_Refcounted_Auto_Ptr_Rep object; reset() will create a new one for
1975   the new pointer specified as its argument. This change may cause referenced
1976   objects to be deleted in cases where previous ACE versions would not have.
1978 . The return type of "ACE_Refcounted_Auto_Ptr::null (void) const" changed
1979   from int to bool. It's possible values, true and false, have not changed.
1981 . TTY_IO now accepts "none" as a valid parity value. Due to this change
1982   'parityenb' member is now deprecated and will be removed in the future.
1983   The users of TTY_IO class should change their code to use only 'paritymode'
1984   member for parity control and leave 'parityenb' unchanged (it is
1985   enabled by default in class constructor).
1987 . Support for Intel C++ 9.1 on Windows and Linux
1989 . VxWorks 6.3 support
1991 . Fixed Bugzilla #2648 to make sure ACE_Service_Object::fini()
1992   is called iff ACE_Service_Object::init() succeeded, as per
1993   C++NPv2.
1995 . Added preliminary support for Mac OS X 10.4 on Intel CPU's.
1997 . Fixed Bugzilla #2602 to re-enable XML Service Configurator
1998   file support.
2000 USER VISIBLE CHANGES BETWEEN ACE-5.5.1 and ACE-5.5.2
2001 ====================================================
2003 . Added support for:
2004    - VxWorks 6.2 for the rtp model using pthread support
2005    - OpenVMS 8.2 for Alpha
2007 . Removed code and configurations that provided support for:
2008    - Visual C++ 6.0 and 7.0
2009    - Chorus
2010    - pSOS
2011    - KAI C++ on all platforms
2013 . Explicit template instantiation support has been removed. This effectively
2014   removes support for Sun Forte 6 and 7 which required explicit template
2015   instantiation to build ACE reliably.
2017 . Added support for multiple independent Service Repositories through
2018   configuration contexts called "Gestalt". Full backwards compatibility
2019   is maintained through the existing ACE_Service_Config static methods,
2020   while direct individual repository access is enabled through instances
2021   of the new ACE_Service_Gestalt class. ACE_Service_Config has changed to
2022   a specialization of ACE_Service_Gestalt and is only responsible for the
2023   process-wide configuration.
2025 . To support dynamically-sized ACE_Log_Record messages, the netsvcs
2026   logging components now use ACE CDR encoding and transfer mechanisms
2027   inspired by the examples in Chapter 4 of the C++NPv1 book.
2028   The client and server logging daemons in ACE 5.5.2 and forward will
2029   not interoperate with those in previous ACE versions.
2031 . Added a wrapper for the sendfile API (ACE_OS::sendfile()).
2033 . Added support for netlink sockets on Linux.
2035 . Added a new method, ACE_Task::last_thread(). This method returns the thread
2036   ID (ACE_thread_t) of the last thread to exit from the ACE_Task object.
2037   Users checking to see if a thread is the last one out (for example, to know
2038   when to perform cleanup operations) should compare the current thread ID to
2039   the return value from last_thread(). This is a change from the previously
2040   recommended practice (C++NPv2, page 189) of comparing the return value of
2041   thr_count() with 0.
2043 . Changed the first argument to ACE_OS::strptime() to be 'const' which
2044   matches its usual usage in POSIX strptime(). This change allows users to
2045   pass const strings in - a common use case.
2047 . Made part of the file support in ACE 64bit but we have some places where
2048   32bit types are used, this could lead to some conversion warnings which
2049   will be addressed in the near future, but getting everything 64bit
2050   compliant is a lot of work.
2052 USER VISIBLE CHANGES BETWEEN ACE-5.5 and ACE-5.5.1
2053 ====================================================
2055 . Added support for the --enable-symbol-visibility configure option
2056   to the autoconf build infrastructure instead of solely relying on
2057   feature tests to enable/disable symbol visibility support.  This
2058   avoids build problems with icc, etc.
2060 . Added support for the --enable-fl-reactor configure option to the
2061   autoconf build infrastructure to build the ACE_FlReactor library.
2063 . Added support for the --enable-qt-reactor configure option to the
2064   autoconf build infrastructure to build the ACE_QtReactor library.
2066 . Added support for the --enable-xt-reactor configure option to the
2067   autoconf build infrastructure to build the ACE_XtReactor library.
2069 . Fixed a bug that would cause timer IDs from ACE_Timer_Heap to be
2070   improperly duplicated under certain conditions (Bugzilla #2447).
2072 . Fixed ACE_SSL_Context::private_key(), context(), and dh_params() methods
2073   to allow retrying a file load after a failed call.
2075 . Fixed ACE_SSL_Asynch_Stream so it can be instantiated; also moved the
2076   declarations for ACE_SSL_Asynch_Read_Stream_Result,
2077   ACE_SSL_Asynch_Write_Stream_Result, and ACE_SSL_Asynch_Result classes
2078   to the ace/SSL/SSL_Asynch_Stream.h file so applications can see them.
2080 USER VISIBLE CHANGES BETWEEN ACE-5.4.10 and ACE-5.5
2081 ====================================================
2083 . Added a platform macros option "templates=manual", currently only
2084   applies to AIX 5.3 with XL 7 compiler.  It allows the user to tell the
2085   compiler to set -qnotempinc and -qnotemplateregistry and works well
2086   in static builds.
2088 . ACE and its tests compile error free with GCC 4.1 pre release.
2090 . ACE_Recursive_Thread_Mutex::get_nesting_level() fixed for 64-bit Windows
2091   XP on amd64/EM64T hardware.
2093 . Many build-time fixes for Windows Mobile 5 and Windows PocketPC 2003 using
2094   Visual Studio .NET 2005 (VC8).
2096 . Added support for the --enable-tk-reactor configure option to the
2097   autoconf build infrastructure to build the ACE_TkReactor library.
2099 USER VISIBLE CHANGES BETWEEN ACE-5.4.9 and ACE-5.4.10
2100 ====================================================
2102 . Fixed a bug in ACE_Timer_Heap_T::cancel().
2104 . Improved ACE_Time_Value support for boundary conditions.
2106 . Fixed problems with operator placement delete on certain C++ compilers.
2108 . Fixed a bug with the ACE_SPIPE_Acceptor on Windows.
2110 . Correctly set sockaddr_in.sin_len and sockaddr_in6.sin6_len on
2111   platforms that have these fields.
2113 . Avoided problems with namespace pollution for max() macros.
2115 . Many fixes for ACE_LACKS* and ACE_HAS* macros for autoconfig.
2117 USER VISIBLE CHANGES BETWEEN ACE-5.4.8 and ACE-5.4.9
2118 ====================================================
2120 . Added dozens of new ACE_LACKS and ACE_HAS defines which are used to
2121   simplify the ACE_OS layer
2123 . Constructors of ACE_Time_Value have been made explicit to prevent
2124   implicit conversions.
2126 . Added a shutdown() method to ACE_Barrier. The new method aborts the
2127   wait by all threads.
2129 . Changed the behavior of ACE_Message_Queue::enqueue_head() and
2130   enqueue_tail(). If the enqueued message block has other blocks
2131   chained to it via its next() pointer, the entire chain of blocks
2132   will be enqueued at once.
2134 . Improved the support for high-resolution timers with
2135   ACE_Timer_Queue_Adapter.
2137 . Make it possible to disable file caching in JAWS.
2139 . Improved ACE_Pipe implementation so that it uses localhost to avoid
2140   firewall problems.
2142 . Added Unicode support to the Service Configurator.
2144 USER VISIBLE CHANGES BETWEEN ACE-5.4.7 and ACE-5.4.8
2145 ====================================================
2147 . Improved IPv6 support
2149 . Improved 64bit portability
2151 . TTY_IO overhaul
2152   - Improved documentation.
2153   - It is now possible to request infinite timeout in portable manner.
2154     This can be achieved by setting negative value to readtimeoutmsec.
2155   - Various bugs fixed and portability issues resolved.
2157 . Subset ACE for TAO and TAO Services
2159 . Support for Intel C++ 9.0 on Windows and Linux
2161 . Support for Microsoft Visual Studio 2005 (aka VC8) for Win32 as well
2162   as the Windows CE platforms Pocket PC 2003 and Windows Mobile 5.
2163   Solution/project files are generated with an appended "_vc8" for
2164   Win32 and "_WinCE" for the CE platforms. See
2165   ACE_wrappers/docs/CE-status.txt for more information.
2167 . Completed implementation of ACE_Dev_Poll_Reactor using the Linux epoll
2168   facility; tested on Red Hat Enterprise Linux 4.
2170 . The in-memory size of an ACE_RB_Tree will be smaller due to rearranged
2171   placement of pointers.
2173 . Added an optimization to CDR stream to ignores alignment when marshaling
2174   data.  Use this new ACE_LACKS_CDR_ALIGNMENT compile-time option only
2175   when the ACE_DISABLE_SWAP_ON_READ macro is enabled.  This new option
2176   requires ACE CDR engine to do both marshaling and demarshaling, and
2177   when this option is enabled the encoded streams are no longer
2178   compliant with the CORBA CDR specification.
2180 . Developed Feature Oriented Customizer (FOCUS) tool to enable
2181   specialization of middleware frameworks such as Reactor and Protocol
2182   framework.  FOCUS provides an XML based transformation engine, where
2183   the transformations to specialize the components are captured in XML
2184   file and a weaver specializes the code.
2186 . Added support for unrolling ACE_OS::memcpy copy loop where
2187   applicable to improve performance. Autoconf tests empirically
2188   determine whether loop unrolling is at least 10% better than default
2189   version.
2191 . Added support for an ACE "versioned" namespace.  When enabled, ACE
2192   library sources will be placed within a namespace of the user's
2193   choice or a namespace of the form ACE_5_4_7 by default, where
2194   "5_4_7" is the ACE major, minor and beta versions.  The default may
2195   be overridden by defining the ACE_VERSIONED_NAMESPACE_NAME
2196   preprocessor symbol.  Enable overall versioned namespace support by
2197   adding "versioned_namespace=1" to your MPC default.features file.
2199 USER VISIBLE CHANGES BETWEEN ACE-5.4.6 and ACE-5.4.7
2200 ====================================================
2202 . Support for shared libraries with VxWorks
2204 . Support for Solaris 10 on x86 with Sun Studio 10 (C++ 5.7).
2206 . Extended ACE_OS::event_xxx implementation to support platforms
2207   having either PThread support with Process Shared condition
2208   variables or POSIX semaphores with named (process shared)
2209   semaphore support or using the new FIFO based semaphores.
2211 . ACE_OS::closesocket() no longer calls ACE_OS::shutdown() on any platform
2212   while closing the socket. It previously called ACE_OS::shutdown() on
2213   HP-UX. Removing this call fixes the fork-and-close programming paradigm
2214   that's common to many networked applications.
2216 . RMCast
2217    - Support for message fragmentation. This will allow
2218      for messages larger than 64K.
2219    - Support for flow control.
2220    - Timed recv() in RMCast::Socket.
2221    - Per-instance configurable protocol parameters (e.g., message
2222      retention time, NAK timeout, etc).
2224 USER VISIBLE CHANGES BETWEEN ACE-5.4.5 and ACE-5.4.6
2225 ====================================================
2227 . Updated RMCast to include
2228    - Reactor-compatible interface.
2229    - Message unavailability reporting.
2230    - Protocol documentation.
2232 . Added support for 64bit Visual Age on AIX
2234 . Improved g++ 4.0 support.  A number of RTTI related problems have been
2235   fixed.
2237 . Smaller footprint.
2239 . Fixed memory leaks ACE_DLL and ACE_Log_Msg classes.
2241 . The ACE::ICMP_Socket and ACE::Ping_Socket classes were moved out of
2242   the ACE namespace and "flattened" to ACE_ICMP_Socket and
2243   ACE_Ping_Socket to be consistent with the rest of ACE.
2245 . ACE_INET_Addr::set_address() - fixed a possible struct member
2246   alignment issue when building an IPv4-mapped IPv6 address.
2248 . Added a new ACE::wild_match() function to match a string based on
2249   wildcards.
2251 . Added efficient overloads for string concatenation to the
2252   ACE_String_Base class.
2254 . Added support for the use of pthread_getschedparam on MacOS X.
2256 . Fixed an issue with static initialization of TSS related classes on
2257   static builds for Windows.
2259 USER VISIBLE CHANGES BETWEEN ACE-5.4.4 and ACE-5.4.5
2260 ====================================================
2262 . Remove special handling in the Thread Specific Storage(TSS) code
2263   that released the TSS key for ACE_TSS<TYPE>.  ACE_TSS<TYPE> has
2264   been changed to explicitly free the TSS key when necessary.
2266 . On Win32 systems: detect thread termination via a hook in DLLMain
2267   for ACE.dll.  This allows cleanup of TSS objects for non-ACE threads
2268   that use ACE functions.  The most common case was threads that used
2269   ACE logging.  Formerly any TSS objects created by these threads would
2270   be leaked.
2272 . Added support for GNU G++ 4.0.  The x.4.5 beta takes advantage of
2273   g++ 4.0's symbol visibility.  This feature is conceptually similar
2274   to MS Windows "__declspec(dllexport)" DLL functionality.  Using this
2275   new g++ feature results in substantially improved ACE/TAO/CIAO
2276   shared library binaries.  A subset of the improvements include the
2277   following:
2279       * The number of unnecessarily exported DSO/DLL symbols is
2280         greatly reduced, resulting in faster program start times.
2281       * Smaller footprint.
2282       * Improved performance since run-time indirection of internal
2283         symbols is no longer needed.
2285   No changes to the ACE/TAO sources were necessary to support this
2286   feature since the required visibility attributes were hidden behind
2287   the various "*_Export" macros (formerly only useful for MS Windows
2288   DLLs) used throughout ACE/TAO.
2290 . The ACE_Reactor destructor will now call close() on the referenced reactor
2291   implementation. This assures that all handlers are notified before the
2292   ACE_Reactor object that's most likely referenced in these handlers is
2293   invalid. Although this should not be a user-visible change, it did catch
2294   some ACE tests off guard destroying reactor implementations and ACE_Reactor
2295   interfaces in the wrong order, so it may come up in the field as well.
2296   When using dynamically allocated reactor implementations, do not destroy
2297   the implementation object before the ACE_Reactor interface object. Use of
2298   the ACE_Reactor constructor's delete_implementation argument (with a value
2299   of 1) is recommended when dynamically allocating reactor implementations.
2301 . Improved performance of HTBP by not requiring a lookup of peer hostname.
2303 . Added new ACE_SizeCDR stream which allows one to calculate size of the
2304   representation without writing anything.
2306 . Number of improvements in RMCast, reliable multicast implementation.
2308 USER VISIBLE CHANGES BETWEEN ACE-5.4.3 and ACE-5.4.4
2309 ====================================================
2311 . The ace-config script has been replaced by pkg-config metadata files
2312   which are installed in ${prefix}/lib/pkgconfig by the automake build.
2314 . Remove ACE_OS::gets() implementation.  While this ACE implementation
2315   of gets() did not contain the security holes that all standard
2316   gets() implementations have, keeping it around only serves to foster
2317   confusion since (1) some may incorrectly assume that this
2318   ACE-specific gets() implementation has the same holes as standard
2319   ones, and (2) invoking it with a default size argument so that it
2320   looks like a standard gets() call results in behavior that is
2321   different from the standard.  Use ACE_OS::fgets() instead.
2323 . Removed ACE_Unbounded_Set_Ex, this gave the false idea that it had
2324   thread safe iterators. Use ACE_Unbounded_Set instead
2326 . Improved VxWorks support for static libraries. Shared libraries do cause
2327   several known problems which will be fixed in the x.4.5 release.
2329 . Removed the usage of the ACE_x_cast macros, we are using the C++ casts
2330   from now on. The ACE_x_cast macros are deprecated and will be removed
2331   after the x.5.1 release
2333 . Some improvements in autoconf support; better detection of available
2334   OS and compiler features.
2336 . Fixed bugs in ACE TSS emulation
2338 USER VISIBLE CHANGES BETWEEN ACE-5.4.2 and ACE-5.4.3
2339 ====================================================
2341 . Improved Cygwin 1.5.12 support, 90% of the tests now succeed
2343 . Improved OpenVMS support.
2345 . Added ability to use fltk with Cygwin/MinGW
2347 . Added ACE_INT64 that defines a native 64 bit type.
2349 . Added 'q' as usable specifier for ACE_Log_Msg to print out int64 bit number.
2351 . Added better support for Intel C++ compilers.
2353 . Improved HPUX support.
2355 . Added a new directory ("ACE_wrappers/protocols/ace") for new protocols
2356   that are not directly components of ACE, but are relate to ACE and
2357   defined a new protocol, HTBP (Hypertext Tunneling, Bidirectional
2358   Protocol) providing ACE_Acceptor/Connector/Stream semantics over a
2359   connection owned by an HTTP proxy. Test cases in
2360   ACE_wrappers/tests/HTBP provide examples of use.
2362 . Performace enhancement in TP_Reactor's handle_timer_events method [Bug
2363   1971].
2365 . Various changes to permit ACE to execute on HP NonStop platform (e.g
2366   support for its pthreads version).
2368 . Updated HP NonStop configuration files (config-tandem-nsk).
2370 . The "ACE" pseudo-namespace is now a true C++ namespace.  Transitional
2371   pseudo-namespaces that were only meant to be used internally by ACE,
2372   such as "ACE_Sock_Connect", no longer exist.
2374 . ACE_CDR::Boolean type is now a true C++ "bool" on all platforms except
2375   MSVC++ 6.  We plan to deprecate MSVC++ 6 support sometime after the
2376   x.5 release of ACE+TAO+CIAO, so we recommend you start migrating to a
2377   later version of MSVC++.
2379 . More GNU g++ 3.4.x fixes.
2381 . Added ICMP and "ping" socket support.
2383 . Added mkstemp() emulation.
2385 . Fixed problem on Linux < 2.5.47 platforms where equality comparison of
2386   two logically equal sockaddr_in structure instances would incorrectly
2387   fail.
2389 . Support for wide characters has been improved on non-Windows
2390   platforms.
2392 . A number of Windows CE problems have been fixed.
2394 . ACE's loading of DLLs (for example, as a result of loading synamic
2395   services) has been changed to use the native OS's facilities for
2396   locating the DLL instead of searching LD_LIBRARY_PATH (or its
2397   equivalent) then loading the DLL using a full pathname. This restores
2398   enforcement of a platform's loading and security policy.  To use the
2399   old DLL locating method, add ACE_MUST_HELP_DLOPEN_SEARCH_PATH to your
2400   config.h file before building ACE.
2402 . A number of errors in the APG example programs have been corrected.
2404 . Select_Reactor and Priority_Reactor performance improved. [Bug 1890]
2406 . Wide-char functionality on POSIX (Linux, etc.)
2408 . TSS memory leak fixes [Bug 1542]
2410 . Ported to HPUX 11i v2 on Itanium
2412 . Added code to ACE for platform RedHat AS 3.0 on Opteron.
2414 . Changed ACE::crc32() family of functions to NOT fold in the length of
2415   the string/buffer/iovec into the CRC.
2418 USER VISIBLE CHANGES BETWEEN ACE-5.4.1 and ACE-5.4.2
2419 ====================================================
2421 . Support for g++ 3.4.1.
2423 . All ACE Makefiles, project files, etc, are now generated by OCI's
2424   "MakeProjectCreator" (MPC) tool.  Makefiles and project files for
2425   commonly used configurations have been pre-generated and distributed
2426   with the beta(s).  Please see:
2428   $ACE_ROOT/ACE-INSTALL.html
2430   for information on how to use MPC with ACE.
2432 . Improved Doxygen documentation.
2434 . Reduced header file dependencies, which should speedup compilation
2435   and help minimize static footprint.
2437 . ACE now requires support for the following standard C++ features:
2439   - "bool" keyword
2441   - "mutable" keyword
2443   - "explicit" keyword
2445   - C++ casts (e.g. static_cast<>, reinterpret_cast<>, dynamic_cast<>
2446     and const_cast<>)
2448   If you're using a compiler that does NOT support these features
2449   please contact Steve Huston <shuston@riverace.com> for support.
2451 . Changed the select()-based reactor implementations to scan for
2452   broken handles to remove based on the registered handles, not on
2453   event handlers.  This allows for bad handles to be removed from the
2454   reactor even if the event handler doesn't implement get_handle() the
2455   way we expect.
2457 . Support for Pthreads native recursive mutexes was added. This
2458   capability is specified to ACE_OS::mutex_init() as an optional
2459   argument, lock_type. To fix confusion from an earlier attempt to add
2460   this functionality, the meaning of the old 'type' argument to
2461   ACE_OS::thread_mutex_init() is changed. It previously combined the
2462   scope and type. Now it is just the type (e.g. recursive), as the
2463   scope is inherent in the method used. For clarification on
2464   ACE_HAS_RECURSIVE_MUTEXES, it means that the platform is capable of
2465   them, not that they always are, as one would expect. However, before
2466   Pthreads had recursion added, it was never optional. Now it is.
2468 . Initial support for new Linux sys_epoll() interface in
2469   Dev_Poll_Reactor.  The obsolete Linux /dev/epoll interface is no
2470   longer supported.
2472 . Improved Cygwin support.
2473   - Threading works without problems.
2474   - Problems with shared memory, process shared mutexes, multicast and
2475     some other small things still exist.
2477 . New OpenVMS port.
2478   -  This is for the latest version of OpenVMS with all available ECOs
2479      applied. Basic stuff works without problems.  Advanced features
2480      still need some work.
2482 . Usage of ASYS_INLINE is deprecated in ACE.  Use ACE_INLINE instead.
2484 . All inline source files now end in ".inl".  The previous ".i"
2485   extension is generally used for preprocessed C sources.
2487 . Autoconf support has been improved and fixed on a number of
2488   platforms, including the BSD variants (e.g. FreeBSD).  It is still
2489   not the preferred way to configure most platforms, but it is ready
2490   for wider testing. Please report any problems found to
2491   ace-bugs@cs.wustl.edu.
2493 . A number of fixes were made to quiet compile errors and warnings on
2494   64-bit Windows.
2496 . For builds on AIX using Visual Age C++, the make rtti option default
2497   was changed to 1, enabling RTTI by default.
2499 . ACE_Service_Repository::remove() has a new, optional argument that
2500   can receive the service record pointer for the removed service. If
2501   the pointer is returned to the caller, it is not deleted. If the
2502   pointer is not returned to the caller (the default) it is deleted
2503   (this is the historic behavior).
2505 . The tutorials in ACE_wrappers/docs have been removed. They were not
2506   being maintained and caused confusion in a number of cases. Now that
2507   there are complete examples that match the printed books (C++NPv1,
2508   C++NPv2, APG), the older tutorials are no longer useful.  Please see
2510   $ACE_ROOT/examples/C++NPv1/
2511   $ACE_ROOT/examples/C++NPv2/
2512   $ACE_ROOT/examples/APG/
2514   for the source code of the examples in those books.
2516 . ACE_String_Base::fast_clear() is a new method which sets the string
2517   length to 0. Doesn't release string-allocated memory, but if the
2518   memory was externally supplied, it is no longer referenced from the
2519   string object.
2521 . A true C++ "bool" is now used as the CDR stream boolean type, if
2522   supported by the compiler.
2524 . Renamed AIX 5L configuration header from config-aix5.1.h to
2525   config-aix-5.x.h.
2527 . All C++ equality, relational and logical operators now return bool
2528   instead of int, as is the norm for modern C++.
2530 . Added new ACE_OS::realpath() implementation.  Contributed by Olli
2531   Savia  <ops at iki dot fi>
2534 USER VISIBLE CHANGES BETWEEN ACE-5.4 and ACE-5.4.1
2535 ====================================================
2540 . Fixed "make install" support in ACE+autoconf configurations.
2542 . Fixed autoconf support on Solaris.
2544 . Corrected invalid `aux' directory (on MS Windows) found in ACE
2545   distribution.
2547 . ACE/TAO build now without problems with MinGW and all ACE tests run
2548   now without problems
2550 . Added some more support for the new CBuilderX Preview compiler, this
2551   is not 100% ready yet because the compiler is still a preview and
2552   has its own problems.
2554 . Added Visual SlickEdit 8.1 MPC template
2556 . Added workaround for compile problems in Borland Release builds
2558 . Cygwin 1.5.9 is now supported
2560 . Tests for IPV6 have been added
2562 . Implement lstat() so that it'll use stat() on platforms that don't
2563   support lstat().
2565 . Problems related to ACE_Event_Handler usage in WFMO_Reactor was
2566   fixed.
2568 . A wrapper for rmdir () has been added.
2570 . Threads spawned in thread-per-connection mode never inherited the
2571   priority. This problem was fixed and this fix is consistent with the
2572   C++ NPV* books.
2574 . Fixed memory leaks with ACE_String_Base::resize ()
2576 . Enable the usage of native recursive mutexes for the implementation
2577   of ACE recursive mutexes on Linux.
2579 . The ACE Proactor framework can now be enabled for AIX 5.2. Since AIO
2580   functionality is not run-time enabled by default on AIX 5.2, the ACE
2581   Proactor code is not built by default on AIX. To enable it, the
2582   config.h file must contain #define ACE_HAS_AIO_CALLS before
2583   including the config-aix-5.1.h file.
2585 . The ACE_POSIX_CB_Proactor implementation is now built on all
2586   platforms except LynxOS.
2589 USER VISIBLE CHANGES BETWEEN ACE-5.3.6 and ACE-5.4
2590 ==================================================
2592 ACE:
2594 . Added a new makefile commandline flag, static_link, that can be
2595   used to force static linking when static_libs_only is turned on. It
2596   uses the new STATIC_LINK_FLAG variable and is currently only
2597   implemented for for GNU ld, i.e., it adds the "-static" option to
2598   LDFLAGS. It's turned off by default since using it causes the
2599   footprint to go up by almost 1 MB on Linux, since it links all the
2600   system and compiler .a files, but can be turned on if users
2601   want/need to use it, by enabling both static_libs_only and static_link.
2604 . Added macros ACE_USES_GPROF which enables users to use gprof in a
2605   multithreaded environment with ACE libs.
2607 . Added a new functor template class, ACE_Malloc_Lock_Adapter_T,
2608   that's used by ACE_Malloc_T as a factory for the ACE_LOCK template
2609   parameter, and allows the use of locking strategy classes, like
2610   ACE_Process_Semaphore and ACE_Thread_Semaphore that don't have a
2611   satisfactory ctor taking a single required ACE_TCHAR* parameter, to
2612   be adapted to work with ACE_Malloc_T.
2614 . The source code examples from "The ACE Programmer's Guide" book by
2615   Huston, Syyid, and Johnston, are now located in
2616   $ACE_ROOT/examples/APG.
2618 . Support for GNU autoconf is now in ACE. Please see ACE-INSTALL.html
2619   for details.
2621 . Fixed problems that prevented ACE from being compiled on LynxOS
2622   4.0.0.
2624 . Fixed compilation error which prevented ACE from being compiled when
2625   ACE_COMPILE_TIMEPROBES was set to 1.
2627 . Preliminary support for Tandem NSK has been added.
2629 . Lots of bug fixes with TLI and XPG5. Please see $ACE_ROOT/ChangeLog
2630   for details.
2632 . Fixed ACE_OS::event_timedwait() and ACE_OS::event_wait() so that
2633   they use a while loop around the ACE_OS::cond_[timed]wait() calls to
2634   avoid problems with spurious wakeups, etc.
2636 . ACE's wrapper around getipnodebyname() and getipnodebyaddr () has
2637   been made go through the IPv4-only case on ACE_WIN32. Since Windows
2638   IPv6 implementation doesn't offer support (at thistime) for
2639   getipnodebyname() the code has been changed to use the IPV4 part of
2640   the code.
2642 . Install with Borland C++ of ACE library fixed
2644 ACEXML:
2645 -------
2647 . Fixed memory leak in ACEXML parser.
2649 . Fixed implementations of rewind() in all the CharStreams. They were
2650   broken previously.
2652 . Fixed bugs in the parser associated with incorrect handling of PE
2653   References for keywords.