Compile fixes
[ACE_TAO.git] / ACE / NEWS
blob991e25e40b532227e1f02828083137069c99a228
1 USER VISIBLE CHANGES BETWEEN ACE-7.0.11 and ACE-7.1.0
2 =====================================================
4 . Removed support for Windows CE, OpenVMS, HPUX, AIX, RTEMS,
5   Pharlap, and Solaris
7 USER VISIBLE CHANGES BETWEEN ACE-7.0.10 and ACE-7.0.11
8 ======================================================
10 . Fixed some compiler warnings given by newer compilers
12 . Make use of noexcept instead of throw()
14 . Fixed a bug in ACE_Configuration_Heap with uses_wchar=1 builds
16 USER VISIBLE CHANGES BETWEEN ACE-7.0.9 and ACE-7.0.10
17 =====================================================
19 . Add missing resource files for several DLLs on Windows
21 . VxWorks runtime fixes
23 . Various cleanup and using more C++11 features
25 . Embarcadero C++ Builder 11.2 fixes
27 USER VISIBLE CHANGES BETWEEN ACE-7.0.8 and ACE-7.0.9
28 ====================================================
30 . Compile fixes for VxWorks 22.03
32 . Various cleanup
34 . Minor fixes
36 USER VISIBLE CHANGES BETWEEN ACE-7.0.7 and ACE-7.0.8
37 ====================================================
39 . Minor changes
41 USER VISIBLE CHANGES BETWEEN ACE-7.0.6 and ACE-7.0.7
42 ====================================================
44 . Minor changes
46 USER VISIBLE CHANGES BETWEEN ACE-7.0.5 and ACE-7.0.6
47 ====================================================
49 . Various cleanup and using more C++11 features
51 . Various packaging related fixes
53 USER VISIBLE CHANGES BETWEEN ACE-7.0.4 and ACE-7.0.5
54 ====================================================
56 . Initial not tested support for Visual Studio 2022
58 . Fixed compile errors when using Visual Studio 2019 with C++17
59   or C++20 support enabled
61 . Various cleanup and using more C++11 features
63 USER VISIBLE CHANGES BETWEEN ACE-7.0.3 and ACE-7.0.4
64 ====================================================
66 . Add support for Embarcadero C++ Builder 11.0 Alexandria using
67   the bcc32c compiler
69 . Allow ACE_Module and ACE_SOCK_Dgram_Mcast to be sub-classed
71 . Add ACE_SWAP_LONG_LONG byte swap macro for ACE_UINT64
73 . Improved ACE_Atomic implementation for g++
75 . Various cleanup and using more C++11 features
77 USER VISIBLE CHANGES BETWEEN ACE-7.0.2 and ACE-7.0.3
78 ====================================================
80 . The macro ACE_HAS_WIN32_STRUCTURAL_EXCEPTIONS has been renamed
81   to ACE_HAS_WIN32_STRUCTURED_EXCEPTIONS, update your code accordingly
83 . MinGW 2 has been deprecated
85 . ACE CDR supports (u)int8
87 . Use more C++11 features including using std alternatives
89 . Various cleanup
91 . Fix SocketConnect::ip_check() Concurrency and Too-Early Request Issues for Windows
93 . Make install: use relative links in prefix/share
95 USER VISIBLE CHANGES BETWEEN ACE-7.0.1 and ACE-7.0.2
96 ====================================================
98 . Fixed various warnings given by newer compilers
100 . Use more C++11 features
102 . Various cleanup
104 USER VISIBLE CHANGES BETWEEN ACE-7.0.0 and ACE-7.0.1
105 ====================================================
107 . Cleanup of ACE_* macros which are not used anymore
109 . Removed support for LynxOS 4 which has gcc3
111 . Make sure C++11 is enabled on MacOSX
113 USER VISIBLE CHANGES BETWEEN ACE-6.5.12 and ACE-7.0.0
114 =====================================================
116 . C++11 is now a mandatory compiler feature which is
117   required for ACE. Cleaned up part of the support for compilers
118   that lack C++11 support
120 . When valgrind is enabled we don't disable dlclose anymore,
121   this reduces the amount of leaks reported related to dlclose.
122   When you unload your shared libraries before the end of your program
123   you can use `--keep-debuginfo=yes` as valgrind options as alternative
124   or you can disable dlclose yourself by adding
125   `#define ACE_LACKS_DLCLOSE` to your ace/config.h file
127 . Removed `ACE_OS::readdir_r`. `readdir_r` was marked as depracated in glibc
128   and FreeBSD libc. Also removed `ACE_Dirent::read (ACE_DIRENT *, ACE_DIRENT **)`
129   which used it. `ACE_LACKS_READDIR_R` will now always be defined.
131 . Modernized part of the code using clang-type, added override, use nullptr,
132   use unique_ptr, remove redundant void, use bool, simplify boolean expressions,
133   make use of std::atomic, use using
135 . New Latest_ACE7TAO3_ branches which can be used to always checkout the
136   latest ACE7/TAO3 micro/minor release
138 . Android Support:
140   . `gnuace` no longer supports Android NDKs before r18. This means only clang
141     is now supported when building for Android.
143   . Support for building with the Android NDK r19 or later directly instead of
144     having to use a generated standalone toolchain. See `ACE-INSTALL.html` for
145     details. Using a standalone toolchain is still supported.
147   . Made it easier to use `gnuace`-built libraries in as imported libraries in
148     CMake-based Android Studio native projects.
150   . Removed support for old `ANDROID_ARCH` make variable. Replaced
151     `ANDROID_ABI` with `android_abi`, but kept the former as an alias of the
152     later for compatibility. Also will no longer default to 32-bit ARM, so
153     `android_abi` or `ANDROID_ABI` must be defined.
155   . As recommend by Google, building with neon support is now the default when
156     `android_abi` is `armeabi-v7a`. If support for these processors without
157     NEON extensions is needed, put `androind_neon := 0` in
158     `platform_macros.GNU`.
160   . As recommend by Google, `gnuace` will start using LLD, the LLVM linker,
161     instead of the default GNU linkers. If the NDK being used doesn't default
162     to LLD and you want to use the GNU linkers, put `androind_set_lld := 0` in
163     `platform_macros.GNU`.
165 . Removed support for the Alpha CPU
167 USER VISIBLE CHANGES BETWEEN ACE-6.5.11 and ACE-6.5.12
168 ======================================================
170 . Fixed some C++11 warnings
172 . Fixed compile problem on AIX
174 . Removed c++0x and c++1y as GNU make variables, use c++11 and c++14 as
175   alternatives
177 . Moved all CI builds to github actions
179 . Added ACE_GCC_NO_RETURN to fix fall through warnings
181 . Fix ACE_Thread_Manager::join memory leak and potential deadlock
183 USER VISIBLE CHANGES BETWEEN ACE-6.5.10 and ACE-6.5.11
184 ======================================================
186 . Latest_{Major,Minor,Micro,Beta} tags have been replaced with
187   branches because tags are not intended to move where branches are
189 . Removed emulated operations in ACE_OS which are not used anymore
191 . Resolved some compile warnings when using C++11 or newer
193 . Integrated debian packaging changes
195 . Visual Studio 2015 solutions are not part of the release
196   packaging anymore. When you require these you need to generate
197   them locally using MPC
199 . Improve multicast join by interface name on Windows
201 . Fixed ACE_INT64_FORMAT_SPECIFIER (and similar) preprocessor macros
202   on macOS (Apple-clang) with -std=c++11 or higher
204 . On Windows, use unnamed kernel objects (Events and Semaphores)
205   for thread-scoped reader-write mutexes in ACE_OS::rwlock_init
207 USER VISIBLE CHANGES BETWEEN ACE-6.5.9 and ACE-6.5.10
208 =====================================================
210 . Add support for Embarcadero C++ Builder 10.4 Sydney using the
211   classic compiler. ACE/TAO compile with the new 32/64 bit clang
212   compilers but runtime tests show several runtime problems which
213   makes them not safe to use
215 . Make a change in the ACE Process Manager to resolve an internal
216   compiler error with Visual Studio 2019 16.5.x compilers
218 . Android enhancements for if_nameindex
220 USER VISIBLE CHANGES BETWEEN ACE-6.5.8 and ACE-6.5.9
221 ====================================================
223 . On Windows, ACE no longer defines _WIN32_WINNT.  ACE wrappers for
224   if_nametoindex and if_indextoname are available if the version of the
225   Windows SDK supports them.
227 . IPv6 extended datagram receive info now supported on macOS.
229 . ACE_(U)INT8/16/32/64 map to (u)int8/16/32/64_t when C++11 has been
230   enabled.
232 . CDR_Base uses ACE_INT64 for LongLong, all old emulated support
233   has been removed
235 . Updated debian and rpm packaging support
237 USER VISIBLE CHANGES BETWEEN ACE-6.5.7 and ACE-6.5.8
238 ====================================================
240 . Added instructions to ACE-INSTALL.html for building ACE/TAO for Android on
241   Windows.
243 . Embarcadero C++ Builder Rio fixes
245 . Renamed `VERSION` file to `VERSION.txt` to avoid conflicting with the
246   `version` standard header.
248 USER VISIBLE CHANGES BETWEEN ACE-6.5.6 and ACE-6.5.7
249 ====================================================
251 . Fixed compile problem with glibc 2.30 and newer
253 . gnuace makefiles: Updated handling of generated files and
254   use requires/avoids to make postbuild steps conditional
256 . Removed references to the ACE_LACKS_MONOTONIC_TIME preprocessor macro because
257   it was equivalent to ACE_LACKS_CLOCK_MONOTONIC.
259 . Exposed support status of monotonic times features using preprocessor macros.
260   See "Testing for Monotonic Time Support" in docs/ACE-monotonic-timer.html for
261   details.
263 . Added support for ARM and ARM64 stack traces with Microsoft Visual C++.
265 . The "optional argument for the receive address in ACE_SOCK_Dgram::recv"
266   feature from ACE-6.5.5 is now supported on Windows.  This includes enhanced
267   support for sendmsg/recvmsg on Windows.
269 USER VISIBLE CHANGES BETWEEN ACE-6.5.5 and ACE-6.5.6
270 ====================================================
272 . On Linux, the ACE_Log_Msg format specifier `%t` is now replaced with the
273   system thread id provided by gettid(), instead of the much longer pthread id.
275 . Added support for MQX
277 . Enhanced Android support
279 USER VISIBLE CHANGES BETWEEN ACE-6.5.4 and ACE-6.5.5
280 ====================================================
282 . Fixed several broken links due to the removal of
283   Douglas Schmidt website at WashU
285 . On Android:
287   . ACE_Log_Msg (and therefore ACE_DEBUG and ACE_ERROR) now uses
288     Android's logging system (aka Logcat) by default in addition to stderr
289     because stdout and stderr are discarded under normal circumstances.
290     To disable this at runtime, run:
291       ACE_LOG_MSG->clr_flags (ACE_Log_Msg::SYSLOG)
292     To disable this at compile time include these lines in config.h:
293       #define ACE_DEFAULT_LOG_FLAGS ACE_Log_Msg::STDERR
294       #define ACE_DEFAULT_LOG_BACKEND_FLAGS 0
296   . When statically linking to OpenSSL, prevent usage of the preloaded and
297     unpredictable system SSL library when using ace_openssl.
299 . minizip has been moved from ACE to DANCE
301 . Add initial support for Visual Studio 2019
303 . Validated ACE for usage SLES15.0 x86_64 using 32bit g++ compiler
305 . Add optional argument for the receive address in ACE_SOCK_Dgram::recv
307 USER VISIBLE CHANGES BETWEEN ACE-6.5.3 and ACE-6.5.4
308 ====================================================
310 . Fix ACE_Vector::end(), which now correctly
311   represents the end of the elements of the vector
312   instead of the end of the base array.
314 USER VISIBLE CHANGES BETWEEN ACE-6.5.2 and ACE-6.5.3
315 ====================================================
317 . Enhance Android support
319 . Fix AIX and Solaris linking rpath errors
321 . Add support for SSL_INCDIR/SSL_LIBDIR and XERCESC_INCDIR/XERCESC_LIBDIR
322   to specify a custom include/lib dir as required for vcpkg versions of
323   openssl/xercesc
325 USER VISIBLE CHANGES BETWEEN ACE-6.5.1 and ACE-6.5.2
326 ====================================================
328 . Enhanced C++Builder XE2 support
330 . ACE_QtReactor can be built with Qt version 5 using the qt5 MPC feature
332 USER VISIBLE CHANGES BETWEEN ACE-6.5.0 and ACE-6.5.1
333 ====================================================
335 . At the moment C++11 or newer is enabled ACE_Strong_Bound_Ptr
336   doesn't provide the convenience functions to use a
337   std::auto_ptr anymore
339 . Optimized CDR std::(w)string insertion and extraction
340   when C++11 or newer is enabled
342 . Solved Visual Studio 2017 solution loading due to duplicate
343   files generated in a project file
345 USER VISIBLE CHANGES BETWEEN ACE-6.4.8 and ACE-6.5.0
346 ====================================================
348 . The ACE core libraries now use std::unique_ptr instead
349   of std::auto_ptr when C++11 or newer is enabled
351 USER VISIBLE CHANGES BETWEEN ACE-6.4.7 and ACE-6.4.8
352 ====================================================
354 . Enhanced Embarcadero C++ Builder support
356 . ACE XML_Utils enhancements
358 . Debian packaging enhancements
360 . Support for clang6 and gcc8
362 . Enhanced Android support
364 . Remove addr_any restriction from ipv6_only UDP
366 USER VISIBLE CHANGES BETWEEN ACE-6.4.6 and ACE-6.4.7
367 ====================================================
369 . Added a new, optional argument named ipv6_only to:
370     ACE_Acceptor::ACE_Acceptor
371     ACE_Acceptor::open
372     ACE_SOCK_Dgram::ACE_SOCK_Dgram
373     ACE_SOCK_Dgram::open
374   If ipv6_only is 0/false (the default) the socket will accept
375   both IPv6 and IPv4 connections/datagrams. If ipv6_only is
376   1/true the socket will only accept IPv6.
377   This behavior only applies when ACE_HAS_IPV6 is true and the
378   local-side IP address is the generic localhost IP address.
380 . Integrated some changes from XSC into XML Utils
382 . Enable ACE_HAS_CPP11 when we have clang with C++11 enabled
384 . Added support for cross compiling using MinGW on a Linux host
386 . Added support for FreeBSD 11
388 . Fixed issue ACE_Singleton was broken after ACE::fini, ACE::init (GitHub #554)
390 USER VISIBLE CHANGES BETWEEN ACE-6.4.5 and ACE-6.4.6
391 ====================================================
393 . Fixed some Codacy and C++ Core guidelines reported issues
395 . VxWorks 7 (SR0510) support
397 . Support make install on newer Apple MacOS versions
399 USER VISIBLE CHANGES BETWEEN ACE-6.4.4 and ACE-6.4.5
400 ====================================================
402 . Add support for OpenSSL 1.1. ACE users on Windows have
403   to add openssl11=1 to their default.features file so
404   that the correct OpenSSL library names are used.
406 USER VISIBLE CHANGES BETWEEN ACE-6.4.3 and ACE-6.4.4
407 ====================================================
409 . Enhanced support for Embarcadero C++ Builder 10.2 (Tokyo).
410   Support for bcc32/bcc64/bcc32c has been enhanced and by
411   default the clang based versions are used. When the old
412   bcc32 has to be used set the CLASSIC environment variable
413   to 1. At this moment runtime test results for bcc64/bcc32c
414   show some structural problems
416 . Add support for Oracle Studio 12.5
418 . Removed usage of ACE_REGISTER and register keyword because
419   they trigger deprecated warnings with newer gcc and clang
420   versions
422 . Add support for gcc 7
424 . Enhanced Android support
426 . Fix ACE_INET_Addr::set(domain_name, AF_UNSPEC) to be set to IPv4 address
427   when IPv6 is enabled and the domain_name could be resolved to IPv4 address.
429 USER VISIBLE CHANGES BETWEEN ACE-6.4.2 and ACE-6.4.3
430 ====================================================
432 . Enhancements for Visual Studio 2017
434 . Enhancements for Android
436 USER VISIBLE CHANGES BETWEEN ACE-6.4.1 and ACE-6.4.2
437 ====================================================
439 . Added support for Mac OS X on x86_64 to get the network adapter
440   address in ACE_OS::getmacaddress().
442 . Added support for the December 2016 updates to VxWorks 7.
444 USER VISIBLE CHANGES BETWEEN ACE-6.4.0 and ACE-6.4.1
445 ====================================================
447 . The ACE_DEBUG environment variable can again be used to set the
448   internal debug flag.  This used to work but was mistakenly changed
449   in an earlier release.
451 . Corrected usage of ACE_Singleton and template instantation to be
452   valid C++ (GCC cross-compiler arm-linux-gnueabihf-g++ requires it).
454 . Added support for detecting the Mac OS X version when configured with
455   ace/config-macosx.h and include/makeinclude/platform_macosx.GNU.
456   Also on 10.11 El Capitan, use rpath to avoid a problem with SIP.
458 . Added support for Android NDK r12b (Platform API 24) and improved
459   cross compilation support
461 USER VISIBLE CHANGES BETWEEN ACE-6.3.4 and ACE-6.4.0
462 ====================================================
464 . Added support for obtaining the micro version number
466 . Reduced include of ace/Auto_Ptr.h in header files
468 USER VISIBLE CHANGES BETWEEN ACE-6.3.3 and ACE-6.3.4
469 ====================================================
471 . ACE_SSL_Context::set_mode() can no longer be used to select a specific
472   SSL/TLS protocol version, use ACE_SSL_Context::filter_versions() for that.
473   This follows general advice by the OpenSSL project to go through
474   SSL_CTX_set_options() to limit the list of protocols available. The purpose
475   of ACE_SSL_Context::set_mode() is now limited to explicitly restricting
476   behaviour to client or server (defaults to both).
478 . Improve Oracle Studio support
480 . CIAO and DAnCE are forked to their own github repositories
481   and are not part anymore of the ACE+TAO release packages
483 . Fixed several Coverity reported issues
485 . Added ACE configuration for FACE safety profiles (see config-face-safety.h).
486   FACE, or Future Airborne Capability Environment http://www.opengroup.org/face,
487   specifies a restricted subset of OS functions and rules for controlling
488   dynamic memory allocation.  When built in this configuration on a platform
489   that supports it, ACE conforms to the FACE requirements.
491 . ACE uses new netdb.h functions (getaddrinfo/getnameinfo) if they are
492   available, in place of deprecated functions (gethostbyname/addr).
494 USER VISIBLE CHANGES BETWEEN ACE-6.3.2 and ACE-6.3.3
495 ====================================================
497 . Visual Studio 2015 has adequate C++11 support, because of this
498   ACE_HAS_CPP11 is now defined with this compiler. A large amount
499   of warnings given by this new compiler have been fixed
501 . As part of the release script we generate vc12 and vc14
502   solution files which are packaged as part of the release
504 . Added support for VxWorks 7 (kernel mode and RTP).
505   See the comments in include/makeinclude/platform_vxworks7.0.GNU for details.
507 . Ended daily maintenance for OpenVMS
509 . Fixed a defect in ACE_INET_Addr when there is a non-empty interface
510   address list and set_port_number() is called.
512 USER VISIBLE CHANGES BETWEEN ACE-6.3.1 and ACE-6.3.2
513 ====================================================
515 . Added support for std::chrono to ACE_Time_Value. It's
516   now possible to construct an ACE_Time_Value with a
517   std::duration. Also streaming, adding and substracting
518   an ACE_Time_Value to and from a std::duration is
519   supported. Please see tests/Chrono_Test.cpp for more
520   details.
522 . Allow ACE_INET_Addr to hold all addresses associated with a hostname. The
523   set of addresses always has a "current" address which is accessed by the
524   usual "get"-type methods on the class. Two new methods are added to deal
525   with multiple addresses:
526     - bool next (void): makes the next available address the "current" one.
527       Returns false if there are no more addresses.
528     - void reset (void): resets the iteration mechanism to be able to examine
529       all of the addresses again.
530   ACE_Multihomed_INET_Addr has also been enhanced so that the get_addresses()
531   methods copy all available addresses related to each name.
533 . The ACE_Addr::set_addr (void*, int) signature was changed to
534   ACE_Addr::set_addr (const void*, int). All classes that inherit from
535   ACE_Addr also have the same change. This affects ACE_ATM_Addr, ACE_Addr,
536   ACE_INET_Addr, ACE_MEM_Addr, ACE_Netlink_Addr, ACE_SPIPE_Addr, ACE_UNIX_Addr.
537   Any user-written classes derived from ACE_Addr will also need to change to
538   match the new signature for virtual method dispatch to continue working
539   properly in all cases.
541 . Added the class ACE_CDR::Fixed (CDR_Base.h) for CDR's fixed-point decimal
542   data type which stores up to 31 decimal digits and a sign bit.
544 USER VISIBLE CHANGES BETWEEN ACE-6.3.0 and ACE-6.3.1
545 ====================================================
547 . ACE is now hosted on github (https://github.com/DOCGroup/ATCD).
548   As part of the release process we now generate a ChangeLog
549   for each release which is stored in the ChangeLogs directory
551 . ACE has been ported to OpenBSD 5.6. Old versions of
552   OpenBSD are no longer supported.
554 USER VISIBLE CHANGES BETWEEN ACE-6.2.8 and ACE-6.3.0
555 ====================================================
557 . ACE now supports Oracle Solaris Studio 12.4 on Solaris.
559 . New config macros were added:
560   ACE_DISABLE_MKTEMP:  Disables the availability of ACE_OS::mktemp().
561   ACE_DISABLE_TEMPNAM: Disables the availability of ACE_OS::tempnam().
562   These can be added to your $ACE_ROOT/ace/config.h to disable these
563   wrappers which are considered to be a potential security risk. Disabling
564   one or both will also disable the following:
565     - ACE_FILE_Addr::set () with the 'any' address specified.
566     - ACE_MMAP_Memory_Pool use of the 'unique' option.
568 . Reduced size of all doxygen documentation by changing the
569   type of diagrams shown
571 . Removed Windows specific workarounds from ACE_OS::setsockopt, as a
572   result SO_REUSEPORT is not defined anymore on Windows and SO_REUSEADDR
573   is passed directly to the OS
575 . By adding a 'specific' section to a MPC (base) project it is now possible
576   to have object file output directories per project for GNUACE projects.
577   The following should be added to MPC projects (bugzilla #3868):
578   specific(gnuace) {
579     build_dir_per_project=1
580   }
582 . ACE_Asynch_Write_File will now correctly accept non-socket (file, TTY ..)
583   handles (bugzilla #3762 and #3992)
585 . Fixes for VxWorks 6.9
587 USER VISIBLE CHANGES BETWEEN ACE-6.2.7 and ACE-6.2.8
588 ====================================================
590 . Add new ACE::make_event_handler<T>() which is similar
591   to std::make_shared but than for allocation of ACE
592   event handlers. This template method is only enabled
593   when ACE_HAS_CPP11 has been defined, which is set
594   automatically when a C++ compiler with adequate
595   C++11 support is used. Also ACE_Event_Handler_var is
596   extended with some C++11 specific operations
598 . For all reactor types calling cancel_timer with a
599   nullptr is now allowed, will result in a return of 0
601 . ACE_DLL and ACE_DLL_Manager have been extended with
602   the support to retrieve any dynamic loader errors
604 USER VISIBLE CHANGES BETWEEN ACE-6.2.6 and ACE-6.2.7
605 ====================================================
607 . Added configuration files for Microsoft Visual Studio 2014
609 . Added configuration files for MacOSX Yosemite
611 . Added configuration files for IBM AIX XL C++ 12.1
613 USER VISIBLE CHANGES BETWEEN ACE-6.2.5 and ACE-6.2.6
614 ====================================================
616 . Resolved several data races reported by Intel Inspector XE
618 . Added optional socket connection optimization for Windows
620 . Improve functionality and stability of running tests on
621   Android Virtual Device (AVD).
623 USER VISIBLE CHANGES BETWEEN ACE-6.2.4 and ACE-6.2.5
624 ====================================================
626 . Added the ability to build RPMs for just ACE, using an ACE-src tarball.
627   To do this add "--without tao" to the rpmbuild command line.
629 . Added support for Embarcadero C++Builder XE5 using
630   bcc32 in debug and release mode
632 . Added support for Embarcadero C++Builder XE6 using
633   bcc32 in debug and release mode
635 . When Intel C++ 2013 SP1 Update 2 is used with C++11 enabled
636   as compiler feature now also ACE_HAS_CPP11 will be defined,
637   this compiler is now able to compile all our C++11 feature
638   tests
640 . Fixed several boundary bugs in the ACE RLE Compressor
642 USER VISIBLE CHANGES BETWEEN ACE-6.2.3 and ACE-6.2.4
643 ====================================================
645 . Added support for FC20 and ended maintenance for FC19
647 . Extended C++11 feature test suite
649 . Improved support for MingW64
651 . Improvements to IPv6 support on Windows
653 USER VISIBLE CHANGES BETWEEN ACE-6.2.2 and ACE-6.2.3
654 ====================================================
656 . The ACE_OS::thr_join() method will detect if the thread to be waited on is
657   the calling thread and avert that deadlock. The support needed for this
658   method is available at Vista/Windows Server 2003 and higher; to enable
659   the deadlock prevention, compile ACE with _WIN32_WINNT=0x0502 or higher.
661 . Ended maintenance and support for FC12 CEEL
663 . Further improvements of the Android port: Added new define
664   ACE_HAS_EXPLICIT_TEMPLATE_CLASS_INSTANTIATION and related macros
665   ACE_SINGLETON_TEMPLATE_INSTANTIATION and ACE_SINGLETON_TEMPLATE_INSTANTIATE
666   providing a cleaner way to support explicit template (static member or class)
667   instantiation.
669 ' Improvements of the test framework for running tests in a mixed environment
670   where different targets run on different physiscal devices (possibly having
671   different OS).
673 USER VISIBLE CHANGES BETWEEN ACE-6.2.1 and ACE-6.2.2
674 ====================================================
676 . The max_len argument to ACE_Process::command_line_buf changed from int*
677   to size_t*. This corrects a mismatch between the argument type and the
678   data member in ACE_Process from which the value comes.
680 . Removed some include files from ACE.h. These were not required for ACE.
681   The removed includes are OS_NS_math, Flag_Manip, Handle_Ops, Lib_Find,
682   Init_ACE, Sock_Connect.h. You may have to explicitly add one of these
683   in your own code to restore compiling.
685 . Further improvements of the Android port, still work in progress.
687 USER VISIBLE CHANGES BETWEEN ACE-6.2.0 and ACE-6.2.1
688 ====================================================
690 . Added support for Fedora 19, ended daily maintenance
691   for Fedora 17 and 18
693 . Added support for Embarcadero C++BuilderXE4 using
694   bcc32 in debug and release mode
696 . Improved support for Android
698 USER VISIBLE CHANGES BETWEEN ACE-6.1.9 and ACE-6.2.0
699 ====================================================
701 . None
703 USER VISIBLE CHANGES BETWEEN ACE-6.1.8 and ACE-6.1.9
704 ====================================================
706 . Added MinGW64 as supported platform
708 . Added support for GCC 4.8.0
710 USER VISIBLE CHANGES BETWEEN ACE-6.1.7 and ACE-6.1.8
711 ====================================================
713 . Small bug fixes
715 USER VISIBLE CHANGES BETWEEN ACE-6.1.6 and ACE-6.1.7
716 ====================================================
718 . Integrated several patches to simplify Debian/Ubuntu
719   packaging
721 USER VISIBLE CHANGES BETWEEN ACE-6.1.5 and ACE-6.1.6
722 ====================================================
724 . Added new event and sema initialization methods to OS_NS_Thread
725   to allow passing pre-initialized condition attributes providing
726   basic support for using time policies in ACE Event classes.
728 . Added TIME_POLICY support to ACE_Event classes to allow for
729   monotonic timer support for ACE Events.
731 . Added new regression test:
732   Monotonic_Manual_Event_Test
734 USER VISIBLE CHANGES BETWEEN ACE-6.1.4 and ACE-6.1.5
735 ====================================================
737 . When a ACE_Event_Handler registered for signals is unregistered,
738   whether by unregistering, returning -1 from handle_signal(), or by
739   the reactor closing, the ACE_Event_Handler::handle_close() hook will
740   be called. The close_mask passed will be ACE_Event_Handler::SIGNAL_MASK.
741   In previous versions, handle_close() would only be called when the
742   handle_signal() callback returned -1. This resolves Bugzilla #2368.
744 . Some initial ACE unit tests to validate the C++11 support of various
745   compilers
747 . Added support for OpenSuSE 12.2
749 USER VISIBLE CHANGES BETWEEN ACE-6.1.3 and ACE-6.1.4
750 ====================================================
752 . Added a new ACE_Time_Value derived template class (Time_Value_T.h):
754   template <class TIME_POLICY> class ACE_Time_Value_T
756   This template class overloads 4 new virtual methods from
757   the ACE_Time_Value base class to provide time policy aware
758   time values:
759   to_relative_time ()
760   to_absolute_time ()
761   now ()
762   duplicate ()
764 . Updated time policy classes to return ACE_Time_Value_T<> instantiations
765   for the corresponding time policy instead of 'common' time values.
767 . Added new ACE_Monotonic_Time_Policy (Monotonic_Time_Policy.h).
768   This class provides a monotonic time source for supported
769   platforms (Windows and POSIX platforms providing the required
770   clock_gettime() time source; currently verified for Windows and
771   Linux)
773 . Updated OS_NS_Thread to use the new time policy support in ACE_Time_Value
774   for (relative) time calculations and added new ACE_OS::condattr_setclock ()
775   method.
777 . Added TIME_POLICY support to ACE_Condition_Attributes to allow for
778   monotonic timer support for ACE_Condition.
780 . Added TIME_POLICY support to ACE_Message_Queue-s, ACE_Task-s and
781   related classes to enable support for monotonic timers in the timed
782   wait methods (ACE_Condition based). See docs/ACE-monotonic-timer.html
783   for how to use this.
785 . Added two new regression tests:
786   Monotonic_Task_Test
787   Monotonic_Message_Queue_Test
788   and updated the Bug_4055_Regression_Test to a fixed state.
790 USER VISIBLE CHANGES BETWEEN ACE-6.1.2 and ACE-6.1.3
791 ====================================================
793 . Added support for Oracle Solaris Studio 12 Update 3 (SunCC 5.12)
795 . Added new XML_Utils library which comes from DAnCE but is now also used
796   by OpenDDS
798 USER VISIBLE CHANGES BETWEEN ACE-6.1.1 and ACE-6.1.2
799 ====================================================
801 . Added compile time support for Windows CE 7, no runtime testing has
802   been performed
804 . The High Res Timer global scale factor on Windows is now 64bit, see bugzilla
805   3703 for the background of this. If you use the gsf in your code, use the
806   new ACE_High_Res_Timer::global_scale_factor_type type trait to not get
807   any conversion warnings
809 . Removed Tandem NSK v2/v3 support which resulted in cleanup throughout all
810   code. The emulations for ACE_INT64/ACE_UINT64 have been removed because no
811   platform is using them anymore
813 USER VISIBLE CHANGES BETWEEN ACE-6.1.0 and ACE-6.1.1
814 ====================================================
816 . Minor bug fixes
818 USER VISIBLE CHANGES BETWEEN ACE-6.0.8 and ACE-6.1.0
819 ====================================================
821 . Added compilation support for VxWorks 6.9, no runtime
822   testing has been performed
824 . Added ACE Run-length encoding compressor
826 . Fixed several Coverity reported issues
828 USER VISIBLE CHANGES BETWEEN ACE-6.0.7 and ACE-6.0.8
829 ====================================================
831 . Added support for MPC's new feature that creates dependency files for IDL
832   files when generating '-type gnuace' projects. Turned off by default, it
833   can be enabled in a features file or on the command line with
834   '-features ace_idl_dependencies=1'.
836 USER VISIBLE CHANGES BETWEEN ACE-6.0.6 and ACE-6.0.7
837 ====================================================
839 . Added a new method to ACE_Atomic_Op<LOCK, TYPE>, TYPE exchange (TYPE newval)
840   which does an atomic exchange of the new value with ACE_Atomic_Op's value
841   and returns the old value. The tests/Atomic_Op_Test.cpp test program has a
842   test case that exemplifies its usage; see the Exchange_Tester class.
844 . Added a new feature to timer queue templates classes: TIME_POLICY.
845   This feature is specified through a new template argument and provides the
846   timer queue with a policy for a timer (time of day) value. This feature is
847   intended to replace (in time) the gettimeofday setter method which has been
848   marked @deprecated. For now backwards compatibility is guaranteed.
849   The TIME_POLICY feature provides flexibility with regards to providing a timer
850   source to the timer queues as well as the possibility for a fully optimized
851   calling path.
852   A number of standard time policies are provided in ace/Time_Policy.h.
853   The tests/Timer_Queue_Test.cpp has been updated to reflect and exemplify these
854   changes.
856 . Added the TIME_POLICY feature also to countdown time class which has now
857   become a template (ace/Countdown_Time_T.h)
859 . Initial support for Microsoft Visual Studio 11
861 . Increased overall code quality by using Coverity and Klocwork
863 USER VISIBLE CHANGES BETWEEN ACE-6.0.5 and ACE-6.0.6
864 ====================================================
866 . Removed autoconf support, only traditional way of
867   compilation is shipped from now
869 . Add support for RHEL 6.1 64bit
871 USER VISIBLE CHANGES BETWEEN ACE-6.0.4 and ACE-6.0.5
872 ====================================================
874 . Improved support for Android and added the ability to run all ACE/TAO tests
875   automatically using the Android emulator
877 USER VISIBLE CHANGES BETWEEN ACE-6.0.3 and ACE-6.0.4
878 ====================================================
880 . Removed support for C++ Builder
882 . Added support for building with the Android NDK, at least r5c. This
883   is currently available for linux host platforms.
885 USER VISIBLE CHANGES BETWEEN ACE-6.0.2 and ACE-6.0.3
886 ====================================================
888 . Added support for GCC 4.6
890 USER VISIBLE CHANGES BETWEEN ACE-6.0.1 and ACE-6.0.2
891 ====================================================
893 . The ACE_wrappers/ace/OS.h file has been restored in order to ensure
894   build-time compatibility with older ACE versions. Its use will still
895   cause your build to incur more processing time than using the needed
896   ace/OS_NS_*.h files; however, you should be able to build OS.h-including
897   code without needing to replace it with OS_NS_* includes.
899 . Improved and simplified QNX support
901 . Changed rand_r() and getpwnam_r() to conform Single UNIX Specification.
903 . Fixed performance of send_v on windows when individual iovec elements
904   are particularly large.
906 USER VISIBLE CHANGES BETWEEN ACE-6.0.0 and ACE-6.0.1
907 ====================================================
909 . Added support for MinGW with GCC 4.5
911 USER VISIBLE CHANGES BETWEEN ACE-5.8.3 and ACE-6.0.0
912 ====================================================
914 . Changed the string format produced by ACE::timestamp() from the ctime
915   format "Day Mon dd hh:mm:ss yyyy" to ISO-8601 yyyy-mm-dd hh:mm:ss.mmmmmm.
916   This makes the time easier to collate and removes any dependence on locale.
917   The change affects the output from ACE_Log_Msg's %D format and both VERBOSE
918   and VERBOSE_LIGHT timestamps in addition to application-made direct calls
919   to ACE::timestamp().
921 . Removed GCC < 3 support
923 . A new build system hook was added for users to include site-private rules
924   in a build. If a file named "rules.private.GNU" in located in any build
925   directory it will get included from
926   $ACE_ROOT/include/makeinclude/rules.local.GNU. The "private_rules_file"
927   make variable can be set to override the name and/or location of the file.
928   If no such rules file exists, its absence is silently ignored. This
929   facility can be used, for example, to integrate a specialized code checker
930   into the build process.
932 USER VISIBLE CHANGES BETWEEN ACE-5.8.2 and ACE-5.8.3
933 ====================================================
935 . Two new methods were added to ACE_Pipe: close_read() and close_write().
936   These methods can be used to close individual pipe handles.
938 . The ACE::handle_ready() family of methods was changed to prefer using
939   poll() over select() on platforms where poll() is available. This
940   preference was previously only used if ACE_HAS_LIMITED_SELECT was set.
941   The ACE_HAS_LIMITED_SELECT choice is removed, making ACE_HAS_POLL the
942   setting that switches this preference. The driving reason for this
943   is that if select() is called to detect changes on a handle whose
944   values falls outside that which can safely be stored in an fdset,
945   the handle-setting macros/functions will set/clear bits outside
946   of the fdset. This results in very weird memory changes, often in
947   the stack, which are very hard to diagnose. poll()'s operation
948   does not suffer from this affect. With the growing use of large
949   numbers of handles and use of ACE_Dev_Poll_Reactor on Linux,
950   the rate at which this problem was cropping up was increasing.
952 . Added a simple helper ACE::is_equal() which compares equality of two
953   objects without using operator==. This is useful for comparing floating
954   point values.
956 . Removed all deprecated methods, arguments, files, classes, macros and
957   anything else we kept for years.
959 . Removed Irix/Tru64/SCO/Uniware/Cray support
961 . ACE_Pair has been removed. Users should now use std::pair.
963 . This is the last micro release that will work with GCC < 3, after x.8.3
964   support for GCC < 3 will be removed
966 USER VISIBLE CHANGES BETWEEN ACE-5.8.1 and ACE-5.8.2
967 ====================================================
969 . Added support for the Microsoft Visual Studio 2010 IDE (vc10)
971 . Removed complete support for emulated C++ exceptions
973 USER VISIBLE CHANGES BETWEEN ACE-5.8.0 and ACE-5.8.1
974 ====================================================
976 . Added support for Microsoft Visual Studio 2010 using nmake
978 . Reduced the amount of doxygen pages generated, the original settings caused
979   a doxygen generated html package of 1.4GB which was way too large
981 . Extended ACE INet addon library with:
982   * HTTP Basic Authentication
983   * SSL/HTTPS support.
984   * Proxy CONNECT tunneling.
986 USER VISIBLE CHANGES BETWEEN ACE-5.7.9 and ACE-5.8.0
987 ====================================================
989 . There are two new ACE_Time_Value methods for getting and setting millisecond
990   values to/from ACE_UINT64 values:
992       ACE_UINT64 ACE_Time_Value::get_msec () const
993       void ACE_Time_Value::set_msec (const ACE_UINT64 &ms)
995   The former is a replacement for the existing msec(ACE_UINT64&) methods that
996   are "getter" methods whose signatures look confusingly like "setters". See
997   Bugzilla #3336 for the history behind this change.
999   The latter is for consistency and clarity.
1001 . Added ACE INet addon library for Inet protocol clients (and possibly
1002   servers at some point) like http://, ftp:// etc.
1003   The library implements standard C++ iostream wrapper classes for
1004   ACE Svc_Handler and Reactor based input/output handling, URL classes
1005   and protocol handler classes.
1006   NOTE: This is work in progress! There is no guarentee that the API
1007   won't change in the next few releases.
1008   Protocol handling is currently restricted to client side download
1009   requests for HTTP and FTP.
1010   Handling for upload requests should be added in the near future as well
1011   as HTTP Basic Authentication.
1013 USER VISIBLE CHANGES BETWEEN ACE-5.7.8 and ACE-5.7.9
1014 ====================================================
1016 . ACE's default makefiles (traditional ACE/GNU, not autoconf/automake)
1017   now support installation with "make install".
1018   Please see the ACE-INSTALL.html file for instructions.
1020 . Support for the ARCH make variable has been enhanced to apply to executables
1021   (in addition to libraries and object files), and the ARCH feature has been
1022   integrated into the MPC-generated makefiles (to work with MPC's requires
1023   and avoids features).
1025 USER VISIBLE CHANGES BETWEEN ACE-5.7.7 and ACE-5.7.8
1026 ====================================================
1028 . ACE now uses GCC builtin Atomic instructions for short,
1029   unsigned short, long, unsigned long, int, unsigned int,
1030   and bool. This makes our Atomic_Op around 7 times faster
1032 . ACE Service Configuration Framework now process first service
1033   configuration files and then command-line directives. Thus if
1034   application uses both service configuration files and command-line
1035   directives then the command-line directives may override results of
1036   directives in the configuration files. At the same time if the
1037   application uses only the default svc.conf file and command-line
1038   directives then the directives from svc.conf can not override
1039   results of the user provided command-line directives.
1041 . ACE_Dev_Poll_Reactor now dispatches notifications in only one thread at
1042   a time. This brings notification handling more in line with behavior in
1043   other Reactor implementations.
1045 USER VISIBLE CHANGES BETWEEN ACE-5.7.6 and ACE-5.7.7
1046 ====================================================
1048 . Integrated fix for bug 3104 and regression test for
1049   interval timers.
1051 . Added support for GCC builtin Atomic instructions which
1052   are enabled with GCC >= 4.1 for PPC32/PPC64/IA64
1054 . Improved autoconf support for debian
1056 . Added support for -mcpu and -mtune. Add TCPU=.. to your
1057   environment/platform_macros.GNU to specify you cpu and
1058   than add cpumodelflag=1 and/or tunemodelflag=1. Using
1059   this with IBM Cell increased the performance significantly
1061 USER VISIBLE CHANGES BETWEEN ACE-5.7.5 and ACE-5.7.6
1062 ====================================================
1064 . Added support for iPhone/iPod Touch/iPad. The following
1065   environment variables are needed:
1067   IPHONE_TARGET, should be set to either SIMULATOR or
1068   HARDWARE. Set to HARDWARE if you want to deploy
1069   on the iPhone/iPod Touch/iPad device.
1071   IPHONE_VERSION, should be set to 3.1.2 or 3.2. One can
1072   set the version to any future or past versions, but
1073   only 3.1.2 and 3.2 have been tried.
1075   Note that one has to compile ACE/TAO statically as
1076   it is believed that the iPhone OS does not support
1077   dynamic loading of external libraries. The usual
1078   procedure of cross compiling ACE/TAO applies
1079   (such as setting HOST_ROOT environment variable).
1081 . Added support for Embarcadero C++ Builder 2010
1083 . Added option to print a given ACE_Time_Value in the log
1084   message instead of system supplied timestamp as in %T
1085   and %D.
1086   The option is implemented as a variant of the %D/%T
1087   options by using the '#' flag character like '%#D' or
1088   '%#T'. When using this flag an ACE_Time_Value pointer is
1089   expected in the argument list supplied with the log message.
1090   This fixed Bugzilla #3221.
1092 . Fixed problems with ACE_INET_Addr::is_multicast() on
1093   little endian platforms. This fixed bugzilla #3729.
1095 . Added compilation support for VxWorks 6.8, no runtime
1096   testing has been performed
1098 USER VISIBLE CHANGES BETWEEN ACE-5.7.4 and ACE-5.7.5
1099 ====================================================
1101 . Added MacOSX Snow Leopard support
1103 . Added strsignal() wrapper
1105 . Improved LynxOS support
1107 . Updated Interix port
1109 . Fixed MinGW compilation problems
1111 USER VISIBLE CHANGES BETWEEN ACE-5.7.3 and ACE-5.7.4
1112 ====================================================
1114 . ACE_CDR::consolidate now returns an int, 0 is ok, -1 is failure
1116 . Fixed a bug in the realclean feature of the GNU makefiles
1118 . Improved Sun Studio for Linux support
1120 . Improved OpenBSD support
1122 USER VISIBLE CHANGES BETWEEN ACE-5.7.2 and ACE-5.7.3
1123 ====================================================
1125 . C++ Builder 2009 Update 3 is the only C++Builder that is supported, older
1126   and newer compilers are not supported anymore
1128 . Made final changes for the CEGCC port
1130 . Added a set of tests to validate C++ compiler and the stl implementation
1131   they ship.
1133 . HP-UX PARISC aCC < 3.80 are deprecated and can't be used anymore. Upgrade
1134   to aCC 3.80 or newer
1136 USER VISIBLE CHANGES BETWEEN ACE-5.7.1 and ACE-5.7.2
1137 ====================================================
1139 . Borland C++ makefiles aren't shipped anymore as part of the release
1140   but have to be generated by the user
1142 . Refactored gperf to have its own shared library so that we can reuse
1143   that in TAO
1145 . Added support for SuSE Enterprise 10
1147 . ACE_Configuration_Heap::open() now returns -1 with errno EBUSY if it is
1148   called multiple times. Previous versions would allow multiple calls to
1149   open() but leak resources.
1151 USER VISIBLE CHANGES BETWEEN ACE-5.7.0 and ACE-5.7.1
1152 ====================================================
1154 . Added support for Sun Studio 12 Update Pack 1
1156 . Fixed compile problems when using Windows CE x86 release mode
1158 . Fixed compile problems for FreeBSD
1160 USER VISIBLE CHANGES BETWEEN ACE-5.6.9 and ACE-5.7.0
1161 ====================================================
1163 . Added support for the VxWorks vxAtomicLib which is available with VxWorks 6.6
1164   and newer. If you don't want to use this library undef ACE_HAS_VXATOMICLIB
1165   in your config.h file
1167 . Added support for C++ Builder 2009 Update 3
1169 . Added support for ACE/TAO using the CEGCC project
1171 . Added support for upcoming Fedora 11 and OpenSuSE Factory
1173 USER VISIBLE CHANGES BETWEEN ACE-5.6.8 and ACE-5.6.9
1174 ====================================================
1176 . Removed Borland/CodeGear C++ Builder 2007 support.  If you'd like to
1177   fund this support please let us know.
1179 . Removed VxWorks 5.5.x, 6.2, and 6.3 support.  If you'd like to fund
1180   this support please let us know.
1182 . Improved Unicode support.
1184 . Added support for the native Windows Vista and Windows Server 2008
1185   condition variables. These has to be enabled at compile time, and when
1186   enabled the application can only run on Vista or Server 2008.  Add
1187   ACE_HAS_WTHREADS_CONDITION_VARIABLE to your config.h file to enable
1188   these
1190 . Fixed a bug when trying to read a file of 1 byte when unicode is
1191   enabled
1193 . Improved the Windows CE port
1195 . Fixed several Klocwork reported issues
1197 . Added support for MinGW 3.15
1199 . Added support for Incredibuild, which is an MSVC++ feature that
1200   optimizes compiles via distributing builds.
1202 USER VISIBLE CHANGES BETWEEN ACE-5.6.7 and ACE-5.6.8
1203 ====================================================
1205 . Added a new function ACE::isdotdir() which determines if a specified
1206   pathname is "dot dir" (ie. "." or ".."). ACE::isdotdir() is significantly
1207   faster than pair of strcmp() calls.
1209 . Last micro release that is maintained for Borland/CodeGear C++
1210   Builder 2007 and Intel C++ on Windows.
1212 . Fixed crash when ACE thread tries to inherit the logging attributes
1213   from non ACE threads.
1215 . Fixed many small compile and test errors that occur on some platforms.
1217 . Fixed log output formatting on some platforms.
1219 . Bugs fixed:  2748, 3164, 3480, 3494, 3502, 3541, 3542, 3544, 3557.
1221 USER VISIBLE CHANGES BETWEEN ACE-5.6.6 and ACE-5.6.7
1222 ====================================================
1224 . Changed the automake build's feature test for a "usable" config
1225   to warn on failure instead of exiting with an error.  This should
1226   make it easier to diagnose configure failures, as the script will
1227   now generate a config.h file even when the test fails.
1229 . Removed borland MPC template, use the bmake template from now
1231 . Added Windows Mobile 6 support and improved the WinCE port
1233 . Removed BCB6 and BCB2006 support
1235 . Added BCB2009 MPC template
1237 . Updated stat struct on Windows CE to match the stat struct on other
1238   platforms so that application code can be written portable
1240 . Added new ACE_OS wrappers: raise, atof, atol, isblank, isascii,
1241   isctype, and iswctype
1243 . Added ACE_OS wrapper for narrow-char version of strtoll.
1245 . ACE_OS wrappers for wide-char versions of strtol, strtoul,
1246   strtoll, and strtoll.
1248 . Added Visual Studio 2010 (vc10) support
1250 . Added a new feature for the "Traditional Make" build facility to allow
1251   building for multiple architectures out of a single source directory.
1252   To use this facility, set the ARCH make variable. The ARCH value will be
1253   used to add a subdirectory layer below the source directory where the
1254   traditional .shobj, .obj, etc. directories will be placed.
1256 . Added support for HP-UX 11iv3 on Integrity using aC++
1258 . ACE (and TAO) can now be built using GNU make and the Microsoft Visual C++
1259   compiler and linker.  See include/makeinclude/platform_win32_msvc.GNU for
1260   more details.
1262 . Added support for FC10
1264 USER VISIBLE CHANGES BETWEEN ACE-5.6.5 and ACE-5.6.6
1265 ====================================================
1267 . Added an option to the ACE_Process_Options class to use a wchar_t
1268   environment buffer on Windows.
1270 . A new configure option, --enable-rcsid, was added to the autoconf build.
1271   This is used to embed RCS IDs in object files.
1273 . A new method was added: void ACE_Time_Value::msec (ACE_UINT64&)
1274   This method, like the existing msec(ACE_UINT64&)const method, obtains the
1275   time value in milliseconds and stores it in the passed ACE_UINT64 object.
1276   This method was added so that msec(ACE_UINT64&) can be called on both
1277   const and non-const ACE_Time_Value objects without triggering compile errors.
1278   Fixes Bugzilla #3336.
1280 . Added ACE_Stack_Trace class to allow users to obtain a stack trace
1281   within their application on supported platforms. A new conversion
1282   character, the question mark, was added to ACE_Log_Msg for stack
1283   trace logging.
1285 . Added iterator support to ACE_Message_Queue_Ex class. The resulted in
1286   the addition of ACE_Message_Queue_Ex_Iterator class and
1287   ACE_Message_Queue_Ex_Reverse_Iterator class.
1289 . Renamed gperf to ace_gperf to prevent clashes with the regular gperf
1290   tool that is available in linux distributions
1292 . Added support for FC9
1294 . Added support for OpenSuSE 11.0
1296 . Improved support for GCC 4.2 and 4.3
1298 . Added support for CodeGear C++ Builder 2009
1300 USER VISIBLE CHANGES BETWEEN ACE-5.6.4 and ACE-5.6.5
1301 ====================================================
1303 . Added new Monitoring lib that can be used to store and retrieve
1304   counters. This is disabled by default because it is not 100%
1305   finished yet, with the next release it will be enabled by default
1307 . Fixed bug in ACE_Service_Config when it was used from a thread
1308   not spawned by ACE
1310 . Add VxWorks 6.x kernel mode with shared library support to ACE
1312 . Extended the implementation of Unbounded_Set, which has been
1313   renamed Unbounded_Set_Ex, to accept a second parameter which is
1314   a comparator that implements operator() which returns true if
1315   the items are equivalent.  Unbounded_Set has been reimplemented
1316   in terms of Unbounded_Set_Ex using a comparator that uses operator==,
1317   which captures the previous behavior.
1319 . Added support for Intel C++ on MacOSX
1321 USER VISIBLE CHANGES BETWEEN ACE-5.6.3 and ACE-5.6.4
1322 ====================================================
1324 . Reworked the relationship between ACE_Service_Config and
1325   ACE_Service_Gestalt
1327 . Improved autoconf support
1329 . Improved AIX with gcc support
1331 . Improved OpenVMS support
1333 . Improved VxWorks support
1335 USER VISIBLE CHANGES BETWEEN ACE-5.6.2 and ACE-5.6.3
1336 ====================================================
1338 . Deprecated Visual Age 5 and older
1340 . Closed a rare race condition hole whereby ACE_Atomic_Op<> function
1341   pointers would not be fully initialized prior to use.  See bugzilla
1342   3185 for details.
1344 . Tweaks to support MacOS X Leopard (10.5 and 10.5.1) on Intel
1346 . Fixed compile problems with MinGW with GCC 4.2. Do note that we do see
1347   much more test failures then when using GCC 3.4.
1349 . Changed to use synchronous exception handling with msvc 8/9 which is the
1350   default. Asynchrous exception handling does catch access violations but
1351   it leads to lower performance and other problems. See also bugzilla 3169
1353 . Make ace_main extern C with VxWorks so that it doesn't get mangled
1355 . Fixed compile errors and warnings for VxWorks 6.6
1357 . Added an MPC generator for the WindRiver Workbench 2.6 which is shipped
1358   with VxWorks 6.4
1360 . Added support for CodeGear C++ Builder 2007 with December 2007 update
1361   installed
1363 . Added support for VxWorks 5.5.1
1365 . Implemented the const reverse iterator for ACE_Hash_Map_Manager_Ex
1367 . Increased support for using ACE_Hash_Map_Manager_Ex with STL <algorithm>
1368   functions based on latest standard C++ draft
1370 USER VISIBLE CHANGES BETWEEN ACE-5.6.1 and ACE-5.6.2
1371 ====================================================
1373 . ACE-ified the UUID class, which will change user applications slightly.
1375 . Added support for Sun Studio 12
1377 . Added support for Intel C++ 10.1
1379 . Fixed runtime problems with VxWorks 6.x in kernel mode, several improvements
1380   have been made to ACE, but also some problems in the VxWorks kernel have
1381   been found for which WindRiver has made patches.
1383 . Added support for VxWorks 6.5 kernel mode
1385 . Added support for MacOS 10.5
1387 . Support for MacOS 10.4 is now deprecated.
1389 . Added support for OpenSuSE 10.3
1391 . Added support for RedHat 5.1
1393 . Added support for Microsoft Visual Studio 2008
1395 . Added support for Fedora Core 8
1397 . Added support for Ubuntu 7.10
1399 . With Ubuntu 7.04 and 7.10 we can't use visibility, that results in
1400   unresolved externals when building some tests. With lsb_release we
1401   now detect Ubuntu 7.04 and 7.10 automatically and then we disable
1402   visibility
1404 . Removed deprecated (un)subscribe methods from ACE_SOCK_Dgram_Mcast
1406 . Added an additional replace() method to ACE_OuptutCDR for replacing a
1407   ACE_CDR::Short value. Also added write_long_placeholder() and
1408   write_short_placeholder() to properly align the stream's write pointer,
1409   write a placeholder value and return the placeholder's pointer. The pointer
1410   can later be used in a call to replace() to replace the placeholder with a
1411   different value.
1413 . Initial support for VxWorks 6.6
1415 . Removed support for pthread draft 4, 6, & 7. This makes the ACE threading
1416   code much cleaner
1418 . Improved autoconf support
1420 . Fixed TSS emulation problems
1422 . Changed ACE_thread_t and ACE_hthread_t to int for VxWorks kernel mode. All
1423   thread creation methods do have an additional const char* argument to
1424   specify the task name, this now also works with pthread support enabled
1426 . Use bool in much more interfaces where this is possible
1428 . Added support for Debian Etch
1430 . Fixed ACE CDR LongDouble support on VxWorks 6.x
1432 . Added Microsoft Visual Studio 2008 project files to the release packages
1434 . Fixed a few bugs in the ACE_Vector template
1436 USER VISIBLE CHANGES BETWEEN ACE-5.6 and ACE-5.6.1
1437 ====================================================
1439 . Added support for CodeGear RAD Studio 2007
1441 . Added support for CodeGear C++ Builder 2007 Update 3
1443 . Modified the definiton of ACE_DEFAULT_THREAD_KEYS on Windows so it
1444   is based on the version of the OS as defined by Microsoft in this web
1445   page: http://tinyurl.com/2jqcmd
1446   This fixes bugzilla #2753
1448 USER VISIBLE CHANGES BETWEEN ACE-5.5.10 and ACE-5.6
1449 ====================================================
1451 . OpenVMS 8.3 on IA64 port
1453 . Added autoconf support for Intel C++ 10.0
1455 . Improved autoconf support on Linux, Solaris, NetBSD and HPUX
1457 . CodeGear C++ Builder 2007 Update 2 support
1459 . The netsvcs's client logging daemon has a new configuration option,
1460   -llocal-ip[:local-port], which can be used to specify the local IP
1461   address and port number for the client logging daemon's connection to
1462   the server logging daemon. If the -l option is specified with an IP
1463   address but not a port number, an unused port number is selected.
1465 . A new ACE+TAO port to LabVIEW RT 8.2 with Pharlap ETS. The host build
1466   environment is Windows with Microsoft Visual Studio .NET 2003 (VC7.1).
1467   Please see the ACE-INSTALL.html file for build instructions.
1469 USER VISIBLE CHANGES BETWEEN ACE-5.5.9 and ACE-5.5.10
1470 ====================================================
1472 . The ACE_utsname struct, used in the ACE_OS::uname() function when the
1473   platform doesn't provide the standard utsname struct, was changed. It
1474   defines a number of text fields and their types were changed from
1475   ACE_TCHAR[] to char[] in order to be consistent with all other platforms.
1476   This removes the need to write different code for platforms where
1477   ACE_LACKS_UTSNAME_T is set and that have wide characters (most probably
1478   Windows). Fixes Bugzilla #2665.
1480 . The ACE::daemonize() "close_all_handles" parameter was changed from
1481   an "int" to a "bool" to better reflect how it is used.
1483 . VxWorks 6.5 support. Compilation of the core libraries has been validated
1484   but no runtime testing has been performed.
1486 . CodeGear C++ Builder 2007 support.
1488 . The FaCE utility was moved from the ACE_wrappers/apps directory to
1489   ACE_wrappers/contrib. It is used for testing ACE+TAO apps on WinCE.
1490   See the ACE_wrappers/contrib/FaCE/README file for more information.
1492 . ACE_INET_Addr::set (u_short port, char *host_name, ...) now favors IPv6
1493   addresses when compiled with ACE_HAS_IPV6 defined and the supplied address
1494   family is AF_UNSPEC. This means that if host_name has an IPv6 address in
1495   DNS or /etc/hosts, that will be used over an IPv4 address. If no IPv6
1496   address exists for host_name, then its IPv4 address will be used.
1498 . Intel C++ 10.0 support
1500 . Support for the version of vc8 for 64-bit (AMD64) shipped with the Microsoft
1501   Platform SDK.
1503 . Fixed ACE_Vector::swap() (bugzilla #2951).
1505 . Make use of the Atomic_Op optimizations on Intel EM64T processors. The
1506   Atomic_Op is now several times faster on EM64T then with previous versions
1507   of ACE
1509 USER VISIBLE CHANGES BETWEEN ACE-5.5.8 and ACE-5.5.9
1510 ====================================================
1512 . Use Intel C++ specific optimizations for Linux on IA64
1514 . Improved support for ACE_OS::fgetc. Added support for ACE_OS::fputc,
1515   ACE_OS::getc, ACE_OS::putc and ACE_OS::ungetc.
1517 . Added support for ACE_OS::log2(double) and improved support for
1518   ACE::log2(u_long).
1520 . Shared library builds on AIX now produce a libxxx.so file instead of the
1521   previous practice of producing libxxx.a(shr.o).
1523 . GCC 4.1.2 that comes with Fedora 7 seems to have a fix for the visibility
1524   attribute we use for the singletons. F7 users will therefore need to
1525   define the following in your config.h file.
1526   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1528 . Fixed (rare) problem in TP_Reactor where incorrect event handler was
1529   resumed.
1531 . Reduced footprint on some platforms, particularly those that use
1532   g++ >= 3.3.
1534 USER VISIBLE CHANGES BETWEEN ACE-5.5.7 and ACE-5.5.8
1535 ====================================================
1537 . Extended ACE_Event constructor with optional LPSECURITY_ATTRIBUTES
1538   argument
1540 . Added support for QT4
1542 . Added support to integrate with the FOX Toolkit (www.fox-toolkit.org)
1544 . Added support for Microsoft Visual Studio Code Name "Orcas", which is
1545   the msvc9 beta
1547 . Added ability to provide an optional priority when calling
1548   ACE_Message_Queue_Ex::enqueue_prio(). There was previously no way
1549   to specify a priority for queueing.
1551 . Removed support for Visual Age on Windows.
1553 . ACE will compile once again with ACE_LACKS_CDR_ALIGNMENT #defined.
1555 . ACE_Process_Manager::terminate() no longer removes the process from the
1556   process descriptor table; the pid remains available in order to call
1557   ACE_Process_Manager::wait().
1559 USER VISIBLE CHANGES BETWEEN ACE-5.5.6 and ACE-5.5.7
1560 ====================================================
1562 . ACE 5.5 contained a set of pragmas which prevented Visual Studio 2005 (VC8)
1563   from issuing warnings where C run-time functions are used but a more
1564   secure alternative is available. For more information on the C run-time
1565   issues and Microsoft's response, please see the following MSDN page:
1566   http://msdn2.microsoft.com/en-us/library/8ef0s5kh(VS.80).aspx.
1567   In this beta, the pragmas which prevented the warnings have been removed.
1568   The ACE library has been reviewed and most of the use of "unsafe" functions
1569   has been fixed where possible. Since not all of the warnings emanating from
1570   ACE are situations that can or should be fixed, the ACE VC8 projects will
1571   prevent the warnings while building the ACE kit and its contained examples,
1572   tests, etc. The warnings are disabled by adding Microsoft-specified macros
1573   to the compile line via MPC. If desired, the warnings can be re-enabled by
1574   regenerating the project files with different MPC features. Note, however,
1575   that while ACE without warnings caused by the new C run-time functions, your
1576   application builds may trigger these warnings either by use of the "unsafe"
1577   C run-time functions or via use of an inlined ACE_OS method which uses it.
1578   If the warning is caused by an ACE_OS method, there is a more safe alternate
1579   available, probably located by appending _r to the method name (e.g.,
1580   instead of using ACE_OS::ctime(), use ACE_OS::ctime_r()).
1581   There are other cases where the compiler may have issued warnings and ACE
1582   prevented this via a #pragma. These #pragmas have been removed as well.
1583   This may cause your application builds to trigger more warnings from VC8
1584   than past ACE versions. You should review your code and either correct
1585   the code or disable the warnings locally, as appropriate.
1587 . The "release" argument to a number of ACE_String_Base<> methods was changed
1588   from int to bool to more accurately reflect its purpose. The following
1589   methods were changed:
1591             ACE_String_Base (const CHAR *s,
1592                              ACE_Allocator *the_allocator = 0,
1593                              int release = 1);
1594           to
1595             ACE_String_Base (const CHAR *s,
1596                              ACE_Allocator *the_allocator = 0,
1597                              bool release = true);
1599             ACE_String_Base (const CHAR *s,
1600                              size_type len,
1601                              ACE_Allocator *the_allocator = 0,
1602                              int release = 1);
1603           to
1604             ACE_String_Base (const CHAR *s,
1605                              size_type len,
1606                              ACE_Allocator *the_allocator = 0,
1607                              bool release = true);
1609             void set (const CHAR * s, int release = 1);
1610           to
1611             void set (const CHAR * s, bool release = true);
1613             void set (const CHAR * s, size_type len, int release);
1614           to
1615             void set (const CHAR * s, size_type len, bool release);
1617             void clear (int release = 0);
1618           to
1619             void clear (bool release = false);
1621   Since ACE_String_Base forms the basis of the ACE_CString and ACE_TString
1622   classes, this may ripple out to user application code. If you encounter
1623   errors in this area while building your applications, replace the
1624   int argument you are passing to the method now with either true or false.
1626 . Solutions for the eVC3/4 platform have been removed from this
1627   release.  Note that we package WinCE projects/workspaces for use
1628   with VC8.
1630 . There were 3 new ACE_Log_Msg logging format specifiers added to make logging
1631   easier for types that may change sizes across platforms. These all take one
1632   argument, and the new formats are:
1633     %b - format a ssize_t value
1634     %B - format a size_t value
1635     %: - format a time_t value
1637 . The ace/Time_Request_Reply.h and ace/Time_Request_Reply.cpp files were
1638   moved from $ACE_ROOT/ace to $ACE_ROOT/netsvcs/lib. The time arguments in
1639   the public API to ACE_Time_Request were changed from ACE_UINT32 to time_t
1640   and the portions of the on-wire protocol that contains time was changed from
1641   ACE_UINT32 to ACE_UINT64. Thus, code that uses the ACE_Time_Request class
1642   to transfer time information will not interoperate properly with prior
1643   ACE versions. This will affect uses of the netsvcs time clerk/server.
1645 . The portion of the ACE_Name_Request class that carries the on-wire seconds
1646   portion of a timeout value was changed from ACE_UINT32 to ACE_UINT64. This
1647   means that Name server/clients at ACE 5.5.7 and higher will not interoperate
1648   properly with previous ACE versions' name servers/clients.
1650 . In the ACE_Log_Record (ACE_Log_Priority, long, long) constructor, the
1651   second argument, long time_stamp, was changed to be of type time_t. This
1652   aligns the type with the expected value, a time stamp such as that returned
1653   from ACE_OS::time().
1655 . Added support for VxWorks 6.x cross compilation using a Windows host
1656   system
1658 . Added support for VxWorks 6.x using the diab compiler
1660 . The destructor of ACE_Event_Handler no longer calls
1661   purge_pending_notifications().  Please see bugzilla #2845 for the full
1662   rationale.
1663   (http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2845)
1665 USER VISIBLE CHANGES BETWEEN ACE-5.5.5 and ACE-5.5.6
1666 ====================================================
1668 . The ACE_TYPENAME macro has been added to those that are not
1669   available when the ACE_LACKS_DEPRECATED_MACROS config option is set
1670   (it is not set by default). You are encouraged to replace the use of
1671   ACE_TYPENAME with the C++ typename keyword before the ACE_TYPENAME
1672   macros is removed from ACE in the future.
1674 . A new script, rm_exception_macros.pl, has been added to help users
1675   remove the use of the ACE exception macros from their own code.
1677 USER VISIBLE CHANGES BETWEEN ACE-5.5.4 and ACE-5.5.5
1678 ====================================================
1680 . The prebuild MPC keyword is now supported by the gnuace project type.
1681   This fixes Bugzilla #2713.
1683 . Support for Windows earlier than NT 4 SP2 was removed. ACE will not build
1684   for Windows 95, 98, Me, etc. out of the box any longer.
1686 . Reformat stringified IPv6 addresses to use [addr]:port when printing
1687   addresses that contain ':' such as "::1".
1689 . Added method to ACE_INET_Addr to determine if address is IPv6 or
1690   IPv4 multicast.
1692 . Fixed a bug in ACE_Async_Timer_Adapter_Timer_Queue_Adapter<TQ> where the
1693   gettimeofday function of the timer queue was ignored when setting the alarm.
1695 . Fixed a problem where, on Solaris 9 onwards, calling
1696   ACE_OS::thr_create(THR_NEW_LWP) more than 2^15 (65535) times in a
1697   process will fail.  See changelog entry from "Wed Jan 3 22:31:05 UTC
1698   2007 Chris Cleeland <cleeland_c@ociweb.com>" for more information.
1700 . Fixed a bug in ACE_QtReactor where the two select() calls in that function
1701   might select on different handler sets.
1703 . ACE_SOCK_IO::recvv(iovec[], size_t, const ACE_Time_Value* = 0) and
1704   ACE_SOCK_IO::sendv (const iovec[], size_t, const ACE_Time_Value* = 0) methods
1705   were changed to specify the iovec count argument as int instead of size_t
1706   since it gets reduced to int in the underlying OS calls (usually).
1708 . The following deprecated methods were removed:
1710     ssize_t ACE_SOCK_IO::recv (iovec iov[],
1711                                size_t n,
1712                                const ACE_Time_Value *timeout = 0) const;
1714     ssize_t ACE_SOCK_IO::recv (iovec *io_vec,
1715                                const ACE_Time_Value *timeout = 0) const;
1717     ssize_t ACE_SOCK_IO::send (const iovec iov[],
1718                                size_t n,
1719                                const ACE_Time_Value *timeout = 0) const;
1721     These were previously replaced with more specific recvv() and sendv()
1722     methods.
1724 . The ACE_Service_Repository::find(const ACE_TCHAR name[],
1725                                    const ACE_Service_Type **srp = 0,
1726                                    int ignore_suspended = true) const
1727   method's 'ignore_suspended' parameter was changed from int to bool to
1728   reflect it's purpose as a yes/no indicator.
1730 . Added --enable-ace-reactor-notification-queue configure script
1731   option to the autoconf build for enabling the Reactor's userspace
1732   notification queue (defines ACE_HAS_REACTOR_NOTIFICATION_QUEUE in
1733   config.h).
1735 . The int ACE_OutputCDR::consolidate(void) method was contributed by
1736   Howard Finer at Sonus Networks. This method consolidates any continuation
1737   blocks used by an ACE_OutputCDR object into a single block. It's useful for
1738   situations which require access to a single memory area containing the
1739   encoded stream, regardless of its length, when the length cannot be known
1740   in advance.
1742 . There are a number of new methods defined on ACE_String_Base<CHAR>:
1744         size_t capacity (void) const:  This method returns the number
1745             of allocated CHAR units in the string object.
1747         void fast_resize (size_t): This method manage the sizing/reallocating
1748             of the string, but doesn't do the memory setting of resize().
1750         bool operator!= (const CHAR *) const
1751         bool operator== (const CHAR *) const: These methods compare the
1752             string with a nul-terminated CHAR* string.
1754         nonmember functions operator== and operator!= where also added
1755             that compare const ACE_String_Base and const CHAR*; these make
1756             it possible to switch ACE_String and CHAR* on either side of
1757             the operator.
1759   Thank you to Kelly Hickel <kfh at mqsoftware dot com> for these additions.
1761 . There are 2 new build options on the traditional make command:
1762   dmalloc and mtrace. When specified at build time (e.g. make mtrace=1)
1763   the PLATFORM_DMALLOC_CPPFLAGS and/or PLATFORM_MTRACE_CPPFLAGS values
1764   are added to CPPFLAGS. For dmalloc, the PLATFORM_DMALLOC_LDFLAGS and
1765   PLATFORM_DMALLOC_LIBS are added to LDFLAGS and LIBS, respectively.
1766   Thank you to Howard Finer for supplying these additions.
1768 . Added the ability to specify additional purify and quantify command-line
1769   options by setting PLATFORM_PURIFY_OPTIONS and PLATFORM_QUANTIFY_OPTIONS,
1770   respectively. Thank you to Howard Finer for supplying these additions.
1772 . Added the ability to use trio (http://sourceforge.net/projects/ctrio/)
1773   if platform lacks decent support for vsnprintf. trio support is
1774   enabled by defining trio=1 in plaform_macros.GNU
1776 . Removed Irix 5, DGUX, and m88k support
1778 . Improved LynxOS 4.2 support
1780 . VxWorks 6.4 support
1782 . Added support for FC6. Because the GCC 4.1.1 version that gets shipped
1783   has a fix for the visibility attribute we use for the singletons
1784   you will need to define the following in your config.h file. This can't be
1785   done automatically because SuSE 10.2 gets shipped with GCC 4.1.2 but
1786   doesn't have the same fix
1787   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1789 . RTEMS port
1791 USER VISIBLE CHANGES BETWEEN ACE-5.5.3 and ACE-5.5.4
1792 ====================================================
1794 . Added appropriate intptr_t and uintptr_t typedefs on platforms that
1795   don't provide them (i.e. when ACE_LACKS_INTPTR_T is defined).
1797 . Added ability to explicitly choose support for 32 bit or 64 bit file
1798   offsets on all platforms.  Define the _FILE_OFFSET_BITS preprocessor
1799   symbol to either 32 or 64 to choose the desired number of file
1800   offset bits.  This preprocessor symbol is supported natively by most
1801   UNIX and UNIX-like operating systems, and supported by ACE on
1802   Windows.  Use the new ACE_OFF_T typedef to refer to file offsets
1803   across UNIX and Windows portably.
1805 . 64-bit file offsets are now enabled by default in Win64
1806   configurations.
1808 . Improved support for 64 bit platforms (64 bit addresses, etc).
1810 . Added STL-style traits, iterators and a swap() method to the
1811   ACE_Array_Base<> class template.
1813 . Added STL-style traits and iterator accessors to the
1814   ACE_Hash_Map_Manager_Ex<> class template, as well as new find() and
1815   unbind() methods that return (as an "out" parameter) and accept
1816   iterators, respectively.
1818 . Greatly improved event handler dispatch performance in
1819   select()-based reactors (e.g. ACE_Select_Reactor and ACE_TP_Reactor)
1820   for large handle sets on Windows. Previous event handler search
1821   were linear, and are now constant on average.
1823 . Addressed a number of Coverity errors (CHECKED_RETURN, DEADCODE,
1824   LOCK, USE_AFTER_FREE, RESOURCE_LEAK, FORWARD_NULL).
1826 . Added STL-style "element_type" trait to all ACE auto_ptr class
1827   templates.
1829 . Removed support for LynxOS 3.x.
1831 . Resolved Bugzilla #2701 to ensure fini() is called for all
1832   Service Objects upon calling ACE_Service_Config::close()
1834 . VxWorks 5.5.2 has been tested, for ACE the support is exactly
1835   the same as for VxWorks 5.5.1. No specific defines or flags have
1836   to be used.
1838 USER VISIBLE CHANGES BETWEEN ACE-5.5.2 and ACE-5.5.3
1839 ====================================================
1841 . Added the base projects for executionmanager_stub and plan_generator.
1843 . Added the ACE_Hash_MultiMap_Manager class and its test file.
1845 . Changed the ACE_Synch_Options::operator[] method to return bool rather than
1846   int. The value returned is a yes/no indication of whether or not the
1847   specified option(s) are set in the object.
1849 . Changed the prototype(s) for ACE::debug () to return (and take) a
1850   bool. This is consistent with the original intent for this
1851   feature. If you have been using it like 'ACE::debug () > 0' or
1852   'ACE::debug (1)', you may have to rebuild ACE. The value of the
1853   ACE_DEBUG environment variable can be used to specify the initial
1854   value for ACE::debug(), at the process start up.
1856 . An assembler (within a C source file) based implementation for SPARC
1857   of atomic operations suitable for use with the
1858   ACE_Atomic_Op<ACE_Thread_Mutex, long> and
1859   ACE_Atomic_Op<ACE_Thread_Mutex, unsigned long> specializations has
1860   been added.  Currently, it can only be enabled by setting the
1861   atomic_ops_sparc make macro to 1 when using the GNUACE build system with
1862   the Solaris SunCC compiler.  It should be noted that this requires the
1863   -xarch=v8plus (or higher) be added to the CFLAGS make macro or the
1864   assembler code will not compile.
1866 . The ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> class
1867   is new, contributed by Guy Peleg <guy dot peleg at amdocs dot com>.
1868   ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> is
1869   similar to ACE_Message_Queue_Ex in that the object queued is a
1870   template parameter. However, ACE_Message_Queue_Ex_N allows the
1871   enqueueing and dequeueing of multiple chained objects at once. This
1872   wasn't added to ACE_Message_Queue_Ex because the chained object
1873   functionality requires the ACE_MESSAGE_TYPE class to have a
1874   ACE_MESSAGE_TYPE *next (void) const method, analogous to
1875   ACE_Message_Block::next(), to follow the chain and this would
1876   probably break existing applications using ACE_Message_Queue_Ex.
1877   The ACE_wrappers/tests/Message_Queue_Test_Ex.cpp test has an example of
1878   how to use the new class.
1880 . The selector and comparator function pointer arguments to ACE_OS::scandir()
1881   and ACE_Dirent_Selector are now marked as extern "C" to enforce their
1882   use with a C RTL function. User code that defines functions which are
1883   passed as the selector or comparator arguments which are not declared
1884   extern "C" may generate compile warnings. To resolve this, add extern "C"
1885   to the function's signature. See ACE_wrappers/tests/Dirent_Test.cpp for
1886   an example.
1888 . To address a problem in the ACE string interface that prevented
1889   substring or character searches in very large strings (e.g. greater
1890   than the maximum value of an ssize_t type) from being correctly
1891   reported to the caller, the find(), rfind() and strstr() methods now
1892   return an unsigned integer (size_t) instead of a signed one
1893   (ssize_t). Affected classes include:
1895     * ACE_CString
1896     * ACE_WString
1897     * ACE_TString
1898     * ACE_NS_WString
1900   Unless you have been explicitly using -1 instead of npos when
1901   comparing the return value of find(), rfind() and strstr(), and/or
1902   assigning the return value to ssize_t you should not see any
1903   difference. A new size_type typedef has been added to the ACE string
1904   class to aid developers.  This typedef is analogous to the standard
1905   C++ string::size_type typedef.
1907   The ACE_String_Base<>::strstr() documentation and the default
1908   rfind() argument erroneously referred to -1 instead of npos. Those
1909   instances have been corrected.
1911   To summarize, a "no position" condition is denoted using the npos
1912   constant, not -1. It can be referred directly by scoping it with the
1913   appropriate string class (e.g. ACE_CString::npos, ACE_WString::npos,
1914   etc).
1916 . Changing the shared library extension for hpux ia64 to ".so". On
1917   HP-UX 11i Version 1.5 the naming scheme is lib*.sl for PA and
1918   lib*.so on IPF.
1920 . The ACE_Refcounted_Auto_Ptr reset() and release() methods were changed
1921   per Bugzilla #1925. They will both now detach from the underlying
1922   ACE_Refcounted_Auto_Ptr_Rep object; reset() will create a new one for
1923   the new pointer specified as its argument. This change may cause referenced
1924   objects to be deleted in cases where previous ACE versions would not have.
1926 . The return type of "ACE_Refcounted_Auto_Ptr::null (void) const" changed
1927   from int to bool. It's possible values, true and false, have not changed.
1929 . TTY_IO now accepts "none" as a valid parity value. Due to this change
1930   'parityenb' member is now deprecated and will be removed in the future.
1931   The users of TTY_IO class should change their code to use only 'paritymode'
1932   member for parity control and leave 'parityenb' unchanged (it is
1933   enabled by default in class constructor).
1935 . Support for Intel C++ 9.1 on Windows and Linux
1937 . VxWorks 6.3 support
1939 . Fixed Bugzilla #2648 to make sure ACE_Service_Object::fini()
1940   is called iff ACE_Service_Object::init() succeeded, as per
1941   C++NPv2.
1943 . Added preliminary support for Mac OS X 10.4 on Intel CPU's.
1945 . Fixed Bugzilla #2602 to re-enable XML Service Configurator
1946   file support.
1948 USER VISIBLE CHANGES BETWEEN ACE-5.5.1 and ACE-5.5.2
1949 ====================================================
1951 . Added support for:
1952    - VxWorks 6.2 for the rtp model using pthread support
1953    - OpenVMS 8.2 for Alpha
1955 . Removed code and configurations that provided support for:
1956    - Visual C++ 6.0 and 7.0
1957    - Chorus
1958    - pSOS
1959    - KAI C++ on all platforms
1961 . Explicit template instantiation support has been removed. This effectively
1962   removes support for Sun Forte 6 and 7 which required explicit template
1963   instantiation to build ACE reliably.
1965 . Added support for multiple independent Service Repositories through
1966   configuration contexts called "Gestalt". Full backwards compatibility
1967   is maintained through the existing ACE_Service_Config static methods,
1968   while direct individual repository access is enabled through instances
1969   of the new ACE_Service_Gestalt class. ACE_Service_Config has changed to
1970   a specialization of ACE_Service_Gestalt and is only responsible for the
1971   process-wide configuration.
1973 . To support dynamically-sized ACE_Log_Record messages, the netsvcs
1974   logging components now use ACE CDR encoding and transfer mechanisms
1975   inspired by the examples in Chapter 4 of the C++NPv1 book.
1976   The client and server logging daemons in ACE 5.5.2 and forward will
1977   not interoperate with those in previous ACE versions.
1979 . Added a wrapper for the sendfile API (ACE_OS::sendfile()).
1981 . Added support for netlink sockets on Linux.
1983 . Added a new method, ACE_Task::last_thread(). This method returns the thread
1984   ID (ACE_thread_t) of the last thread to exit from the ACE_Task object.
1985   Users checking to see if a thread is the last one out (for example, to know
1986   when to perform cleanup operations) should compare the current thread ID to
1987   the return value from last_thread(). This is a change from the previously
1988   recommended practice (C++NPv2, page 189) of comparing the return value of
1989   thr_count() with 0.
1991 . Changed the first argument to ACE_OS::strptime() to be 'const' which
1992   matches its usual usage in POSIX strptime(). This change allows users to
1993   pass const strings in - a common use case.
1995 . Made part of the file support in ACE 64bit but we have some places where
1996   32bit types are used, this could lead to some conversion warnings which
1997   will be addressed in the near future, but getting everything 64bit
1998   compliant is a lot of work.
2000 USER VISIBLE CHANGES BETWEEN ACE-5.5 and ACE-5.5.1
2001 ====================================================
2003 . Added support for the --enable-symbol-visibility configure option
2004   to the autoconf build infrastructure instead of solely relying on
2005   feature tests to enable/disable symbol visibility support.  This
2006   avoids build problems with icc, etc.
2008 . Added support for the --enable-fl-reactor configure option to the
2009   autoconf build infrastructure to build the ACE_FlReactor library.
2011 . Added support for the --enable-qt-reactor configure option to the
2012   autoconf build infrastructure to build the ACE_QtReactor library.
2014 . Added support for the --enable-xt-reactor configure option to the
2015   autoconf build infrastructure to build the ACE_XtReactor library.
2017 . Fixed a bug that would cause timer IDs from ACE_Timer_Heap to be
2018   improperly duplicated under certain conditions (Bugzilla #2447).
2020 . Fixed ACE_SSL_Context::private_key(), context(), and dh_params() methods
2021   to allow retrying a file load after a failed call.
2023 . Fixed ACE_SSL_Asynch_Stream so it can be instantiated; also moved the
2024   declarations for ACE_SSL_Asynch_Read_Stream_Result,
2025   ACE_SSL_Asynch_Write_Stream_Result, and ACE_SSL_Asynch_Result classes
2026   to the ace/SSL/SSL_Asynch_Stream.h file so applications can see them.
2028 USER VISIBLE CHANGES BETWEEN ACE-5.4.10 and ACE-5.5
2029 ====================================================
2031 . Added a platform macros option "templates=manual", currently only
2032   applies to AIX 5.3 with XL 7 compiler.  It allows the user to tell the
2033   compiler to set -qnotempinc and -qnotemplateregistry and works well
2034   in static builds.
2036 . ACE and its tests compile error free with GCC 4.1 pre release.
2038 . ACE_Recursive_Thread_Mutex::get_nesting_level() fixed for 64-bit Windows
2039   XP on amd64/EM64T hardware.
2041 . Many build-time fixes for Windows Mobile 5 and Windows PocketPC 2003 using
2042   Visual Studio .NET 2005 (VC8).
2044 . Added support for the --enable-tk-reactor configure option to the
2045   autoconf build infrastructure to build the ACE_TkReactor library.
2047 USER VISIBLE CHANGES BETWEEN ACE-5.4.9 and ACE-5.4.10
2048 ====================================================
2050 . Fixed a bug in ACE_Timer_Heap_T::cancel().
2052 . Improved ACE_Time_Value support for boundary conditions.
2054 . Fixed problems with operator placement delete on certain C++ compilers.
2056 . Fixed a bug with the ACE_SPIPE_Acceptor on Windows.
2058 . Correctly set sockaddr_in.sin_len and sockaddr_in6.sin6_len on
2059   platforms that have these fields.
2061 . Avoided problems with namespace pollution for max() macros.
2063 . Many fixes for ACE_LACKS* and ACE_HAS* macros for autoconfig.
2065 USER VISIBLE CHANGES BETWEEN ACE-5.4.8 and ACE-5.4.9
2066 ====================================================
2068 . Added dozens of new ACE_LACKS and ACE_HAS defines which are used to
2069   simplify the ACE_OS layer
2071 . Constructors of ACE_Time_Value have been made explicit to prevent
2072   implicit conversions.
2074 . Added a shutdown() method to ACE_Barrier. The new method aborts the
2075   wait by all threads.
2077 . Changed the behavior of ACE_Message_Queue::enqueue_head() and
2078   enqueue_tail(). If the enqueued message block has other blocks
2079   chained to it via its next() pointer, the entire chain of blocks
2080   will be enqueued at once.
2082 . Improved the support for high-resolution timers with
2083   ACE_Timer_Queue_Adapter.
2085 . Make it possible to disable file caching in JAWS.
2087 . Improved ACE_Pipe implementation so that it uses localhost to avoid
2088   firewall problems.
2090 . Added Unicode support to the Service Configurator.
2092 USER VISIBLE CHANGES BETWEEN ACE-5.4.7 and ACE-5.4.8
2093 ====================================================
2095 . Improved IPv6 support
2097 . Improved 64bit portability
2099 . TTY_IO overhaul
2100   - Improved documentation.
2101   - It is now possible to request infinite timeout in portable manner.
2102     This can be achieved by setting negative value to readtimeoutmsec.
2103   - Various bugs fixed and portability issues resolved.
2105 . Subset ACE for TAO and TAO Services
2107 . Support for Intel C++ 9.0 on Windows and Linux
2109 . Support for Microsoft Visual Studio 2005 (aka VC8) for Win32 as well
2110   as the Windows CE platforms Pocket PC 2003 and Windows Mobile 5.
2111   Solution/project files are generated with an appended "_vc8" for
2112   Win32 and "_WinCE" for the CE platforms. See
2113   ACE_wrappers/docs/CE-status.txt for more information.
2115 . Completed implementation of ACE_Dev_Poll_Reactor using the Linux epoll
2116   facility; tested on Red Hat Enterprise Linux 4.
2118 . The in-memory size of an ACE_RB_Tree will be smaller due to rearranged
2119   placement of pointers.
2121 . Added an optimization to CDR stream to ignores alignment when marshaling
2122   data.  Use this new ACE_LACKS_CDR_ALIGNMENT compile-time option only
2123   when the ACE_DISABLE_SWAP_ON_READ macro is enabled.  This new option
2124   requires ACE CDR engine to do both marshaling and demarshaling, and
2125   when this option is enabled the encoded streams are no longer
2126   compliant with the CORBA CDR specification.
2128 . Developed Feature Oriented Customizer (FOCUS) tool to enable
2129   specialization of middleware frameworks such as Reactor and Protocol
2130   framework.  FOCUS provides an XML based transformation engine, where
2131   the transformations to specialize the components are captured in XML
2132   file and a weaver specializes the code.
2134 . Added support for unrolling ACE_OS::memcpy copy loop where
2135   applicable to improve performance. Autoconf tests empirically
2136   determine whether loop unrolling is at least 10% better than default
2137   version.
2139 . Added support for an ACE "versioned" namespace.  When enabled, ACE
2140   library sources will be placed within a namespace of the user's
2141   choice or a namespace of the form ACE_5_4_7 by default, where
2142   "5_4_7" is the ACE major, minor and beta versions.  The default may
2143   be overridden by defining the ACE_VERSIONED_NAMESPACE_NAME
2144   preprocessor symbol.  Enable overall versioned namespace support by
2145   adding "versioned_namespace=1" to your MPC default.features file.
2147 USER VISIBLE CHANGES BETWEEN ACE-5.4.6 and ACE-5.4.7
2148 ====================================================
2150 . Support for shared libraries with VxWorks
2152 . Support for Solaris 10 on x86 with Sun Studio 10 (C++ 5.7).
2154 . Extended ACE_OS::event_xxx implementation to support platforms
2155   having either PThread support with Process Shared condition
2156   variables or POSIX semaphores with named (process shared)
2157   semaphore support or using the new FIFO based semaphores.
2159 . ACE_OS::closesocket() no longer calls ACE_OS::shutdown() on any platform
2160   while closing the socket. It previously called ACE_OS::shutdown() on
2161   HP-UX. Removing this call fixes the fork-and-close programming paradigm
2162   that's common to many networked applications.
2164 . RMCast
2165    - Support for message fragmentation. This will allow
2166      for messages larger than 64K.
2167    - Support for flow control.
2168    - Timed recv() in RMCast::Socket.
2169    - Per-instance configurable protocol parameters (e.g., message
2170      retention time, NAK timeout, etc).
2172 USER VISIBLE CHANGES BETWEEN ACE-5.4.5 and ACE-5.4.6
2173 ====================================================
2175 . Updated RMCast to include
2176    - Reactor-compatible interface.
2177    - Message unavailability reporting.
2178    - Protocol documentation.
2180 . Added support for 64bit Visual Age on AIX
2182 . Improved g++ 4.0 support.  A number of RTTI related problems have been
2183   fixed.
2185 . Smaller footprint.
2187 . Fixed memory leaks ACE_DLL and ACE_Log_Msg classes.
2189 . The ACE::ICMP_Socket and ACE::Ping_Socket classes were moved out of
2190   the ACE namespace and "flattened" to ACE_ICMP_Socket and
2191   ACE_Ping_Socket to be consistent with the rest of ACE.
2193 . ACE_INET_Addr::set_address() - fixed a possible struct member
2194   alignment issue when building an IPv4-mapped IPv6 address.
2196 . Added a new ACE::wild_match() function to match a string based on
2197   wildcards.
2199 . Added efficient overloads for string concatenation to the
2200   ACE_String_Base class.
2202 . Added support for the use of pthread_getschedparam on MacOS X.
2204 . Fixed an issue with static initialization of TSS related classes on
2205   static builds for Windows.
2207 USER VISIBLE CHANGES BETWEEN ACE-5.4.4 and ACE-5.4.5
2208 ====================================================
2210 . Remove special handling in the Thread Specific Storage(TSS) code
2211   that released the TSS key for ACE_TSS<TYPE>.  ACE_TSS<TYPE> has
2212   been changed to explicitly free the TSS key when necessary.
2214 . On Win32 systems: detect thread termination via a hook in DLLMain
2215   for ACE.dll.  This allows cleanup of TSS objects for non-ACE threads
2216   that use ACE functions.  The most common case was threads that used
2217   ACE logging.  Formerly any TSS objects created by these threads would
2218   be leaked.
2220 . Added support for GNU G++ 4.0.  The x.4.5 beta takes advantage of
2221   g++ 4.0's symbol visibility.  This feature is conceptually similar
2222   to MS Windows "__declspec(dllexport)" DLL functionality.  Using this
2223   new g++ feature results in substantially improved ACE/TAO/CIAO
2224   shared library binaries.  A subset of the improvements include the
2225   following:
2227       * The number of unnecessarily exported DSO/DLL symbols is
2228         greatly reduced, resulting in faster program start times.
2229       * Smaller footprint.
2230       * Improved performance since run-time indirection of internal
2231         symbols is no longer needed.
2233   No changes to the ACE/TAO sources were necessary to support this
2234   feature since the required visibility attributes were hidden behind
2235   the various "*_Export" macros (formerly only useful for MS Windows
2236   DLLs) used throughout ACE/TAO.
2238 . The ACE_Reactor destructor will now call close() on the referenced reactor
2239   implementation. This assures that all handlers are notified before the
2240   ACE_Reactor object that's most likely referenced in these handlers is
2241   invalid. Although this should not be a user-visible change, it did catch
2242   some ACE tests off guard destroying reactor implementations and ACE_Reactor
2243   interfaces in the wrong order, so it may come up in the field as well.
2244   When using dynamically allocated reactor implementations, do not destroy
2245   the implementation object before the ACE_Reactor interface object. Use of
2246   the ACE_Reactor constructor's delete_implementation argument (with a value
2247   of 1) is recommended when dynamically allocating reactor implementations.
2249 . Improved performance of HTBP by not requiring a lookup of peer hostname.
2251 . Added new ACE_SizeCDR stream which allows one to calculate size of the
2252   representation without writing anything.
2254 . Number of improvements in RMCast, reliable multicast implementation.
2256 USER VISIBLE CHANGES BETWEEN ACE-5.4.3 and ACE-5.4.4
2257 ====================================================
2259 . The ace-config script has been replaced by pkg-config metadata files
2260   which are installed in ${prefix}/lib/pkgconfig by the automake build.
2262 . Remove ACE_OS::gets() implementation.  While this ACE implementation
2263   of gets() did not contain the security holes that all standard
2264   gets() implementations have, keeping it around only serves to foster
2265   confusion since (1) some may incorrectly assume that this
2266   ACE-specific gets() implementation has the same holes as standard
2267   ones, and (2) invoking it with a default size argument so that it
2268   looks like a standard gets() call results in behavior that is
2269   different from the standard.  Use ACE_OS::fgets() instead.
2271 . Removed ACE_Unbounded_Set_Ex, this gave the false idea that it had
2272   thread safe iterators. Use ACE_Unbounded_Set instead
2274 . Improved VxWorks support for static libraries. Shared libraries do cause
2275   several known problems which will be fixed in the x.4.5 release.
2277 . Removed the usage of the ACE_x_cast macros, we are using the C++ casts
2278   from now on. The ACE_x_cast macros are deprecated and will be removed
2279   after the x.5.1 release
2281 . Some improvements in autoconf support; better detection of available
2282   OS and compiler features.
2284 . Fixed bugs in ACE TSS emulation
2286 USER VISIBLE CHANGES BETWEEN ACE-5.4.2 and ACE-5.4.3
2287 ====================================================
2289 . Improved Cygwin 1.5.12 support, 90% of the tests now succeed
2291 . Improved OpenVMS support.
2293 . Added ability to use fltk with Cygwin/MinGW
2295 . Added ACE_INT64 that defines a native 64 bit type.
2297 . Added 'q' as usable specifier for ACE_Log_Msg to print out int64 bit number.
2299 . Added better support for Intel C++ compilers.
2301 . Improved HPUX support.
2303 . Added a new directory ("ACE_wrappers/protocols/ace") for new protocols
2304   that are not directly components of ACE, but are relate to ACE and
2305   defined a new protocol, HTBP (Hypertext Tunneling, Bidirectional
2306   Protocol) providing ACE_Acceptor/Connector/Stream semantics over a
2307   connection owned by an HTTP proxy. Test cases in
2308   ACE_wrappers/tests/HTBP provide examples of use.
2310 . Performace enhancement in TP_Reactor's handle_timer_events method [Bug
2311   1971].
2313 . Various changes to permit ACE to execute on HP NonStop platform (e.g
2314   support for its pthreads version).
2316 . Updated HP NonStop configuration files (config-tandem-nsk).
2318 . The "ACE" pseudo-namespace is now a true C++ namespace.  Transitional
2319   pseudo-namespaces that were only meant to be used internally by ACE,
2320   such as "ACE_Sock_Connect", no longer exist.
2322 . ACE_CDR::Boolean type is now a true C++ "bool" on all platforms except
2323   MSVC++ 6.  We plan to deprecate MSVC++ 6 support sometime after the
2324   x.5 release of ACE+TAO+CIAO, so we recommend you start migrating to a
2325   later version of MSVC++.
2327 . More GNU g++ 3.4.x fixes.
2329 . Added ICMP and "ping" socket support.
2331 . Added mkstemp() emulation.
2333 . Fixed problem on Linux < 2.5.47 platforms where equality comparison of
2334   two logically equal sockaddr_in structure instances would incorrectly
2335   fail.
2337 . Support for wide characters has been improved on non-Windows
2338   platforms.
2340 . A number of Windows CE problems have been fixed.
2342 . ACE's loading of DLLs (for example, as a result of loading synamic
2343   services) has been changed to use the native OS's facilities for
2344   locating the DLL instead of searching LD_LIBRARY_PATH (or its
2345   equivalent) then loading the DLL using a full pathname. This restores
2346   enforcement of a platform's loading and security policy.  To use the
2347   old DLL locating method, add ACE_MUST_HELP_DLOPEN_SEARCH_PATH to your
2348   config.h file before building ACE.
2350 . A number of errors in the APG example programs have been corrected.
2352 . Select_Reactor and Priority_Reactor performance improved. [Bug 1890]
2354 . Wide-char functionality on POSIX (Linux, etc.)
2356 . TSS memory leak fixes [Bug 1542]
2358 . Ported to HPUX 11i v2 on Itanium
2360 . Added code to ACE for platform RedHat AS 3.0 on Opteron.
2362 . Changed ACE::crc32() family of functions to NOT fold in the length of
2363   the string/buffer/iovec into the CRC.
2366 USER VISIBLE CHANGES BETWEEN ACE-5.4.1 and ACE-5.4.2
2367 ====================================================
2369 . Support for g++ 3.4.1.
2371 . All ACE Makefiles, project files, etc, are now generated by OCI's
2372   "MakeProjectCreator" (MPC) tool.  Makefiles and project files for
2373   commonly used configurations have been pre-generated and distributed
2374   with the beta(s).  Please see:
2376   $ACE_ROOT/ACE-INSTALL.html
2378   for information on how to use MPC with ACE.
2380 . Improved Doxygen documentation.
2382 . Reduced header file dependencies, which should speedup compilation
2383   and help minimize static footprint.
2385 . ACE now requires support for the following standard C++ features:
2387   - "bool" keyword
2389   - "mutable" keyword
2391   - "explicit" keyword
2393   - C++ casts (e.g. static_cast<>, reinterpret_cast<>, dynamic_cast<>
2394     and const_cast<>)
2396   If you're using a compiler that does NOT support these features
2397   please contact Steve Huston <shuston@riverace.com> for support.
2399 . Changed the select()-based reactor implementations to scan for
2400   broken handles to remove based on the registered handles, not on
2401   event handlers.  This allows for bad handles to be removed from the
2402   reactor even if the event handler doesn't implement get_handle() the
2403   way we expect.
2405 . Support for Pthreads native recursive mutexes was added. This
2406   capability is specified to ACE_OS::mutex_init() as an optional
2407   argument, lock_type. To fix confusion from an earlier attempt to add
2408   this functionality, the meaning of the old 'type' argument to
2409   ACE_OS::thread_mutex_init() is changed. It previously combined the
2410   scope and type. Now it is just the type (e.g. recursive), as the
2411   scope is inherent in the method used. For clarification on
2412   ACE_HAS_RECURSIVE_MUTEXES, it means that the platform is capable of
2413   them, not that they always are, as one would expect. However, before
2414   Pthreads had recursion added, it was never optional. Now it is.
2416 . Initial support for new Linux sys_epoll() interface in
2417   Dev_Poll_Reactor.  The obsolete Linux /dev/epoll interface is no
2418   longer supported.
2420 . Improved Cygwin support.
2421   - Threading works without problems.
2422   - Problems with shared memory, process shared mutexes, multicast and
2423     some other small things still exist.
2425 . New OpenVMS port.
2426   -  This is for the latest version of OpenVMS with all available ECOs
2427      applied. Basic stuff works without problems.  Advanced features
2428      still need some work.
2430 . Usage of ASYS_INLINE is deprecated in ACE.  Use ACE_INLINE instead.
2432 . All inline source files now end in ".inl".  The previous ".i"
2433   extension is generally used for preprocessed C sources.
2435 . Autoconf support has been improved and fixed on a number of
2436   platforms, including the BSD variants (e.g. FreeBSD).  It is still
2437   not the preferred way to configure most platforms, but it is ready
2438   for wider testing. Please report any problems found to
2439   ace-bugs@cs.wustl.edu.
2441 . A number of fixes were made to quiet compile errors and warnings on
2442   64-bit Windows.
2444 . For builds on AIX using Visual Age C++, the make rtti option default
2445   was changed to 1, enabling RTTI by default.
2447 . ACE_Service_Repository::remove() has a new, optional argument that
2448   can receive the service record pointer for the removed service. If
2449   the pointer is returned to the caller, it is not deleted. If the
2450   pointer is not returned to the caller (the default) it is deleted
2451   (this is the historic behavior).
2453 . The tutorials in ACE_wrappers/docs have been removed. They were not
2454   being maintained and caused confusion in a number of cases. Now that
2455   there are complete examples that match the printed books (C++NPv1,
2456   C++NPv2, APG), the older tutorials are no longer useful.  Please see
2458   $ACE_ROOT/examples/C++NPv1/
2459   $ACE_ROOT/examples/C++NPv2/
2460   $ACE_ROOT/examples/APG/
2462   for the source code of the examples in those books.
2464 . ACE_String_Base::fast_clear() is a new method which sets the string
2465   length to 0. Doesn't release string-allocated memory, but if the
2466   memory was externally supplied, it is no longer referenced from the
2467   string object.
2469 . A true C++ "bool" is now used as the CDR stream boolean type, if
2470   supported by the compiler.
2472 . Renamed AIX 5L configuration header from config-aix5.1.h to
2473   config-aix-5.x.h.
2475 . All C++ equality, relational and logical operators now return bool
2476   instead of int, as is the norm for modern C++.
2478 . Added new ACE_OS::realpath() implementation.  Contributed by Olli
2479   Savia  <ops at iki dot fi>
2482 USER VISIBLE CHANGES BETWEEN ACE-5.4 and ACE-5.4.1
2483 ====================================================
2488 . Fixed "make install" support in ACE+autoconf configurations.
2490 . Fixed autoconf support on Solaris.
2492 . Corrected invalid `aux' directory (on MS Windows) found in ACE
2493   distribution.
2495 . ACE/TAO build now without problems with MinGW and all ACE tests run
2496   now without problems
2498 . Added some more support for the new CBuilderX Preview compiler, this
2499   is not 100% ready yet because the compiler is still a preview and
2500   has its own problems.
2502 . Added Visual SlickEdit 8.1 MPC template
2504 . Added workaround for compile problems in Borland Release builds
2506 . Cygwin 1.5.9 is now supported
2508 . Tests for IPV6 have been added
2510 . Implement lstat() so that it'll use stat() on platforms that don't
2511   support lstat().
2513 . Problems related to ACE_Event_Handler usage in WFMO_Reactor was
2514   fixed.
2516 . A wrapper for rmdir () has been added.
2518 . Threads spawned in thread-per-connection mode never inherited the
2519   priority. This problem was fixed and this fix is consistent with the
2520   C++ NPV* books.
2522 . Fixed memory leaks with ACE_String_Base::resize ()
2524 . Enable the usage of native recursive mutexes for the implementation
2525   of ACE recursive mutexes on Linux.
2527 . The ACE Proactor framework can now be enabled for AIX 5.2. Since AIO
2528   functionality is not run-time enabled by default on AIX 5.2, the ACE
2529   Proactor code is not built by default on AIX. To enable it, the
2530   config.h file must contain #define ACE_HAS_AIO_CALLS before
2531   including the config-aix-5.1.h file.
2533 . The ACE_POSIX_CB_Proactor implementation is now built on all
2534   platforms except LynxOS.
2537 USER VISIBLE CHANGES BETWEEN ACE-5.3.6 and ACE-5.4
2538 ==================================================
2540 ACE:
2542 . Added a new makefile commandline flag, static_link, that can be
2543   used to force static linking when static_libs_only is turned on. It
2544   uses the new STATIC_LINK_FLAG variable and is currently only
2545   implemented for for GNU ld, i.e., it adds the "-static" option to
2546   LDFLAGS. It's turned off by default since using it causes the
2547   footprint to go up by almost 1 MB on Linux, since it links all the
2548   system and compiler .a files, but can be turned on if users
2549   want/need to use it, by enabling both static_libs_only and static_link.
2552 . Added macros ACE_USES_GPROF which enables users to use gprof in a
2553   multithreaded environment with ACE libs.
2555 . Added a new functor template class, ACE_Malloc_Lock_Adapter_T,
2556   that's used by ACE_Malloc_T as a factory for the ACE_LOCK template
2557   parameter, and allows the use of locking strategy classes, like
2558   ACE_Process_Semaphore and ACE_Thread_Semaphore that don't have a
2559   satisfactory ctor taking a single required ACE_TCHAR* parameter, to
2560   be adapted to work with ACE_Malloc_T.
2562 . The source code examples from "The ACE Programmer's Guide" book by
2563   Huston, Syyid, and Johnston, are now located in
2564   $ACE_ROOT/examples/APG.
2566 . Support for GNU autoconf is now in ACE. Please see ACE-INSTALL.html
2567   for details.
2569 . Fixed problems that prevented ACE from being compiled on LynxOS
2570   4.0.0.
2572 . Fixed compilation error which prevented ACE from being compiled when
2573   ACE_COMPILE_TIMEPROBES was set to 1.
2575 . Preliminary support for Tandem NSK has been added.
2577 . Lots of bug fixes with TLI and XPG5. Please see $ACE_ROOT/ChangeLog
2578   for details.
2580 . Fixed ACE_OS::event_timedwait() and ACE_OS::event_wait() so that
2581   they use a while loop around the ACE_OS::cond_[timed]wait() calls to
2582   avoid problems with spurious wakeups, etc.
2584 . ACE's wrapper around getipnodebyname() and getipnodebyaddr () has
2585   been made go through the IPv4-only case on ACE_WIN32. Since Windows
2586   IPv6 implementation doesn't offer support (at thistime) for
2587   getipnodebyname() the code has been changed to use the IPV4 part of
2588   the code.
2590 . Install with Borland C++ of ACE library fixed
2592 ACEXML:
2593 -------
2595 . Fixed memory leak in ACEXML parser.
2597 . Fixed implementations of rewind() in all the CharStreams. They were
2598   broken previously.
2600 . Fixed bugs in the parser associated with incorrect handling of PE
2601   References for keywords.