Merge pull request #2216 from jwillemsen/jwi-cxxversionchecks
[ACE_TAO.git] / ACE / NEWS
bloba0a0d67506461dee70fc139e8cdae0479cdeac4f
1 USER VISIBLE CHANGES BETWEEN ACE-7.1.4 and ACE-7.1.5
2 ====================================================
4 USER VISIBLE CHANGES BETWEEN ACE-7.1.3 and ACE-7.1.4
5 ====================================================
7 . With g++ versions < 11 we default to C++17 as
8   minimum C++ standards level
10 USER VISIBLE CHANGES BETWEEN ACE-7.1.2 and ACE-7.1.3
11 ====================================================
13 . Fixed possible race conditions in extreme use case
14   in the barrier and future implementations
16 . Improve support for QNX 7.1 and FreeBSD
18 . Integrated debian packaging changes
20 USER VISIBLE CHANGES BETWEEN ACE-7.1.1 and ACE-7.1.2
21 ====================================================
23 . C++17 removed std::auto_ptr, updated ACE/TAO to not
24   use std::auto_ptr anymore and also not provide our
25   own auto_ptr. With C++17 ACE doesn't provide ACE_Auto_Ptr,
26   ACE_Auto_Basic_Ptr, ACE_Auto_Basic_Array_Ptr, ACE_Auto_Array_Ptr,
27   and ACE_auto_ptr_reset anymore, just use std::unique_ptr
29 . Add c++std which can be used in the platform_macros.GNU
30   to set the C++ revision to be used (results in -std= flag)
32 . Improve support for QNX 7.1
34 . Embarcadero C++ Builder enhancements
36 USER VISIBLE CHANGES BETWEEN ACE-7.1.0 and ACE-7.1.1
37 ====================================================
39 . Fixed shared memory leak by ACE_Shared_Memory_Pool
41 . Fixed ACE_INET_Addr::set when ACE_LACKS_GETSERVBYNAME has
42   been defined
44 USER VISIBLE CHANGES BETWEEN ACE-7.0.11 and ACE-7.1.0
45 =====================================================
47 . Removed support for Windows CE, OpenVMS, HPUX, AIX, RTEMS,
48   Pharlap, Solaris, and Visual Studio 2015
50 . ACE/TAO now require C++14 or newer
52 USER VISIBLE CHANGES BETWEEN ACE-7.0.10 and ACE-7.0.11
53 ======================================================
55 . Fixed some compiler warnings given by newer compilers
57 . Make use of noexcept instead of throw()
59 . Fixed a bug in ACE_Configuration_Heap with uses_wchar=1 builds
61 USER VISIBLE CHANGES BETWEEN ACE-7.0.9 and ACE-7.0.10
62 =====================================================
64 . Add missing resource files for several DLLs on Windows
66 . VxWorks runtime fixes
68 . Various cleanup and using more C++11 features
70 . Embarcadero C++ Builder 11.2 fixes
72 USER VISIBLE CHANGES BETWEEN ACE-7.0.8 and ACE-7.0.9
73 ====================================================
75 . Compile fixes for VxWorks 22.03
77 . Various cleanup
79 . Minor fixes
81 USER VISIBLE CHANGES BETWEEN ACE-7.0.7 and ACE-7.0.8
82 ====================================================
84 . Minor changes
86 USER VISIBLE CHANGES BETWEEN ACE-7.0.6 and ACE-7.0.7
87 ====================================================
89 . Minor changes
91 USER VISIBLE CHANGES BETWEEN ACE-7.0.5 and ACE-7.0.6
92 ====================================================
94 . Various cleanup and using more C++11 features
96 . Various packaging related fixes
98 USER VISIBLE CHANGES BETWEEN ACE-7.0.4 and ACE-7.0.5
99 ====================================================
101 . Initial not tested support for Visual Studio 2022
103 . Fixed compile errors when using Visual Studio 2019 with C++17
104   or C++20 support enabled
106 . Various cleanup and using more C++11 features
108 USER VISIBLE CHANGES BETWEEN ACE-7.0.3 and ACE-7.0.4
109 ====================================================
111 . Add support for Embarcadero C++ Builder 11.0 Alexandria using
112   the bcc32c compiler
114 . Allow ACE_Module and ACE_SOCK_Dgram_Mcast to be sub-classed
116 . Add ACE_SWAP_LONG_LONG byte swap macro for ACE_UINT64
118 . Improved ACE_Atomic implementation for g++
120 . Various cleanup and using more C++11 features
122 USER VISIBLE CHANGES BETWEEN ACE-7.0.2 and ACE-7.0.3
123 ====================================================
125 . The macro ACE_HAS_WIN32_STRUCTURAL_EXCEPTIONS has been renamed
126   to ACE_HAS_WIN32_STRUCTURED_EXCEPTIONS, update your code accordingly
128 . MinGW 2 has been deprecated
130 . ACE CDR supports (u)int8
132 . Use more C++11 features including using std alternatives
134 . Various cleanup
136 . Fix SocketConnect::ip_check() Concurrency and Too-Early Request Issues for Windows
138 . Make install: use relative links in prefix/share
140 USER VISIBLE CHANGES BETWEEN ACE-7.0.1 and ACE-7.0.2
141 ====================================================
143 . Fixed various warnings given by newer compilers
145 . Use more C++11 features
147 . Various cleanup
149 USER VISIBLE CHANGES BETWEEN ACE-7.0.0 and ACE-7.0.1
150 ====================================================
152 . Cleanup of ACE_* macros which are not used anymore
154 . Removed support for LynxOS 4 which has gcc3
156 . Make sure C++11 is enabled on MacOSX
158 USER VISIBLE CHANGES BETWEEN ACE-6.5.12 and ACE-7.0.0
159 =====================================================
161 . C++11 is now a mandatory compiler feature which is
162   required for ACE. Cleaned up part of the support for compilers
163   that lack C++11 support
165 . When valgrind is enabled we don't disable dlclose anymore,
166   this reduces the amount of leaks reported related to dlclose.
167   When you unload your shared libraries before the end of your program
168   you can use `--keep-debuginfo=yes` as valgrind options as alternative
169   or you can disable dlclose yourself by adding
170   `#define ACE_LACKS_DLCLOSE` to your ace/config.h file
172 . Removed `ACE_OS::readdir_r`. `readdir_r` was marked as depracated in glibc
173   and FreeBSD libc. Also removed `ACE_Dirent::read (ACE_DIRENT *, ACE_DIRENT **)`
174   which used it. `ACE_LACKS_READDIR_R` will now always be defined.
176 . Modernized part of the code using clang-type, added override, use nullptr,
177   use unique_ptr, remove redundant void, use bool, simplify boolean expressions,
178   make use of std::atomic, use using
180 . New Latest_ACE7TAO3_ branches which can be used to always checkout the
181   latest ACE7/TAO3 micro/minor release
183 . Android Support:
185   . `gnuace` no longer supports Android NDKs before r18. This means only clang
186     is now supported when building for Android.
188   . Support for building with the Android NDK r19 or later directly instead of
189     having to use a generated standalone toolchain. See `ACE-INSTALL.html` for
190     details. Using a standalone toolchain is still supported.
192   . Made it easier to use `gnuace`-built libraries in as imported libraries in
193     CMake-based Android Studio native projects.
195   . Removed support for old `ANDROID_ARCH` make variable. Replaced
196     `ANDROID_ABI` with `android_abi`, but kept the former as an alias of the
197     later for compatibility. Also will no longer default to 32-bit ARM, so
198     `android_abi` or `ANDROID_ABI` must be defined.
200   . As recommend by Google, building with neon support is now the default when
201     `android_abi` is `armeabi-v7a`. If support for these processors without
202     NEON extensions is needed, put `androind_neon := 0` in
203     `platform_macros.GNU`.
205   . As recommend by Google, `gnuace` will start using LLD, the LLVM linker,
206     instead of the default GNU linkers. If the NDK being used doesn't default
207     to LLD and you want to use the GNU linkers, put `androind_set_lld := 0` in
208     `platform_macros.GNU`.
210 . Removed support for the Alpha CPU
212 USER VISIBLE CHANGES BETWEEN ACE-6.5.11 and ACE-6.5.12
213 ======================================================
215 . Fixed some C++11 warnings
217 . Fixed compile problem on AIX
219 . Removed c++0x and c++1y as GNU make variables, use c++11 and c++14 as
220   alternatives
222 . Moved all CI builds to github actions
224 . Added ACE_GCC_NO_RETURN to fix fall through warnings
226 . Fix ACE_Thread_Manager::join memory leak and potential deadlock
228 USER VISIBLE CHANGES BETWEEN ACE-6.5.10 and ACE-6.5.11
229 ======================================================
231 . Latest_{Major,Minor,Micro,Beta} tags have been replaced with
232   branches because tags are not intended to move where branches are
234 . Removed emulated operations in ACE_OS which are not used anymore
236 . Resolved some compile warnings when using C++11 or newer
238 . Integrated debian packaging changes
240 . Visual Studio 2015 solutions are not part of the release
241   packaging anymore. When you require these you need to generate
242   them locally using MPC
244 . Improve multicast join by interface name on Windows
246 . Fixed ACE_INT64_FORMAT_SPECIFIER (and similar) preprocessor macros
247   on macOS (Apple-clang) with -std=c++11 or higher
249 . On Windows, use unnamed kernel objects (Events and Semaphores)
250   for thread-scoped reader-write mutexes in ACE_OS::rwlock_init
252 USER VISIBLE CHANGES BETWEEN ACE-6.5.9 and ACE-6.5.10
253 =====================================================
255 . Add support for Embarcadero C++ Builder 10.4 Sydney using the
256   classic compiler. ACE/TAO compile with the new 32/64 bit clang
257   compilers but runtime tests show several runtime problems which
258   makes them not safe to use
260 . Make a change in the ACE Process Manager to resolve an internal
261   compiler error with Visual Studio 2019 16.5.x compilers
263 . Android enhancements for if_nameindex
265 USER VISIBLE CHANGES BETWEEN ACE-6.5.8 and ACE-6.5.9
266 ====================================================
268 . On Windows, ACE no longer defines _WIN32_WINNT.  ACE wrappers for
269   if_nametoindex and if_indextoname are available if the version of the
270   Windows SDK supports them.
272 . IPv6 extended datagram receive info now supported on macOS.
274 . ACE_(U)INT8/16/32/64 map to (u)int8/16/32/64_t when C++11 has been
275   enabled.
277 . CDR_Base uses ACE_INT64 for LongLong, all old emulated support
278   has been removed
280 . Updated debian and rpm packaging support
282 USER VISIBLE CHANGES BETWEEN ACE-6.5.7 and ACE-6.5.8
283 ====================================================
285 . Added instructions to ACE-INSTALL.html for building ACE/TAO for Android on
286   Windows.
288 . Embarcadero C++ Builder Rio fixes
290 . Renamed `VERSION` file to `VERSION.txt` to avoid conflicting with the
291   `version` standard header.
293 USER VISIBLE CHANGES BETWEEN ACE-6.5.6 and ACE-6.5.7
294 ====================================================
296 . Fixed compile problem with glibc 2.30 and newer
298 . gnuace makefiles: Updated handling of generated files and
299   use requires/avoids to make postbuild steps conditional
301 . Removed references to the ACE_LACKS_MONOTONIC_TIME preprocessor macro because
302   it was equivalent to ACE_LACKS_CLOCK_MONOTONIC.
304 . Exposed support status of monotonic times features using preprocessor macros.
305   See "Testing for Monotonic Time Support" in docs/ACE-monotonic-timer.html for
306   details.
308 . Added support for ARM and ARM64 stack traces with Microsoft Visual C++.
310 . The "optional argument for the receive address in ACE_SOCK_Dgram::recv"
311   feature from ACE-6.5.5 is now supported on Windows.  This includes enhanced
312   support for sendmsg/recvmsg on Windows.
314 USER VISIBLE CHANGES BETWEEN ACE-6.5.5 and ACE-6.5.6
315 ====================================================
317 . On Linux, the ACE_Log_Msg format specifier `%t` is now replaced with the
318   system thread id provided by gettid(), instead of the much longer pthread id.
320 . Added support for MQX
322 . Enhanced Android support
324 USER VISIBLE CHANGES BETWEEN ACE-6.5.4 and ACE-6.5.5
325 ====================================================
327 . Fixed several broken links due to the removal of
328   Douglas Schmidt website at WashU
330 . On Android:
332   . ACE_Log_Msg (and therefore ACE_DEBUG and ACE_ERROR) now uses
333     Android's logging system (aka Logcat) by default in addition to stderr
334     because stdout and stderr are discarded under normal circumstances.
335     To disable this at runtime, run:
336       ACE_LOG_MSG->clr_flags (ACE_Log_Msg::SYSLOG)
337     To disable this at compile time include these lines in config.h:
338       #define ACE_DEFAULT_LOG_FLAGS ACE_Log_Msg::STDERR
339       #define ACE_DEFAULT_LOG_BACKEND_FLAGS 0
341   . When statically linking to OpenSSL, prevent usage of the preloaded and
342     unpredictable system SSL library when using ace_openssl.
344 . minizip has been moved from ACE to DANCE
346 . Add initial support for Visual Studio 2019
348 . Validated ACE for usage SLES15.0 x86_64 using 32bit g++ compiler
350 . Add optional argument for the receive address in ACE_SOCK_Dgram::recv
352 USER VISIBLE CHANGES BETWEEN ACE-6.5.3 and ACE-6.5.4
353 ====================================================
355 . Fix ACE_Vector::end(), which now correctly
356   represents the end of the elements of the vector
357   instead of the end of the base array.
359 USER VISIBLE CHANGES BETWEEN ACE-6.5.2 and ACE-6.5.3
360 ====================================================
362 . Enhance Android support
364 . Fix AIX and Solaris linking rpath errors
366 . Add support for SSL_INCDIR/SSL_LIBDIR and XERCESC_INCDIR/XERCESC_LIBDIR
367   to specify a custom include/lib dir as required for vcpkg versions of
368   openssl/xercesc
370 USER VISIBLE CHANGES BETWEEN ACE-6.5.1 and ACE-6.5.2
371 ====================================================
373 . Enhanced C++Builder XE2 support
375 . ACE_QtReactor can be built with Qt version 5 using the qt5 MPC feature
377 USER VISIBLE CHANGES BETWEEN ACE-6.5.0 and ACE-6.5.1
378 ====================================================
380 . At the moment C++11 or newer is enabled ACE_Strong_Bound_Ptr
381   doesn't provide the convenience functions to use a
382   std::auto_ptr anymore
384 . Optimized CDR std::(w)string insertion and extraction
385   when C++11 or newer is enabled
387 . Solved Visual Studio 2017 solution loading due to duplicate
388   files generated in a project file
390 USER VISIBLE CHANGES BETWEEN ACE-6.4.8 and ACE-6.5.0
391 ====================================================
393 . The ACE core libraries now use std::unique_ptr instead
394   of std::auto_ptr when C++11 or newer is enabled
396 USER VISIBLE CHANGES BETWEEN ACE-6.4.7 and ACE-6.4.8
397 ====================================================
399 . Enhanced Embarcadero C++ Builder support
401 . ACE XML_Utils enhancements
403 . Debian packaging enhancements
405 . Support for clang6 and gcc8
407 . Enhanced Android support
409 . Remove addr_any restriction from ipv6_only UDP
411 USER VISIBLE CHANGES BETWEEN ACE-6.4.6 and ACE-6.4.7
412 ====================================================
414 . Added a new, optional argument named ipv6_only to:
415     ACE_Acceptor::ACE_Acceptor
416     ACE_Acceptor::open
417     ACE_SOCK_Dgram::ACE_SOCK_Dgram
418     ACE_SOCK_Dgram::open
419   If ipv6_only is 0/false (the default) the socket will accept
420   both IPv6 and IPv4 connections/datagrams. If ipv6_only is
421   1/true the socket will only accept IPv6.
422   This behavior only applies when ACE_HAS_IPV6 is true and the
423   local-side IP address is the generic localhost IP address.
425 . Integrated some changes from XSC into XML Utils
427 . Enable ACE_HAS_CPP11 when we have clang with C++11 enabled
429 . Added support for cross compiling using MinGW on a Linux host
431 . Added support for FreeBSD 11
433 . Fixed issue ACE_Singleton was broken after ACE::fini, ACE::init (GitHub #554)
435 USER VISIBLE CHANGES BETWEEN ACE-6.4.5 and ACE-6.4.6
436 ====================================================
438 . Fixed some Codacy and C++ Core guidelines reported issues
440 . VxWorks 7 (SR0510) support
442 . Support make install on newer Apple MacOS versions
444 USER VISIBLE CHANGES BETWEEN ACE-6.4.4 and ACE-6.4.5
445 ====================================================
447 . Add support for OpenSSL 1.1. ACE users on Windows have
448   to add openssl11=1 to their default.features file so
449   that the correct OpenSSL library names are used.
451 USER VISIBLE CHANGES BETWEEN ACE-6.4.3 and ACE-6.4.4
452 ====================================================
454 . Enhanced support for Embarcadero C++ Builder 10.2 (Tokyo).
455   Support for bcc32/bcc64/bcc32c has been enhanced and by
456   default the clang based versions are used. When the old
457   bcc32 has to be used set the CLASSIC environment variable
458   to 1. At this moment runtime test results for bcc64/bcc32c
459   show some structural problems
461 . Add support for Oracle Studio 12.5
463 . Removed usage of ACE_REGISTER and register keyword because
464   they trigger deprecated warnings with newer gcc and clang
465   versions
467 . Add support for gcc 7
469 . Enhanced Android support
471 . Fix ACE_INET_Addr::set(domain_name, AF_UNSPEC) to be set to IPv4 address
472   when IPv6 is enabled and the domain_name could be resolved to IPv4 address.
474 USER VISIBLE CHANGES BETWEEN ACE-6.4.2 and ACE-6.4.3
475 ====================================================
477 . Enhancements for Visual Studio 2017
479 . Enhancements for Android
481 USER VISIBLE CHANGES BETWEEN ACE-6.4.1 and ACE-6.4.2
482 ====================================================
484 . Added support for Mac OS X on x86_64 to get the network adapter
485   address in ACE_OS::getmacaddress().
487 . Added support for the December 2016 updates to VxWorks 7.
489 USER VISIBLE CHANGES BETWEEN ACE-6.4.0 and ACE-6.4.1
490 ====================================================
492 . The ACE_DEBUG environment variable can again be used to set the
493   internal debug flag.  This used to work but was mistakenly changed
494   in an earlier release.
496 . Corrected usage of ACE_Singleton and template instantation to be
497   valid C++ (GCC cross-compiler arm-linux-gnueabihf-g++ requires it).
499 . Added support for detecting the Mac OS X version when configured with
500   ace/config-macosx.h and include/makeinclude/platform_macosx.GNU.
501   Also on 10.11 El Capitan, use rpath to avoid a problem with SIP.
503 . Added support for Android NDK r12b (Platform API 24) and improved
504   cross compilation support
506 USER VISIBLE CHANGES BETWEEN ACE-6.3.4 and ACE-6.4.0
507 ====================================================
509 . Added support for obtaining the micro version number
511 . Reduced include of ace/Auto_Ptr.h in header files
513 USER VISIBLE CHANGES BETWEEN ACE-6.3.3 and ACE-6.3.4
514 ====================================================
516 . ACE_SSL_Context::set_mode() can no longer be used to select a specific
517   SSL/TLS protocol version, use ACE_SSL_Context::filter_versions() for that.
518   This follows general advice by the OpenSSL project to go through
519   SSL_CTX_set_options() to limit the list of protocols available. The purpose
520   of ACE_SSL_Context::set_mode() is now limited to explicitly restricting
521   behaviour to client or server (defaults to both).
523 . Improve Oracle Studio support
525 . CIAO and DAnCE are forked to their own github repositories
526   and are not part anymore of the ACE+TAO release packages
528 . Fixed several Coverity reported issues
530 . Added ACE configuration for FACE safety profiles (see config-face-safety.h).
531   FACE, or Future Airborne Capability Environment http://www.opengroup.org/face,
532   specifies a restricted subset of OS functions and rules for controlling
533   dynamic memory allocation.  When built in this configuration on a platform
534   that supports it, ACE conforms to the FACE requirements.
536 . ACE uses new netdb.h functions (getaddrinfo/getnameinfo) if they are
537   available, in place of deprecated functions (gethostbyname/addr).
539 USER VISIBLE CHANGES BETWEEN ACE-6.3.2 and ACE-6.3.3
540 ====================================================
542 . Visual Studio 2015 has adequate C++11 support, because of this
543   ACE_HAS_CPP11 is now defined with this compiler. A large amount
544   of warnings given by this new compiler have been fixed
546 . As part of the release script we generate vc12 and vc14
547   solution files which are packaged as part of the release
549 . Added support for VxWorks 7 (kernel mode and RTP).
550   See the comments in include/makeinclude/platform_vxworks7.0.GNU for details.
552 . Ended daily maintenance for OpenVMS
554 . Fixed a defect in ACE_INET_Addr when there is a non-empty interface
555   address list and set_port_number() is called.
557 USER VISIBLE CHANGES BETWEEN ACE-6.3.1 and ACE-6.3.2
558 ====================================================
560 . Added support for std::chrono to ACE_Time_Value. It's
561   now possible to construct an ACE_Time_Value with a
562   std::duration. Also streaming, adding and substracting
563   an ACE_Time_Value to and from a std::duration is
564   supported. Please see tests/Chrono_Test.cpp for more
565   details.
567 . Allow ACE_INET_Addr to hold all addresses associated with a hostname. The
568   set of addresses always has a "current" address which is accessed by the
569   usual "get"-type methods on the class. Two new methods are added to deal
570   with multiple addresses:
571     - bool next (void): makes the next available address the "current" one.
572       Returns false if there are no more addresses.
573     - void reset (void): resets the iteration mechanism to be able to examine
574       all of the addresses again.
575   ACE_Multihomed_INET_Addr has also been enhanced so that the get_addresses()
576   methods copy all available addresses related to each name.
578 . The ACE_Addr::set_addr (void*, int) signature was changed to
579   ACE_Addr::set_addr (const void*, int). All classes that inherit from
580   ACE_Addr also have the same change. This affects ACE_ATM_Addr, ACE_Addr,
581   ACE_INET_Addr, ACE_MEM_Addr, ACE_Netlink_Addr, ACE_SPIPE_Addr, ACE_UNIX_Addr.
582   Any user-written classes derived from ACE_Addr will also need to change to
583   match the new signature for virtual method dispatch to continue working
584   properly in all cases.
586 . Added the class ACE_CDR::Fixed (CDR_Base.h) for CDR's fixed-point decimal
587   data type which stores up to 31 decimal digits and a sign bit.
589 USER VISIBLE CHANGES BETWEEN ACE-6.3.0 and ACE-6.3.1
590 ====================================================
592 . ACE is now hosted on github (https://github.com/DOCGroup/ATCD).
593   As part of the release process we now generate a ChangeLog
594   for each release which is stored in the ChangeLogs directory
596 . ACE has been ported to OpenBSD 5.6. Old versions of
597   OpenBSD are no longer supported.
599 USER VISIBLE CHANGES BETWEEN ACE-6.2.8 and ACE-6.3.0
600 ====================================================
602 . ACE now supports Oracle Solaris Studio 12.4 on Solaris.
604 . New config macros were added:
605   ACE_DISABLE_MKTEMP:  Disables the availability of ACE_OS::mktemp().
606   ACE_DISABLE_TEMPNAM: Disables the availability of ACE_OS::tempnam().
607   These can be added to your $ACE_ROOT/ace/config.h to disable these
608   wrappers which are considered to be a potential security risk. Disabling
609   one or both will also disable the following:
610     - ACE_FILE_Addr::set () with the 'any' address specified.
611     - ACE_MMAP_Memory_Pool use of the 'unique' option.
613 . Reduced size of all doxygen documentation by changing the
614   type of diagrams shown
616 . Removed Windows specific workarounds from ACE_OS::setsockopt, as a
617   result SO_REUSEPORT is not defined anymore on Windows and SO_REUSEADDR
618   is passed directly to the OS
620 . By adding a 'specific' section to a MPC (base) project it is now possible
621   to have object file output directories per project for GNUACE projects.
622   The following should be added to MPC projects (bugzilla #3868):
623   specific(gnuace) {
624     build_dir_per_project=1
625   }
627 . ACE_Asynch_Write_File will now correctly accept non-socket (file, TTY ..)
628   handles (bugzilla #3762 and #3992)
630 . Fixes for VxWorks 6.9
632 USER VISIBLE CHANGES BETWEEN ACE-6.2.7 and ACE-6.2.8
633 ====================================================
635 . Add new ACE::make_event_handler<T>() which is similar
636   to std::make_shared but than for allocation of ACE
637   event handlers. This template method is only enabled
638   when ACE_HAS_CPP11 has been defined, which is set
639   automatically when a C++ compiler with adequate
640   C++11 support is used. Also ACE_Event_Handler_var is
641   extended with some C++11 specific operations
643 . For all reactor types calling cancel_timer with a
644   nullptr is now allowed, will result in a return of 0
646 . ACE_DLL and ACE_DLL_Manager have been extended with
647   the support to retrieve any dynamic loader errors
649 USER VISIBLE CHANGES BETWEEN ACE-6.2.6 and ACE-6.2.7
650 ====================================================
652 . Added configuration files for Microsoft Visual Studio 2014
654 . Added configuration files for MacOSX Yosemite
656 . Added configuration files for IBM AIX XL C++ 12.1
658 USER VISIBLE CHANGES BETWEEN ACE-6.2.5 and ACE-6.2.6
659 ====================================================
661 . Resolved several data races reported by Intel Inspector XE
663 . Added optional socket connection optimization for Windows
665 . Improve functionality and stability of running tests on
666   Android Virtual Device (AVD).
668 USER VISIBLE CHANGES BETWEEN ACE-6.2.4 and ACE-6.2.5
669 ====================================================
671 . Added the ability to build RPMs for just ACE, using an ACE-src tarball.
672   To do this add "--without tao" to the rpmbuild command line.
674 . Added support for Embarcadero C++Builder XE5 using
675   bcc32 in debug and release mode
677 . Added support for Embarcadero C++Builder XE6 using
678   bcc32 in debug and release mode
680 . When Intel C++ 2013 SP1 Update 2 is used with C++11 enabled
681   as compiler feature now also ACE_HAS_CPP11 will be defined,
682   this compiler is now able to compile all our C++11 feature
683   tests
685 . Fixed several boundary bugs in the ACE RLE Compressor
687 USER VISIBLE CHANGES BETWEEN ACE-6.2.3 and ACE-6.2.4
688 ====================================================
690 . Added support for FC20 and ended maintenance for FC19
692 . Extended C++11 feature test suite
694 . Improved support for MingW64
696 . Improvements to IPv6 support on Windows
698 USER VISIBLE CHANGES BETWEEN ACE-6.2.2 and ACE-6.2.3
699 ====================================================
701 . The ACE_OS::thr_join() method will detect if the thread to be waited on is
702   the calling thread and avert that deadlock. The support needed for this
703   method is available at Vista/Windows Server 2003 and higher; to enable
704   the deadlock prevention, compile ACE with _WIN32_WINNT=0x0502 or higher.
706 . Ended maintenance and support for FC12 CEEL
708 . Further improvements of the Android port: Added new define
709   ACE_HAS_EXPLICIT_TEMPLATE_CLASS_INSTANTIATION and related macros
710   ACE_SINGLETON_TEMPLATE_INSTANTIATION and ACE_SINGLETON_TEMPLATE_INSTANTIATE
711   providing a cleaner way to support explicit template (static member or class)
712   instantiation.
714 ' Improvements of the test framework for running tests in a mixed environment
715   where different targets run on different physiscal devices (possibly having
716   different OS).
718 USER VISIBLE CHANGES BETWEEN ACE-6.2.1 and ACE-6.2.2
719 ====================================================
721 . The max_len argument to ACE_Process::command_line_buf changed from int*
722   to size_t*. This corrects a mismatch between the argument type and the
723   data member in ACE_Process from which the value comes.
725 . Removed some include files from ACE.h. These were not required for ACE.
726   The removed includes are OS_NS_math, Flag_Manip, Handle_Ops, Lib_Find,
727   Init_ACE, Sock_Connect.h. You may have to explicitly add one of these
728   in your own code to restore compiling.
730 . Further improvements of the Android port, still work in progress.
732 USER VISIBLE CHANGES BETWEEN ACE-6.2.0 and ACE-6.2.1
733 ====================================================
735 . Added support for Fedora 19, ended daily maintenance
736   for Fedora 17 and 18
738 . Added support for Embarcadero C++BuilderXE4 using
739   bcc32 in debug and release mode
741 . Improved support for Android
743 USER VISIBLE CHANGES BETWEEN ACE-6.1.9 and ACE-6.2.0
744 ====================================================
746 . None
748 USER VISIBLE CHANGES BETWEEN ACE-6.1.8 and ACE-6.1.9
749 ====================================================
751 . Added MinGW64 as supported platform
753 . Added support for GCC 4.8.0
755 USER VISIBLE CHANGES BETWEEN ACE-6.1.7 and ACE-6.1.8
756 ====================================================
758 . Small bug fixes
760 USER VISIBLE CHANGES BETWEEN ACE-6.1.6 and ACE-6.1.7
761 ====================================================
763 . Integrated several patches to simplify Debian/Ubuntu
764   packaging
766 USER VISIBLE CHANGES BETWEEN ACE-6.1.5 and ACE-6.1.6
767 ====================================================
769 . Added new event and sema initialization methods to OS_NS_Thread
770   to allow passing pre-initialized condition attributes providing
771   basic support for using time policies in ACE Event classes.
773 . Added TIME_POLICY support to ACE_Event classes to allow for
774   monotonic timer support for ACE Events.
776 . Added new regression test:
777   Monotonic_Manual_Event_Test
779 USER VISIBLE CHANGES BETWEEN ACE-6.1.4 and ACE-6.1.5
780 ====================================================
782 . When a ACE_Event_Handler registered for signals is unregistered,
783   whether by unregistering, returning -1 from handle_signal(), or by
784   the reactor closing, the ACE_Event_Handler::handle_close() hook will
785   be called. The close_mask passed will be ACE_Event_Handler::SIGNAL_MASK.
786   In previous versions, handle_close() would only be called when the
787   handle_signal() callback returned -1. This resolves Bugzilla #2368.
789 . Some initial ACE unit tests to validate the C++11 support of various
790   compilers
792 . Added support for OpenSuSE 12.2
794 USER VISIBLE CHANGES BETWEEN ACE-6.1.3 and ACE-6.1.4
795 ====================================================
797 . Added a new ACE_Time_Value derived template class (Time_Value_T.h):
799   template <class TIME_POLICY> class ACE_Time_Value_T
801   This template class overloads 4 new virtual methods from
802   the ACE_Time_Value base class to provide time policy aware
803   time values:
804   to_relative_time ()
805   to_absolute_time ()
806   now ()
807   duplicate ()
809 . Updated time policy classes to return ACE_Time_Value_T<> instantiations
810   for the corresponding time policy instead of 'common' time values.
812 . Added new ACE_Monotonic_Time_Policy (Monotonic_Time_Policy.h).
813   This class provides a monotonic time source for supported
814   platforms (Windows and POSIX platforms providing the required
815   clock_gettime() time source; currently verified for Windows and
816   Linux)
818 . Updated OS_NS_Thread to use the new time policy support in ACE_Time_Value
819   for (relative) time calculations and added new ACE_OS::condattr_setclock ()
820   method.
822 . Added TIME_POLICY support to ACE_Condition_Attributes to allow for
823   monotonic timer support for ACE_Condition.
825 . Added TIME_POLICY support to ACE_Message_Queue-s, ACE_Task-s and
826   related classes to enable support for monotonic timers in the timed
827   wait methods (ACE_Condition based). See docs/ACE-monotonic-timer.html
828   for how to use this.
830 . Added two new regression tests:
831   Monotonic_Task_Test
832   Monotonic_Message_Queue_Test
833   and updated the Bug_4055_Regression_Test to a fixed state.
835 USER VISIBLE CHANGES BETWEEN ACE-6.1.2 and ACE-6.1.3
836 ====================================================
838 . Added support for Oracle Solaris Studio 12 Update 3 (SunCC 5.12)
840 . Added new XML_Utils library which comes from DAnCE but is now also used
841   by OpenDDS
843 USER VISIBLE CHANGES BETWEEN ACE-6.1.1 and ACE-6.1.2
844 ====================================================
846 . Added compile time support for Windows CE 7, no runtime testing has
847   been performed
849 . The High Res Timer global scale factor on Windows is now 64bit, see bugzilla
850   3703 for the background of this. If you use the gsf in your code, use the
851   new ACE_High_Res_Timer::global_scale_factor_type type trait to not get
852   any conversion warnings
854 . Removed Tandem NSK v2/v3 support which resulted in cleanup throughout all
855   code. The emulations for ACE_INT64/ACE_UINT64 have been removed because no
856   platform is using them anymore
858 USER VISIBLE CHANGES BETWEEN ACE-6.1.0 and ACE-6.1.1
859 ====================================================
861 . Minor bug fixes
863 USER VISIBLE CHANGES BETWEEN ACE-6.0.8 and ACE-6.1.0
864 ====================================================
866 . Added compilation support for VxWorks 6.9, no runtime
867   testing has been performed
869 . Added ACE Run-length encoding compressor
871 . Fixed several Coverity reported issues
873 USER VISIBLE CHANGES BETWEEN ACE-6.0.7 and ACE-6.0.8
874 ====================================================
876 . Added support for MPC's new feature that creates dependency files for IDL
877   files when generating '-type gnuace' projects. Turned off by default, it
878   can be enabled in a features file or on the command line with
879   '-features ace_idl_dependencies=1'.
881 USER VISIBLE CHANGES BETWEEN ACE-6.0.6 and ACE-6.0.7
882 ====================================================
884 . Added a new method to ACE_Atomic_Op<LOCK, TYPE>, TYPE exchange (TYPE newval)
885   which does an atomic exchange of the new value with ACE_Atomic_Op's value
886   and returns the old value. The tests/Atomic_Op_Test.cpp test program has a
887   test case that exemplifies its usage; see the Exchange_Tester class.
889 . Added a new feature to timer queue templates classes: TIME_POLICY.
890   This feature is specified through a new template argument and provides the
891   timer queue with a policy for a timer (time of day) value. This feature is
892   intended to replace (in time) the gettimeofday setter method which has been
893   marked @deprecated. For now backwards compatibility is guaranteed.
894   The TIME_POLICY feature provides flexibility with regards to providing a timer
895   source to the timer queues as well as the possibility for a fully optimized
896   calling path.
897   A number of standard time policies are provided in ace/Time_Policy.h.
898   The tests/Timer_Queue_Test.cpp has been updated to reflect and exemplify these
899   changes.
901 . Added the TIME_POLICY feature also to countdown time class which has now
902   become a template (ace/Countdown_Time_T.h)
904 . Initial support for Microsoft Visual Studio 11
906 . Increased overall code quality by using Coverity and Klocwork
908 USER VISIBLE CHANGES BETWEEN ACE-6.0.5 and ACE-6.0.6
909 ====================================================
911 . Removed autoconf support, only traditional way of
912   compilation is shipped from now
914 . Add support for RHEL 6.1 64bit
916 USER VISIBLE CHANGES BETWEEN ACE-6.0.4 and ACE-6.0.5
917 ====================================================
919 . Improved support for Android and added the ability to run all ACE/TAO tests
920   automatically using the Android emulator
922 USER VISIBLE CHANGES BETWEEN ACE-6.0.3 and ACE-6.0.4
923 ====================================================
925 . Removed support for C++ Builder
927 . Added support for building with the Android NDK, at least r5c. This
928   is currently available for linux host platforms.
930 USER VISIBLE CHANGES BETWEEN ACE-6.0.2 and ACE-6.0.3
931 ====================================================
933 . Added support for GCC 4.6
935 USER VISIBLE CHANGES BETWEEN ACE-6.0.1 and ACE-6.0.2
936 ====================================================
938 . The ACE_wrappers/ace/OS.h file has been restored in order to ensure
939   build-time compatibility with older ACE versions. Its use will still
940   cause your build to incur more processing time than using the needed
941   ace/OS_NS_*.h files; however, you should be able to build OS.h-including
942   code without needing to replace it with OS_NS_* includes.
944 . Improved and simplified QNX support
946 . Changed rand_r() and getpwnam_r() to conform Single UNIX Specification.
948 . Fixed performance of send_v on windows when individual iovec elements
949   are particularly large.
951 USER VISIBLE CHANGES BETWEEN ACE-6.0.0 and ACE-6.0.1
952 ====================================================
954 . Added support for MinGW with GCC 4.5
956 USER VISIBLE CHANGES BETWEEN ACE-5.8.3 and ACE-6.0.0
957 ====================================================
959 . Changed the string format produced by ACE::timestamp() from the ctime
960   format "Day Mon dd hh:mm:ss yyyy" to ISO-8601 yyyy-mm-dd hh:mm:ss.mmmmmm.
961   This makes the time easier to collate and removes any dependence on locale.
962   The change affects the output from ACE_Log_Msg's %D format and both VERBOSE
963   and VERBOSE_LIGHT timestamps in addition to application-made direct calls
964   to ACE::timestamp().
966 . Removed GCC < 3 support
968 . A new build system hook was added for users to include site-private rules
969   in a build. If a file named "rules.private.GNU" in located in any build
970   directory it will get included from
971   $ACE_ROOT/include/makeinclude/rules.local.GNU. The "private_rules_file"
972   make variable can be set to override the name and/or location of the file.
973   If no such rules file exists, its absence is silently ignored. This
974   facility can be used, for example, to integrate a specialized code checker
975   into the build process.
977 USER VISIBLE CHANGES BETWEEN ACE-5.8.2 and ACE-5.8.3
978 ====================================================
980 . Two new methods were added to ACE_Pipe: close_read() and close_write().
981   These methods can be used to close individual pipe handles.
983 . The ACE::handle_ready() family of methods was changed to prefer using
984   poll() over select() on platforms where poll() is available. This
985   preference was previously only used if ACE_HAS_LIMITED_SELECT was set.
986   The ACE_HAS_LIMITED_SELECT choice is removed, making ACE_HAS_POLL the
987   setting that switches this preference. The driving reason for this
988   is that if select() is called to detect changes on a handle whose
989   values falls outside that which can safely be stored in an fdset,
990   the handle-setting macros/functions will set/clear bits outside
991   of the fdset. This results in very weird memory changes, often in
992   the stack, which are very hard to diagnose. poll()'s operation
993   does not suffer from this affect. With the growing use of large
994   numbers of handles and use of ACE_Dev_Poll_Reactor on Linux,
995   the rate at which this problem was cropping up was increasing.
997 . Added a simple helper ACE::is_equal() which compares equality of two
998   objects without using operator==. This is useful for comparing floating
999   point values.
1001 . Removed all deprecated methods, arguments, files, classes, macros and
1002   anything else we kept for years.
1004 . Removed Irix/Tru64/SCO/Uniware/Cray support
1006 . ACE_Pair has been removed. Users should now use std::pair.
1008 . This is the last micro release that will work with GCC < 3, after x.8.3
1009   support for GCC < 3 will be removed
1011 USER VISIBLE CHANGES BETWEEN ACE-5.8.1 and ACE-5.8.2
1012 ====================================================
1014 . Added support for the Microsoft Visual Studio 2010 IDE (vc10)
1016 . Removed complete support for emulated C++ exceptions
1018 USER VISIBLE CHANGES BETWEEN ACE-5.8.0 and ACE-5.8.1
1019 ====================================================
1021 . Added support for Microsoft Visual Studio 2010 using nmake
1023 . Reduced the amount of doxygen pages generated, the original settings caused
1024   a doxygen generated html package of 1.4GB which was way too large
1026 . Extended ACE INet addon library with:
1027   * HTTP Basic Authentication
1028   * SSL/HTTPS support.
1029   * Proxy CONNECT tunneling.
1031 USER VISIBLE CHANGES BETWEEN ACE-5.7.9 and ACE-5.8.0
1032 ====================================================
1034 . There are two new ACE_Time_Value methods for getting and setting millisecond
1035   values to/from ACE_UINT64 values:
1037       ACE_UINT64 ACE_Time_Value::get_msec () const
1038       void ACE_Time_Value::set_msec (const ACE_UINT64 &ms)
1040   The former is a replacement for the existing msec(ACE_UINT64&) methods that
1041   are "getter" methods whose signatures look confusingly like "setters". See
1042   Bugzilla #3336 for the history behind this change.
1044   The latter is for consistency and clarity.
1046 . Added ACE INet addon library for Inet protocol clients (and possibly
1047   servers at some point) like http://, ftp:// etc.
1048   The library implements standard C++ iostream wrapper classes for
1049   ACE Svc_Handler and Reactor based input/output handling, URL classes
1050   and protocol handler classes.
1051   NOTE: This is work in progress! There is no guarentee that the API
1052   won't change in the next few releases.
1053   Protocol handling is currently restricted to client side download
1054   requests for HTTP and FTP.
1055   Handling for upload requests should be added in the near future as well
1056   as HTTP Basic Authentication.
1058 USER VISIBLE CHANGES BETWEEN ACE-5.7.8 and ACE-5.7.9
1059 ====================================================
1061 . ACE's default makefiles (traditional ACE/GNU, not autoconf/automake)
1062   now support installation with "make install".
1063   Please see the ACE-INSTALL.html file for instructions.
1065 . Support for the ARCH make variable has been enhanced to apply to executables
1066   (in addition to libraries and object files), and the ARCH feature has been
1067   integrated into the MPC-generated makefiles (to work with MPC's requires
1068   and avoids features).
1070 USER VISIBLE CHANGES BETWEEN ACE-5.7.7 and ACE-5.7.8
1071 ====================================================
1073 . ACE now uses GCC builtin Atomic instructions for short,
1074   unsigned short, long, unsigned long, int, unsigned int,
1075   and bool. This makes our Atomic_Op around 7 times faster
1077 . ACE Service Configuration Framework now process first service
1078   configuration files and then command-line directives. Thus if
1079   application uses both service configuration files and command-line
1080   directives then the command-line directives may override results of
1081   directives in the configuration files. At the same time if the
1082   application uses only the default svc.conf file and command-line
1083   directives then the directives from svc.conf can not override
1084   results of the user provided command-line directives.
1086 . ACE_Dev_Poll_Reactor now dispatches notifications in only one thread at
1087   a time. This brings notification handling more in line with behavior in
1088   other Reactor implementations.
1090 USER VISIBLE CHANGES BETWEEN ACE-5.7.6 and ACE-5.7.7
1091 ====================================================
1093 . Integrated fix for bug 3104 and regression test for
1094   interval timers.
1096 . Added support for GCC builtin Atomic instructions which
1097   are enabled with GCC >= 4.1 for PPC32/PPC64/IA64
1099 . Improved autoconf support for debian
1101 . Added support for -mcpu and -mtune. Add TCPU=.. to your
1102   environment/platform_macros.GNU to specify you cpu and
1103   than add cpumodelflag=1 and/or tunemodelflag=1. Using
1104   this with IBM Cell increased the performance significantly
1106 USER VISIBLE CHANGES BETWEEN ACE-5.7.5 and ACE-5.7.6
1107 ====================================================
1109 . Added support for iPhone/iPod Touch/iPad. The following
1110   environment variables are needed:
1112   IPHONE_TARGET, should be set to either SIMULATOR or
1113   HARDWARE. Set to HARDWARE if you want to deploy
1114   on the iPhone/iPod Touch/iPad device.
1116   IPHONE_VERSION, should be set to 3.1.2 or 3.2. One can
1117   set the version to any future or past versions, but
1118   only 3.1.2 and 3.2 have been tried.
1120   Note that one has to compile ACE/TAO statically as
1121   it is believed that the iPhone OS does not support
1122   dynamic loading of external libraries. The usual
1123   procedure of cross compiling ACE/TAO applies
1124   (such as setting HOST_ROOT environment variable).
1126 . Added support for Embarcadero C++ Builder 2010
1128 . Added option to print a given ACE_Time_Value in the log
1129   message instead of system supplied timestamp as in %T
1130   and %D.
1131   The option is implemented as a variant of the %D/%T
1132   options by using the '#' flag character like '%#D' or
1133   '%#T'. When using this flag an ACE_Time_Value pointer is
1134   expected in the argument list supplied with the log message.
1135   This fixed Bugzilla #3221.
1137 . Fixed problems with ACE_INET_Addr::is_multicast() on
1138   little endian platforms. This fixed bugzilla #3729.
1140 . Added compilation support for VxWorks 6.8, no runtime
1141   testing has been performed
1143 USER VISIBLE CHANGES BETWEEN ACE-5.7.4 and ACE-5.7.5
1144 ====================================================
1146 . Added MacOSX Snow Leopard support
1148 . Added strsignal() wrapper
1150 . Improved LynxOS support
1152 . Updated Interix port
1154 . Fixed MinGW compilation problems
1156 USER VISIBLE CHANGES BETWEEN ACE-5.7.3 and ACE-5.7.4
1157 ====================================================
1159 . ACE_CDR::consolidate now returns an int, 0 is ok, -1 is failure
1161 . Fixed a bug in the realclean feature of the GNU makefiles
1163 . Improved Sun Studio for Linux support
1165 . Improved OpenBSD support
1167 USER VISIBLE CHANGES BETWEEN ACE-5.7.2 and ACE-5.7.3
1168 ====================================================
1170 . C++ Builder 2009 Update 3 is the only C++Builder that is supported, older
1171   and newer compilers are not supported anymore
1173 . Made final changes for the CEGCC port
1175 . Added a set of tests to validate C++ compiler and the stl implementation
1176   they ship.
1178 . HP-UX PARISC aCC < 3.80 are deprecated and can't be used anymore. Upgrade
1179   to aCC 3.80 or newer
1181 USER VISIBLE CHANGES BETWEEN ACE-5.7.1 and ACE-5.7.2
1182 ====================================================
1184 . Borland C++ makefiles aren't shipped anymore as part of the release
1185   but have to be generated by the user
1187 . Refactored gperf to have its own shared library so that we can reuse
1188   that in TAO
1190 . Added support for SuSE Enterprise 10
1192 . ACE_Configuration_Heap::open() now returns -1 with errno EBUSY if it is
1193   called multiple times. Previous versions would allow multiple calls to
1194   open() but leak resources.
1196 USER VISIBLE CHANGES BETWEEN ACE-5.7.0 and ACE-5.7.1
1197 ====================================================
1199 . Added support for Sun Studio 12 Update Pack 1
1201 . Fixed compile problems when using Windows CE x86 release mode
1203 . Fixed compile problems for FreeBSD
1205 USER VISIBLE CHANGES BETWEEN ACE-5.6.9 and ACE-5.7.0
1206 ====================================================
1208 . Added support for the VxWorks vxAtomicLib which is available with VxWorks 6.6
1209   and newer. If you don't want to use this library undef ACE_HAS_VXATOMICLIB
1210   in your config.h file
1212 . Added support for C++ Builder 2009 Update 3
1214 . Added support for ACE/TAO using the CEGCC project
1216 . Added support for upcoming Fedora 11 and OpenSuSE Factory
1218 USER VISIBLE CHANGES BETWEEN ACE-5.6.8 and ACE-5.6.9
1219 ====================================================
1221 . Removed Borland/CodeGear C++ Builder 2007 support.  If you'd like to
1222   fund this support please let us know.
1224 . Removed VxWorks 5.5.x, 6.2, and 6.3 support.  If you'd like to fund
1225   this support please let us know.
1227 . Improved Unicode support.
1229 . Added support for the native Windows Vista and Windows Server 2008
1230   condition variables. These has to be enabled at compile time, and when
1231   enabled the application can only run on Vista or Server 2008.  Add
1232   ACE_HAS_WTHREADS_CONDITION_VARIABLE to your config.h file to enable
1233   these
1235 . Fixed a bug when trying to read a file of 1 byte when unicode is
1236   enabled
1238 . Improved the Windows CE port
1240 . Fixed several Klocwork reported issues
1242 . Added support for MinGW 3.15
1244 . Added support for Incredibuild, which is an MSVC++ feature that
1245   optimizes compiles via distributing builds.
1247 USER VISIBLE CHANGES BETWEEN ACE-5.6.7 and ACE-5.6.8
1248 ====================================================
1250 . Added a new function ACE::isdotdir() which determines if a specified
1251   pathname is "dot dir" (ie. "." or ".."). ACE::isdotdir() is significantly
1252   faster than pair of strcmp() calls.
1254 . Last micro release that is maintained for Borland/CodeGear C++
1255   Builder 2007 and Intel C++ on Windows.
1257 . Fixed crash when ACE thread tries to inherit the logging attributes
1258   from non ACE threads.
1260 . Fixed many small compile and test errors that occur on some platforms.
1262 . Fixed log output formatting on some platforms.
1264 . Bugs fixed:  2748, 3164, 3480, 3494, 3502, 3541, 3542, 3544, 3557.
1266 USER VISIBLE CHANGES BETWEEN ACE-5.6.6 and ACE-5.6.7
1267 ====================================================
1269 . Changed the automake build's feature test for a "usable" config
1270   to warn on failure instead of exiting with an error.  This should
1271   make it easier to diagnose configure failures, as the script will
1272   now generate a config.h file even when the test fails.
1274 . Removed borland MPC template, use the bmake template from now
1276 . Added Windows Mobile 6 support and improved the WinCE port
1278 . Removed BCB6 and BCB2006 support
1280 . Added BCB2009 MPC template
1282 . Updated stat struct on Windows CE to match the stat struct on other
1283   platforms so that application code can be written portable
1285 . Added new ACE_OS wrappers: raise, atof, atol, isblank, isascii,
1286   isctype, and iswctype
1288 . Added ACE_OS wrapper for narrow-char version of strtoll.
1290 . ACE_OS wrappers for wide-char versions of strtol, strtoul,
1291   strtoll, and strtoll.
1293 . Added Visual Studio 2010 (vc10) support
1295 . Added a new feature for the "Traditional Make" build facility to allow
1296   building for multiple architectures out of a single source directory.
1297   To use this facility, set the ARCH make variable. The ARCH value will be
1298   used to add a subdirectory layer below the source directory where the
1299   traditional .shobj, .obj, etc. directories will be placed.
1301 . Added support for HP-UX 11iv3 on Integrity using aC++
1303 . ACE (and TAO) can now be built using GNU make and the Microsoft Visual C++
1304   compiler and linker.  See include/makeinclude/platform_win32_msvc.GNU for
1305   more details.
1307 . Added support for FC10
1309 USER VISIBLE CHANGES BETWEEN ACE-5.6.5 and ACE-5.6.6
1310 ====================================================
1312 . Added an option to the ACE_Process_Options class to use a wchar_t
1313   environment buffer on Windows.
1315 . A new configure option, --enable-rcsid, was added to the autoconf build.
1316   This is used to embed RCS IDs in object files.
1318 . A new method was added: void ACE_Time_Value::msec (ACE_UINT64&)
1319   This method, like the existing msec(ACE_UINT64&)const method, obtains the
1320   time value in milliseconds and stores it in the passed ACE_UINT64 object.
1321   This method was added so that msec(ACE_UINT64&) can be called on both
1322   const and non-const ACE_Time_Value objects without triggering compile errors.
1323   Fixes Bugzilla #3336.
1325 . Added ACE_Stack_Trace class to allow users to obtain a stack trace
1326   within their application on supported platforms. A new conversion
1327   character, the question mark, was added to ACE_Log_Msg for stack
1328   trace logging.
1330 . Added iterator support to ACE_Message_Queue_Ex class. The resulted in
1331   the addition of ACE_Message_Queue_Ex_Iterator class and
1332   ACE_Message_Queue_Ex_Reverse_Iterator class.
1334 . Renamed gperf to ace_gperf to prevent clashes with the regular gperf
1335   tool that is available in linux distributions
1337 . Added support for FC9
1339 . Added support for OpenSuSE 11.0
1341 . Improved support for GCC 4.2 and 4.3
1343 . Added support for CodeGear C++ Builder 2009
1345 USER VISIBLE CHANGES BETWEEN ACE-5.6.4 and ACE-5.6.5
1346 ====================================================
1348 . Added new Monitoring lib that can be used to store and retrieve
1349   counters. This is disabled by default because it is not 100%
1350   finished yet, with the next release it will be enabled by default
1352 . Fixed bug in ACE_Service_Config when it was used from a thread
1353   not spawned by ACE
1355 . Add VxWorks 6.x kernel mode with shared library support to ACE
1357 . Extended the implementation of Unbounded_Set, which has been
1358   renamed Unbounded_Set_Ex, to accept a second parameter which is
1359   a comparator that implements operator() which returns true if
1360   the items are equivalent.  Unbounded_Set has been reimplemented
1361   in terms of Unbounded_Set_Ex using a comparator that uses operator==,
1362   which captures the previous behavior.
1364 . Added support for Intel C++ on MacOSX
1366 USER VISIBLE CHANGES BETWEEN ACE-5.6.3 and ACE-5.6.4
1367 ====================================================
1369 . Reworked the relationship between ACE_Service_Config and
1370   ACE_Service_Gestalt
1372 . Improved autoconf support
1374 . Improved AIX with gcc support
1376 . Improved OpenVMS support
1378 . Improved VxWorks support
1380 USER VISIBLE CHANGES BETWEEN ACE-5.6.2 and ACE-5.6.3
1381 ====================================================
1383 . Deprecated Visual Age 5 and older
1385 . Closed a rare race condition hole whereby ACE_Atomic_Op<> function
1386   pointers would not be fully initialized prior to use.  See bugzilla
1387   3185 for details.
1389 . Tweaks to support MacOS X Leopard (10.5 and 10.5.1) on Intel
1391 . Fixed compile problems with MinGW with GCC 4.2. Do note that we do see
1392   much more test failures then when using GCC 3.4.
1394 . Changed to use synchronous exception handling with msvc 8/9 which is the
1395   default. Asynchrous exception handling does catch access violations but
1396   it leads to lower performance and other problems. See also bugzilla 3169
1398 . Make ace_main extern C with VxWorks so that it doesn't get mangled
1400 . Fixed compile errors and warnings for VxWorks 6.6
1402 . Added an MPC generator for the WindRiver Workbench 2.6 which is shipped
1403   with VxWorks 6.4
1405 . Added support for CodeGear C++ Builder 2007 with December 2007 update
1406   installed
1408 . Added support for VxWorks 5.5.1
1410 . Implemented the const reverse iterator for ACE_Hash_Map_Manager_Ex
1412 . Increased support for using ACE_Hash_Map_Manager_Ex with STL <algorithm>
1413   functions based on latest standard C++ draft
1415 USER VISIBLE CHANGES BETWEEN ACE-5.6.1 and ACE-5.6.2
1416 ====================================================
1418 . ACE-ified the UUID class, which will change user applications slightly.
1420 . Added support for Sun Studio 12
1422 . Added support for Intel C++ 10.1
1424 . Fixed runtime problems with VxWorks 6.x in kernel mode, several improvements
1425   have been made to ACE, but also some problems in the VxWorks kernel have
1426   been found for which WindRiver has made patches.
1428 . Added support for VxWorks 6.5 kernel mode
1430 . Added support for MacOS 10.5
1432 . Support for MacOS 10.4 is now deprecated.
1434 . Added support for OpenSuSE 10.3
1436 . Added support for RedHat 5.1
1438 . Added support for Microsoft Visual Studio 2008
1440 . Added support for Fedora Core 8
1442 . Added support for Ubuntu 7.10
1444 . With Ubuntu 7.04 and 7.10 we can't use visibility, that results in
1445   unresolved externals when building some tests. With lsb_release we
1446   now detect Ubuntu 7.04 and 7.10 automatically and then we disable
1447   visibility
1449 . Removed deprecated (un)subscribe methods from ACE_SOCK_Dgram_Mcast
1451 . Added an additional replace() method to ACE_OuptutCDR for replacing a
1452   ACE_CDR::Short value. Also added write_long_placeholder() and
1453   write_short_placeholder() to properly align the stream's write pointer,
1454   write a placeholder value and return the placeholder's pointer. The pointer
1455   can later be used in a call to replace() to replace the placeholder with a
1456   different value.
1458 . Initial support for VxWorks 6.6
1460 . Removed support for pthread draft 4, 6, & 7. This makes the ACE threading
1461   code much cleaner
1463 . Improved autoconf support
1465 . Fixed TSS emulation problems
1467 . Changed ACE_thread_t and ACE_hthread_t to int for VxWorks kernel mode. All
1468   thread creation methods do have an additional const char* argument to
1469   specify the task name, this now also works with pthread support enabled
1471 . Use bool in much more interfaces where this is possible
1473 . Added support for Debian Etch
1475 . Fixed ACE CDR LongDouble support on VxWorks 6.x
1477 . Added Microsoft Visual Studio 2008 project files to the release packages
1479 . Fixed a few bugs in the ACE_Vector template
1481 USER VISIBLE CHANGES BETWEEN ACE-5.6 and ACE-5.6.1
1482 ====================================================
1484 . Added support for CodeGear RAD Studio 2007
1486 . Added support for CodeGear C++ Builder 2007 Update 3
1488 . Modified the definiton of ACE_DEFAULT_THREAD_KEYS on Windows so it
1489   is based on the version of the OS as defined by Microsoft in this web
1490   page: http://tinyurl.com/2jqcmd
1491   This fixes bugzilla #2753
1493 USER VISIBLE CHANGES BETWEEN ACE-5.5.10 and ACE-5.6
1494 ====================================================
1496 . OpenVMS 8.3 on IA64 port
1498 . Added autoconf support for Intel C++ 10.0
1500 . Improved autoconf support on Linux, Solaris, NetBSD and HPUX
1502 . CodeGear C++ Builder 2007 Update 2 support
1504 . The netsvcs's client logging daemon has a new configuration option,
1505   -llocal-ip[:local-port], which can be used to specify the local IP
1506   address and port number for the client logging daemon's connection to
1507   the server logging daemon. If the -l option is specified with an IP
1508   address but not a port number, an unused port number is selected.
1510 . A new ACE+TAO port to LabVIEW RT 8.2 with Pharlap ETS. The host build
1511   environment is Windows with Microsoft Visual Studio .NET 2003 (VC7.1).
1512   Please see the ACE-INSTALL.html file for build instructions.
1514 USER VISIBLE CHANGES BETWEEN ACE-5.5.9 and ACE-5.5.10
1515 ====================================================
1517 . The ACE_utsname struct, used in the ACE_OS::uname() function when the
1518   platform doesn't provide the standard utsname struct, was changed. It
1519   defines a number of text fields and their types were changed from
1520   ACE_TCHAR[] to char[] in order to be consistent with all other platforms.
1521   This removes the need to write different code for platforms where
1522   ACE_LACKS_UTSNAME_T is set and that have wide characters (most probably
1523   Windows). Fixes Bugzilla #2665.
1525 . The ACE::daemonize() "close_all_handles" parameter was changed from
1526   an "int" to a "bool" to better reflect how it is used.
1528 . VxWorks 6.5 support. Compilation of the core libraries has been validated
1529   but no runtime testing has been performed.
1531 . CodeGear C++ Builder 2007 support.
1533 . The FaCE utility was moved from the ACE_wrappers/apps directory to
1534   ACE_wrappers/contrib. It is used for testing ACE+TAO apps on WinCE.
1535   See the ACE_wrappers/contrib/FaCE/README file for more information.
1537 . ACE_INET_Addr::set (u_short port, char *host_name, ...) now favors IPv6
1538   addresses when compiled with ACE_HAS_IPV6 defined and the supplied address
1539   family is AF_UNSPEC. This means that if host_name has an IPv6 address in
1540   DNS or /etc/hosts, that will be used over an IPv4 address. If no IPv6
1541   address exists for host_name, then its IPv4 address will be used.
1543 . Intel C++ 10.0 support
1545 . Support for the version of vc8 for 64-bit (AMD64) shipped with the Microsoft
1546   Platform SDK.
1548 . Fixed ACE_Vector::swap() (bugzilla #2951).
1550 . Make use of the Atomic_Op optimizations on Intel EM64T processors. The
1551   Atomic_Op is now several times faster on EM64T then with previous versions
1552   of ACE
1554 USER VISIBLE CHANGES BETWEEN ACE-5.5.8 and ACE-5.5.9
1555 ====================================================
1557 . Use Intel C++ specific optimizations for Linux on IA64
1559 . Improved support for ACE_OS::fgetc. Added support for ACE_OS::fputc,
1560   ACE_OS::getc, ACE_OS::putc and ACE_OS::ungetc.
1562 . Added support for ACE_OS::log2(double) and improved support for
1563   ACE::log2(u_long).
1565 . Shared library builds on AIX now produce a libxxx.so file instead of the
1566   previous practice of producing libxxx.a(shr.o).
1568 . GCC 4.1.2 that comes with Fedora 7 seems to have a fix for the visibility
1569   attribute we use for the singletons. F7 users will therefore need to
1570   define the following in your config.h file.
1571   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1573 . Fixed (rare) problem in TP_Reactor where incorrect event handler was
1574   resumed.
1576 . Reduced footprint on some platforms, particularly those that use
1577   g++ >= 3.3.
1579 USER VISIBLE CHANGES BETWEEN ACE-5.5.7 and ACE-5.5.8
1580 ====================================================
1582 . Extended ACE_Event constructor with optional LPSECURITY_ATTRIBUTES
1583   argument
1585 . Added support for QT4
1587 . Added support to integrate with the FOX Toolkit (www.fox-toolkit.org)
1589 . Added support for Microsoft Visual Studio Code Name "Orcas", which is
1590   the msvc9 beta
1592 . Added ability to provide an optional priority when calling
1593   ACE_Message_Queue_Ex::enqueue_prio(). There was previously no way
1594   to specify a priority for queueing.
1596 . Removed support for Visual Age on Windows.
1598 . ACE will compile once again with ACE_LACKS_CDR_ALIGNMENT #defined.
1600 . ACE_Process_Manager::terminate() no longer removes the process from the
1601   process descriptor table; the pid remains available in order to call
1602   ACE_Process_Manager::wait().
1604 USER VISIBLE CHANGES BETWEEN ACE-5.5.6 and ACE-5.5.7
1605 ====================================================
1607 . ACE 5.5 contained a set of pragmas which prevented Visual Studio 2005 (VC8)
1608   from issuing warnings where C run-time functions are used but a more
1609   secure alternative is available. For more information on the C run-time
1610   issues and Microsoft's response, please see the following MSDN page:
1611   http://msdn2.microsoft.com/en-us/library/8ef0s5kh(VS.80).aspx.
1612   In this beta, the pragmas which prevented the warnings have been removed.
1613   The ACE library has been reviewed and most of the use of "unsafe" functions
1614   has been fixed where possible. Since not all of the warnings emanating from
1615   ACE are situations that can or should be fixed, the ACE VC8 projects will
1616   prevent the warnings while building the ACE kit and its contained examples,
1617   tests, etc. The warnings are disabled by adding Microsoft-specified macros
1618   to the compile line via MPC. If desired, the warnings can be re-enabled by
1619   regenerating the project files with different MPC features. Note, however,
1620   that while ACE without warnings caused by the new C run-time functions, your
1621   application builds may trigger these warnings either by use of the "unsafe"
1622   C run-time functions or via use of an inlined ACE_OS method which uses it.
1623   If the warning is caused by an ACE_OS method, there is a more safe alternate
1624   available, probably located by appending _r to the method name (e.g.,
1625   instead of using ACE_OS::ctime(), use ACE_OS::ctime_r()).
1626   There are other cases where the compiler may have issued warnings and ACE
1627   prevented this via a #pragma. These #pragmas have been removed as well.
1628   This may cause your application builds to trigger more warnings from VC8
1629   than past ACE versions. You should review your code and either correct
1630   the code or disable the warnings locally, as appropriate.
1632 . The "release" argument to a number of ACE_String_Base<> methods was changed
1633   from int to bool to more accurately reflect its purpose. The following
1634   methods were changed:
1636             ACE_String_Base (const CHAR *s,
1637                              ACE_Allocator *the_allocator = 0,
1638                              int release = 1);
1639           to
1640             ACE_String_Base (const CHAR *s,
1641                              ACE_Allocator *the_allocator = 0,
1642                              bool release = true);
1644             ACE_String_Base (const CHAR *s,
1645                              size_type len,
1646                              ACE_Allocator *the_allocator = 0,
1647                              int release = 1);
1648           to
1649             ACE_String_Base (const CHAR *s,
1650                              size_type len,
1651                              ACE_Allocator *the_allocator = 0,
1652                              bool release = true);
1654             void set (const CHAR * s, int release = 1);
1655           to
1656             void set (const CHAR * s, bool release = true);
1658             void set (const CHAR * s, size_type len, int release);
1659           to
1660             void set (const CHAR * s, size_type len, bool release);
1662             void clear (int release = 0);
1663           to
1664             void clear (bool release = false);
1666   Since ACE_String_Base forms the basis of the ACE_CString and ACE_TString
1667   classes, this may ripple out to user application code. If you encounter
1668   errors in this area while building your applications, replace the
1669   int argument you are passing to the method now with either true or false.
1671 . Solutions for the eVC3/4 platform have been removed from this
1672   release.  Note that we package WinCE projects/workspaces for use
1673   with VC8.
1675 . There were 3 new ACE_Log_Msg logging format specifiers added to make logging
1676   easier for types that may change sizes across platforms. These all take one
1677   argument, and the new formats are:
1678     %b - format a ssize_t value
1679     %B - format a size_t value
1680     %: - format a time_t value
1682 . The ace/Time_Request_Reply.h and ace/Time_Request_Reply.cpp files were
1683   moved from $ACE_ROOT/ace to $ACE_ROOT/netsvcs/lib. The time arguments in
1684   the public API to ACE_Time_Request were changed from ACE_UINT32 to time_t
1685   and the portions of the on-wire protocol that contains time was changed from
1686   ACE_UINT32 to ACE_UINT64. Thus, code that uses the ACE_Time_Request class
1687   to transfer time information will not interoperate properly with prior
1688   ACE versions. This will affect uses of the netsvcs time clerk/server.
1690 . The portion of the ACE_Name_Request class that carries the on-wire seconds
1691   portion of a timeout value was changed from ACE_UINT32 to ACE_UINT64. This
1692   means that Name server/clients at ACE 5.5.7 and higher will not interoperate
1693   properly with previous ACE versions' name servers/clients.
1695 . In the ACE_Log_Record (ACE_Log_Priority, long, long) constructor, the
1696   second argument, long time_stamp, was changed to be of type time_t. This
1697   aligns the type with the expected value, a time stamp such as that returned
1698   from ACE_OS::time().
1700 . Added support for VxWorks 6.x cross compilation using a Windows host
1701   system
1703 . Added support for VxWorks 6.x using the diab compiler
1705 . The destructor of ACE_Event_Handler no longer calls
1706   purge_pending_notifications().  Please see bugzilla #2845 for the full
1707   rationale.
1708   (http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2845)
1710 USER VISIBLE CHANGES BETWEEN ACE-5.5.5 and ACE-5.5.6
1711 ====================================================
1713 . The ACE_TYPENAME macro has been added to those that are not
1714   available when the ACE_LACKS_DEPRECATED_MACROS config option is set
1715   (it is not set by default). You are encouraged to replace the use of
1716   ACE_TYPENAME with the C++ typename keyword before the ACE_TYPENAME
1717   macros is removed from ACE in the future.
1719 . A new script, rm_exception_macros.pl, has been added to help users
1720   remove the use of the ACE exception macros from their own code.
1722 USER VISIBLE CHANGES BETWEEN ACE-5.5.4 and ACE-5.5.5
1723 ====================================================
1725 . The prebuild MPC keyword is now supported by the gnuace project type.
1726   This fixes Bugzilla #2713.
1728 . Support for Windows earlier than NT 4 SP2 was removed. ACE will not build
1729   for Windows 95, 98, Me, etc. out of the box any longer.
1731 . Reformat stringified IPv6 addresses to use [addr]:port when printing
1732   addresses that contain ':' such as "::1".
1734 . Added method to ACE_INET_Addr to determine if address is IPv6 or
1735   IPv4 multicast.
1737 . Fixed a bug in ACE_Async_Timer_Adapter_Timer_Queue_Adapter<TQ> where the
1738   gettimeofday function of the timer queue was ignored when setting the alarm.
1740 . Fixed a problem where, on Solaris 9 onwards, calling
1741   ACE_OS::thr_create(THR_NEW_LWP) more than 2^15 (65535) times in a
1742   process will fail.  See changelog entry from "Wed Jan 3 22:31:05 UTC
1743   2007 Chris Cleeland <cleeland_c@ociweb.com>" for more information.
1745 . Fixed a bug in ACE_QtReactor where the two select() calls in that function
1746   might select on different handler sets.
1748 . ACE_SOCK_IO::recvv(iovec[], size_t, const ACE_Time_Value* = 0) and
1749   ACE_SOCK_IO::sendv (const iovec[], size_t, const ACE_Time_Value* = 0) methods
1750   were changed to specify the iovec count argument as int instead of size_t
1751   since it gets reduced to int in the underlying OS calls (usually).
1753 . The following deprecated methods were removed:
1755     ssize_t ACE_SOCK_IO::recv (iovec iov[],
1756                                size_t n,
1757                                const ACE_Time_Value *timeout = 0) const;
1759     ssize_t ACE_SOCK_IO::recv (iovec *io_vec,
1760                                const ACE_Time_Value *timeout = 0) const;
1762     ssize_t ACE_SOCK_IO::send (const iovec iov[],
1763                                size_t n,
1764                                const ACE_Time_Value *timeout = 0) const;
1766     These were previously replaced with more specific recvv() and sendv()
1767     methods.
1769 . The ACE_Service_Repository::find(const ACE_TCHAR name[],
1770                                    const ACE_Service_Type **srp = 0,
1771                                    int ignore_suspended = true) const
1772   method's 'ignore_suspended' parameter was changed from int to bool to
1773   reflect it's purpose as a yes/no indicator.
1775 . Added --enable-ace-reactor-notification-queue configure script
1776   option to the autoconf build for enabling the Reactor's userspace
1777   notification queue (defines ACE_HAS_REACTOR_NOTIFICATION_QUEUE in
1778   config.h).
1780 . The int ACE_OutputCDR::consolidate(void) method was contributed by
1781   Howard Finer at Sonus Networks. This method consolidates any continuation
1782   blocks used by an ACE_OutputCDR object into a single block. It's useful for
1783   situations which require access to a single memory area containing the
1784   encoded stream, regardless of its length, when the length cannot be known
1785   in advance.
1787 . There are a number of new methods defined on ACE_String_Base<CHAR>:
1789         size_t capacity (void) const:  This method returns the number
1790             of allocated CHAR units in the string object.
1792         void fast_resize (size_t): This method manage the sizing/reallocating
1793             of the string, but doesn't do the memory setting of resize().
1795         bool operator!= (const CHAR *) const
1796         bool operator== (const CHAR *) const: These methods compare the
1797             string with a nul-terminated CHAR* string.
1799         nonmember functions operator== and operator!= where also added
1800             that compare const ACE_String_Base and const CHAR*; these make
1801             it possible to switch ACE_String and CHAR* on either side of
1802             the operator.
1804   Thank you to Kelly Hickel <kfh at mqsoftware dot com> for these additions.
1806 . There are 2 new build options on the traditional make command:
1807   dmalloc and mtrace. When specified at build time (e.g. make mtrace=1)
1808   the PLATFORM_DMALLOC_CPPFLAGS and/or PLATFORM_MTRACE_CPPFLAGS values
1809   are added to CPPFLAGS. For dmalloc, the PLATFORM_DMALLOC_LDFLAGS and
1810   PLATFORM_DMALLOC_LIBS are added to LDFLAGS and LIBS, respectively.
1811   Thank you to Howard Finer for supplying these additions.
1813 . Added the ability to specify additional purify and quantify command-line
1814   options by setting PLATFORM_PURIFY_OPTIONS and PLATFORM_QUANTIFY_OPTIONS,
1815   respectively. Thank you to Howard Finer for supplying these additions.
1817 . Added the ability to use trio (http://sourceforge.net/projects/ctrio/)
1818   if platform lacks decent support for vsnprintf. trio support is
1819   enabled by defining trio=1 in plaform_macros.GNU
1821 . Removed Irix 5, DGUX, and m88k support
1823 . Improved LynxOS 4.2 support
1825 . VxWorks 6.4 support
1827 . Added support for FC6. Because the GCC 4.1.1 version that gets shipped
1828   has a fix for the visibility attribute we use for the singletons
1829   you will need to define the following in your config.h file. This can't be
1830   done automatically because SuSE 10.2 gets shipped with GCC 4.1.2 but
1831   doesn't have the same fix
1832   ACE_GCC_HAS_TEMPLATE_INSTANTIATION_VISIBILITY_ATTRS 1
1834 . RTEMS port
1836 USER VISIBLE CHANGES BETWEEN ACE-5.5.3 and ACE-5.5.4
1837 ====================================================
1839 . Added appropriate intptr_t and uintptr_t typedefs on platforms that
1840   don't provide them (i.e. when ACE_LACKS_INTPTR_T is defined).
1842 . Added ability to explicitly choose support for 32 bit or 64 bit file
1843   offsets on all platforms.  Define the _FILE_OFFSET_BITS preprocessor
1844   symbol to either 32 or 64 to choose the desired number of file
1845   offset bits.  This preprocessor symbol is supported natively by most
1846   UNIX and UNIX-like operating systems, and supported by ACE on
1847   Windows.  Use the new ACE_OFF_T typedef to refer to file offsets
1848   across UNIX and Windows portably.
1850 . 64-bit file offsets are now enabled by default in Win64
1851   configurations.
1853 . Improved support for 64 bit platforms (64 bit addresses, etc).
1855 . Added STL-style traits, iterators and a swap() method to the
1856   ACE_Array_Base<> class template.
1858 . Added STL-style traits and iterator accessors to the
1859   ACE_Hash_Map_Manager_Ex<> class template, as well as new find() and
1860   unbind() methods that return (as an "out" parameter) and accept
1861   iterators, respectively.
1863 . Greatly improved event handler dispatch performance in
1864   select()-based reactors (e.g. ACE_Select_Reactor and ACE_TP_Reactor)
1865   for large handle sets on Windows. Previous event handler search
1866   were linear, and are now constant on average.
1868 . Addressed a number of Coverity errors (CHECKED_RETURN, DEADCODE,
1869   LOCK, USE_AFTER_FREE, RESOURCE_LEAK, FORWARD_NULL).
1871 . Added STL-style "element_type" trait to all ACE auto_ptr class
1872   templates.
1874 . Removed support for LynxOS 3.x.
1876 . Resolved Bugzilla #2701 to ensure fini() is called for all
1877   Service Objects upon calling ACE_Service_Config::close()
1879 . VxWorks 5.5.2 has been tested, for ACE the support is exactly
1880   the same as for VxWorks 5.5.1. No specific defines or flags have
1881   to be used.
1883 USER VISIBLE CHANGES BETWEEN ACE-5.5.2 and ACE-5.5.3
1884 ====================================================
1886 . Added the base projects for executionmanager_stub and plan_generator.
1888 . Added the ACE_Hash_MultiMap_Manager class and its test file.
1890 . Changed the ACE_Synch_Options::operator[] method to return bool rather than
1891   int. The value returned is a yes/no indication of whether or not the
1892   specified option(s) are set in the object.
1894 . Changed the prototype(s) for ACE::debug () to return (and take) a
1895   bool. This is consistent with the original intent for this
1896   feature. If you have been using it like 'ACE::debug () > 0' or
1897   'ACE::debug (1)', you may have to rebuild ACE. The value of the
1898   ACE_DEBUG environment variable can be used to specify the initial
1899   value for ACE::debug(), at the process start up.
1901 . An assembler (within a C source file) based implementation for SPARC
1902   of atomic operations suitable for use with the
1903   ACE_Atomic_Op<ACE_Thread_Mutex, long> and
1904   ACE_Atomic_Op<ACE_Thread_Mutex, unsigned long> specializations has
1905   been added.  Currently, it can only be enabled by setting the
1906   atomic_ops_sparc make macro to 1 when using the GNUACE build system with
1907   the Solaris SunCC compiler.  It should be noted that this requires the
1908   -xarch=v8plus (or higher) be added to the CFLAGS make macro or the
1909   assembler code will not compile.
1911 . The ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> class
1912   is new, contributed by Guy Peleg <guy dot peleg at amdocs dot com>.
1913   ACE_Message_Queue_Ex_N<class ACE_MESSAGE_TYPE, ACE_SYNCH_DECL> is
1914   similar to ACE_Message_Queue_Ex in that the object queued is a
1915   template parameter. However, ACE_Message_Queue_Ex_N allows the
1916   enqueueing and dequeueing of multiple chained objects at once. This
1917   wasn't added to ACE_Message_Queue_Ex because the chained object
1918   functionality requires the ACE_MESSAGE_TYPE class to have a
1919   ACE_MESSAGE_TYPE *next (void) const method, analogous to
1920   ACE_Message_Block::next(), to follow the chain and this would
1921   probably break existing applications using ACE_Message_Queue_Ex.
1922   The ACE_wrappers/tests/Message_Queue_Test_Ex.cpp test has an example of
1923   how to use the new class.
1925 . The selector and comparator function pointer arguments to ACE_OS::scandir()
1926   and ACE_Dirent_Selector are now marked as extern "C" to enforce their
1927   use with a C RTL function. User code that defines functions which are
1928   passed as the selector or comparator arguments which are not declared
1929   extern "C" may generate compile warnings. To resolve this, add extern "C"
1930   to the function's signature. See ACE_wrappers/tests/Dirent_Test.cpp for
1931   an example.
1933 . To address a problem in the ACE string interface that prevented
1934   substring or character searches in very large strings (e.g. greater
1935   than the maximum value of an ssize_t type) from being correctly
1936   reported to the caller, the find(), rfind() and strstr() methods now
1937   return an unsigned integer (size_t) instead of a signed one
1938   (ssize_t). Affected classes include:
1940     * ACE_CString
1941     * ACE_WString
1942     * ACE_TString
1943     * ACE_NS_WString
1945   Unless you have been explicitly using -1 instead of npos when
1946   comparing the return value of find(), rfind() and strstr(), and/or
1947   assigning the return value to ssize_t you should not see any
1948   difference. A new size_type typedef has been added to the ACE string
1949   class to aid developers.  This typedef is analogous to the standard
1950   C++ string::size_type typedef.
1952   The ACE_String_Base<>::strstr() documentation and the default
1953   rfind() argument erroneously referred to -1 instead of npos. Those
1954   instances have been corrected.
1956   To summarize, a "no position" condition is denoted using the npos
1957   constant, not -1. It can be referred directly by scoping it with the
1958   appropriate string class (e.g. ACE_CString::npos, ACE_WString::npos,
1959   etc).
1961 . Changing the shared library extension for hpux ia64 to ".so". On
1962   HP-UX 11i Version 1.5 the naming scheme is lib*.sl for PA and
1963   lib*.so on IPF.
1965 . The ACE_Refcounted_Auto_Ptr reset() and release() methods were changed
1966   per Bugzilla #1925. They will both now detach from the underlying
1967   ACE_Refcounted_Auto_Ptr_Rep object; reset() will create a new one for
1968   the new pointer specified as its argument. This change may cause referenced
1969   objects to be deleted in cases where previous ACE versions would not have.
1971 . The return type of "ACE_Refcounted_Auto_Ptr::null (void) const" changed
1972   from int to bool. It's possible values, true and false, have not changed.
1974 . TTY_IO now accepts "none" as a valid parity value. Due to this change
1975   'parityenb' member is now deprecated and will be removed in the future.
1976   The users of TTY_IO class should change their code to use only 'paritymode'
1977   member for parity control and leave 'parityenb' unchanged (it is
1978   enabled by default in class constructor).
1980 . Support for Intel C++ 9.1 on Windows and Linux
1982 . VxWorks 6.3 support
1984 . Fixed Bugzilla #2648 to make sure ACE_Service_Object::fini()
1985   is called iff ACE_Service_Object::init() succeeded, as per
1986   C++NPv2.
1988 . Added preliminary support for Mac OS X 10.4 on Intel CPU's.
1990 . Fixed Bugzilla #2602 to re-enable XML Service Configurator
1991   file support.
1993 USER VISIBLE CHANGES BETWEEN ACE-5.5.1 and ACE-5.5.2
1994 ====================================================
1996 . Added support for:
1997    - VxWorks 6.2 for the rtp model using pthread support
1998    - OpenVMS 8.2 for Alpha
2000 . Removed code and configurations that provided support for:
2001    - Visual C++ 6.0 and 7.0
2002    - Chorus
2003    - pSOS
2004    - KAI C++ on all platforms
2006 . Explicit template instantiation support has been removed. This effectively
2007   removes support for Sun Forte 6 and 7 which required explicit template
2008   instantiation to build ACE reliably.
2010 . Added support for multiple independent Service Repositories through
2011   configuration contexts called "Gestalt". Full backwards compatibility
2012   is maintained through the existing ACE_Service_Config static methods,
2013   while direct individual repository access is enabled through instances
2014   of the new ACE_Service_Gestalt class. ACE_Service_Config has changed to
2015   a specialization of ACE_Service_Gestalt and is only responsible for the
2016   process-wide configuration.
2018 . To support dynamically-sized ACE_Log_Record messages, the netsvcs
2019   logging components now use ACE CDR encoding and transfer mechanisms
2020   inspired by the examples in Chapter 4 of the C++NPv1 book.
2021   The client and server logging daemons in ACE 5.5.2 and forward will
2022   not interoperate with those in previous ACE versions.
2024 . Added a wrapper for the sendfile API (ACE_OS::sendfile()).
2026 . Added support for netlink sockets on Linux.
2028 . Added a new method, ACE_Task::last_thread(). This method returns the thread
2029   ID (ACE_thread_t) of the last thread to exit from the ACE_Task object.
2030   Users checking to see if a thread is the last one out (for example, to know
2031   when to perform cleanup operations) should compare the current thread ID to
2032   the return value from last_thread(). This is a change from the previously
2033   recommended practice (C++NPv2, page 189) of comparing the return value of
2034   thr_count() with 0.
2036 . Changed the first argument to ACE_OS::strptime() to be 'const' which
2037   matches its usual usage in POSIX strptime(). This change allows users to
2038   pass const strings in - a common use case.
2040 . Made part of the file support in ACE 64bit but we have some places where
2041   32bit types are used, this could lead to some conversion warnings which
2042   will be addressed in the near future, but getting everything 64bit
2043   compliant is a lot of work.
2045 USER VISIBLE CHANGES BETWEEN ACE-5.5 and ACE-5.5.1
2046 ====================================================
2048 . Added support for the --enable-symbol-visibility configure option
2049   to the autoconf build infrastructure instead of solely relying on
2050   feature tests to enable/disable symbol visibility support.  This
2051   avoids build problems with icc, etc.
2053 . Added support for the --enable-fl-reactor configure option to the
2054   autoconf build infrastructure to build the ACE_FlReactor library.
2056 . Added support for the --enable-qt-reactor configure option to the
2057   autoconf build infrastructure to build the ACE_QtReactor library.
2059 . Added support for the --enable-xt-reactor configure option to the
2060   autoconf build infrastructure to build the ACE_XtReactor library.
2062 . Fixed a bug that would cause timer IDs from ACE_Timer_Heap to be
2063   improperly duplicated under certain conditions (Bugzilla #2447).
2065 . Fixed ACE_SSL_Context::private_key(), context(), and dh_params() methods
2066   to allow retrying a file load after a failed call.
2068 . Fixed ACE_SSL_Asynch_Stream so it can be instantiated; also moved the
2069   declarations for ACE_SSL_Asynch_Read_Stream_Result,
2070   ACE_SSL_Asynch_Write_Stream_Result, and ACE_SSL_Asynch_Result classes
2071   to the ace/SSL/SSL_Asynch_Stream.h file so applications can see them.
2073 USER VISIBLE CHANGES BETWEEN ACE-5.4.10 and ACE-5.5
2074 ====================================================
2076 . Added a platform macros option "templates=manual", currently only
2077   applies to AIX 5.3 with XL 7 compiler.  It allows the user to tell the
2078   compiler to set -qnotempinc and -qnotemplateregistry and works well
2079   in static builds.
2081 . ACE and its tests compile error free with GCC 4.1 pre release.
2083 . ACE_Recursive_Thread_Mutex::get_nesting_level() fixed for 64-bit Windows
2084   XP on amd64/EM64T hardware.
2086 . Many build-time fixes for Windows Mobile 5 and Windows PocketPC 2003 using
2087   Visual Studio .NET 2005 (VC8).
2089 . Added support for the --enable-tk-reactor configure option to the
2090   autoconf build infrastructure to build the ACE_TkReactor library.
2092 USER VISIBLE CHANGES BETWEEN ACE-5.4.9 and ACE-5.4.10
2093 ====================================================
2095 . Fixed a bug in ACE_Timer_Heap_T::cancel().
2097 . Improved ACE_Time_Value support for boundary conditions.
2099 . Fixed problems with operator placement delete on certain C++ compilers.
2101 . Fixed a bug with the ACE_SPIPE_Acceptor on Windows.
2103 . Correctly set sockaddr_in.sin_len and sockaddr_in6.sin6_len on
2104   platforms that have these fields.
2106 . Avoided problems with namespace pollution for max() macros.
2108 . Many fixes for ACE_LACKS* and ACE_HAS* macros for autoconfig.
2110 USER VISIBLE CHANGES BETWEEN ACE-5.4.8 and ACE-5.4.9
2111 ====================================================
2113 . Added dozens of new ACE_LACKS and ACE_HAS defines which are used to
2114   simplify the ACE_OS layer
2116 . Constructors of ACE_Time_Value have been made explicit to prevent
2117   implicit conversions.
2119 . Added a shutdown() method to ACE_Barrier. The new method aborts the
2120   wait by all threads.
2122 . Changed the behavior of ACE_Message_Queue::enqueue_head() and
2123   enqueue_tail(). If the enqueued message block has other blocks
2124   chained to it via its next() pointer, the entire chain of blocks
2125   will be enqueued at once.
2127 . Improved the support for high-resolution timers with
2128   ACE_Timer_Queue_Adapter.
2130 . Make it possible to disable file caching in JAWS.
2132 . Improved ACE_Pipe implementation so that it uses localhost to avoid
2133   firewall problems.
2135 . Added Unicode support to the Service Configurator.
2137 USER VISIBLE CHANGES BETWEEN ACE-5.4.7 and ACE-5.4.8
2138 ====================================================
2140 . Improved IPv6 support
2142 . Improved 64bit portability
2144 . TTY_IO overhaul
2145   - Improved documentation.
2146   - It is now possible to request infinite timeout in portable manner.
2147     This can be achieved by setting negative value to readtimeoutmsec.
2148   - Various bugs fixed and portability issues resolved.
2150 . Subset ACE for TAO and TAO Services
2152 . Support for Intel C++ 9.0 on Windows and Linux
2154 . Support for Microsoft Visual Studio 2005 (aka VC8) for Win32 as well
2155   as the Windows CE platforms Pocket PC 2003 and Windows Mobile 5.
2156   Solution/project files are generated with an appended "_vc8" for
2157   Win32 and "_WinCE" for the CE platforms. See
2158   ACE_wrappers/docs/CE-status.txt for more information.
2160 . Completed implementation of ACE_Dev_Poll_Reactor using the Linux epoll
2161   facility; tested on Red Hat Enterprise Linux 4.
2163 . The in-memory size of an ACE_RB_Tree will be smaller due to rearranged
2164   placement of pointers.
2166 . Added an optimization to CDR stream to ignores alignment when marshaling
2167   data.  Use this new ACE_LACKS_CDR_ALIGNMENT compile-time option only
2168   when the ACE_DISABLE_SWAP_ON_READ macro is enabled.  This new option
2169   requires ACE CDR engine to do both marshaling and demarshaling, and
2170   when this option is enabled the encoded streams are no longer
2171   compliant with the CORBA CDR specification.
2173 . Developed Feature Oriented Customizer (FOCUS) tool to enable
2174   specialization of middleware frameworks such as Reactor and Protocol
2175   framework.  FOCUS provides an XML based transformation engine, where
2176   the transformations to specialize the components are captured in XML
2177   file and a weaver specializes the code.
2179 . Added support for unrolling ACE_OS::memcpy copy loop where
2180   applicable to improve performance. Autoconf tests empirically
2181   determine whether loop unrolling is at least 10% better than default
2182   version.
2184 . Added support for an ACE "versioned" namespace.  When enabled, ACE
2185   library sources will be placed within a namespace of the user's
2186   choice or a namespace of the form ACE_5_4_7 by default, where
2187   "5_4_7" is the ACE major, minor and beta versions.  The default may
2188   be overridden by defining the ACE_VERSIONED_NAMESPACE_NAME
2189   preprocessor symbol.  Enable overall versioned namespace support by
2190   adding "versioned_namespace=1" to your MPC default.features file.
2192 USER VISIBLE CHANGES BETWEEN ACE-5.4.6 and ACE-5.4.7
2193 ====================================================
2195 . Support for shared libraries with VxWorks
2197 . Support for Solaris 10 on x86 with Sun Studio 10 (C++ 5.7).
2199 . Extended ACE_OS::event_xxx implementation to support platforms
2200   having either PThread support with Process Shared condition
2201   variables or POSIX semaphores with named (process shared)
2202   semaphore support or using the new FIFO based semaphores.
2204 . ACE_OS::closesocket() no longer calls ACE_OS::shutdown() on any platform
2205   while closing the socket. It previously called ACE_OS::shutdown() on
2206   HP-UX. Removing this call fixes the fork-and-close programming paradigm
2207   that's common to many networked applications.
2209 . RMCast
2210    - Support for message fragmentation. This will allow
2211      for messages larger than 64K.
2212    - Support for flow control.
2213    - Timed recv() in RMCast::Socket.
2214    - Per-instance configurable protocol parameters (e.g., message
2215      retention time, NAK timeout, etc).
2217 USER VISIBLE CHANGES BETWEEN ACE-5.4.5 and ACE-5.4.6
2218 ====================================================
2220 . Updated RMCast to include
2221    - Reactor-compatible interface.
2222    - Message unavailability reporting.
2223    - Protocol documentation.
2225 . Added support for 64bit Visual Age on AIX
2227 . Improved g++ 4.0 support.  A number of RTTI related problems have been
2228   fixed.
2230 . Smaller footprint.
2232 . Fixed memory leaks ACE_DLL and ACE_Log_Msg classes.
2234 . The ACE::ICMP_Socket and ACE::Ping_Socket classes were moved out of
2235   the ACE namespace and "flattened" to ACE_ICMP_Socket and
2236   ACE_Ping_Socket to be consistent with the rest of ACE.
2238 . ACE_INET_Addr::set_address() - fixed a possible struct member
2239   alignment issue when building an IPv4-mapped IPv6 address.
2241 . Added a new ACE::wild_match() function to match a string based on
2242   wildcards.
2244 . Added efficient overloads for string concatenation to the
2245   ACE_String_Base class.
2247 . Added support for the use of pthread_getschedparam on MacOS X.
2249 . Fixed an issue with static initialization of TSS related classes on
2250   static builds for Windows.
2252 USER VISIBLE CHANGES BETWEEN ACE-5.4.4 and ACE-5.4.5
2253 ====================================================
2255 . Remove special handling in the Thread Specific Storage(TSS) code
2256   that released the TSS key for ACE_TSS<TYPE>.  ACE_TSS<TYPE> has
2257   been changed to explicitly free the TSS key when necessary.
2259 . On Win32 systems: detect thread termination via a hook in DLLMain
2260   for ACE.dll.  This allows cleanup of TSS objects for non-ACE threads
2261   that use ACE functions.  The most common case was threads that used
2262   ACE logging.  Formerly any TSS objects created by these threads would
2263   be leaked.
2265 . Added support for GNU G++ 4.0.  The x.4.5 beta takes advantage of
2266   g++ 4.0's symbol visibility.  This feature is conceptually similar
2267   to MS Windows "__declspec(dllexport)" DLL functionality.  Using this
2268   new g++ feature results in substantially improved ACE/TAO/CIAO
2269   shared library binaries.  A subset of the improvements include the
2270   following:
2272       * The number of unnecessarily exported DSO/DLL symbols is
2273         greatly reduced, resulting in faster program start times.
2274       * Smaller footprint.
2275       * Improved performance since run-time indirection of internal
2276         symbols is no longer needed.
2278   No changes to the ACE/TAO sources were necessary to support this
2279   feature since the required visibility attributes were hidden behind
2280   the various "*_Export" macros (formerly only useful for MS Windows
2281   DLLs) used throughout ACE/TAO.
2283 . The ACE_Reactor destructor will now call close() on the referenced reactor
2284   implementation. This assures that all handlers are notified before the
2285   ACE_Reactor object that's most likely referenced in these handlers is
2286   invalid. Although this should not be a user-visible change, it did catch
2287   some ACE tests off guard destroying reactor implementations and ACE_Reactor
2288   interfaces in the wrong order, so it may come up in the field as well.
2289   When using dynamically allocated reactor implementations, do not destroy
2290   the implementation object before the ACE_Reactor interface object. Use of
2291   the ACE_Reactor constructor's delete_implementation argument (with a value
2292   of 1) is recommended when dynamically allocating reactor implementations.
2294 . Improved performance of HTBP by not requiring a lookup of peer hostname.
2296 . Added new ACE_SizeCDR stream which allows one to calculate size of the
2297   representation without writing anything.
2299 . Number of improvements in RMCast, reliable multicast implementation.
2301 USER VISIBLE CHANGES BETWEEN ACE-5.4.3 and ACE-5.4.4
2302 ====================================================
2304 . The ace-config script has been replaced by pkg-config metadata files
2305   which are installed in ${prefix}/lib/pkgconfig by the automake build.
2307 . Remove ACE_OS::gets() implementation.  While this ACE implementation
2308   of gets() did not contain the security holes that all standard
2309   gets() implementations have, keeping it around only serves to foster
2310   confusion since (1) some may incorrectly assume that this
2311   ACE-specific gets() implementation has the same holes as standard
2312   ones, and (2) invoking it with a default size argument so that it
2313   looks like a standard gets() call results in behavior that is
2314   different from the standard.  Use ACE_OS::fgets() instead.
2316 . Removed ACE_Unbounded_Set_Ex, this gave the false idea that it had
2317   thread safe iterators. Use ACE_Unbounded_Set instead
2319 . Improved VxWorks support for static libraries. Shared libraries do cause
2320   several known problems which will be fixed in the x.4.5 release.
2322 . Removed the usage of the ACE_x_cast macros, we are using the C++ casts
2323   from now on. The ACE_x_cast macros are deprecated and will be removed
2324   after the x.5.1 release
2326 . Some improvements in autoconf support; better detection of available
2327   OS and compiler features.
2329 . Fixed bugs in ACE TSS emulation
2331 USER VISIBLE CHANGES BETWEEN ACE-5.4.2 and ACE-5.4.3
2332 ====================================================
2334 . Improved Cygwin 1.5.12 support, 90% of the tests now succeed
2336 . Improved OpenVMS support.
2338 . Added ability to use fltk with Cygwin/MinGW
2340 . Added ACE_INT64 that defines a native 64 bit type.
2342 . Added 'q' as usable specifier for ACE_Log_Msg to print out int64 bit number.
2344 . Added better support for Intel C++ compilers.
2346 . Improved HPUX support.
2348 . Added a new directory ("ACE_wrappers/protocols/ace") for new protocols
2349   that are not directly components of ACE, but are relate to ACE and
2350   defined a new protocol, HTBP (Hypertext Tunneling, Bidirectional
2351   Protocol) providing ACE_Acceptor/Connector/Stream semantics over a
2352   connection owned by an HTTP proxy. Test cases in
2353   ACE_wrappers/tests/HTBP provide examples of use.
2355 . Performace enhancement in TP_Reactor's handle_timer_events method [Bug
2356   1971].
2358 . Various changes to permit ACE to execute on HP NonStop platform (e.g
2359   support for its pthreads version).
2361 . Updated HP NonStop configuration files (config-tandem-nsk).
2363 . The "ACE" pseudo-namespace is now a true C++ namespace.  Transitional
2364   pseudo-namespaces that were only meant to be used internally by ACE,
2365   such as "ACE_Sock_Connect", no longer exist.
2367 . ACE_CDR::Boolean type is now a true C++ "bool" on all platforms except
2368   MSVC++ 6.  We plan to deprecate MSVC++ 6 support sometime after the
2369   x.5 release of ACE+TAO+CIAO, so we recommend you start migrating to a
2370   later version of MSVC++.
2372 . More GNU g++ 3.4.x fixes.
2374 . Added ICMP and "ping" socket support.
2376 . Added mkstemp() emulation.
2378 . Fixed problem on Linux < 2.5.47 platforms where equality comparison of
2379   two logically equal sockaddr_in structure instances would incorrectly
2380   fail.
2382 . Support for wide characters has been improved on non-Windows
2383   platforms.
2385 . A number of Windows CE problems have been fixed.
2387 . ACE's loading of DLLs (for example, as a result of loading synamic
2388   services) has been changed to use the native OS's facilities for
2389   locating the DLL instead of searching LD_LIBRARY_PATH (or its
2390   equivalent) then loading the DLL using a full pathname. This restores
2391   enforcement of a platform's loading and security policy.  To use the
2392   old DLL locating method, add ACE_MUST_HELP_DLOPEN_SEARCH_PATH to your
2393   config.h file before building ACE.
2395 . A number of errors in the APG example programs have been corrected.
2397 . Select_Reactor and Priority_Reactor performance improved. [Bug 1890]
2399 . Wide-char functionality on POSIX (Linux, etc.)
2401 . TSS memory leak fixes [Bug 1542]
2403 . Ported to HPUX 11i v2 on Itanium
2405 . Added code to ACE for platform RedHat AS 3.0 on Opteron.
2407 . Changed ACE::crc32() family of functions to NOT fold in the length of
2408   the string/buffer/iovec into the CRC.
2411 USER VISIBLE CHANGES BETWEEN ACE-5.4.1 and ACE-5.4.2
2412 ====================================================
2414 . Support for g++ 3.4.1.
2416 . All ACE Makefiles, project files, etc, are now generated by OCI's
2417   "MakeProjectCreator" (MPC) tool.  Makefiles and project files for
2418   commonly used configurations have been pre-generated and distributed
2419   with the beta(s).  Please see:
2421   $ACE_ROOT/ACE-INSTALL.html
2423   for information on how to use MPC with ACE.
2425 . Improved Doxygen documentation.
2427 . Reduced header file dependencies, which should speedup compilation
2428   and help minimize static footprint.
2430 . ACE now requires support for the following standard C++ features:
2432   - "bool" keyword
2434   - "mutable" keyword
2436   - "explicit" keyword
2438   - C++ casts (e.g. static_cast<>, reinterpret_cast<>, dynamic_cast<>
2439     and const_cast<>)
2441   If you're using a compiler that does NOT support these features
2442   please contact Steve Huston <shuston@riverace.com> for support.
2444 . Changed the select()-based reactor implementations to scan for
2445   broken handles to remove based on the registered handles, not on
2446   event handlers.  This allows for bad handles to be removed from the
2447   reactor even if the event handler doesn't implement get_handle() the
2448   way we expect.
2450 . Support for Pthreads native recursive mutexes was added. This
2451   capability is specified to ACE_OS::mutex_init() as an optional
2452   argument, lock_type. To fix confusion from an earlier attempt to add
2453   this functionality, the meaning of the old 'type' argument to
2454   ACE_OS::thread_mutex_init() is changed. It previously combined the
2455   scope and type. Now it is just the type (e.g. recursive), as the
2456   scope is inherent in the method used. For clarification on
2457   ACE_HAS_RECURSIVE_MUTEXES, it means that the platform is capable of
2458   them, not that they always are, as one would expect. However, before
2459   Pthreads had recursion added, it was never optional. Now it is.
2461 . Initial support for new Linux sys_epoll() interface in
2462   Dev_Poll_Reactor.  The obsolete Linux /dev/epoll interface is no
2463   longer supported.
2465 . Improved Cygwin support.
2466   - Threading works without problems.
2467   - Problems with shared memory, process shared mutexes, multicast and
2468     some other small things still exist.
2470 . New OpenVMS port.
2471   -  This is for the latest version of OpenVMS with all available ECOs
2472      applied. Basic stuff works without problems.  Advanced features
2473      still need some work.
2475 . Usage of ASYS_INLINE is deprecated in ACE.  Use ACE_INLINE instead.
2477 . All inline source files now end in ".inl".  The previous ".i"
2478   extension is generally used for preprocessed C sources.
2480 . Autoconf support has been improved and fixed on a number of
2481   platforms, including the BSD variants (e.g. FreeBSD).  It is still
2482   not the preferred way to configure most platforms, but it is ready
2483   for wider testing. Please report any problems found to
2484   ace-bugs@cs.wustl.edu.
2486 . A number of fixes were made to quiet compile errors and warnings on
2487   64-bit Windows.
2489 . For builds on AIX using Visual Age C++, the make rtti option default
2490   was changed to 1, enabling RTTI by default.
2492 . ACE_Service_Repository::remove() has a new, optional argument that
2493   can receive the service record pointer for the removed service. If
2494   the pointer is returned to the caller, it is not deleted. If the
2495   pointer is not returned to the caller (the default) it is deleted
2496   (this is the historic behavior).
2498 . The tutorials in ACE_wrappers/docs have been removed. They were not
2499   being maintained and caused confusion in a number of cases. Now that
2500   there are complete examples that match the printed books (C++NPv1,
2501   C++NPv2, APG), the older tutorials are no longer useful.  Please see
2503   $ACE_ROOT/examples/C++NPv1/
2504   $ACE_ROOT/examples/C++NPv2/
2505   $ACE_ROOT/examples/APG/
2507   for the source code of the examples in those books.
2509 . ACE_String_Base::fast_clear() is a new method which sets the string
2510   length to 0. Doesn't release string-allocated memory, but if the
2511   memory was externally supplied, it is no longer referenced from the
2512   string object.
2514 . A true C++ "bool" is now used as the CDR stream boolean type, if
2515   supported by the compiler.
2517 . Renamed AIX 5L configuration header from config-aix5.1.h to
2518   config-aix-5.x.h.
2520 . All C++ equality, relational and logical operators now return bool
2521   instead of int, as is the norm for modern C++.
2523 . Added new ACE_OS::realpath() implementation.  Contributed by Olli
2524   Savia  <ops at iki dot fi>
2527 USER VISIBLE CHANGES BETWEEN ACE-5.4 and ACE-5.4.1
2528 ====================================================
2533 . Fixed "make install" support in ACE+autoconf configurations.
2535 . Fixed autoconf support on Solaris.
2537 . Corrected invalid `aux' directory (on MS Windows) found in ACE
2538   distribution.
2540 . ACE/TAO build now without problems with MinGW and all ACE tests run
2541   now without problems
2543 . Added some more support for the new CBuilderX Preview compiler, this
2544   is not 100% ready yet because the compiler is still a preview and
2545   has its own problems.
2547 . Added Visual SlickEdit 8.1 MPC template
2549 . Added workaround for compile problems in Borland Release builds
2551 . Cygwin 1.5.9 is now supported
2553 . Tests for IPV6 have been added
2555 . Implement lstat() so that it'll use stat() on platforms that don't
2556   support lstat().
2558 . Problems related to ACE_Event_Handler usage in WFMO_Reactor was
2559   fixed.
2561 . A wrapper for rmdir () has been added.
2563 . Threads spawned in thread-per-connection mode never inherited the
2564   priority. This problem was fixed and this fix is consistent with the
2565   C++ NPV* books.
2567 . Fixed memory leaks with ACE_String_Base::resize ()
2569 . Enable the usage of native recursive mutexes for the implementation
2570   of ACE recursive mutexes on Linux.
2572 . The ACE Proactor framework can now be enabled for AIX 5.2. Since AIO
2573   functionality is not run-time enabled by default on AIX 5.2, the ACE
2574   Proactor code is not built by default on AIX. To enable it, the
2575   config.h file must contain #define ACE_HAS_AIO_CALLS before
2576   including the config-aix-5.1.h file.
2578 . The ACE_POSIX_CB_Proactor implementation is now built on all
2579   platforms except LynxOS.
2582 USER VISIBLE CHANGES BETWEEN ACE-5.3.6 and ACE-5.4
2583 ==================================================
2585 ACE:
2587 . Added a new makefile commandline flag, static_link, that can be
2588   used to force static linking when static_libs_only is turned on. It
2589   uses the new STATIC_LINK_FLAG variable and is currently only
2590   implemented for for GNU ld, i.e., it adds the "-static" option to
2591   LDFLAGS. It's turned off by default since using it causes the
2592   footprint to go up by almost 1 MB on Linux, since it links all the
2593   system and compiler .a files, but can be turned on if users
2594   want/need to use it, by enabling both static_libs_only and static_link.
2597 . Added macros ACE_USES_GPROF which enables users to use gprof in a
2598   multithreaded environment with ACE libs.
2600 . Added a new functor template class, ACE_Malloc_Lock_Adapter_T,
2601   that's used by ACE_Malloc_T as a factory for the ACE_LOCK template
2602   parameter, and allows the use of locking strategy classes, like
2603   ACE_Process_Semaphore and ACE_Thread_Semaphore that don't have a
2604   satisfactory ctor taking a single required ACE_TCHAR* parameter, to
2605   be adapted to work with ACE_Malloc_T.
2607 . The source code examples from "The ACE Programmer's Guide" book by
2608   Huston, Syyid, and Johnston, are now located in
2609   $ACE_ROOT/examples/APG.
2611 . Support for GNU autoconf is now in ACE. Please see ACE-INSTALL.html
2612   for details.
2614 . Fixed problems that prevented ACE from being compiled on LynxOS
2615   4.0.0.
2617 . Fixed compilation error which prevented ACE from being compiled when
2618   ACE_COMPILE_TIMEPROBES was set to 1.
2620 . Preliminary support for Tandem NSK has been added.
2622 . Lots of bug fixes with TLI and XPG5. Please see $ACE_ROOT/ChangeLog
2623   for details.
2625 . Fixed ACE_OS::event_timedwait() and ACE_OS::event_wait() so that
2626   they use a while loop around the ACE_OS::cond_[timed]wait() calls to
2627   avoid problems with spurious wakeups, etc.
2629 . ACE's wrapper around getipnodebyname() and getipnodebyaddr () has
2630   been made go through the IPv4-only case on ACE_WIN32. Since Windows
2631   IPv6 implementation doesn't offer support (at thistime) for
2632   getipnodebyname() the code has been changed to use the IPV4 part of
2633   the code.
2635 . Install with Borland C++ of ACE library fixed
2637 ACEXML:
2638 -------
2640 . Fixed memory leak in ACEXML parser.
2642 . Fixed implementations of rewind() in all the CharStreams. They were
2643   broken previously.
2645 . Fixed bugs in the parser associated with incorrect handling of PE
2646   References for keywords.