Use =default for skeleton copy constructor
[ACE_TAO.git] / TAO / NEWS
blob2152e220f370169b286d732efeabf6edec559f87
1 USER VISIBLE CHANGES BETWEEN TAO-4.0.2 and TAO-4.0.3
2 ====================================================
4 USER VISIBLE CHANGES BETWEEN TAO-4.0.1 and TAO-4.0.2
5 ====================================================
7 - None
9 USER VISIBLE CHANGES BETWEEN TAO-4.0.0 and TAO-4.0.1
10 ====================================================
12 - TAO_IDL:
13   - Support the following IDL v4 features (may not work everywhere in TAO):
14     - Empty structs
15     - `octet` and `wchar` union discriminators
16     - Allow using `typedef`s of `int8` and `uint8` as union discriminators
17     - Allow using empty parentheses in annotation applications to
18       workaround syntax errors when an annotation with no arguments has to
19       be followed by a complete scoped name:
20         `@example_annotation() ::ex::ExampleType`
21       This is a proposed solution to an IDL spec issue.
22     - Reserve the `bitfield`, `bitmask`, and `bitset` keywords in IDL v4
23       (these are not implemented yet)
24   - Allow using `map` as an identifier in IDL v3 again
26 USER VISIBLE CHANGES BETWEEN TAO-3.1.4 and TAO-4.0.0
27 ====================================================
29 - ACE/TAO now require C++17 or newer
31 USER VISIBLE CHANGES BETWEEN TAO-3.1.3 and TAO-3.1.4
32 ====================================================
34 - None
36 USER VISIBLE CHANGES BETWEEN TAO-3.1.2 and TAO-3.1.3
37 ====================================================
39 - None
41 USER VISIBLE CHANGES BETWEEN TAO-3.1.1 and TAO-3.1.2
42 ====================================================
44 - TAO_IDL: Added support for the map data type, but this isn't supported in TAO
45   user applications except for local usage
47 USER VISIBLE CHANGES BETWEEN TAO-3.1.0 and TAO-3.1.1
48 ====================================================
50 - Removed deprecated -ORBResources flag
52 USER VISIBLE CHANGES BETWEEN TAO-3.0.11 and TAO-3.1.0
53 =====================================================
55 . Removed usage of ACE service configurator for all
56   POA internal strategy classes
58 USER VISIBLE CHANGES BETWEEN TAO-3.0.10 and TAO-3.0.11
59 ======================================================
61 . Fixed some compiler warnings given by newer compilers
63 . PortableGroup cleanup
65 USER VISIBLE CHANGES BETWEEN TAO-3.0.9 and TAO-3.0.10
66 =====================================================
68 . Various cleanup and using more C++11 features
70 USER VISIBLE CHANGES BETWEEN TAO-3.0.8 and TAO-3.0.9
71 ====================================================
73 . Various cleanup
75 USER VISIBLE CHANGES BETWEEN TAO-3.0.7 and TAO-3.0.8
76 ====================================================
78 . Moved operators<<= and >>= for CORBA::Any to the CORBA namespace.
79   This makes the code compatible with GCC 12 and removes the need for
80   both the -fdelayed-template-parsing workaround (for clang) and defining
81   ACE_ANY_OPS_USE_NAMESPACE in config-macos*.h.
83 . Removed unused configuration option ACE_ANY_OPS_USE_NAMESPACE
85 USER VISIBLE CHANGES BETWEEN TAO-3.0.6 and TAO-3.0.7
86 ====================================================
88 . Fixed an issue with handling spaces in paths for TAO_IDL
90 . TAO_IDL: Fix open file error not mentioning the filename and not checking if
91   the file is actually a directory.
93 USER VISIBLE CHANGES BETWEEN TAO-3.0.5 and TAO-3.0.6
94 ====================================================
96 . Various cleanup and using more C++11 features
98 . Fixed compilation error in the TAO core when using C++20
100 USER VISIBLE CHANGES BETWEEN TAO-3.0.4 and TAO-3.0.5
101 ====================================================
103 . TAO_IDL: Fix bug where floating point constant expressions fail to evaluate.
104   This bug was introduced in 3.0.3
106 USER VISIBLE CHANGES BETWEEN TAO-3.0.3 and TAO-3.0.4
107 ====================================================
109 . Various cleanup and using more C++11 features
111 USER VISIBLE CHANGES BETWEEN TAO-3.0.2 and TAO-3.0.3
112 ====================================================
114 . Support for IDL 4 explicitly-named integer types like `int64` in TAO_IDL.
115   Support for `uint8` and `int8` is limited in TAO. Unlike the larger types,
116   these are new distinct types that are not aliases of existing types covered
117   by the CORBA specification
119 . Added the `tao/idl_features.h` header file for getting the IDL features
120   supported by TAO_IDL. See the file for example usage
122 . TAO_IDL: Fix empty case evaluation on unions with enum discriminators
124 USER VISIBLE CHANGES BETWEEN TAO-3.0.1 and TAO-3.0.2
125 ====================================================
127 . Fix wstring coerce leak in tao_idl
129 . Support C++ Keywords in `DCPS_DATA_SEQUENCE_TYPE`
131 . Minor cleanup
133 USER VISIBLE CHANGES BETWEEN TAO-3.0.0 and TAO-3.0.1
134 ====================================================
136 . Minor cleanup
138 USER VISIBLE CHANGES BETWEEN TAO-2.5.12 and TAO-3.0.0
139 =====================================================
141 . C++11 is now a mandatory compiler feature which is
142   required for TAO
144 . Fixed some CORBA spec mismatches for the CORBA server
145   portable interceptors
147 . Add portspan support to DIOP
149 USER VISIBLE CHANGES BETWEEN TAO-2.5.11 and TAO-2.5.12
150 ======================================================
152 . Removed usage of narrow_from_decl and narrow_from_scope
153   from TAO_IDL, use dynamic_cast now that we have RTTI. Any
154   user that has a custom backend should make the similar
155   changes to their own TAO_IDL backend
157 USER VISIBLE CHANGES BETWEEN TAO-2.5.10 and TAO-2.5.11
158 ======================================================
160 . Simplified some code generated by tao_idl
162 USER VISIBLE CHANGES BETWEEN TAO-2.5.9 and TAO-2.5.10
163 =====================================================
165 . TAO IDL Frontend annotation support extended: (#1125)
166   . All the direct contents of interfaces
167   . Porttypes, eventtypes, components, and all their direct contents
168   . Valuetypes and most of their direct contents
170 . TAO IDL now supports anonymous types when using IDL4. (#1135)
172 USER VISIBLE CHANGES BETWEEN TAO-2.5.8 and TAO-2.5.9
173 ====================================================
175 . With C++11 we are now using (u)int8/16/32/64 to map all
176   CORBA types
178 USER VISIBLE CHANGES BETWEEN TAO-2.5.7 and TAO-2.5.8
179 ====================================================
181 . Fixed handling of transient errors with DII requests
183 . Renamed `VERSION` file to `VERSION.txt` to avoid conflicting with the
184   `version` standard header.
186 USER VISIBLE CHANGES BETWEEN TAO-2.5.6 and TAO-2.5.7
187 ====================================================
189 . Fixed deprecated-copy warnings in TAO_IDL generated code
191 . The TAO IDL Frontend now supports annotations on interfaces, operations, and
192   attributes. (#967)
194 . `idl_global->eval` in the TAO IDL Frontend will now produce error and warning
195   messages. This can be silenced by passing `true` as a second argument. (#967)
197 . Expanded documentation on what can be annotated and roughly how to extend
198   annotation support in `TAO_IDL/docs/annotations.md`. Also made various
199   corrections. (#967)
201 . Fixed invalid free in the TAO IDL Frontend while parsing an IDL wstring
202   literal. (#984)
204 USER VISIBLE CHANGES BETWEEN TAO-2.5.5 and TAO-2.5.6
205 ====================================================
207 . Fixed race condition in ImplRepo on server shutdown/restart (#889)
209 USER VISIBLE CHANGES BETWEEN TAO-2.5.4 and TAO-2.5.5
210 ====================================================
212 . Fixed Memory Leaks in TAO_IDL caused by the addition of Annotations (#811)
214 . Changes in the Annotations API in TAO_IDL, see
215   TAO/TAO_IDL/docs/annotations.md section titled "TAO 2.5.5" for details.
217 USER VISIBLE CHANGES BETWEEN TAO-2.5.3 and TAO-2.5.4
218 ====================================================
220 . Enhanced the ImR to better handle a huge number
221   of servers which use the ImR heavily and each of
222   them does a frequent shutdown/start cycle
224 . The TAO_IDL frontend library now parses all IDL4
225   annotation-related syntax: using and defining annotations.
226   Use the tao_idl command-line options --idl-version and
227   --unknown-annotations to control annotation parsing.
228   Documentation on this feature is located in
229   TAO/TAO_IDL/docs/annotations.md.
231 . TAO_IDL now will return an error status code when
232   passing an invalid command line argument.
233   Backends will have to support this behavior
234   explicitly, see TAO/TAO_IDL/include/idl_defines.h
235   for details.
236   TAO_IDL also accepts new options such as -h,
237   --help, --version, and --syntax-only, the latter
238   of which won't generate any files, just check
239   syntax of the IDL file(s).
240   See tao_idl -h for details.
242 . When using IDL_Files in MPC, generated files will
243   now be placed in the current directory by default,
244   instead of the directory of the IDL file.
245   Use
246     idlflags += -o <IDL_FILE_DIR>
247     gendir = <IDL_FILE_DIR>
248   to output generated files to where the IDL file
249   is.
251 USER VISIBLE CHANGES BETWEEN TAO-2.5.2 and TAO-2.5.3
252 ====================================================
254 . Enhance ssliop and uiop corbaloc parsers
256 USER VISIBLE CHANGES BETWEEN TAO-2.5.1 and TAO-2.5.2
257 ====================================================
259 . Enhance logging within the ImR
261 . Enhance the behavior of the ImR with a per-client
262   activation mode and multiple clients starting in
263   parallel
265 . Modified the SSLIOP::Protocol_Factory::init to
266   process an "-SSLEcName" argument to set the ECDH
267   curve name.
269 USER VISIBLE CHANGES BETWEEN TAO-2.5.0 and TAO-2.5.1
270 ====================================================
272 . Make use of std::atomic when C++11 or newer is enabled
273   for the CORBA reference counting
275 USER VISIBLE CHANGES BETWEEN TAO-2.4.8 and TAO-2.5.0
276 ====================================================
278 . The TAO core libraries now use std::unique_ptr instead
279   of std::auto_ptr when C++11 or newer is enabled
281 USER VISIBLE CHANGES BETWEEN TAO-2.4.7 and TAO-2.4.8
282 ====================================================
284 . Logging enhancements to the TAO core for some possible
285   error situations
287 USER VISIBLE CHANGES BETWEEN TAO-2.4.6 and TAO-2.4.7
288 ====================================================
290 . TAO_IDL parses and discards IDLv4 annotations (applying, not defining)
292 . Fixed Bug 1220 as it applies to the SHMIOP transport.
294 USER VISIBLE CHANGES BETWEEN TAO-2.4.5 and TAO-2.4.6
295 ====================================================
297 . Added support for IPv4-mapped IPv6 addresses in BiDirGIOP+SSLIOP.
299 . Fixed Bug 1220 as it applies to the SSLIOP transport.
301 USER VISIBLE CHANGES BETWEEN TAO-2.4.4 and TAO-2.4.5
302 ====================================================
304 . Extended TAO_IDL with a new -Gsd which enabled the generation of two
305   additional static operations for each interface. _desc_repository_id to
306   retrieve the repository id as string, second _desc_interface_name to
307   return the interface name. Both can be useful in template meta programming
308   use cases where we want to use the repository id or interface name
309   of a specific type.
311 USER VISIBLE CHANGES BETWEEN TAO-2.4.3 and TAO-2.4.4
312 ====================================================
314 . Minor cleanup and fixes to the code generated by TAO_IDL
316 USER VISIBLE CHANGES BETWEEN TAO-2.4.2 and TAO-2.4.3
317 ====================================================
319 . Added enhanced hot-standby feature to FT_Naming_Service. Use
320   tao_ft_naming -h to get a list of new configuration options.
321   This feature addresses performance problems on heavily loaded systems.
323 USER VISIBLE CHANGES BETWEEN TAO-2.4.1 and TAO-2.4.2
324 ====================================================
326 . Fixed some problems with versioned namespaces in the
327   tao_idl generated code
329 . Removed the non-const Any extraction operators which
330   are deprecated within the IDL to C++ specification
331   for a long time. Reduces footprint and simplifies the
332   code. Make sure you are using 'const Foo*' as extraction
333   type for Foo instead of 'Foo*'.
335 USER VISIBLE CHANGES BETWEEN TAO-2.4.0 and TAO-2.4.1
336 ====================================================
338 . Reduced amount of warnings given by newer gcc/clang
339   versions on the generated tao_idl code
341 USER VISIBLE CHANGES BETWEEN TAO-2.3.4 and TAO-2.4.0
342 ====================================================
344 . None
346 USER VISIBLE CHANGES BETWEEN TAO-2.3.3 and TAO-2.3.4
347 ====================================================
349 . ImR enhancement - Added a "force remove" option to the Implementation repository
350   that will remove a server entry from the ImR Locator repository and kill any
351   running instance with a single command.
353 . ImR enhancement - Fix to allow very large ( > 4K ) command line.
355 . ImR enhancement - Enhance the coordination between the Locator and the Activator
356   to tolerate running on heavily loaded systems, in particular when a server process
357   is slow to shut down, and a new server is started before the shutdown is complete
359 . LogWalker utility improvements for handling truncated GIOP buffer dumps, added
360   tracking thread first/last contact times.
362 . Fault-Tolerance improvement - Optimize performance on NFS mounted filesystems. First
363   a deadlock is resolved. Second, use of writer locks is minimized to only when writing
364   is necessary. Third, NFS occasionally causes transient EBADF errors on access, so
365   file access that results in a bad file error is retried before the error is reported
366   to the application.
368 USER VISIBLE CHANGES BETWEEN TAO-2.3.2 and TAO-2.3.3
369 ====================================================
371 . Extended SL2 Security Manager to easily allow non-secure collocated
372   invocations but still disallow non-secure remote invocations
374 . Relaxed upper limit on POA Thread pool size.
376 . Fixed PICurrent improper reset issue. Now slot data is retained through an
377   ImR forced retry.
379 . Bugzilla #4205 fixed.
381 . Defaulted IIOP endpoints on IPv6 enabled systems will no longer append localhost
382   to the IOR if there are no routable IPv6 addresses but there are routable IPv4
383   addresses available.
385 . Improved the performance of the FT-ImR while under very heavy loads.
387 . ImR now may be built on "uses_wchar" platforms.
389 . The temporary directory used by the tao_idl preprocessor may now
390   contain spaces.
392 USER VISIBLE CHANGES BETWEEN TAO-2.3.1 and TAO-2.3.2
393 ====================================================
395 . New SSLIOP Factory option -SSLPassword <password descriptor> facilitates
396   distributing password protected private keys.
398 . New SSLIOP Factory option -SSLVersionList <list> constrains the list of
399   cypher versions allowed.
401 . New SSLIOP Factory option -SSLCheckHost enables a second layer of
402   authentication by comparing the sending hostname to the name or names in
403   the supplied certificate
405 USER VISIBLE CHANGES BETWEEN TAO-2.3.0 and TAO-2.3.1
406 ====================================================
408 . TAO is now hosted on github (https://github.com/DOCGroup/ATCD).
409   As part of the release process we now generate a ChangeLog
410   for each release which is stored in the ChangeLogs directory
412 . Fixed incorrect server status shown by tao_imr after a
413   crashed server has been given a shutdown command
415 USER VISIBLE CHANGES BETWEEN TAO-2.2.8 and TAO-2.3.0
416 ====================================================
418 . New feature added to constrain client ORBs using IIOP to only use local TCP
419   ports spanning a supplied range. Use new ORB_init parameters
420   -ORBIIOPClientPortBase <base> and -ORBIIOPClientPortSpan <count> to specify
421   a range from base to base + count. A base supplied without a span indicates
422   the client may use only a single port. A span supplied without a base is
423   silently ignored.
425 . Fixed the manual activation mode of the Implementation Repository
427 . Reintroduced the restart attempt limiting of the Implementation Repository
429 . Fix a connection leak that occurred when the server side cache purged a
430   Thread-Per-Connection managed entry.
432 USER VISIBLE CHANGES BETWEEN TAO-2.2.7 and TAO-2.2.8
433 ====================================================
435 . Address a problem with Failover between primary and backup ImplRepo locators.
436   Access state information is now shared during a server restart allowing a client
437   to request a new server from either the ImR instance.
439 USER VISIBLE CHANGES BETWEEN TAO-2.2.6 and TAO-2.2.7
440 ====================================================
442 . Improved the performance of the load balancing feature of the tao_ft_naming
443   service. Now a global load balancing strategy may be set via the command line
444   using the new -l ["random"|"round_robin"] argument. The newly implemented
445   random strategy is lockless.
447 . Fixed active server detection when switching from the primary ImR locator to
448   the backup.
450 . Added a new command for the windows NT Naming service CLI to set the service's
451   start up argv list without invoking regedit.
453 . Added a new command for the windows NT Notify service CLI to set the service's
454   start up argv list without invoking regedit.
456 USER VISIBLE CHANGES BETWEEN TAO-2.2.5 and TAO-2.2.6
457 ====================================================
459 . Fix bug with mt_noupcall that allowed upcalls while waiting for a new connection
461 . Improved the performance of dynamic thread pool when activating new threads
463 . Improved the performance of the SYNC_WITH_SERVER oneway synchronization when
464   used in conjunction with the CSD framework and POA thread pools
466 . Fix support for long double types when used with dynamic Anys
468 . Improve functionality and stability of running tests on
469   Android Virtual Device (AVD).
471 USER VISIBLE CHANGES BETWEEN TAO-2.2.4 and TAO-2.2.5
472 ====================================================
474 . Implementation Repository new features added.
475   - New tao_imr kill command to signal an otherwise unresponsive server.
476   - New tao_imr link command to identify groups of POAs that share a server.
477   - ImR is better able to avoid errantly starting multiple server instances.
479 . Added support for Embarcadero C++Builder XE5 using
480   bcc32 in debug and release mode
482 . Added support for Embarcadero C++Builder XE6 using
483   bcc32 in debug and release mode
485 USER VISIBLE CHANGES BETWEEN TAO-2.2.3 and TAO-2.2.4
486 ====================================================
488 . Added a new Client Strategy Factory option, -ORBDefaultSyncScope which
489   takes the label "None", "Transport", "Server", or "Target" to define the
490   sync scope to be used when a Messaging SyncScopePolicy is not in use.
492 . Improved recursive typecode handling
494 . Ended maintenance for Solaris 10 with Sun Studio
496 USER VISIBLE CHANGES BETWEEN TAO-2.2.2 and TAO-2.2.3
497 ====================================================
499 . Fix for extra CDR padding bytes following a request header when there are no
500   IN or INOUT arguments in the request. This happened when a request had at least
501   one OUT argument, and also had a service context that ended off a CDR alignment
502   boundary. While this is not a problem for TAO-TAO messaging, some non-TAO
503   servers will reject such requests with a MARSHAL exception. See bug 4141 for more
504   information.
506 USER VISIBLE CHANGES BETWEEN TAO-2.2.1 and TAO-2.2.2
507 ====================================================
509 . None
511 USER VISIBLE CHANGES BETWEEN TAO-2.2.0 and TAO-2.2.1
512 ====================================================
514 . Implementation Repository is better able to handle high request volume
515   particularly when registered servers are going up and down.
517 . Fixed several memory leaks in the Trading Service
519 . Added support for Embarcadero C++BuilderXE4 using
520   bcc32 in release mode
522 USER VISIBLE CHANGES BETWEEN TAO-2.1.9 and TAO-2.2.0
523 ====================================================
525 . Feature enhancement for the Implementation Repository, the command to
526   list currently active servers, confirmed with a ping, is now asynchronous
527   along with the rest of the implementation.
529 . Added the new -ORBListenerInterface UIPMC option to provide detailed control
530   over which IP interfaces are to be listened on for which mutlicast addresses.
531   This works in a similar way to the existing -ORBPreferredInterfaces
532   ORB_init command line option but for UDP server listeners instead of client
533   senders. See the TAO_UIPMC_Protocol_Factory section in the
534   docs/release/TAO/Options.html document for details. This option allows
535   UIPMC/MIOP to control which interfaces are used by the server to listen
536   for broadcast messages instead of only using the "default" interface.
538   If TAO is built with the #define TAO_ALLOW_UNICAST_MIOP in effect, the
539   normal error checking on joins is short circuited, such that MIOP can
540   be used to send to a unicast address instead of a broadcast group. In general
541   I would not recommend building TAO with this option set, end users should
542   concider using the DIOP protocol instead.
544 . Fix for long standing Valuetype non-conformance (Bugzilla_1391):
546   tao_idl generated ValueType OBV_* classes now also provide a
547   _copy_value() method where this class is supposed to be the final
548   "most derived" class. It is still left to the end user to provide
549   such a method in their own most derived class when this is not
550   the case (as only the final implimentation of the Valuetype will
551   know how this duplication is performed).
553   TAO can be built specifically to treat _copy_value() as a pure virtual
554   function (as per the standard, and now the default behaviour) or,
555   if #define TAO_VALUETYPE_COPY_VALUE_IS_NOT_PURE is defined during the
556   building of TAO, a non-pure virtual function (in which TAO does not
557   require an implimentation to provide the _copy_value() function as per
558   the previous TAO implimentations).
560   TAO doesn't normally use the _copy_value() fuction itself, but if
561   #define TAO_VALUETYPE_COPYING_ANY_INSERTION_USES_COPY_VALUE
562   is in effect during the build, valuetypes "copy" inserted into an any
563   will call _copy_value() instead of increasing the reference count of the
564   actual valuetype being "copied". In such cases obviosuly the _copy_value()
565   method is required to be implemented. There are problems taking this
566   general approach however, as the automatically generated _copy_value() is
567   not capable of duplicating cyclic graphs held in valuetypes, which
568   realistially require the reference counting insertions to be utalised
569   and/or knowledge of the actual use of the valuetype itself. This setting
570   is not recommended.
572 USER VISIBLE CHANGES BETWEEN TAO-2.1.8 and TAO-2.1.9
573 ====================================================
575 . High performance implementation Repository [#4104] - The Implementation
576   Repository Locator has been reimplemented using AMI/AMH to avoid the
577   problem of nested upcalls under heavy load.
579 USER VISIBLE CHANGES BETWEEN TAO-2.1.7 and TAO-2.1.8
580 ====================================================
582 . Fault Tolerant Implementation Repository [#4091] - The Implementation
583   Repository Locator now supports a dual-redundant fault tolerant
584   configuration which provides replication and seamless failover between
585   the primary and backup locator servers.
587 . Implementation Repository interoperable with JacORB servers [#4101] -
588   The Implementation Repository can now be used to manage JacORB
589   3.3 or later application servers.
591 . Fault Tolerant Naming Service [#4092 & #4095] - A new Fault Tolerant
592   Naming Service (tao_ft_naming), provides dual-redundant fault tolerant
593   servers which utilize replication and seamless failover between the
594   primary and backup server. The Fault Tolerant Naming Service can be
595   used to provide load balancing capabilities (only the round-robin load
596   balancing strategy is currently supported) through the use object groups.
597   This feature is supported by a separate utility for managing the object
598   groups (tao_nsgroup) as well as a programatic interface via IDL.
600 . Configurable Persistence Mechanism [#4092] - Extracted persistence
601   mechanism used for storable naming context into Storable_* classes so
602   that it can be reused. Simplified use of storable read/write so that
603   it behaves more like C++ streams to read/write binary and CDR data.
604   Added support for creating a backup mechanism to accomodate
605   potentially corrupted files.  Providing configurable hooks so
606   applications can decide if files are obsolete and need to be written
607   to the persistence store.
609 . ORB Dynamic Thread Pool [#4093] - Added a new ORB thread pool strategy
610   to dynamically adjust the number of threads which the ORB uses to
611   service received calls based on several configuration parameters.
612   These parameters include initial threads, minimum pool threads,
613   maximum pool threads, request queue depth, thread stack size, and
614   thread idle time.
616 . POA Dynamic Thread Pool [#4094] - A new Dynamic Thread Pool and
617   Queuing strategy was created for POA usage. It leverages the
618   existing Custom Servant Dispatching framework for invocation and
619   activation. The strategy also dynamically adjusts the number of
620   threads using configuration parameters similar to the ORB Dynamic
621   Thread Pool. The Dynamic Thread Pool POA Strategy supports
622   applications in associating a single thread pool with either
623   1) a single POA in a dedicated configuration, or 2) multiple
624   POAs in a shared configuration.  The strategy controls a request
625   queue used to accept calls directed to an associated servant and
626   a pool of threads that wait to service calls coming in on a
627   particular queue.
629 . Multiple Invocation Retry [#4096] - Extended TAO to support multiple
630   retry in the presence of COMM_FAILURE, TRANSIENT, OBJECT_NOT_EXIST,
631   and INV_OBJREF exceptions. In addition, retries can occur if it has
632   been detected that a connection has closed while waiting for a reply
633   (currently not available under FreeBSD, OpenVMS, AIX, and Solaris). This
634   feature can be used to support fault tolerant services (specifically
635   the Fault Tolerant Naming and Implementation Repository services
636   described earlier).  The invocation retry support allows
637   configuration on how many times to try to connect to each server and
638   the delay between tries.
640 . Added MIOP configuration options -ORBSendThrottling and -ORBEagerDequeueing,
641   along with #define overrides for their default settings. See the descriptions
642   in the MIOP section of doc/Options.html for their use.
644 USER VISIBLE CHANGES BETWEEN TAO-2.1.6 and TAO-2.1.7
645 ====================================================
647 . Integrated several patches to simplify Debian/Ubuntu
648   packaging
650 . Fixed IDL compiler bug related to internal reinitialization
651   when processing multiple IDL files in a single execution.
653 USER VISIBLE CHANGES BETWEEN TAO-2.1.5 and TAO-2.1.6
654 ====================================================
656 . We only try to load the ObjRefTemplate library at POA
657   creation instead of trying to load it at each servant
658   activation
660 USER VISIBLE CHANGES BETWEEN TAO-2.1.4 and TAO-2.1.5
661 ====================================================
663 . None
665 USER VISIBLE CHANGES BETWEEN TAO-2.1.3 and TAO-2.1.4
666 ====================================================
668 . CORBA::string_dup() and CORBA::string_free() have been enhanced to use
669   non-allocated and shared static null strings. This allows for optimized
670   default null string initialization in CORBA string members and a
671   reduction in redundant dynamic memory management required for such.
672   This enhancement can be removed via the config.h by including
673     #define TAO_NO_SHARED_NULL_CORBA_STRING
675   NOTE that it is a (CORBA spec) requirement that all CORBA::strings are
676   deleted via the CORBA::string_free() and allocated via the
677   CORBA::string_dup() or CORBA::string_alloc() calls; you must not use
678   the c++ keywords new and delete[] directly. Previously it was possiable
679   to ignore this requirement, however if you do so now, this enhancement
680   for null strings will catch you out, as deleting these null
681   CORBA::strings will cause corrupt heap and/or segfaults.
683 . Add support for -ORBPreferredInterfaces option to UIPMC. The form follows
684   the same pattern as IIOP for IPv4 i.e. a local interface IP address should
685   be specified as the mapping. e.g. -ORBPreferredInterfaces 225.*=192.168.0.2.
686   For IPv6 the preferred interface should (neccessarily) be set as an interface
687   name (e.g. 'eth0' for linux, or 'Loopback Pseudo-Interface' on windows) or an
688   interface index number on windows. e.g. -ORBPreferredInterfaces FF01:*=eth0.
689   Also add support an -ORBListenOnAll 0|1 UIPMCFactory option that can
690   be specified in the svc.conf to make the acceptor listen on all multicast
691   enabled interfaces on platforms that this is not the default. This has been
692   observed to be required for the UIPMCAcceptor to open on the most recent
693   Linux distribs.
695   NOTE that there is an obvious elephant in the room in testing this option,
696   we can't rely on any build/test machine having more than one (or any?)
697   interfaces so the test (TAO/orbsvcs/tests/Miop/McastPreferredInterfaces),
698   such as it is, is relying on side effects which may not hold for all platforms.
699   Additionally the IPv6 behaviour isn't even consistent across platforms and
700   the build machines can't be relied upon to have a 'proper' (non-zero conf
701   link local) IPv6 configuration. Basically, if you want some confidence this is
702   actually working I'd advise testing this option before you use it, running it
703   on a machine with multiple interfaces with the debug level turned up.
705 . Enhanced the MIOP implementation; this protocol now supports MIOP message
706   fragmentation which is controlled via the new MIOP_Strategy_Factory.
707   For details see the MIOP_Strategy_Factory section in the docs/Options.html
708   document included with this distribution.
710 USER VISIBLE CHANGES BETWEEN TAO-2.1.2 and TAO-2.1.3
711 ====================================================
713 . Added OpenSSL configuration options SSLCipherList and
714   SSLServerCipherOrder to SSLIOP_Factory.  Allows SSL/TLS BEAST
715   exploit to be mitigated.
717 USER VISIBLE CHANGES BETWEEN TAO-2.1.1 and TAO-2.1.2
718 ====================================================
720 . Changed behavior of Receive-Wait client wait strategy with
721   ORBConnectionHandlerCleanup after oneway calls to register with
722   the reactor after the call to clean up after connection closure.
724 . Added an extension of the CosNotifyFilter::FilterFactory to
725   allow removal of filters created by the factory.  The extension
726   also has accessors for existing filters and ids.
728 USER VISIBLE CHANGES BETWEEN TAO-2.1.0 and TAO-2.1.1
729 ====================================================
731 . Correct ZIOP compression arbitration on the server reply
732   path. The server now responds with one of the clients
733   exposed compressors that the server also supports
734   according to the ZIOP specification.
736 . Enhanced the plugable transports such that the
737   send_message() api now provides an optional TAO_ServerRequest
738   object pointer to provide access to any client side
739   policies that are broadcast with each request. This enabled
740   the ZIOP compression correction to be coded.
742 USER VISIBLE CHANGES BETWEEN TAO-2.0.8 and TAO-2.1.0
743 ====================================================
745 . Added new rle compressor and enabled ZIOP by default
747 . Implimented DynValue, DynValueBox and DynValueCommon and their
748   creation/use by TAO_DynAnyFactory::
749     create_dyn_any (), create_dyn_any_from_type_code (),
750     create_dyn_any_without_truncation (), create_multiple_dyn_anys ()
751     and create_multiple_anys ().
753 . Correct the interaction of CORBA::ValueTypes and CORBA::Anys.
754     The insertion into an Any of a ValueType base pointer
755     used to set the Anys typecode to the fully derived valuetype.
756     This allowed the any to be marshaled correctly sending the
757     derived typecode and value over the wire. However it also
758     stopped the user from extracting the valuetype from the any
759     as the typecode for, or the actual pointer type being used for,
760     the extraction couldn't match the any's internal two different
761     types. The any's typecode is now simply set to match the base
762     pointer which allows for the correct insertion/extraction from
763     the any, whilst the marshalling code for anys containing
764     valuetypes now sends the fully derived typecode of the fully
765     derived data it is marshalling instead of the anys embedded
766     (possiably base valuetype) typecode.
768 USER VISIBLE CHANGES BETWEEN TAO-2.0.7 and TAO-2.0.8
769 ====================================================
771 . Added support for MPC's new feature that creates dependency files for IDL
772   files when generating '-type gnuace' projects. Turned off by default, it
773   can be enabled in a features file or on the command line with
774   '-features ace_idl_dependencies=1'.
776 . Fixed IDL compiler bug where a generated component servant method that
777   is called by the middleware to initialize a component's attributes
778   was not including attributes of supported interfaces.
780 USER VISIBLE CHANGES BETWEEN TAO-2.0.6 and TAO-2.0.7
781 ====================================================
783 . Added Time_Policy_Manager, a TIME_POLICY strategy manager configurable
784   through the service configurator framework.
785   This allows the dynamic configuration of the TIME_POLICY strategy used for
786   ORB timers and countdowns. TAO includes two default TIME_POLICY strategies as
787   statically linked service objects; TAO_System_Time_Policy_Strategy and
788   TAO_HR_Time_Policy_Strategy (the first being used as default strategy).
789   The docs/Options.html file describes the configuration options in detail.
790   Two new tests have been added exemplifying these new options; tests/Time_Policy
791   and tests/Time_Policy_Custom.
792   Furthermore two new compile time option macros have been added related to
793   TIME_POLICY strategies:
794   - TAO_USE_HR_TIME_POLICY_STRATEGY if defined will force the use of the new
795     TAO_HR_Time_Policy_Strategy as default time strategy instead of
796     TAO_System_Time_Policy_Strategy;
797   - TAO_HAS_TIME_POLICY if explicitly defined as 0 ('#define TAO_HAS_TIME_POLICY 0')
798     will build TAO without the new TIME_POLICY strategy support.
800 USER VISIBLE CHANGES BETWEEN TAO-2.0.5 and TAO-2.0.6
801 ====================================================
803 . Added new define TAO_DEFAULT_COLLOCATION_STRATEGY (default = thru_poa)
804   which is used as -ORBCollocationStrategy isn't specified.
806 . Added new -ORBCollocationStrategy best. TAO tries to perform the best
807   possible collocation, first direct if possible, then through_poa if possible
808   else no collocation.
810 . Enhanced the RW -ORBWaitStrategy and the EXCLUSIVE -ORBTransportMuxStrategy
811   to also work with AMI requests.
813 . mt_noupcall has been improved and generically speaking the handling of client
814   leader threads in LF has been improved and fixed of potential deadlock
815   situations
817 . The TAO skeletons got refactored to reduced footprint, a footprint saving
818   for the skeletons between 10 and 60% has been achieved. For the full
819   distribution including CIAO, DAnCE, OpenDDS, and DDS4CCM using RTI DDS this
820   resulted in a reduction of 650,000 lines of code. Also the S.inl files are
821   not generated anymore
823 USER VISIBLE CHANGES BETWEEN TAO-2.0.4 and TAO-2.0.5
824 ====================================================
826 . Updated several TAO tests for automatic testing on Android
828 USER VISIBLE CHANGES BETWEEN TAO-2.0.3 and TAO-2.0.4
829 ====================================================
831 . Added new IFR_Client_skel library that is now used by the IFR_Service
833 . Moved TAO_IDL generation of argument traits from the stub and
834   skeleton .cpp files to the corresponding .h files.
836 USER VISIBLE CHANGES BETWEEN TAO-2.0.2 and TAO-2.0.3
837 ====================================================
839 . Improved support for mt_noupcall but this is still not optimal due to a 2ms
840   wait delay
842 . Addressed several Coverity reported issues
844 USER VISIBLE CHANGES BETWEEN TAO-2.0.1 and TAO-2.0.2
845 ====================================================
847 . Remove support for already deprecated -ORBConnectionCachingStrategy
849 . Removed -ORBObjectKeyTableLock and -ORBPOALock, very risk options and this
850   way the regular invocation path can be optimized much more
852 . Improved support for mt_noupcall wait strategy. Upcall detection has been
853   improved and the transport is polled each 2ms to see if we can do the
854   upcall.
856 . Improved performance of the Parallel Connect Strategy in TAO.
858 . tao_catior does a better job with JacORB generated IORs.
860 . tao_cosnaming can now be multithreaded.
862 USER VISIBLE CHANGES BETWEEN TAO-2.0.0 and TAO-2.0.1
863 ====================================================
865 . Fixed IDL compiler bug that caused illegal references to items
866   in the scope of a template module to be overlooked.
868 USER VISIBLE CHANGES BETWEEN TAO-1.8.3 and TAO-2.0.0
869 ====================================================
871 . Improved support for abstract
873 USER VISIBLE CHANGES BETWEEN TAO-1.8.2 and TAO-1.8.3
874 ====================================================
876 . TAO IDL compiler now generates attribute members for generated CCM
877   executor implementation classes, as well as full implementations for
878   the associated set/get operations.
880 . Add TAO IDL compiler command line option -iC, which overrides the
881   default include path (current directory or $TAO_ROOT/tao) for
882   *C.h files included in generated *A.h files.
884 . Removed autoconf support for TAO, it is really not tested, unstable, and
885   unmaintainable at this moment
887 . The TAO IDL compiler now gives the following error when anonymous
888   types are used: 'anonymous types are deprecated by OMG spec'.
889   One can changes this error into a warning. There's also a possibility
890   to silence the TAO IDL compiler about this message. One of the following
891   defines can be added to your config.h file in order to change the behavior
892   of the TAO IDL compiler:
893   * IDL_ANON_ERROR:   The TAO IDL generates an error when it encounters
894                       an anonymous type (default behavior).
895   * IDL_ANON_WARNING: The TAO IDL generates a warning when it encounters
896                       an anonymous type.
897   * ANON_TYPE_SILENT: The TAO IDL doesn't generate a warning nor an error
898                       when it encounters an anonymous type.
900 . Renamed ALL ORB services executables. This because of
901   the fact that the TAO ORB services should be recognizable
902   between the ORB services of other CORBA vendors. There are
903   systems where ORB services of several CORBA vendors are
904   installed (mainly via the installed packages). The following
905   rename actions have been taken place:
906   * 'LifeCycle_Service'       to 'tao_coslifecycle'
907   * 'Dump_Schedule'           to 'tao_dump_schedule'
908   * 'NT_Notify_Service'       to 'tao_nt_cosnotification'
909   * 'Notify_Service'          to 'tao_cosnotification'
910   * 'FT_ReplicationManager'   to 'tao_ft_replicationmanager'
911   * 'IFR_Service'             to 'tao_ifr_service'
912   * 'TAO_Service'             to 'tao_service'
913   * 'Fault_Detector'          to 'tao_fault_detector'
914   * 'Scheduling_Service'      to 'tao_cosscheduling'
915   * 'Basic_Logging_Service'   to 'tao_tls_basic'
916   * 'Notify_Logging_Service'  to 'tao_tls_notify'
917   * 'Event_Logging_Service'   to 'tao_tls_event'
918   * 'RTEvent_Logging_Service' to 'tao_tls_rtevent'
919   * 'Naming_Service'          to 'tao_cosnaming'
920   * 'NT_Naming_Service'       to 'tao_nt_cosnaming'
921   * 'CosEvent_Service'        to 'tao_cosevent'
922   * 'Event_Service'           to 'tao_rtevent'
923   * 'LoadManager'             to 'tao_loadmanager'
924   * 'LoadMonitor'             to 'tao_loadmonitor'
925   * 'Trading_Service'         to 'tao_costrading'
926   * 'Time_Service_Server'     to 'tao_costime_server'
927   * 'Time_Service_Clerk'      to 'tao_costime_clerk'
928   * 'ImplRepo_Service'        to 'tao_imr_locator'
929   * 'ImR_Activator'           to 'tao_imr_activator'
930   * 'Fault_Notifier'          to 'tao_fault_notifier'
931   * 'Concurrency_Service'     to 'tao_cosconcurrency'
933 . Fixed several bugs related to recursive typecodes
935 USER VISIBLE CHANGES BETWEEN TAO-1.8.1 and TAO-1.8.2
936 ====================================================
938 . Extended logging related to the POA active object map
940 USER VISIBLE CHANGES BETWEEN TAO-1.8.0 and TAO-1.8.1
941 ====================================================
943 . IDL compiler
945   - Added code generation for an empty implementation of
946     the reply handler interface generated as part of an
947     AMI4CCM connector, triggered by the same option, -Gex,
948     that generates a similar implementation for a
949     component executor.
951   - Added flags that can be defined in config.h to output
952     an error or warning if an anonymous IDL construct is
953     seen by the IDL compiler. Also added IDL compiler
954     options to do the same (or override a global flag)
955     for individual IDL files.
957 USER VISIBLE CHANGES BETWEEN TAO-1.7.9 and TAO-1.8.0
958 ====================================================
960 . Added minimal exploratory support for alternate IDL->C++
961   mapping: IDL string->std::string and IDL sequence->std:vectors.
962   We are talking with sponsors to see if we can raise funds
963   to make a full new IDL to C++ mapping proposal that uses
964   all new C++0x features
966 . Fixed bugzilla #3853.
968 . Improved the speed of tao_idl when processing
969   large input files with many module re-openings.
971 . Removed MCPP support from TAO_IDL.
973 . Extended support for CIAO DDS4CCM and AMI4CCM in TAO_IDL
975 USER VISIBLE CHANGES BETWEEN TAO-1.7.8 and TAO-1.7.9
976 ====================================================
978 . TAO's default makefiles (traditional ACE/GNU, not autoconf/automake)
979   now support installation with "make install".
980   Please see the ACE-INSTALL.html file for instructions.
982 . Refactored several parts of TAO_IDL
984 USER VISIBLE CHANGES BETWEEN TAO-1.7.7 and TAO-1.7.8
985 ====================================================
987 . Added -ORBHandleLoggingStrategyEvents option. Given
988   that ORB is run in user application this option allows
989   to easily add log file rotation.
991 . Added a new option -ORBIgnoreDefaultSvcConfFile.
992   This allows TAO to ignore only svc.conf file while
993   processing normally other user provided configuration
994   files or directives.
996 USER VISIBLE CHANGES BETWEEN TAO-1.7.6 and TAO-1.7.7
997 ====================================================
999 . Add IDL3+ support to TAO_IDL
1001 . Cleanup in TAO_IDL. Part of this cleanup closes
1002   (Bugzilla 2200).
1004 USER VISIBLE CHANGES BETWEEN TAO-1.7.5 and TAO-1.7.6
1005 ====================================================
1007 . Added support for iPhone/iPod Touch/iPad. The following
1008   environment variables are needed:
1010   IPHONE_TARGET, should be set to either SIMULATOR or
1011   HARDWARE. Set to HARDWARE if you want to deploy
1012   on the iPhone/iPod Touch/iPad device.
1014   IPHONE_VERSION, should be set to 3.1.2 or 3.2. One can
1015   set the version to any future or past versions, but
1016   only 3.1.2 and 3.2 have been tried.
1018   Note that one has to compile ACE/TAO statically as
1019   it is believed that the iPhone OS does not support
1020   dynamic loading of external libraries. The usual
1021   procedure of cross compiling ACE/TAO applies
1022   (such as setting HOST_ROOT environment variable).
1024 . Added support for IDL template modules in the IDL
1025   compiler front end. This is partly tested, some
1026   parts do work, some not yet
1028 . Fixed bug in optional ostream operator generation
1029   for IDL arrays.
1031 . Added member validation feature to LoadBalancer.
1033 . Add support for valuetype repository id and value
1034   on both input and output streams.
1036 . Added support for Embarcadero C++ Builder 2010
1038 . Added method TAO_Leader_Follower::set_new_leader_generator().
1040 . Fixed missing request id in logging of LocateRequest/LocateReply &
1041   CancelRequest.
1043 . Fixed problems with ORB shutdown in combination with active
1044   requests.
1046 USER VISIBLE CHANGES BETWEEN TAO-1.7.4 and TAO-1.7.5
1047 ====================================================
1049 . Converted a lot of TAO tests to use the new test framework
1051 . Fix problem in the IDL compiler where set/get methods for
1052   attributes in a local interface derived from a non local interface
1053   where not regenerated as pure virtual
1055 . Fixed some bugs concerning spaces within roots, to allow TAO_IDL
1056   to be used by user projects that are installed on windows paths
1057   such as "c:\Project Files\..." or "c:\Documents and Settings\.."
1058   etc.
1060 . The IDL3+ keywords porttype/port/mirrorport are now fully
1061   implemented and tested
1063 . Fixed bug in code generation for components, where a derived
1064   component or home with more than one generation of ancestors
1065   was missing inherited operations in its operation table
1067 . Merged in changes from OCI's distribution which originate from
1068   OCI request ticket [RT 13596, RT 13704].
1070   - Added queue-overflow statistics to the Notification Service MC.
1071   - Modified Notification Service MC to work in static builds.
1072   - Corrected an error that caused Notification Service MC statistics
1073     to fail when -AllocateTaskPerProxy is used.
1074   - QueueDepth have been changed to measure the number of entries
1075     rather than attempting unsuccessfully to estimate the amount of
1076     memory used by the queue.
1077   - Added TAO_EXPLICIT_NEGOTIATE_CODESETS macro to improve the ease
1078     of including optional codeset support to Notify_Service in static
1079     builds.
1080   - Added new MPC features (notify_monitor_control and
1081     negotiate_codesets).
1082   - fixed ACE_Logging_Stragey service loading issue in static builds.
1084 USER VISIBLE CHANGES BETWEEN TAO-1.7.3 and TAO-1.7.4
1085 ====================================================
1087 . Initial support for IDL3+ in the TAO_IDL compiler front end.
1088   IDL3+ is an extension to IDL3 driven by the DDS4CCM draft
1089   standard. IDL3+ adds a porttype which is a logical grouping
1090   of CCM ports and a concept of templates (like C++)
1092 . Changed behaviour of -Glem and -Glfa
1094 . Ported a large set of TAO tests to the new test framework
1096 . Added a capability to throw BAD_PARAM exception in case
1097   there is an attempt to access sequence elements above
1098   sequence length. By default this capability is turned on
1099   in debug builds with defining TAO_CHECKED_SEQUENCE_INDEXING.
1100   BAD_PARAM exception is also thrown in case a new sequence
1101   length for bounded sequence is greater than the bound
1102   defined in IDL.
1104 USER VISIBLE CHANGES BETWEEN TAO-1.7.2 and TAO-1.7.3
1105 ====================================================
1107 . Merged in changes from OCI's distribution which
1108   originate from OCI request ticket [RT 12994]. Added
1109   following ORB options.
1111     -ORBForwardOnceOnObjectNotExist [0|1]
1112     -ORBForwardOnceOnCommFailure [0|1]
1113     -ORBForwardOnceOnTransient [0|1]
1114     -ORBForwardOnceOnInvObjref [0|1]
1116   The -ORBForwardOnceOnObjectNotExist ORB option is added
1117   to avoid side effect from
1118   -ORBForwardInvocationOnObjectNotExist that could cause
1119   the request fall into forward loop in some use cases
1120   (e.g. client sends request while servant is deactivated).
1121   The other options are added for the same purpose to avoid
1122   possible forward loop upon specified exceptions.
1124 . Corrected TAO_IDL dds code generation to count WChar size for wstring
1125   marshal size.
1127 USER VISIBLE CHANGES BETWEEN TAO-1.7.1 and TAO-1.7.2
1128 ====================================================
1130 . Extended IDL compiler to take over all code generation from
1131   the CIAO CIDL compiler, which has been eliminated.
1132   See $TAO_ROOT/docs/compiler.html for details.
1134 . Added code generation for export header files. See
1135   $TAO_ROOT/docs/compiler.html for details.
1137 USER VISIBLE CHANGES BETWEEN TAO-1.7.0 and TAO-1.7.1
1138 ====================================================
1140 . Improved Unicode compatibility.
1142 . Improved service configuration processing.
1144 USER VISIBLE CHANGES BETWEEN TAO-1.6.9 and TAO-1.7.0
1145 ====================================================
1147 . Merged in changes from OCI's distribution which originate from
1148   OCI request ticket [RT 12912]. In their totality, the changes
1149   added new features for IMR to support the capability of client
1150   automatically reconnects servers within same port range upon
1151   server restart. The ServerId is added to ServerInfo in IMR to
1152   help identify server process. The -UnregisterIfAddressReused
1153   option is added to IMR to enable the address reuse checking
1154   upon server registering. The servers that address is reused
1155   are unregistered from IMR. The -ORBForwardInvocationOnObjectNotExist
1156   option is added to forward request to next available profile
1157   upon receiving OBJECT_NOT_EXIST exception reply.
1159 . The -ORBRunThreads of the notification service has been renamed
1160   to -RunThreads and the notification service can now be loaded
1161   as dll.
1163 . Updated ZIOP to match the OMG Beta 2 specification
1165 . Added a new utility, tao_logWalker, see utils/logWalker for details.
1166   This tool analises a collection of log files containing output of
1167   TAO running with -ORBDebuglevel 10, and generates a report showing
1168   process, thread and invocation summaries.
1170 . Fixed bug in Notification Service that the filter constraint expressions
1171   are ignored when event type domain_name or type_name is specified
1172   (see bug 3688).
1174 . The MCPP version optionally used by TAO_IDL has been updated to 2.7.2.
1175   Efforts have been taken to port this to as many platforms as possible,
1176   however, since it is not currently the default configuration it may
1177   not work across all platforms.
1179 USER VISIBLE CHANGES BETWEEN TAO-1.6.8 and TAO-1.6.9
1180 ====================================================
1182 . Reply Dispatchers are refactored. No deadlock occurs when an
1183   (a)synchronous CORBA call is made during dispatching a reply.
1185 . Fixed IDL compiler bug that in some cases caused code generation for
1186   inherited operations to be skipped.
1188 . The Transport Cache Size maximum is now a hard maximum.
1190 . Fixed several bugs related to the purging of transports when the cache
1191   is almost full.
1193 . New TAO-specific feature of Notification service improves management
1194   of proxies when peer goes away without disconnecting from proxy.  See
1195   orbsvcs/Notify_Service/README for details in the svc.conf section.
1197 . Improved Notification topology persistence, now persists filters.
1199 . Updated ZIOP to match the beta 1 OMG specification.
1201 USER VISIBLE CHANGES BETWEEN TAO-1.6.7 and TAO-1.6.8
1202 ====================================================
1204 . Fixed race condition when multiple threads make a connection to the
1205   same server (bugzilla 3543)
1207 . Updated several tests to the new test framework
1209 . Fixed several memory leaks and make sure the TAO singletons are
1210   destructed when the TAO DLL gets unloaded
1212 . Improved WinCE unicode support and extended the number of tests that
1213   can be run with WinCE
1215 . Fixed some race conditions in the transport cache. There are several
1216   known issues resolved in the transport cache when it starts purging.
1218 . Fixed memory leak in string and object reference sequences.
1220 . Bugs fixed: 3078, 3499, 3524, 3543, 3549, 3557, 3559.
1223 USER VISIBLE CHANGES BETWEEN TAO-1.6.6 and TAO-1.6.7
1224 ====================================================
1226 . Added a fix for bug 2415.  Added -DefaultConsumerAdminFilterOp and
1227   -DefaultSupplierAdminFilterOp TAO_CosNotify_Service options for setting
1228   the default filter operators.
1230 . The full TAO distribution compiles with unicode enabled. Work is ongoing
1231   to make the TAO runtime results comparable with the ascii builds.
1233 . Added two new ORB parameters, -ORBIPHopLimit and -ORBIPMulticastLoop. The
1234   first one controls number of hops an IPv4/IPv6 packet can outlive. The
1235   second one is related to MIOP only and it takes boolean value which
1236   directs whether to loop multicast packets to the originating host or not.
1238 . Added the "TAO" and "TAO/orbsvcs" OCI Development Guide Examples under the
1239   directories /DevGuideExamples and /orbsvcs/DevGuideExamples.  NOTE this is
1240   an ongoing port of the original version x.5.x examples and some are not yet
1241   100% compatiable with the current version of TAO.
1243 . Split CosLifeCycle library into separate client stub and server
1244   skeleton libraries.  Fixes bugzilla issue #2409.
1246 . Split CosTime library into separate client stub, server skeleton,
1247   and server implementation libraries.  Fixes bugzilla issue #3433.
1249 . Avoid core dumps when evaluating TCL and ETCL expressions containing
1250   divisions by zero.  Partial fix for bugzilla issue #3429.
1252 USER VISIBLE CHANGES BETWEEN TAO-1.6.5 and TAO-1.6.6
1253 ====================================================
1255 . Added a new text based monitor to the Notify_Service to keep track of
1256   consumers that were removed due to a timeout.
1258 . Repaired the -ORBMuxedConnectionMax <limit> option on the resource factory.
1259   This service configurator option defines an upper limit to the number of
1260   connections an orb will open to the same endpoint.
1262 . Repaired a problem that caused the ORB to open too many connections to
1263   an endpoint.
1265 . Added a -Timeout option to the Notify_Service to allow the user to apply a
1266   relative round-trip timeout to the ORB.  This option requires that the
1267   'corba_messaging' MPC feature be enabled during building of the
1268   Notify_Service, which it is by default.
1270 . Added ZIOP support to TAO. ZIOP adds the ability to compress the
1271   application data on the wire. This is a join effort of Remedy IT, Telefonica,
1272   and IONA. We are working on getting this standardized through the OMG.
1273   Until this has been formally standardized we don't guarantee
1274   interoperability with other ORBs and between different versions of
1275   TAO that support ZIOP, this is done after this has been accepted
1276   by the OMG. If you want to experiment with ZIOP you need to add
1277   TAO_HAS_ZIOP 1 as define to your config.h file. See TAO/tests/ZIOP
1278   for an example how to use it. All policies are not checked on all
1279   places so it can happen that the ORB sends uncompressed data when
1280   it could have compressed it. This is because of limitations in the
1281   policy mechanism in the ORB which will take a few weeks to rework.
1282   Also note that ZIOP doesn't work together with RTCORBA
1284 . Added a -m option to the ImplRepo (ImR, Implementation Repository) Activator,
1285   which specifies the maximum number of environment variables which will be
1286   passed to the child process.  The default (and previous behavior) is 512.
1288 USER VISIBLE CHANGES BETWEEN TAO-1.6.4 and TAO-1.6.5
1289 ====================================================
1291 . Updated TAO to comply with the IDL to C++ mapping v1.2. As a result
1292   CORBA::LocalObject is now refcounted by default
1294 . Added a new ORB parameter, -ORBAcceptErrorDelay, that controls the amount
1295   of time to wait before attempting to accept new connections when a
1296   possibly transient error occurs during accepting a new connection.
1298 . Fixed a bug which could lead to an ACE_ASSERT at runtime when a TAO
1299   is used from a thread that is not spawned using ACE
1301 . Added new Monitoring lib that can be used to retrieve values from
1302   the new Monitoring framework in ACE. This is disabled by default
1303   because it is not 100% finished yet, with the next release it
1304   will be enabled by default
1306 . Extended the -ORBLaneListenEndpoints commandline option to support
1307   *, for details see docs/Options.html
1309 . VxWorks 6.x kernel mode with shared library support
1311 USER VISIBLE CHANGES BETWEEN TAO-1.6.3 and TAO-1.6.4
1312 ====================================================
1314 . Service Context Handling has been made pluggable
1316 . Improved CORBA/e support and as result the footprint decreased when
1317   CORBA/e has been enabled
1319 . Added the ability to remove consumer and supplier proxies and consumer and
1320   supplier admins through the Notify Monitor and Control interface.
1322 . Changed Interface Repository's IOR output file from being
1323   world writable to using ACE_DEFAULT_FILE_PERMS.
1325 . Add support for a location forward with a nil object reference.
1327 USER VISIBLE CHANGES BETWEEN TAO-1.6.2 and TAO-1.6.3
1328 ====================================================
1330 . Fixed send side logic (both synchronous and asynchronous) to honor
1331   timeouts. An RTT enabled two-way invocation could earlier hang
1332   indefinately if tcp buffers were flooded.
1334 . Bug fix for cases where the IDL compiler would abort but with an
1335   exit value of 0.
1337 . Bug fix in IDL compiler's handling of typedef'd constants having
1338   a bitwise integer expression as the value.
1340 . Bug fix that ensures valuetypes and their corresponding supported
1341   interfaces have parallel inheritance hierarchies.
1343 . Fix for possible out-of-order destruction of Unknown_IDL_Type's
1344   static local lock object (bugzilla 3214).
1346 . Added list() iterator functionality for the Naming Service when
1347   using the -u persistence option.
1349 . Various bug fixes to the IFR service and compiler.
1351 . New option (-T) to IFR compiler that permits duplicate typedefs with
1352   warning.  Although not encouraged, this allows IDL that used to pass
1353   through the IFR compiler to still pass through rather than having to
1354   be changed.
1356 . Fix crashing of _validate_connection on an invalid object reference
1358 . Add support for TAO on VxWorks 5.5.1
1360 . _get_implementation has been removed from CORBA::Object, it was
1361   deprecated in CORBA 2.2
1363 . Improved CORBA/e support
1365 . Fixed SSLIOP memory leaks
1367 USER VISIBLE CHANGES BETWEEN TAO-1.6.1 and TAO-1.6.2
1368 ====================================================
1370 . Added support for handling Location Forward exceptions caught when using
1371   AMI with DSI. These exceptions may also be raised from within DSI servants
1372   using AMH.
1374 . Added -RTORBDynamicThreadRunTime which controls the lifetime of dynamic
1375   RTCORBA threads
1377 . Changed the PI code so that send_request is also called at the moment
1378   we don't have a transport (bugzilla 2133)
1380 . Fixed memory leak that occured for each thread that was making CORBA
1381   invocations
1383 . Updated several tests to work correctly on VxWorks
1385 . Removed support for pluggable messaging. As a result the code in the
1386   core of TAO is much cleaner and we are about 5 to 10% faster
1388 . Improved CORBA/e support
1390 . Added gperf's exit code to the error message output if it exits
1391   unsuccessfully when spawned by the IDL compiler to generate an
1392   interface's operation table
1394 . Fixed bug in Interface Repository's handling of base valuetypes
1395   and base components (Bugzilla 3155)
1397 . Fixed code generation bug that occurs when there is both a C++
1398   keyword clash in the IDL and AMI 'implied IDL' code generation
1400 . Fixed IDL compiler bug wherein some cases of illegal use of a
1401   forward declared struct or union wasn't caught
1403 . Improved support for VxWorks 6.4 kernel and rtp mode
1405 USER VISIBLE CHANGES BETWEEN TAO-1.6 and TAO-1.6.1
1406 ====================================================
1408 . Made TAO more compliant to CORBA/e micro
1410 . Fixed invalid code generation by the IDL compiler when the options -Sa -St
1411   and -GA are combined
1413 USER VISIBLE CHANGES BETWEEN TAO-1.5.10 and TAO-1.6
1414 =====================================================
1416 . Added a new interface that allows monitoring of activities within the
1417   Notification Service.  Completely configurable through the Service
1418   Configurator, the monitoring capabilities are only in effect when chosen
1419   by the user.  When the monitoring capabilities are enabled, an outside
1420   user can connect to a service that allows querying statistics gathered by
1421   the Notification Service.
1423 . Moved the BufferingConstraintPolicy to the Messaging lib
1425 . Made it possible to disable not needed IOR parsers to reduce footprint
1427 . Reworked several files to get a smaller footprint with CORBA/e and
1428   Minimum CORBA. This could lead to a reduction of more then 20% then
1429   with previous releases
1431 . Removed the Domain library, it was not used at all and only
1432   contained generated files without implementation
1434 USER VISIBLE CHANGES BETWEEN TAO-1.5.9 and TAO-1.5.10
1435 =====================================================
1437 . Added support for forward declared IDL structs and unions to the
1438   Interface Repository loader
1440 . A new securty option is available using the Access_Decision interface
1441   defined by the CORBA Security Level 2 specification. This enables the
1442   implementation of servers using mixed security levels, allowing some
1443   objects to grant unrestricted access while others require secure
1444   connections. See orbsvcs/tests/Security/mixed_security_test for
1445   details on using this feature.
1447 . Removed GIOP_Messaging_Lite support for all protocols
1449 . Fixed a hanging issue in persistent Notify Service during disconnection.
1451 . Added IPv6 support to DIOP
1453 . Added -Gos option to the IDL compiler to generate ostream
1454   operators for IDL declarations
1456 USER VISIBLE CHANGES BETWEEN TAO-1.5.8 and TAO-1.5.9
1457 ====================================================
1459 . When using AMI collocated in case of exceptions they are deliverd
1460   to the reply handler instead of passed back to the caller
1462 . Added support for IPv6 multicast addresses when federating RTEvent
1463   channels.
1465 . Fixed a bug in the IDL compiler's handling of octet constants where
1466   the rhs consists of integer literals and infix operators (Bugzilla 2944).
1468 . TAO_IDL enhancements for built in sequence support in TAO DDS.
1470 . Provide support for TAO DDS zero-copy read native types.
1472 . TAO_IDL fix for lock-up and incorrect error message generation for
1473   missing definitions within local modules. This fix also stops the
1474   erronious look-up in a parent scoped module (with the same name as
1475   a locally scoped module) that should have been hidden by the local
1476   scope definition.
1478 . The TAO_IORManip library now has a filter class that allows users to
1479   create new object references based on existing multi-profile object
1480   references by filtering out profiles using user defined criteria.  The
1481   use of -ORBUseSharedProfile 0 is required for this to function.
1483 . A problem in TAO_Profile::create_tagged_profile was fixed. This problem
1484   triggered only when MIOP in multi-threaded application was used.
1486 . Added IPv6 support in MIOP so that IPv6 multicast addresses can be used in
1487   addition to those IPv4 class D addresses. DSCP support is implemented in
1488   MIOP as well. However, since MIOP only allows one way communication then it
1489   makes sense to use DSCP on the client side only.
1491 USER VISIBLE CHANGES BETWEEN TAO-1.5.7 and TAO-1.5.8
1492 ====================================================
1494 . Fixed bug in IDL compiler related to abstract interfaces
1496 . Fixed several issues in the AMI support
1498 . Added new -ORBAMICollocation 0 which disables AMI collocated calls
1500 . Improved a lot of test scripts to work with a cross host test
1501   environment where client and server are run on different hosts.
1502   This is used for automated testing with VxWorks
1504 . Fixed handled of a forward request when doing a locate
1505   request call
1507 . Added an option, -a, to the Event_Service to use the thread-per-consumer
1508   dispatching strategy instead of the default dispatching strategy.
1510 . Improved wide character compilation support.
1512 . Fixed IDL compiler to run on both OpenVMS Alpha and OpenVMS IA64.
1514 . Fixed memory leaks in the ImpleRepo_Service.
1516 . Fixed a bug in the IDL compiler relating to include paths.
1518 . Fixed Trader Service issues related to CORBA::Long and CORBA::ULong.
1520 USER VISIBLE CHANGES BETWEEN TAO-1.5.6 and TAO-1.5.7
1521 ====================================================
1523 . Removed ACE_THROW_RETURN.
1525 . Fixed a memory crash problem when using ETCL IN operator with
1526   Notify Service filter.
1528 . Remove exception specifications from ORB mediated operations (C++
1529   mapping requirement)
1531 . New diffserv library to specify diffserv priorities
1532   independent of RTCORBA
1534 . Addressed Coverity errors in core TAO libraries, TAO_IDL compiler,
1535   stubs and skeletons generated by TAO_IDL and the TAO Notification
1536   Service.
1538 . Extended current DynamicInterface to allow DII+AMI+DSI+AMH.
1539   (Thanks to OMC <www.omesc.com> for the sponsorship.)
1541 . Fixed bug in IDL compiler code generation for a comma-separated list of
1542   sequence typedefs.
1544 . TAO no longer sets the unexpected exception handler.
1546 USER VISIBLE CHANGES BETWEEN TAO-1.5.5 and TAO-1.5.6
1547 ====================================================
1549 . Removed all exception environment macros except ACE_THROW_RETURN
1550   and ACE_THROW_SPEC
1552 USER VISIBLE CHANGES BETWEEN TAO-1.5.4 and TAO-1.5.5
1553 ====================================================
1555 . Added an IDL compiler option to generate an explicit instantiation
1556   and export of template base classes generated for IDL sequences,
1557   sometimes necessary as a workaround for a Visual Studio compiler bug
1558   (Bugzilla 2703).
1560 . Beefed up error checking in the IDL compiler when processing
1561   #pragma version directives.
1563 . Modified IDL compiler's handling of a syntax error to eliminate
1564   the chance of a crash (Bugzilla 2688).
1566 . Fixed a bug in code generation for a valuetype when it inherits
1567   an anonymous sequence member from a valuetype in another IDL file.
1569 . Extended tests in tests/IDL_Test to cover generated code for
1570   tie classes.
1572 . Modified tao_idl to emit code to set the exception data in the
1573   Messaging::ExceptionHolder in the AMI _excep operation.  This has the
1574   effect of allowing user defined exceptions to be recognized when
1575   raising an exception without collocation.  This fixes Bug 2350.
1577 . Added hooks to enable custom Object to IOR conversion or allowing local
1578   objects (such as Smart Proxies) to be converted to an IOR string.
1580 . Removed warning issued when using corbaloc with a default object key.
1582 . Added implementation of Dynamic Any methods insert_*_seq() and
1583   get_*_seq() (spec-defined for sequences of IDL basic types),
1584   as well as implementation of insert and get methods for abstract
1585   interfaces.
1587 . Added support for CORBA/e compact
1589 . Added support for CORBA/e micro
1591 . Fixed issues relating to the CosTrading Server library.  The constraint
1592   language lexer now allow negative floating point values, 64-bit signed and
1593   unsigned integers (which can currently be represented as octal or decimal).
1594   Also, fixed a bug where negative integers were being stored and compared as
1595   unsigned integers which resulted in -3 > 0 evaluating to true.
1597 . Added Compression module that delivers the infrastructure
1598   classes with which data can be compressed. This can be used
1599   by regular applications but then also by the ORB in the future.
1601 . Removed support for -Ge 0 and -Ge 1 from the IDL compiler. In practice
1602   this means that the IDL compiler doesn't generate any environment macros
1603   anymore.
1605 . Fixed a problem where TAO mistakenly considered ALL messages
1606   with zero-length payload to be errors and was thus not properly
1607   parsing and handling the GIOP CloseConnection message.  This is
1608   tested via Bug_2702_Regression.
1610 . Added an optimization to servant activation to eliminate calls to
1611   check_bounds() on the object key sequence.  This has been observed
1612   to yield a 30% decrease in activation time for debug builds on VC71
1613   and linux gcc.
1615 . Merged in changes from OCI's distribution which originate from
1616   OCI request tickets [RT 8449] and [RT 8881]. In their totality,
1617   these changes add a feature whereby the notification service
1618   implementation can utilize a separate ORB for dispatching events to
1619   consumers.
1621 . Contributed the Transport::Current support - a TAO-specific
1622   feature providing IDL interfaces which enables users to obtain
1623   information about the Transports used to send or receive a
1624   message.  The basic intent is to provide (typically) a
1625   read-only interface to obtaining data like the number of bytes
1626   transferred or the number of messages sent and received.
1627   Since specific Transports may have very different
1628   characteristics, a simple generic implementation for
1629   Transport::Current is insufficient.  This implementation also
1630   provides support for specific Transport implementations. See
1631   the TC_IIOP implementation, which is an IIOP-specific
1632   Transport::Current. It extends the generic interface with
1633   operations providing information about IIOP endpoints, like
1634   host and port.  By default, TAO builds with support for this feature.
1635   Define "transport_current=0" in your default.features file to disable
1636   it. For more details of how the feature is intended
1637   to be used, see docs/transport_current/index.html
1639 USER VISIBLE CHANGES BETWEEN TAO-1.5.3 and TAO-1.5.4
1640 ====================================================
1642 . Added support for ACE_Dev_Poll_Reactor to Advanced_Resource_Factory.
1644 . Improved tao_idl performance, particularly over networked
1645   filesystems.
1647 . Added new option for the RTEC, -ECDispatchingThreadsFlags, that
1648   allows the user to pass in a list of thread creation flags and
1649   priority for dispatching threads.  These can be used for either the
1650   MT dispatching strategy or the TPC dispatching strategy.  See
1651   docs/ec_options.html for usage information.
1653   Also added -ECDebug option to enable debugging output from the RTEC.
1654   Only the option and variable was added, but no messages.  Therefore,
1655   at the moment, this does not generate much output.
1657 . Resolved Bugzilla #2651 to eliminate incompatibility with the new
1658   mechanism, allowing per-ORB configurations.
1660 . Fixed Bugzilla #2686, which involved correctly managing memory during
1661   exceptional situations.  Throwing an exception during the creation of the
1662   Root POA would cause a leak of a TAO_Adapter and POA manager related
1663   objects.
1665 . Fixed Bugzilla #2699, by uninlining generated code for the
1666   TIE template classes. Inlining of virtual functions in this
1667   code was causing problems with RTTI on some compilers. As a side
1668   result, the idl compiler doesn't generate a S_T.inl file anymore.
1670 . Fixed a bug where calling _set_policy_overrides() on a collocated servant
1671   would return an unusable object reference.
1673 . Addressed a number of Coverity errors (CHECKED_RETURN, DEADCODE, LOCK,
1674   USE_AFTER_FREE, RESOURCE_LEAK, FORWARD_NULL).  In particular, missing
1675   return value checks and unreachable code in the ACE CDR stream
1676   implementation were addressed.  Memory and resource management in the ACE
1677   Configuration classes was corrected.  A potential deadlock upon error was
1678   fixed in ACE_OS::rw_unlock().  Missing return value checks were addressed
1679   in ACE_OS::open() on Windows and ACE_Thread_Manager::wait().  A potential
1680   dereference of a null pointer in ACE_OS::scandir_emulation() was
1681   corrected.  Lastly, the ACE_UUID::lock() accessor interface and
1682   implementation was cleaned up so that it would not return a lock whose
1683   memory had been freed.
1685 USER VISIBLE CHANGES BETWEEN TAO-1.5.2 and TAO-1.5.3
1686 ====================================================
1688 . Added new options, -CECConsumerOperationTimeout and
1689   -CECSupplierOperationTimeout, to the CosEvent service.  See Bugzilla #2594
1690   and $TAO_ROOT/docs/cec_options.html for details.  The purpose of these
1691   options is to use the relative round-trip timeout feature from the TAO
1692   Messaging library to detect clients that are "hung" in push() or pull()
1693   operations but would otherwise not be detetcted as "bad" by the
1694   -CECReactive*Control options (since they have a thread available in
1695   orb->run()).
1697 . The Tk/Fl/Qt/Xt resource factories have been moved to subdirectories
1698   to make maintenance easier. If you are using these you have to update
1699   your include paths.
1701 . Fixed a compatibility problem between TAO and ORBs using Valuetype ID
1702   indirection, such as JacORB. This problem was inadvertently introduced
1703   in 1.5.2.
1705 . Oneway requests when using SYNC_NONE, SYNC_DELAYED_BUFFERING, or
1706   SYNC_EAGER_BUFFERING will be queued until the connection is completed.
1707   Connection completion occurs when one of the following occurs:
1708    a) A one-way request that does NOT use one of the sync-scopes mentioned
1709         above is sent via the same transport
1710    b) A two-way request is sent via the same transport
1711    c) orb->run() is called
1712   Applications that do not currently do one of the above will no longer
1713   establish a connection and therefore no data will be sent.
1715 . Fixed a problem with location forward objects being raised by colocal
1716   ServerInterceptors. This problem did not occure interacting with remote
1717   servers.  Now the raised object-reference will take effect on the object
1718   reference being held by client.
1720 . Fixed a problem with properly shutting down socket connections by
1721   explicitly calling release_os_resources from the destructor of protocol
1722   specific connection handlers. Maintainers of third-party (non-DOC)
1723   pluggable protocols must verify they are releasing any resources they
1724   acquired. The base Connection_Handler destructor can't do it for them.
1726 . Added COIOP as pluggable protocol. This stands for Collocated Only IOP
1727   and it only allows collocated calls. Can be used for embedded systems that
1728   do use corba but don't make any remote calls.
1730 . Notication service works with Microsoft Visual C++ 8.
1732 . Fixed Bugzilla #2582, related to IDL compiler generation of arg traits
1733   template specialization for typedefs.
1735 . Fixed Bugzilla #2583, a bug in the recursive check for local type
1736   containment that controls CDR operator generation in the IDL compiler.
1738 . Addressed Bugzilla #2603, which called for a -oS option for the IDL
1739   compiler to set the output directory for skeleton files.
1741 . Fixed Bugzilla #2634, which reported a bug in code generation for some
1742   escaped IDL identifiers.
1744 . Eliminated the dependency of the TAO Interface Repository IDL3 test on
1745   CIAO libraries.
1747 . Added output message to the IDL compiler, containing the name of the IDL
1748   file being processed.
1750 . Fixed IDL compiler to recognize CORBA::AbstractBase as a pseudo object.
1752 . Fixed a regression on Bugzilla #2074 caused by a reference
1753   counting problem on the Connection Handler.  This change
1754   affects all pluggable transport protocol implementations.
1755   Maintainers of third-party (non-DOC) pluggable protocols will
1756   need to make similar changes to their *_Connection_Handler
1757   implementations.
1759 . Fixed parsing of explicitly wildcarded IIOP endpoints.
1760   These might be iiop://[::]:, iiop://[]: or iiop://0.0.0.0:
1761   The first two examples are useful only when IPv6 is supported.
1762   The last example forces only IPv4 endpoints even when IPv6 is
1763   supported. Use iiop://: to get both IPv4 and IPv6 endpoints.
1765 . Fixed Bugzilla #2651 to properly handle order of destruction
1766   of Codeset Manager instances owned by the Default Resource
1767   Factory.  The ORB_Core is now responsible for managing the
1768   lifecycle of the Codeset Manager instance instead of the
1769   Resource Factory.  The Resource Factory now gives up ownership
1770   of the objects it creates.
1772 . Fixed Bugzilla #2545 so collocated DII oneway requests do not
1773   crash in get_in_arg().
1775 . Added a new "-b" option to the IDL compiler to control whether
1776   or not arguments on oneway invocations are "cloneable".  If the
1777   arguments are cloneable, and Custom Servant Dispatching (CSD)
1778   strategy is in use, the arguments for collocated oneways can be
1779   cloned during the copy of the TAO_Server_Request, which gives a
1780   performance improvement over the old method of copying the
1781   arguments using marshaling.
1783 . Fixed Bugzilla #2604 so the Implementation Repository can
1784   properly keep track of servers it launched in PER_CLIENT
1785   activation mode.
1787 . Fixed build warnings from some 64-bit compilers in code in which
1788   unsigned long and ACE_CDR::ULong were mixed.
1790 . Added various performance enhancements.  Many thread mutex/integer
1791   reference counts were replaced with ACE_Atomic_Op<unsigned long>.  Some
1792   buffers are allocated on the stack instead of the heap where possible.
1794 USER VISIBLE CHANGES BETWEEN TAO-1.5.1 and TAO-1.5.2
1795 ====================================================
1797 . To be able to support CORBA/e the pidl files within the core libs are
1798   now compiled during the building of the core libs. This means that gperf
1799   and TAO_IDL must be build before you can build the core libs!
1801 . Changed NT_Naming_Service project to require new MPC feature variable
1802   "winnt".  Avoids building and installing this on non-Windows systems.
1803   Fixes bugzilla bug #2412.
1805 . Changed NT_Notify_Service project to require new MPC feature variable
1806   "winnt".  Avoids building and installing this on non-Windows systems.
1807   Fixes bugzilla bug #2411.
1809 . Changed Telecom Log Service plug-in Strategy Interface.
1811   Added get_record_attribute(), set_record_attribute(), and
1812   set_records_attribute(); removed remove(), retrieve(), and update().
1813   This will allow plug-in Strategies to handle these high-level
1814   operations more efficiently.
1816   Added get_gauge() and reset_gauge(), to maintain "gauge" used for
1817   capacity threshold alarms when log channel's LogFullActionType is
1818   DsLogAdmin::wrap.  This resolves bugzilla 2420.
1820 . Allow different ORB instances to use a different sets of Service
1821   Objects in their own Service Repository instances. This resolves
1822   bugzilla #2486.
1824 . Integrate new sequence implementation made by Carlos O'Ryan. This
1825   also includes a rework of the TAO_String_Managers and CORBA::(W)String
1826   implementations.
1828 . Store Value Factories per orb instead of per process and made the
1829   storage thread safe.
1831 . Add on demand write functionality that writes out GIOP fragments to
1832   reduce the memory usage
1834 . The TIE files (_S.*) are not generated by default anymore by the
1835   IDL compiler. If you need these for your project, add -GT to the
1836   idl compiler flags.
1838 . Added optional support for implicitly typed values. When the Valuetype
1839   library is compiled with TAO_HAS_OPTIMIZED_VALUETYPE_MARSHALING defined
1840   TAO will skip the marshaling of the value's type when it is allowed to
1841   do so. It is allowed by the spec to do so when the value's actual type
1842   matches the formal type for the parameter through which the value is
1843   passed. As older versions of TAO did not correctly unmarshal implicitly
1844   typed values, the default behavior is for TAO to always marshal the
1845   type id for values.
1847 . Added support for CORBA specified truncatable valuetypes.
1849 . Added support for CORBA specified POAManagerFactory.
1851 . Added TAO-proprietary EndpointPolicy. This is used as a filter to limit
1852   which of an ORBs endpoints are inserted into an object reference. The
1853   endpoint policy is applied to POAManagers created via the POAManagerFactory
1854   and affect all POAs associated with that POAManager.
1856 . Added a client-side connection optimization, the Parallel Connect Strategy
1857   This strategy makes the client evaluate all endpoints in profile at the same
1858   time when trying to connect to the server. For this to work the server must
1859   be run with -ORBUseSharedProfile 1 and the client must be run with
1860   -ORBUseParallelConnect 1.
1862 . Fixed several bugs related to asynchronous connection establishment. These
1863   are represented by the AMI_Buffering tests and bug 2417's regression test.
1865 . Refactored PICurrent, removing PICurrent_Copy_Callback classes, subsuming
1866   this functionality inside PICurrent_Impl where it can be controlled
1867   correctly. The copying of PICurrent objects still performs lazy/deferred
1868   copying where possible, only taking a real physical copy when modifications
1869   are attempted. Interest in PICurrent objects where lazy copies have been
1870   taken can now be correctly reversed when the lazy copy is destroyed fixing
1871   a range of call-back bugs that were performed on already destroyed objects.
1872   (For detail see bugzilla 2552.)
1874 . Updated/Enhanced TAO/utils/nslist utilities nslist,nsadd and nsdel.
1875   These tools now allow for full ID.Kind processing (the separating character
1876   is user controlled, defaulting to .) and sub-context path processing (the
1877   separating character is also user controlled, defaulting to /).
1878   nsadd allows for (re)binding naming contexts in addition to final objects
1879   nsdel allows for destroying naming contexts when unbinding.
1880   nslist output has been prittyfide with user controlled character drawing
1881   of the naming context tree or sub-tree of full or limited depth.
1882   For full usage details execute these utilities with a ? parameter.
1884 . Add the ability to use the sendfile API to send out data
1885   on the transport
1888 USER VISIBLE CHANGES BETWEEN TAO-1.5 and TAO-1.5.1
1889 ====================================================
1891 . Fixed LOCATION_FORWARD_PERM handling. See bugzilla #1777 for full details.
1893 . Fixed bug in detecting name clashes between existing identifiers and
1894   extra code generated for AMI and AMH.
1896 . Fixed bug in connection closure. See bugzilla # 2391
1898 . Added support for the --enable-fl-reactor configure option to the
1899   autoconf build infrastructure to build the TAO_FlResource library.
1901 . Added support for the --enable-qt-reactor configure option to the
1902   autoconf build infrastructure to build the TAO_QtResource library.
1904 . Added support for the --enable-xt-reactor configure option to the
1905   autoconf build infrastructure to build the TAO_XtResource library.
1907 . Fixed a race condition involving two threads active in the same
1908   connection handler at the same time. See bug# 1647 for details.
1910 . Changed #include "..." preprocessor directives to use fully
1911   qualified (from $(ACE_ROOT), $(TAO_ROOT), or $(TAO_ROOT)/orbsvcs)
1912   paths.  We had been depending on non-standard behavior where files
1913   #included with "..." are first looked for in the current directory
1914   and then in the same directories used by #include <...>.  See bug
1915   #2448 for details.
1917 USER VISIBLE CHANGES BETWEEN TAO-1.4.10 and TAO-1.5.0
1918 ====================================================
1920 . Fixed Transport to handle incoming fragmented messages propperly, abstract
1921   interfaces TAO_Pluggable_Messaging and TAO_Transport have been
1922   modified. Custom transport/messaging implementations require
1923   interface modification.
1925 . Fix collocation optimisation when a location forward is received directing a
1926   client to a collocated object.
1928 . Prevent an OBJ_ADAPTER exception when using an object reference containing
1929   an ObjectID that corresponds to a collocated IORTable entry.
1931 . Reverted solution that allowed POA-level control over access to
1932   security-enabled objects due to conflicts with the specification,
1933   i.e. the  Security::SecQoP* are not server-side policies.
1935 . When suppressing any and typecodes during IDL compilation this will not
1936   trigger compile errors due to missing any insert operations
1938 . Bug fix in IFR when creating typecodes for nested structs and unions.
1940 . Added support for the --enable-tk-reactor configure option to the
1941   autoconf build infrastructure to build the TAO_TkResource library.
1943 IDL COMPILER
1944 ------------
1946 . Fix problem with missing includes in the skeleton files for imported arg
1947   trait declarations.
1949 USER VISIBLE CHANGES BETWEEN TAO-1.4.9 and TAO-1.4.10
1950 ====================================================
1952 . Fixed a bug, which allowed security unaware clients to make
1953   invocations on secure objects, when the ORB was configured with
1954   support for Security::SecQoPNoProtection.
1956 . Fixed Bugzilla #2145, which was preventing the building of
1957   the IDL compiler on HPUX.
1959 . Added boxed valuetype support to the Interface Repository
1960   loader.
1962 . Fixed several bugs in the PICurrent implementation
1964 . Fixed GOA factory name
1966 . Fixed -ORBConnectionHandlerCleanup arguments to accept 0 and 1.
1968 . Improved Portable Interceptor implementation.
1970 . Autoconfig improvements.
1972 . Improved Real-time CORBA support for dynamic threads.
1974 IDL COMPILER:
1975 -------------
1977 . Some bug fixes. See bug #2375 and #2390.
1979 USER VISIBLE CHANGES BETWEEN TAO-1.4.8 and TAO-1.4.9
1980 ====================================================
1982 . Added new endpoint selector implementation - Optimized
1983   Connection Endpoint Selector. A member of the tao/Strategies library,
1984   use svc.conf file to load the OC_Endpoint_Factory object. See
1985   tests/AlternateIIOP/svc.conf for an example.
1987 . Continued splitting ORB Services into stub, skeleton, and
1988   implementation libraries.  Changes to the Concurrency Service,
1989   Property Service, and RTEventLog Admin Service (TAO's RTEvent
1990   varient of the OMG Telecom Log Service) have been committed.
1992 . Added a new ORB run-time option "-ORBUseLocalMemoryPool [0|1]" which
1993   controls an individual application's use of TAO's Local Memory Pool.
1994   TAO can use a local memory pool to satisfy some of its needs for
1995   heap storage, as it is often more efficient than using the
1996   platform's default memory allocator. The pool will always grow as
1997   large as necessary to satisfy memory allocations, but it will never
1998   shrink. This means that sometimes a process can retain memory that
1999   it no longer needs. If the default allocator is used then TAO gives
2000   memory back as soon as it is not needed.
2001   The UseLocalMemoryPool option selects between using the local memory
2002   pool or using the default allocator, where 0 means don't use the pool,
2003   1 means use the pool. The default is still controlled by the original
2004   compile-time option controlled by the #define TAO_USE_LOCAL_MEMORY_POOL
2005   which defaults to 1 if not specified.
2007 . Add a property -ORBKeepalive to allow a user to specify that
2008   SO_KEEPALIVE is set on IIOP connections. See docs/Options.html
2009   and Bugzilla #2374.
2011 . Add support for RTCORBA::TCPPrototocolProperties::keep_alive, when
2012   RTCORBA is used, and the application is using a Server or Client
2013   ProtocolPolicy.
2015 . Refined the Telecom Log Service Strategy Interface.  Added methods
2016   to fetch/store capacity alarm thresholds, log QoS, and "week mask".
2017   Rework locking to avoid race conditions and to improve performance.
2019 IDL COMPILER:
2020 -------------
2022 . Fixed bug in computation of repository ids for predefined types.
2024 . Fixed bug in the handling of TAO_IDL_INCLUDE_DIR.
2026 Interface Repository:
2027 ---------------------
2029 . Fixed bug in the lookup of a valuetype member's type using its
2030   repository id.
2032 . Fixed bug in IFR loader in checking for pre-existence before
2033   creating an entry corresponding to an IDL typedef.
2035 . Fixed bug in lookup when checking for a local name clash.
2037 . Fixed bug in the describe_interface() operation when the IDL
2038   interface being described has multiple parents.
2040 USER VISIBLE CHANGES BETWEEN TAO-1.4.7 and TAO-1.4.8
2041 ====================================================
2043 . Fixed bugs in code generation for interfaces that inherit from both
2044   concrete and abstract interfaces.
2046 . Subset Anys and TypeCodes to a separate library. If you use Any/TypeCode
2047   or one of the core TAO libs uses it you should link the AnyTypeCode
2048   library with your application
2050 . PICurrent is moved to the PI library
2052 . POACurrent has been moved back from PI_Server to PortableServer
2054 . Added IPv6 support for IIOP
2056 . When Any and TypeCode generation is suppressed when compiling IDL
2057   no typecodes are generated anymore for user exceptions, they are not
2058   needed for the operation of the ORB
2060 . When making AMI invocation and the send blocks we buffer the message
2061   and send it out when the transport is available again
2063 . Emulated C++ exceptions are not maintained anymore. We are keeping
2064   the macros in the TAO code until x.5.1 is out, if nobody sponsors
2065   maintenance at that moment the macros will be removed from TAO.
2066   See also http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2256
2068 . Support the latest AMI mapping, the old mapping will be kept working
2069   until 1.5.1 has been released. If you need the old mapping add
2070   the define TAO_HAS_DEPRECATED_EXCEPTION_HOLDER to your config.h
2071   file before you build TAO and the TAO_IDL compiler
2073 . Added CodecFactory::create_codec_with_codesets to create a codec with
2074   a specific codeset. See OMG issue 6050 for the background.
2076 . PortableInterceptor::IORInterceptor has been splitted in IORInterceptor
2077   and IORInterceptor_3_0. If you use IORInterceptors read the ChangeLog for
2078   the details, maybe you have to update your code!
2080 . Added the new Custom Servant Dispatching (CSD) feature to provide user
2081   applications with the ability to implement and "plug-in" custom strategies
2082   to handle the dispatching of requests to servants. This new feature is not
2083   currently tested for VxWorks. See TAO release notes for more information.
2085 . Added support for an TAO "versioned" namespace.  When enabled, TAO
2086   library sources will be placed within a namespace of the user's
2087   choice or a namespace of the form TAO_1_4_7 by default, where
2088   "1_4_7" is the TAO major, minor and beta versions.  The default may
2089   be overridden by defining the TAO_VERSIONED_NAMESPACE_NAME
2090   preprocessor symbol.  Enable overall versioned namespace support by
2091   adding "versioned_namespace=1" to your MPC default.features file.
2093 . Changed generated signatures of some valuetype member
2094   accessor/mutator pairs to be consistent with IN
2095   parameter semantics.
2097 . Added spec-required generation of member-initializing
2098   constructor for valuetypes. See C++ mapping (03-06-03)
2099   section 1.17.2. Closes Bugzilla #2270.
2101 . Added default include paths $TAO_ROOT, $TAO_ROOT/tao,
2102   $TAO_ROOT/orbsvcs, and $CIAO_ROOT/ciao to IDL compiler
2103   execution, eliminating the need to add them explicitly
2104   to the command line.
2106 . Added immediate exits to IDL compiler when some name clash
2107   errors are encountered, avoiding a crash if parsing is
2108   continued. Closes Bugzilla #2281.
2110 . Changed the behavior of the _default() method (generated
2111   for IDL unions that have an explicit or implicit default
2112   case label) to clean up memory used by the freed member,
2113   if necessary.
2115 . Fixed bug in IDL compiler when handling a native exception
2116   in an operation declared in Messaging::ExceptionHolder.
2118 . Although not presently supported by CIAO, added error
2119   checking to the IDL compiler's parsing of IDL home
2120   primary keys, which constrain the basic valuetype
2121   syntax in several ways.
2123 . Fixed order of generated base class stub constructor calls
2124   when the IDL interface has both concrete and abstract parents.
2126 . Fixed a bug in the handling of forward declared interfaces
2127   that have both concrete and abstract parents.
2129 . Fixed the command line parsing to preserve the literal
2130   quotes if they are used in an include path that has a space.
2131   Closes Bugzilla #2219.
2133 . Many changes related to refactoring of Anys and Typecodes
2134   into a separate library (POC is Johnny Willemsen
2135   <jwillemsen@remedy.nl>).
2137 . Merging of many Notification Service changes/fixes from OCITAO to
2138   the DOC version.  These generally addressed stability issues such as
2139   memory leaks, thread leaks, etc.
2141 . Introduction of the versioned namespaces changed the name of the
2142   factory function used for dynamically loading the Notification
2143   Service persistence mechanisms.  See the service configurator file
2144   in orbsvcs/tests/Notify/XML_Persistence for an example.
2146 USER VISIBLE CHANGES BETWEEN TAO-1.4.6 and TAO-1.4.7
2147 ====================================================
2149 . The Telecom Logging Service now supports dynamically loaded Strategies
2150   which can be used to implement a persistent log record store.  If none
2151   are specified, a default in-memory hash table implementation is used.
2153 . The CodecFactory is moved to its own library. If you use this in your
2154   application include tao/CodecFactory/CodecFactory.h and link the
2155   TAO_CodecFactory with your app
2157 . The ORBInitializer registry, PolicyFactory registry and ORBInitInfo
2158   are moved to the new PI library. If you use these clases include
2159   tao/PI/PI.h in your application code and link the new TAO_PI
2160   library with your application.
2162 . All server side PortableInterceptor support is moved to the new
2163   TAO_PI_Server library. If you use this, include tao/PI_Server/PI_Server.h
2164   in your application code and link the new TAO_PI_Server lib
2166 . A new set of examples and support code that show how to set up a
2167   multicast-based federation of  Notification Services is now available
2168   in $TAO_ROOT/orbsvcs/examples/Notify/Federation.
2170 . Hard coded loading of services with Service Configurator now uses the
2171   ACE_DYNAMIC_SERVICE_DIRECTIVE macro which also works when the xml
2172   version of service config is enabled.
2174 . The Codeset negotiation support is in its own library. The hooks are
2175   still present in the ORB Core to dynamically load the codeset support
2176   if needed. This behavior is overridden by the new ORB_init option
2177   -ORBNegotiateCodesets 0.
2179 . The Boxed Value Type as specified by the OMG is now accepted by the
2180   TAO_IDL compiler.
2182 . TAO clients now parse the OMG specified TAG_ALTERNATE_IIOP_ADDRESS
2183   profile component. To generate IORs using that component, add the
2184   new ORB_init option, -ORBUseSharedProfiles 1.
2186 . Refactored TAO's codeset negotiation feature to be optionally loadable.
2187   The implementation is now in a separate library, TAO_Codeset. Applications
2188   not wishing to use codeset support may pass -ORBNegotiateCodesets 0 to
2189   ORB_init() to avoid loading the library. When building dynamic applications
2190   codeset negotiation is available by default. For static applications, the
2191   default is to *not* include codeset negotiation. Staticly linked apps
2192   needing codeset negotiation support must do two things:
2193   - Define the new MPC feature "negotiate_codesets=1" in default.features
2194     and regenerate makefiles
2195   - Add "#include <tao/Codeset/Codeset.h>" somewhere in their application
2196     source. Placing this in the source file that includes calling ORB_init()
2197     is probably the best place.
2199 . Added CORBA::Object::_repository_id() and CORBA::Object::_get_orb()
2200   as described by the spec.
2202 USER VISIBLE CHANGES BETWEEN TAO-1.4.5 and TAO-1.4.6
2203 ====================================================
2205 . The RTOldEvent library has been removed. The RTEvent library has been
2206   split in a stub/skel and serv library.
2208 . Support for bi-directional communication over SSLIOP.
2210 . Servants are now always reference counted, in accordance with changes
2211   to the CORBA specification.
2213 . Added a -x option to catior that works like -f except that it reads
2214   the IOR from standard input rather than from a file. This makes catior
2215   much more like the unix "cat" command, and enables it to be used in a
2216   pipeline.
2218 . Changed the precedence rules for the -ORBListenEndpoints (aka
2219   -ORBEndpoint) so that the host identifier (either hostname or IP
2220   address) that appears in IIOP profiles is determined thus:
2222     1. value from hostname_in_ior (if specified);
2223     2. setting of -ORBDottedDecimalAddresses option;
2224     3. value for hostname in -ORBListenEndpoints specification;
2225     4. whatever TAO magically comes up with based on system
2226        configuration
2228   A new test (TAO/tests/IOR_Endpoint_Hostnames) verifies the
2229   operation of this feature.
2231 . Changed the way that Bidirectional endpoint processing happens when
2232   -ORBDottedDecimalAddresses 1 is in effect. The previous behavior
2233   always used the setting of the receiver, but that caused problems when
2234   the sender and receiver were not using the same dotted decimal
2235   addresses setting.  Bidirectional endpoint processing now uses
2236   whatever the sender provides as the hostname since that's also what
2237   will be in that sender's IORs.
2239 . Added a configuration property -ORBIMREndpointsInIOR [0|1] that
2240   controls whether ImR endpoints are written into persistent IORs. See
2241   $(TAO_ROOT)/docs/Options.html and bugzilla #2123 for usage.
2243 . Increment the refcount on the servant in the id_to_servant and
2244   reference_to_servant methods of the POA.
2246 . Improved g++ 4.0 support.  A number of RTTI related problems have been
2247   fixed, in addition to removal of duplicate internal ORB related
2248   singleton instances.
2250 . Fixed assertion that occured in some thru-POA collocated calls.
2252 . Fixed CORBA::UnknownUserException Any insertion problem.
2254 . Fixed TypeCode equivalence failure when comparing aliased and
2255   unaliased TypeCodes of the same type.
2257 USER VISIBLE CHANGES BETWEEN TAO-1.4.4 and TAO-1.4.5
2258 ====================================================
2260 . The POA is rewritten so that it uses strategies for its implementation.
2262 . The ImR handling is moved to the new ImR_Client library. If your server
2263   needs to register itself to the ImR you have to link the new ImR_Client
2264   library
2266 . The MIOP part of the POA is moved to the GOA. See the latest version of the
2267   MIOP specification. You have to link now with the PortableGroup
2268   library and retrieve a GOA instead of the RootPOA.
2270 . Implemented several missing parts of POA functionality as described
2271   by the latest corba specification. Missing functionality, incorrect
2272   exceptions, incorrect minor codes and much more.
2274 . Splitted the huge PortableServer.pidl file in several smaller files
2275   and regenerated all the generated files in the repository.
2277 . Move TAO_ORB_Manager from PortableServer to Utils library, this is a
2278   helper class.
2280 . The POA has been split in Root_POA and Regular_POA, on this we will more
2281   in the future so that the Root_POA just pulls in the minimal set of things
2282   needed.
2284 . The RootPOA now has "RootPOA" as its adapter name, previously it had
2285   an empty string.  This is required by the CORBA specification, you can
2286   overrule this by defining TAO_DEFAULT_ROOTPOA_NAME if you want to
2287   reduce the "RootPOA" string to be shorter, e.g., "".
2289 . Added support for GNU G++ 4.0.  Additional details in ACE `NEWS' file.
2291 . Explicit template support has been dropped for TAO and it is not possible
2292   to use it anymore.
2294 . CORBALOC/CORBANAME patched a memory leak and fixed performance related
2295   to the use of defaulted object keys.
2297 . Added support for Visual Age on AIX
2299 . Made it possible to run most ORB core test with VxWorks in a cross host
2300   scenario where one part of the test runs on the host and the other part
2301   of the test runs on the VxWorks target
2303 . The skeletons generated by the TAO_IDL compiler have been refactored
2304   to significantly reduce the size of server applications.  Please see
2306   http://www.dre.vanderbilt.edu/Stats/
2308   for metrics that illustrate the magnitude of the reduction.
2310 . New TypeCode implementation that reduces the size of TypeCodes in
2311   memory at run-time.
2313 USER VISIBLE CHANGES BETWEEN TAO-1.4.3 and TAO-1.4.4
2314 ====================================================
2316 . Reimplemented the way that TAO_Transport deals with GIOP headers.  In
2317   some cases partial GIOP message headers were read and used as if a full
2318   GIOP header were received. [Bug 1681]
2320 . GIOP fragment handling has changed where a single large allocation and
2321   copy occurs at the end of a fragment chain instead of an allocation and
2322   copy for every fragment received.
2324 . The tao-config script has been replaced by pkg-config metadata files
2325   which are installed in ${prefix}/lib/pkgconfig by the automake build.
2327 . SHMIOP respects now the dotted decimal addresses setting. When this is
2328   set it uses ip addresses instead of hostnames.
2330 . Removed the usage of the ACE_x_cast macros, we are using the C++ casts
2331   from now on.  The TAO core libraries will be updated before the x.4.5
2332   release.
2334 . Removed MPC code that creates unused and unnecessary subfolders in
2335   Visual Studio projects and makefiles.
2337 . Fixed unclosed temporary file created by the IDL compiler on platforms that
2338   lack mkstemp. [BUGID:2026]
2340 . Fixed IDL compiler bug related to handling null object references in a
2341   sequence. [BUGID:2027]
2343 . Made behavior when marshaling null value of an abstract interface similar
2344   to the behavior of CORBA::Object.
2346 . Made use of 'true' and 'false' with CORBA::Boolean more consistent in TAO
2347   source code and generated code.
2349 . Fixed bug in code generation for typedefs of IDL arrays that are not declared
2350   at global scope or in a module (i.e., in an interface, valuetype, eventtype
2351   or home).
2353 . Fixed bug in code generation of parent operations in AMI ReplyHandler
2354   interfaces.
2356 . Changed remaining instances of C-style casts in generated code to the
2357   appropriate C++-style cast.
2359 . Fixed typo in code generation of bounded sequences of CORBA::Object.
2361 . Fixed bug in code generation for attributes which are unaliased bounded
2362   (w)strings.
2364 . Changed implementation of TAO::Unknown_IDL_Type (a subclass of TAO::Any_Impl
2365   used when an Any is first decoded from the wire or created from a Dynamic
2366   Any) to contain its value in a TAO_InputCDR stream rather than an
2367   ACE_Message_Block*, thus cleaning up alignment and memory management code
2368   related to this type.
2370 USER VISIBLE CHANGES BETWEEN TAO-1.4.2 and TAO-1.4.3
2371 ====================================================
2373 . New pluggable protocol for GIOP over HTBP, known as HTIOP.  Source in
2374   orbsvcs/orbsvcs/HTIOP.
2376 . All TAO-specific vendor IDs are now found in the "TAO" namespace.
2377   Documentation for these constants has also been improved in a number
2378   of cases.
2380 . Further reduced inter-header dependencies, which should improve
2381   compilation times for TAO and TAO applications.
2383 . Fixed memory leak in CDR encapsulation Codec's encode_value() method.
2385 . Modified PerlACE scripts for Tests/test environment to allow
2386   per-platform customization of process startup delay.  Used the changes
2387   in various run_test scripts.
2389 . SyncScope::NONE blocks during connects [Bug 1476].
2391 . Improved compatibility with JDK orb.
2393 . Added Wait on LF No Upcalls (MT_NOUPCALLS) wait strategy.  However,
2394   recent experiences with it indicate there may be problems in scenarios
2395   other than its original motivating case (see ChangeLog).  This feature
2396   should be considered EXPERIMENTAL, and use it at your own risk.
2398 . New CORBALOC parsing is available. This feature allows TAO clients to
2399   use any third-party pluggable protocol in corbaloc strings.
2401 . Fixed bug that caused memory fault when incoming object reference
2402   contains an unknown profile.
2404 . Fixed problem in some modules when platform lacks unsigned long long
2405   support.
2407 . Modified catior to allow decoding of additional protocols.
2409 . The PortableServer library isn't depended anymore on the
2410   ObjRefTemplate and IORInterceptor libraries.  ObjRefTemplate and
2411   IORInterceptor are loaded on demand and depend on PortableServer.
2413 . IDL compiler can be built for environments that lack unsigned long
2414   long.
2416 . Reduced the amount of code generated by the TAO_IDL compiler when
2417   using forward declarations.
2419 . Naming Service implementation memory leak fixes.
2421 . Split ORB Services into stub, skeleton, and implementation libraries.
2422   Changes to the Naming, Trading, Event, Notification, and Logging
2423   Services have been committed.
2425 . Common utilities (tao_imr, tao_ifr, nslist, nsadd, nsdel,
2426   NamingViewer) now installed in $ACE_ROOT/bin.
2428 . Changed #includes of orbsvcs header files to be consistent.  The
2429   pathname now always contains a "orbsvcs/" prefix.
2431 . Notification Service EventReliability and ConnectionReliability QoS
2432   have been added to bring the DOC version of Notification Service
2433   into feature parity (in this area) with OCITAO's 1.3a version of the
2434   Notification Service.  Note that due to changes between 1.3a's
2435   source base and DOC's 1.4.3 source base, this is a re-implementation
2436   of the changes and not a simple port.
2438   In addition to the changes made directly to the Notification Service
2439   a number of test and example programs have been created for the
2440   reliable notification service. These programs may be found in
2441   subdirectories of $TAO_ROOT/orbsvcs/tests/Notify. A README file
2442   in each directory provides more detailed information, and a run_test.pl
2443   script is included to run the example or test.
2445 . A change has been made to the Notification Service IDL to improve build
2446   times and reduce the Notification Service footprint. The change suppresses
2447   the generation proxy and stub code for the many interfaces that are
2448   specified by the OMG, but are not implemented in TAO.
2450 . Implementation Repository refactored to allow the locator and
2451   activator to be used as services in the ACE Service Configurator
2452   framework.  The locator and activator services have been split into
2453   separate libraries and executables.  There have also been
2454   miscellaneous bugs fixed and performance enhancements made.
2456 . Fixed Load Balancer binary generation problem.  Libraries were being
2457   created rather than executables.
2459 . Work around MSVC++ 6 namespace brain damage in new Security/SSLIOP
2460   code.
2462 . Fixed memory management problem in SecurityLevel3 code.
2465 USER VISIBLE CHANGES BETWEEN TAO-1.4.1 and TAO-1.4.2
2466 ====================================================
2468 . Overall
2469   - Support for g++ 3.4.1.
2470   - Support added for latest HP aCC compiler.
2471   - Improved Doxygen documentation.
2472   - Reduced header file dependencies, which should speedup compilation
2473     and help minimize static footprint.
2475 . ORB
2476   - Fixed memory leak in DII exception handling.
2477   - Fixed insertion of label values when creating a union type code
2478     with create_union_tc().
2479   - Support for retrieving AMI and AMH reply handlers from a local
2480     memory pool.
2481   - Fixed location forwarding to collocated objects.
2483 . POA
2484    It is now possible to pass user-defined policies unknown to the
2485     POA with corresponding registered policy factories to the
2486     POA::create_POA() method via its policy list parameter, as
2487     required by the CORBA specification.
2489 . TAO_IDL
2490   - Closed security hole on platforms that support mkstemp() function.
2491   - Fixed potential buffer overrun problem.
2492   - A number of scoped name bugs have been fixed, including some
2493     workarounds for MSVC++ 6 scope resolution problems.
2494   - Fixed mixing of *Implicit and *Explicit inheritance lines when the
2495     there is a chain of inheritance in component homes.
2496   - Improved error checking of component and home declarations.
2497   - Code generation for valuetypes that support one or more abstract
2498     interfaces.
2499   - Added new "-GA" option that causes CORBA::Any operators and
2500     TypeCode bodies to be generated in a separate "fooA.cpp" file.
2501     Helps reduce footprint for applications that do not use Anys or
2502     TypeCodes.
2503   - Added required _downcast() method to generated value factories.
2504   - Disabled generation of implementation class for abstract
2505     interfaces.
2506   - Removed support for reading an IDL file from stdin.  This feature
2507     is legacy code used for debugging the IDL compiler in the early
2508     days of its implementation, and is not useful in application
2509     situations.
2510   - Generated stub/skeleton inline files now end in ".inl" instead of
2511     ".i".  The latter is generally used as the extension for
2512     pre-processed C sources.
2513   - Process multiple IDL files in a single execution by iteration
2514     in a single process, rather than spawning a process for each
2515     file as before.
2516   - Added the remaining spec-defined sequences of predefined types
2517     to the CORBA namespace in TAO.
2519 . Added CPU utilization load monitor to TAO's Cygnus load balancer.
2521 . Added basic CSIv2 support, which is the latest CORBA Security
2522   architecture specification.
2524 USER VISIBLE CHANGES BETWEEN TAO-1.4 and TAO-1.4.1
2525 ==================================================
2529 .  Changed the name of a parameter to the TAO type code
2530    internal method to avoid a name clash with STL.
2532 . Added the spec-required ostream insertion operator for
2533   CORBA::Exception* to go with the existing ostream
2534   insertion operator for CORBA::Exception&.
2536 . Moved the above ostream insertion operators into the
2537   CORBA namespace, so they cannot be accidentally hidden by an
2538   application.
2540 . Moved the declaration of Any operators for some ORB
2541   types so that the corresponding definitions may
2542   remain unlinked if the Any operators are not used in
2543   an application.
2545 . Fixed typo in type code factory code that is compiled
2546   only when ACE_SWAP_ON_WRITE is defined.
2548 . Several fixes to MakeProjectCreator (MPC) files, which
2549   generate GNU makefiles, Borland makefiles, and Microsoft
2550   Visual Studio project files.
2552 . Fixed Any insertion and extraction operators for bounded
2553   strings and wstrings to prevent an error if they are
2554   inserted as bounded with bound 0 and extracted as
2555   unbounded, or vice versa.
2557 . Deprecated the TAO-specific _type() method for exceptions.
2558   which is no longer used anywhere in TAO, and is retained
2559   solely for backward compatibility.
2561 . Fixed bug in TAO_SSLIOP pluggable protocol that prevented large
2562   requests from being sent.  [Bug 1429]
2564 . Cleaned up interceptor memory leaks that occurred when
2565   CORBA::ORB::destroy() was called.
2567 . Fixed problem where a ServerRequestInterceptor could be called after
2568   the ORB was shutdown.  [Bug 1642]
2570 . Overhauled PICurrent support to fix several problems. [Bug 1215, 1738]
2572 . SSLIOP documentation is now available.
2574 . Fixed memory leaks in servers when the ORB is operating in a
2575   thread-per-connection  mode. This problem showed up when clients
2576   keep connecting and disconnecting from the servers.
2578 . Fixed memory leaks in AMI clients that connect to a servers over
2579   unreliable connections that keeps getting dropped.
2581 . Fixed a race connection in Any_Impl implementation.
2583 . Fixed a byte order problem with DSI gateways
2585 . Added support for OVATION to work with this BFO of TAO.
2587 IDL COMPILER
2588 -------------
2590 . Changed the names of some local variables in generated
2591   operation code, to reduce that chance of a name clash.
2593 . Fixed bug where a #pragma version directive is sometimes
2594   not reflected in the generated repository id.
2596 . Disambiguated generated template instantiations for array
2597   _var, _out and _forany classes, when two or more arrays
2598   have the same element type and bound.
2600 . Added check for a name clash between a valuetype member
2601   and the first segment of a scoped name referenced in
2602   the valuetype.
2604 . Fixed incorrect code generation for the CDR operator of a
2605   struct/union/exception with an undefined forward declared
2606   interface member.
2608 . Fixed incorrect code generation for operation arguments
2609   that are typedefs of char, octet and boolean.
2611 . Fixed bug in handling complex recursive types.
2613 . Added -GId command line option to generate line and
2614   file debug info in *I.* files, similar to what is
2615   already generated in *C.* and *S.* files. This debug
2616   info generation is now off by default in *I.* files.
2618 . Fixed the handling of included orb.idl file to generate
2619   corresponding C++ includes for the files orb.idl
2620   itself includes, which contain spec-required declarations
2621   of sequences of basic CORBA types.
2623 . Fixed generation of ORB file includes triggered by the
2624   presence of one or more abstract interfaces in an IDL file.
2626 . Added check to the generation of _setup_collocation()
2627   method for abstract interfaces, to make it more robust.
2629 . Added a version of the realpath() system function that
2630   can be used with LynxOS, which does not have a native
2631   version.
2633 . Fixed code generation for bounded strings and wstrings
2634   when they appear anonymously (without a typedef) as operation
2635   parameters.
2637 . Fixed code generation of flat names for AMI-related types.
2639 . Fixed errors in code generation of sequences of components
2640   and eventtypes.
2642 . Fixed code generation of CDR operators for aggregate types
2643   that contain one or more abstract interfaces.
2645 . Fixed bogus errors produced when there are repeated forward
2646   declarations of an interface.
2648 . Fixed errors in some use cases of the propagation of a #pragma
2649   prefix directive to nested scopes in generated repository ids.
2651 . Fixed errors in code generation for attributes in Asynchronous
2652   Method Handler (AMH) classes.
2654 . Fixed a bug that caused the IDL compiler to crash when it sees
2655   certain kinds of illegal IDL.
2657 . Fixed problems in the interaction of checks for local interface
2658   and for null object reference when marshaling an interface
2659   member of an aggregate type.
2661 . Fixed generation of operations inherited by a local interface
2662   from a non-local one - these operations must be regenerated
2663   as pure virtual.
2665 . Added a space between some generated template parameter
2666   opening brackets and a leading double colon of a fully
2667   scoped name, since some compilers would read "<:" as
2668   the digraph character for ']'.
2670 . Fixed bug in code generation for an array of typedef of
2671   string and wstring.
2673 . Fixed a bug in the generation of repository ids for
2674   explicit, implicit and equivalent interfaces for component
2675   homes.
2677 . Fixed bugs in the generation of marshaling and demarshaling
2678   code for aggregate types with component or eventtype members.
2680 ORB SERVICES:
2681 -------------
2683 IFR:
2686 . Fixed bug in creating entries for attributes, which in CORBA 3.x may
2687   have separate get- and set- exceptions lists.
2689 . Added some method overrides to disambiguate multiple inheritance
2690   problems some compilers would have in classes added to support CORBA
2691   3.0 extensions.
2693 . Fixed bugs in entering attributes of abstract and local interfaces,
2694   and in querying for attributes of components.
2696 . Added a "-m" option to IFR_Service to enable multicast discovery of
2697   the service.
2699 LOAD BALANCING
2700 --------------
2702 . Added two new strategies, namely LoadAverage and LoadMinimum.
2704 NOTIFICATION SERVICE:
2705 ---------------------
2706 . Corrected the implementation to add the caller's <subscribed_types>
2707   to the Admin Object's types. This solves the problem that if a
2708   proxy's connect_structured_push_consumer() is called *AFTER* the
2709   proxy's subscription_change(), then the subscriptions do not work.
2711 . Added the -NoUpdates option to the Notification svc.conf
2712   options. If this option is specified, the
2713   subscription_change/offer_change messages are NOT sent to proxy
2714   objects.  This option is useful to turn off entire updates for
2715   applications that do not reply on subscription_change/offer_change
2716   messages.
2719 USER VISIBLE CHANGES BETWEEN TAO-1.3.6 and TAO-1.4
2720 ==================================================
2722 IDL COMPILER:
2723 -------------
2724 . Fixed bug related to the order of #pragma prefix and #include
2725   directives
2727 . Fixed bug in generation of copy constructor for AMH interface
2728   classes.
2730 . Fixed incorrect handling of a parameter name in an AMI sendc_xxx
2731   operation that clashes with a C++ keyword.
2733 . Readded the generation of _unchecked_narrow () back into the stub
2734   code since it is required by the latest OMG CORBA specification.
2736 CORE ORB
2737 -------
2739 . SCIOP endpoints are not created by default. They need explicit
2740   specification of -ORBEndpoint sciop:// at startup.
2742 . Fixed a bug that caused the ORB to dump a core when server side
2743   interceptors returns an exception and if the operation parameters
2744   contains a sequence an out parameter.
2746 . Fixed a bug that caused extraction of basic data types that are
2747   aliased from an Any.
2749 . Added a couple of regressions tests for some of AMH features.
2751 . Lots of other bug fixes (see the bottom of this message for a
2752   complete list of bugzilla bugids fixed in this beta).
2754 . Fixed a problem with dynamic loading of the ORB. This was introduced
2755   by "magic" static constructors in the TAO PortableServer headers
2756   where dynamic loading/unloading of the ORB failed.
2758 . Added an option, -ORBDisableRTCollocation which allows users to
2759   disable the RT collocation technique used by TAO and fall back on the
2760   default collocation technique used for the vanilla ORB.
2762 . Prevent the TP_Reactor used within TAO from exiting when it receives
2763   a EINTR during select ().
2765 ORB SERVICES
2766 ------------
2768 . Added new security variable so that libTAO_Security could be built
2769   independently of libTAO_SSLIOP, and set the default to true.
2771 . An initial implementation of the FTCORBA spec has been added to
2772   TAO. This release features an initial cut of ReplicationManager,
2773   FaultNotifier, and a FaultDetector. Please see
2775   $TAO_ROOT/orbsvcs/tests/FT_App/README
2777   for a simple example that uses the different FTCORBA features that
2778   have been implemented in TAO.
2780 . Fixed a bug, in PG_ObjectGroupManager::remove_member () methods
2781   which caused the group entry to be available in the location_map
2782   when a member of the object group is removed.