Yaml fix
[ACE_TAO.git] / TAO / NEWS
blob0c3828c2eeaaa079d5e2c78f5f07b03dbc734bdb
1 USER VISIBLE CHANGES BETWEEN TAO-2.5.11 and TAO-2.5.12
2 ======================================================
4 USER VISIBLE CHANGES BETWEEN TAO-2.5.10 and TAO-2.5.11
5 ======================================================
7 . Simplified some code generated by tao_idl
9 USER VISIBLE CHANGES BETWEEN TAO-2.5.9 and TAO-2.5.10
10 =====================================================
12 . TAO IDL Frontend annotation support extended: (#1125)
13   . All the direct contents of interfaces
14   . Porttypes, eventtypes, components, and all their direct contents
15   . Valuetypes and most of their direct contents
17 . TAO IDL now supports anonymous types when using IDL4. (#1135)
19 USER VISIBLE CHANGES BETWEEN TAO-2.5.8 and TAO-2.5.9
20 ====================================================
22 . With C++11 we are now using (u)int8/16/32/64 to map all
23   CORBA types
25 USER VISIBLE CHANGES BETWEEN TAO-2.5.7 and TAO-2.5.8
26 ====================================================
28 . Fixed handling of transient errors with DII requests
30 . Renamed `VERSION` file to `VERSION.txt` to avoid conflicting with the
31   `version` standard header.
33 USER VISIBLE CHANGES BETWEEN TAO-2.5.6 and TAO-2.5.7
34 ====================================================
36 . Fixed deprecated-copy warnings in TAO_IDL generated code
38 . The TAO IDL Frontend now supports annotations on interfaces, operations, and
39   attributes. (#967)
41 . `idl_global->eval` in the TAO IDL Frontend will now produce error and warning
42   messages. This can be silenced by passing `true` as a second argument. (#967)
44 . Expanded documentation on what can be annotated and roughly how to extend
45   annotation support in `TAO_IDL/docs/annotations.md`. Also made various
46   corrections. (#967)
48 . Fixed invalid free in the TAO IDL Frontend while parsing an IDL wstring
49   literal. (#984)
51 USER VISIBLE CHANGES BETWEEN TAO-2.5.5 and TAO-2.5.6
52 ====================================================
54 . Fixed race condition in ImplRepo on server shutdown/restart (#889)
56 USER VISIBLE CHANGES BETWEEN TAO-2.5.4 and TAO-2.5.5
57 ====================================================
59 . Fixed Memory Leaks in TAO_IDL caused by the addition of Annotations (#811)
61 . Changes in the Annotations API in TAO_IDL, see
62   TAO/TAO_IDL/docs/annotations.md section titled "TAO 2.5.5" for details.
64 USER VISIBLE CHANGES BETWEEN TAO-2.5.3 and TAO-2.5.4
65 ====================================================
67 . Enhanced the ImR to better handle a huge number
68   of servers which use the ImR heavily and each of
69   them does a frequent shutdown/start cycle
71 . The TAO_IDL frontend library now parses all IDL4
72   annotation-related syntax: using and defining annotations.
73   Use the tao_idl command-line options --idl-version and
74   --unknown-annotations to control annotation parsing.
75   Documentation on this feature is located in
76   TAO/TAO_IDL/docs/annotations.md.
78 . TAO_IDL now will return an error status code when
79   passing an invalid command line argument.
80   Backends will have to support this behavior
81   explicitly, see TAO/TAO_IDL/include/idl_defines.h
82   for details.
83   TAO_IDL also accepts new options such as -h,
84   --help, --version, and --syntax-only, the latter
85   of which won't generate any files, just check
86   syntax of the IDL file(s).
87   See tao_idl -h for details.
89 . When using IDL_Files in MPC, generated files will
90   now be placed in the current directory by default,
91   instead of the directory of the IDL file.
92   Use
93     idlflags += -o <IDL_FILE_DIR>
94     gendir = <IDL_FILE_DIR>
95   to output generated files to where the IDL file
96   is.
98 USER VISIBLE CHANGES BETWEEN TAO-2.5.2 and TAO-2.5.3
99 ====================================================
101 . Enhance ssliop and uiop corbaloc parsers
103 USER VISIBLE CHANGES BETWEEN TAO-2.5.1 and TAO-2.5.2
104 ====================================================
106 . Enhance logging within the ImR
108 . Enhance the behavior of the ImR with a per-client
109   activation mode and multiple clients starting in
110   parallel
112 . Modified the SSLIOP::Protocol_Factory::init to
113   process an "-SSLEcName" argument to set the ECDH
114   curve name.
116 USER VISIBLE CHANGES BETWEEN TAO-2.5.0 and TAO-2.5.1
117 ====================================================
119 . Make use of std::atomic when C++11 or newer is enabled
120   for the CORBA reference counting
122 USER VISIBLE CHANGES BETWEEN TAO-2.4.8 and TAO-2.5.0
123 ====================================================
125 . The TAO core libraries now use std::unique_ptr instead
126   of std::auto_ptr when C++11 or newer is enabled
128 USER VISIBLE CHANGES BETWEEN TAO-2.4.7 and TAO-2.4.8
129 ====================================================
131 . Logging enhancements to the TAO core for some possible
132   error situations
134 USER VISIBLE CHANGES BETWEEN TAO-2.4.6 and TAO-2.4.7
135 ====================================================
137 . TAO_IDL parses and discards IDLv4 annotations (applying, not defining)
139 . Fixed Bug 1220 as it applies to the SHMIOP transport.
141 USER VISIBLE CHANGES BETWEEN TAO-2.4.5 and TAO-2.4.6
142 ====================================================
144 . Added support for IPv4-mapped IPv6 addresses in BiDirGIOP+SSLIOP.
146 . Fixed Bug 1220 as it applies to the SSLIOP transport.
148 USER VISIBLE CHANGES BETWEEN TAO-2.4.4 and TAO-2.4.5
149 ====================================================
151 . Extended TAO_IDL with a new -Gsd which enabled the generation of two
152   additional static operations for each interface. _desc_repository_id to
153   retrieve the repository id as string, second _desc_interface_name to
154   return the interface name. Both can be useful in template meta programming
155   use cases where we want to use the repository id or interface name
156   of a specific type.
158 USER VISIBLE CHANGES BETWEEN TAO-2.4.3 and TAO-2.4.4
159 ====================================================
161 . Minor cleanup and fixes to the code generated by TAO_IDL
163 USER VISIBLE CHANGES BETWEEN TAO-2.4.2 and TAO-2.4.3
164 ====================================================
166 . Added enhanced hot-standby feature to FT_Naming_Service. Use
167   tao_ft_naming -h to get a list of new configuration options.
168   This feature addresses performance problems on heavily loaded systems.
170 USER VISIBLE CHANGES BETWEEN TAO-2.4.1 and TAO-2.4.2
171 ====================================================
173 . Fixed some problems with versioned namespaces in the
174   tao_idl generated code
176 . Removed the non-const Any extraction operators which
177   are deprecated within the IDL to C++ specification
178   for a long time. Reduces footprint and simplifies the
179   code. Make sure you are using 'const Foo*' as extraction
180   type for Foo instead of 'Foo*'.
182 USER VISIBLE CHANGES BETWEEN TAO-2.4.0 and TAO-2.4.1
183 ====================================================
185 . Reduced amount of warnings given by newer gcc/clang
186   versions on the generated tao_idl code
188 USER VISIBLE CHANGES BETWEEN TAO-2.3.4 and TAO-2.4.0
189 ====================================================
191 . None
193 USER VISIBLE CHANGES BETWEEN TAO-2.3.3 and TAO-2.3.4
194 ====================================================
196 . ImR enhancement - Added a "force remove" option to the Implementation repository
197   that will remove a server entry from the ImR Locator repository and kill any
198   running instance with a single command.
200 . ImR enhancement - Fix to allow very large ( > 4K ) command line.
202 . ImR enhancement - Enhance the coordination between the Locator and the Activator
203   to tolerate running on heavily loaded systems, in particular when a server process
204   is slow to shut down, and a new server is started before the shutdown is complete
206 . LogWalker utility improvements for handling truncated GIOP buffer dumps, added
207   tracking thread first/last contact times.
209 . Fault-Tolerance improvement - Optimize performance on NFS mounted filesystems. First
210   a deadlock is resolved. Second, use of writer locks is minimized to only when writing
211   is necessary. Third, NFS occasionally causes transient EBADF errors on access, so
212   file access that results in a bad file error is retried before the error is reported
213   to the application.
215 USER VISIBLE CHANGES BETWEEN TAO-2.3.2 and TAO-2.3.3
216 ====================================================
218 . Extended SL2 Security Manager to easily allow non-secure collocated
219   invocations but still disallow non-secure remote invocations
221 . Relaxed upper limit on POA Thread pool size.
223 . Fixed PICurrent improper reset issue. Now slot data is retained through an
224   ImR forced retry.
226 . Bugzilla #4205 fixed.
228 . Defaulted IIOP endpoints on IPv6 enabled systems will no longer append localhost
229   to the IOR if there are no routable IPv6 addresses but there are routable IPv4
230   addresses available.
232 . Improved the performance of the FT-ImR while under very heavy loads.
234 . ImR now may be built on "uses_wchar" platforms.
236 . The temporary directory used by the tao_idl preprocessor may now
237   contain spaces.
239 USER VISIBLE CHANGES BETWEEN TAO-2.3.1 and TAO-2.3.2
240 ====================================================
242 . New SSLIOP Factory option -SSLPassword <password descriptor> facilitates
243   distributing password protected private keys.
245 . New SSLIOP Factory option -SSLVersionList <list> constrains the list of
246   cypher versions allowed.
248 . New SSLIOP Factory option -SSLCheckHost enables a second layer of
249   authentication by comparing the sending hostname to the name or names in
250   the supplied certificate
252 USER VISIBLE CHANGES BETWEEN TAO-2.3.0 and TAO-2.3.1
253 ====================================================
255 . TAO is now hosted on github (https://github.com/DOCGroup/ATCD).
256   As part of the release process we now generate a ChangeLog
257   for each release which is stored in the ChangeLogs directory
259 . Fixed incorrect server status shown by tao_imr after a
260   crashed server has been given a shutdown command
262 USER VISIBLE CHANGES BETWEEN TAO-2.2.8 and TAO-2.3.0
263 ====================================================
265 . New feature added to constrain client ORBs using IIOP to only use local TCP
266   ports spanning a supplied range. Use new ORB_init parameters
267   -ORBIIOPClientPortBase <base> and -ORBIIOPClientPortSpan <count> to specify
268   a range from base to base + count. A base supplied without a span indicates
269   the client may use only a single port. A span supplied without a base is
270   silently ignored.
272 . Fixed the manual activation mode of the Implementation Repository
274 . Reintroduced the restart attempt limiting of the Implementation Repository
276 . Fix a connection leak that occurred when the server side cache purged a
277   Thread-Per-Connection managed entry.
279 USER VISIBLE CHANGES BETWEEN TAO-2.2.7 and TAO-2.2.8
280 ====================================================
282 . Address a problem with Failover between primary and backup ImplRepo locators.
283   Access state information is now shared during a server restart allowing a client
284   to request a new server from either the ImR instance.
286 USER VISIBLE CHANGES BETWEEN TAO-2.2.6 and TAO-2.2.7
287 ====================================================
289 . Improved the performance of the load balancing feature of the tao_ft_naming
290   service. Now a global load balancing strategy may be set via the command line
291   using the new -l ["random"|"round_robin"] argument. The newly implemented
292   random strategy is lockless.
294 . Fixed active server detection when switching from the primary ImR locator to
295   the backup.
297 . Added a new command for the windows NT Naming service CLI to set the service's
298   start up argv list without invoking regedit.
300 . Added a new command for the windows NT Notify service CLI to set the service's
301   start up argv list without invoking regedit.
303 USER VISIBLE CHANGES BETWEEN TAO-2.2.5 and TAO-2.2.6
304 ====================================================
306 . Fix bug with mt_noupcall that allowed upcalls while waiting for a new connection
308 . Improved the performance of dynamic thread pool when activating new threads
310 . Improved the performance of the SYNC_WITH_SERVER oneway synchronization when
311   used in conjunction with the CSD framework and POA thread pools
313 . Fix support for long double types when used with dynamic Anys
315 . Improve functionality and stability of running tests on
316   Android Virtual Device (AVD).
318 USER VISIBLE CHANGES BETWEEN TAO-2.2.4 and TAO-2.2.5
319 ====================================================
321 . Implementation Repository new features added.
322   - New tao_imr kill command to signal an otherwise unresponsive server.
323   - New tao_imr link command to identify groups of POAs that share a server.
324   - ImR is better able to avoid errantly starting multiple server instances.
326 . Added support for Embarcadero C++Builder XE5 using
327   bcc32 in debug and release mode
329 . Added support for Embarcadero C++Builder XE6 using
330   bcc32 in debug and release mode
332 USER VISIBLE CHANGES BETWEEN TAO-2.2.3 and TAO-2.2.4
333 ====================================================
335 . Added a new Client Strategy Factory option, -ORBDefaultSyncScope which
336   takes the label "None", "Transport", "Server", or "Target" to define the
337   sync scope to be used when a Messaging SyncScopePolicy is not in use.
339 . Improved recursive typecode handling
341 . Ended maintenance for Solaris 10 with Sun Studio
343 USER VISIBLE CHANGES BETWEEN TAO-2.2.2 and TAO-2.2.3
344 ====================================================
346 . Fix for extra CDR padding bytes following a request header when there are no
347   IN or INOUT arguments in the request. This happened when a request had at least
348   one OUT argument, and also had a service context that ended off a CDR alignment
349   boundary. While this is not a problem for TAO-TAO messaging, some non-TAO
350   servers will reject such requests with a MARSHAL exception. See bug 4141 for more
351   information.
353 USER VISIBLE CHANGES BETWEEN TAO-2.2.1 and TAO-2.2.2
354 ====================================================
356 . None
358 USER VISIBLE CHANGES BETWEEN TAO-2.2.0 and TAO-2.2.1
359 ====================================================
361 . Implementation Repository is better able to handle high request volume
362   particularly when registered servers are going up and down.
364 . Fixed several memory leaks in the Trading Service
366 . Added support for Embarcadero C++BuilderXE4 using
367   bcc32 in release mode
369 USER VISIBLE CHANGES BETWEEN TAO-2.1.9 and TAO-2.2.0
370 ====================================================
372 . Feature enhancement for the Implementation Repository, the command to
373   list currently active servers, confirmed with a ping, is now asynchronous
374   along with the rest of the implementation.
376 . Added the new -ORBListenerInterface UIPMC option to provide detailed control
377   over which IP interfaces are to be listened on for which mutlicast addresses.
378   This works in a similar way to the existing -ORBPreferredInterfaces
379   ORB_init command line option but for UDP server listeners instead of client
380   senders. See the TAO_UIPMC_Protocol_Factory section in the
381   docs/release/TAO/Options.html document for details. This option allows
382   UIPMC/MIOP to control which interfaces are used by the server to listen
383   for broadcast messages instead of only using the "default" interface.
385   If TAO is built with the #define TAO_ALLOW_UNICAST_MIOP in effect, the
386   normal error checking on joins is short circuited, such that MIOP can
387   be used to send to a unicast address instead of a broadcast group. In general
388   I would not recommend building TAO with this option set, end users should
389   concider using the DIOP protocol instead.
391 . Fix for long standing Valuetype non-conformance (Bugzilla_1391):
393   tao_idl generated ValueType OBV_* classes now also provide a
394   _copy_value() method where this class is supposed to be the final
395   "most derived" class. It is still left to the end user to provide
396   such a method in their own most derived class when this is not
397   the case (as only the final implimentation of the Valuetype will
398   know how this duplication is performed).
400   TAO can be built specifically to treat _copy_value() as a pure virtual
401   function (as per the standard, and now the default behaviour) or,
402   if #define TAO_VALUETYPE_COPY_VALUE_IS_NOT_PURE is defined during the
403   building of TAO, a non-pure virtual function (in which TAO does not
404   require an implimentation to provide the _copy_value() function as per
405   the previous TAO implimentations).
407   TAO doesn't normally use the _copy_value() fuction itself, but if
408   #define TAO_VALUETYPE_COPYING_ANY_INSERTION_USES_COPY_VALUE
409   is in effect during the build, valuetypes "copy" inserted into an any
410   will call _copy_value() instead of increasing the reference count of the
411   actual valuetype being "copied". In such cases obviosuly the _copy_value()
412   method is required to be implemented. There are problems taking this
413   general approach however, as the automatically generated _copy_value() is
414   not capable of duplicating cyclic graphs held in valuetypes, which
415   realistially require the reference counting insertions to be utalised
416   and/or knowledge of the actual use of the valuetype itself. This setting
417   is not recommended.
419 USER VISIBLE CHANGES BETWEEN TAO-2.1.8 and TAO-2.1.9
420 ====================================================
422 . High performance implementation Repository [#4104] - The Implementation
423   Repository Locator has been reimplemented using AMI/AMH to avoid the
424   problem of nested upcalls under heavy load.
426 USER VISIBLE CHANGES BETWEEN TAO-2.1.7 and TAO-2.1.8
427 ====================================================
429 . Fault Tolerant Implementation Repository [#4091] - The Implementation
430   Repository Locator now supports a dual-redundant fault tolerant
431   configuration which provides replication and seamless failover between
432   the primary and backup locator servers.
434 . Implementation Repository interoperable with JacORB servers [#4101] -
435   The Implementation Repository can now be used to manage JacORB
436   3.3 or later application servers.
438 . Fault Tolerant Naming Service [#4092 & #4095] - A new Fault Tolerant
439   Naming Service (tao_ft_naming), provides dual-redundant fault tolerant
440   servers which utilize replication and seamless failover between the
441   primary and backup server. The Fault Tolerant Naming Service can be
442   used to provide load balancing capabilities (only the round-robin load
443   balancing strategy is currently supported) through the use object groups.
444   This feature is supported by a separate utility for managing the object
445   groups (tao_nsgroup) as well as a programatic interface via IDL.
447 . Configurable Persistence Mechanism [#4092] - Extracted persistence
448   mechanism used for storable naming context into Storable_* classes so
449   that it can be reused. Simplified use of storable read/write so that
450   it behaves more like C++ streams to read/write binary and CDR data.
451   Added support for creating a backup mechanism to accomodate
452   potentially corrupted files.  Providing configurable hooks so
453   applications can decide if files are obsolete and need to be written
454   to the persistence store.
456 . ORB Dynamic Thread Pool [#4093] - Added a new ORB thread pool strategy
457   to dynamically adjust the number of threads which the ORB uses to
458   service received calls based on several configuration parameters.
459   These parameters include initial threads, minimum pool threads,
460   maximum pool threads, request queue depth, thread stack size, and
461   thread idle time.
463 . POA Dynamic Thread Pool [#4094] - A new Dynamic Thread Pool and
464   Queuing strategy was created for POA usage. It leverages the
465   existing Custom Servant Dispatching framework for invocation and
466   activation. The strategy also dynamically adjusts the number of
467   threads using configuration parameters similar to the ORB Dynamic
468   Thread Pool. The Dynamic Thread Pool POA Strategy supports
469   applications in associating a single thread pool with either
470   1) a single POA in a dedicated configuration, or 2) multiple
471   POAs in a shared configuration.  The strategy controls a request
472   queue used to accept calls directed to an associated servant and
473   a pool of threads that wait to service calls coming in on a
474   particular queue.
476 . Multiple Invocation Retry [#4096] - Extended TAO to support multiple
477   retry in the presence of COMM_FAILURE, TRANSIENT, OBJECT_NOT_EXIST,
478   and INV_OBJREF exceptions. In addition, retries can occur if it has
479   been detected that a connection has closed while waiting for a reply
480   (currently not available under FreeBSD, OpenVMS, AIX, and Solaris). This
481   feature can be used to support fault tolerant services (specifically
482   the Fault Tolerant Naming and Implementation Repository services
483   described earlier).  The invocation retry support allows
484   configuration on how many times to try to connect to each server and
485   the delay between tries.
487 . Added MIOP configuration options -ORBSendThrottling and -ORBEagerDequeueing,
488   along with #define overrides for their default settings. See the descriptions
489   in the MIOP section of doc/Options.html for their use.
491 USER VISIBLE CHANGES BETWEEN TAO-2.1.6 and TAO-2.1.7
492 ====================================================
494 . Integrated several patches to simplify Debian/Ubuntu
495   packaging
497 . Fixed IDL compiler bug related to internal reinitialization
498   when processing multiple IDL files in a single execution.
500 USER VISIBLE CHANGES BETWEEN TAO-2.1.5 and TAO-2.1.6
501 ====================================================
503 . We only try to load the ObjRefTemplate library at POA
504   creation instead of trying to load it at each servant
505   activation
507 USER VISIBLE CHANGES BETWEEN TAO-2.1.4 and TAO-2.1.5
508 ====================================================
510 . None
512 USER VISIBLE CHANGES BETWEEN TAO-2.1.3 and TAO-2.1.4
513 ====================================================
515 . CORBA::string_dup() and CORBA::string_free() have been enhanced to use
516   non-allocated and shared static null strings. This allows for optimized
517   default null string initialization in CORBA string members and a
518   reduction in redundant dynamic memory management required for such.
519   This enhancement can be removed via the config.h by including
520     #define TAO_NO_SHARED_NULL_CORBA_STRING
522   NOTE that it is a (CORBA spec) requirement that all CORBA::strings are
523   deleted via the CORBA::string_free() and allocated via the
524   CORBA::string_dup() or CORBA::string_alloc() calls; you must not use
525   the c++ keywords new and delete[] directly. Previously it was possiable
526   to ignore this requirement, however if you do so now, this enhancement
527   for null strings will catch you out, as deleting these null
528   CORBA::strings will cause corrupt heap and/or segfaults.
530 . Add support for -ORBPreferredInterfaces option to UIPMC. The form follows
531   the same pattern as IIOP for IPv4 i.e. a local interface IP address should
532   be specified as the mapping. e.g. -ORBPreferredInterfaces 225.*=192.168.0.2.
533   For IPv6 the preferred interface should (neccessarily) be set as an interface
534   name (e.g. 'eth0' for linux, or 'Loopback Pseudo-Interface' on windows) or an
535   interface index number on windows. e.g. -ORBPreferredInterfaces FF01:*=eth0.
536   Also add support an -ORBListenOnAll 0|1 UIPMCFactory option that can
537   be specified in the svc.conf to make the acceptor listen on all multicast
538   enabled interfaces on platforms that this is not the default. This has been
539   observed to be required for the UIPMCAcceptor to open on the most recent
540   Linux distribs.
542   NOTE that there is an obvious elephant in the room in testing this option,
543   we can't rely on any build/test machine having more than one (or any?)
544   interfaces so the test (TAO/orbsvcs/tests/Miop/McastPreferredInterfaces),
545   such as it is, is relying on side effects which may not hold for all platforms.
546   Additionally the IPv6 behaviour isn't even consistent across platforms and
547   the build machines can't be relied upon to have a 'proper' (non-zero conf
548   link local) IPv6 configuration. Basically, if you want some confidence this is
549   actually working I'd advise testing this option before you use it, running it
550   on a machine with multiple interfaces with the debug level turned up.
552 . Enhanced the MIOP implementation; this protocol now supports MIOP message
553   fragmentation which is controlled via the new MIOP_Strategy_Factory.
554   For details see the MIOP_Strategy_Factory section in the docs/Options.html
555   document included with this distribution.
557 USER VISIBLE CHANGES BETWEEN TAO-2.1.2 and TAO-2.1.3
558 ====================================================
560 . Added OpenSSL configuration options SSLCipherList and
561   SSLServerCipherOrder to SSLIOP_Factory.  Allows SSL/TLS BEAST
562   exploit to be mitigated.
564 USER VISIBLE CHANGES BETWEEN TAO-2.1.1 and TAO-2.1.2
565 ====================================================
567 . Changed behavior of Receive-Wait client wait strategy with
568   ORBConnectionHandlerCleanup after oneway calls to register with
569   the reactor after the call to clean up after connection closure.
571 . Added an extension of the CosNotifyFilter::FilterFactory to
572   allow removal of filters created by the factory.  The extension
573   also has accessors for existing filters and ids.
575 USER VISIBLE CHANGES BETWEEN TAO-2.1.0 and TAO-2.1.1
576 ====================================================
578 . Correct ZIOP compression arbitration on the server reply
579   path. The server now responds with one of the clients
580   exposed compressors that the server also supports
581   according to the ZIOP specification.
583 . Enhanced the plugable transports such that the
584   send_message() api now provides an optional TAO_ServerRequest
585   object pointer to provide access to any client side
586   policies that are broadcast with each request. This enabled
587   the ZIOP compression correction to be coded.
589 USER VISIBLE CHANGES BETWEEN TAO-2.0.8 and TAO-2.1.0
590 ====================================================
592 . Added new rle compressor and enabled ZIOP by default
594 . Implimented DynValue, DynValueBox and DynValueCommon and their
595   creation/use by TAO_DynAnyFactory::
596     create_dyn_any (), create_dyn_any_from_type_code (),
597     create_dyn_any_without_truncation (), create_multiple_dyn_anys ()
598     and create_multiple_anys ().
600 . Correct the interaction of CORBA::ValueTypes and CORBA::Anys.
601     The insertion into an Any of a ValueType base pointer
602     used to set the Anys typecode to the fully derived valuetype.
603     This allowed the any to be marshaled correctly sending the
604     derived typecode and value over the wire. However it also
605     stopped the user from extracting the valuetype from the any
606     as the typecode for, or the actual pointer type being used for,
607     the extraction couldn't match the any's internal two different
608     types. The any's typecode is now simply set to match the base
609     pointer which allows for the correct insertion/extraction from
610     the any, whilst the marshalling code for anys containing
611     valuetypes now sends the fully derived typecode of the fully
612     derived data it is marshalling instead of the anys embedded
613     (possiably base valuetype) typecode.
615 USER VISIBLE CHANGES BETWEEN TAO-2.0.7 and TAO-2.0.8
616 ====================================================
618 . Added support for MPC's new feature that creates dependency files for IDL
619   files when generating '-type gnuace' projects. Turned off by default, it
620   can be enabled in a features file or on the command line with
621   '-features ace_idl_dependencies=1'.
623 . Fixed IDL compiler bug where a generated component servant method that
624   is called by the middleware to initialize a component's attributes
625   was not including attributes of supported interfaces.
627 USER VISIBLE CHANGES BETWEEN TAO-2.0.6 and TAO-2.0.7
628 ====================================================
630 . Added Time_Policy_Manager, a TIME_POLICY strategy manager configurable
631   through the service configurator framework.
632   This allows the dynamic configuration of the TIME_POLICY strategy used for
633   ORB timers and countdowns. TAO includes two default TIME_POLICY strategies as
634   statically linked service objects; TAO_System_Time_Policy_Strategy and
635   TAO_HR_Time_Policy_Strategy (the first being used as default strategy).
636   The docs/Options.html file describes the configuration options in detail.
637   Two new tests have been added exemplifying these new options; tests/Time_Policy
638   and tests/Time_Policy_Custom.
639   Furthermore two new compile time option macros have been added related to
640   TIME_POLICY strategies:
641   - TAO_USE_HR_TIME_POLICY_STRATEGY if defined will force the use of the new
642     TAO_HR_Time_Policy_Strategy as default time strategy instead of
643     TAO_System_Time_Policy_Strategy;
644   - TAO_HAS_TIME_POLICY if explicitly defined as 0 ('#define TAO_HAS_TIME_POLICY 0')
645     will build TAO without the new TIME_POLICY strategy support.
647 USER VISIBLE CHANGES BETWEEN TAO-2.0.5 and TAO-2.0.6
648 ====================================================
650 . Added new define TAO_DEFAULT_COLLOCATION_STRATEGY (default = thru_poa)
651   which is used as -ORBCollocationStrategy isn't specified.
653 . Added new -ORBCollocationStrategy best. TAO tries to perform the best
654   possible collocation, first direct if possible, then through_poa if possible
655   else no collocation.
657 . Enhanced the RW -ORBWaitStrategy and the EXCLUSIVE -ORBTransportMuxStrategy
658   to also work with AMI requests.
660 . mt_noupcall has been improved and generically speaking the handling of client
661   leader threads in LF has been improved and fixed of potential deadlock
662   situations
664 . The TAO skeletons got refactored to reduced footprint, a footprint saving
665   for the skeletons between 10 and 60% has been achieved. For the full
666   distribution including CIAO, DAnCE, OpenDDS, and DDS4CCM using RTI DDS this
667   resulted in a reduction of 650,000 lines of code. Also the S.inl files are
668   not generated anymore
670 USER VISIBLE CHANGES BETWEEN TAO-2.0.4 and TAO-2.0.5
671 ====================================================
673 . Updated several TAO tests for automatic testing on Android
675 USER VISIBLE CHANGES BETWEEN TAO-2.0.3 and TAO-2.0.4
676 ====================================================
678 . Added new IFR_Client_skel library that is now used by the IFR_Service
680 . Moved TAO_IDL generation of argument traits from the stub and
681   skeleton .cpp files to the corresponding .h files.
683 USER VISIBLE CHANGES BETWEEN TAO-2.0.2 and TAO-2.0.3
684 ====================================================
686 . Improved support for mt_noupcall but this is still not optimal due to a 2ms
687   wait delay
689 . Addressed several Coverity reported issues
691 USER VISIBLE CHANGES BETWEEN TAO-2.0.1 and TAO-2.0.2
692 ====================================================
694 . Remove support for already deprecated -ORBConnectionCachingStrategy
696 . Removed -ORBObjectKeyTableLock and -ORBPOALock, very risk options and this
697   way the regular invocation path can be optimized much more
699 . Improved support for mt_noupcall wait strategy. Upcall detection has been
700   improved and the transport is polled each 2ms to see if we can do the
701   upcall.
703 . Improved performance of the Parallel Connect Strategy in TAO.
705 . tao_catior does a better job with JacORB generated IORs.
707 . tao_cosnaming can now be multithreaded.
709 USER VISIBLE CHANGES BETWEEN TAO-2.0.0 and TAO-2.0.1
710 ====================================================
712 . Fixed IDL compiler bug that caused illegal references to items
713   in the scope of a template module to be overlooked.
715 USER VISIBLE CHANGES BETWEEN TAO-1.8.3 and TAO-2.0.0
716 ====================================================
718 . Improved support for abstract
720 USER VISIBLE CHANGES BETWEEN TAO-1.8.2 and TAO-1.8.3
721 ====================================================
723 . TAO IDL compiler now generates attribute members for generated CCM
724   executor implementation classes, as well as full implementations for
725   the associated set/get operations.
727 . Add TAO IDL compiler command line option -iC, which overrides the
728   default include path (current directory or $TAO_ROOT/tao) for
729   *C.h files included in generated *A.h files.
731 . Removed autoconf support for TAO, it is really not tested, unstable, and
732   unmaintainable at this moment
734 . The TAO IDL compiler now gives the following error when anonymous
735   types are used: 'anonymous types are deprecated by OMG spec'.
736   One can changes this error into a warning. There's also a possibility
737   to silence the TAO IDL compiler about this message. One of the following
738   defines can be added to your config.h file in order to change the behavior
739   of the TAO IDL compiler:
740   * IDL_ANON_ERROR:   The TAO IDL generates an error when it encounters
741                       an anonymous type (default behavior).
742   * IDL_ANON_WARNING: The TAO IDL generates a warning when it encounters
743                       an anonymous type.
744   * ANON_TYPE_SILENT: The TAO IDL doesn't generate a warning nor an error
745                       when it encounters an anonymous type.
747 . Renamed ALL ORB services executables. This because of
748   the fact that the TAO ORB services should be recognizable
749   between the ORB services of other CORBA vendors. There are
750   systems where ORB services of several CORBA vendors are
751   installed (mainly via the installed packages). The following
752   rename actions have been taken place:
753   * 'LifeCycle_Service'       to 'tao_coslifecycle'
754   * 'Dump_Schedule'           to 'tao_dump_schedule'
755   * 'NT_Notify_Service'       to 'tao_nt_cosnotification'
756   * 'Notify_Service'          to 'tao_cosnotification'
757   * 'FT_ReplicationManager'   to 'tao_ft_replicationmanager'
758   * 'IFR_Service'             to 'tao_ifr_service'
759   * 'TAO_Service'             to 'tao_service'
760   * 'Fault_Detector'          to 'tao_fault_detector'
761   * 'Scheduling_Service'      to 'tao_cosscheduling'
762   * 'Basic_Logging_Service'   to 'tao_tls_basic'
763   * 'Notify_Logging_Service'  to 'tao_tls_notify'
764   * 'Event_Logging_Service'   to 'tao_tls_event'
765   * 'RTEvent_Logging_Service' to 'tao_tls_rtevent'
766   * 'Naming_Service'          to 'tao_cosnaming'
767   * 'NT_Naming_Service'       to 'tao_nt_cosnaming'
768   * 'CosEvent_Service'        to 'tao_cosevent'
769   * 'Event_Service'           to 'tao_rtevent'
770   * 'LoadManager'             to 'tao_loadmanager'
771   * 'LoadMonitor'             to 'tao_loadmonitor'
772   * 'Trading_Service'         to 'tao_costrading'
773   * 'Time_Service_Server'     to 'tao_costime_server'
774   * 'Time_Service_Clerk'      to 'tao_costime_clerk'
775   * 'ImplRepo_Service'        to 'tao_imr_locator'
776   * 'ImR_Activator'           to 'tao_imr_activator'
777   * 'Fault_Notifier'          to 'tao_fault_notifier'
778   * 'Concurrency_Service'     to 'tao_cosconcurrency'
780 . Fixed several bugs related to recursive typecodes
782 USER VISIBLE CHANGES BETWEEN TAO-1.8.1 and TAO-1.8.2
783 ====================================================
785 . Extended logging related to the POA active object map
787 USER VISIBLE CHANGES BETWEEN TAO-1.8.0 and TAO-1.8.1
788 ====================================================
790 . IDL compiler
792   - Added code generation for an empty implementation of
793     the reply handler interface generated as part of an
794     AMI4CCM connector, triggered by the same option, -Gex,
795     that generates a similar implementation for a
796     component executor.
798   - Added flags that can be defined in config.h to output
799     an error or warning if an anonymous IDL construct is
800     seen by the IDL compiler. Also added IDL compiler
801     options to do the same (or override a global flag)
802     for individual IDL files.
804 USER VISIBLE CHANGES BETWEEN TAO-1.7.9 and TAO-1.8.0
805 ====================================================
807 . Added minimal exploratory support for alternate IDL->C++
808   mapping: IDL string->std::string and IDL sequence->std:vectors.
809   We are talking with sponsors to see if we can raise funds
810   to make a full new IDL to C++ mapping proposal that uses
811   all new C++0x features
813 . Fixed bugzilla #3853.
815 . Improved the speed of tao_idl when processing
816   large input files with many module re-openings.
818 . Removed MCPP support from TAO_IDL.
820 . Extended support for CIAO DDS4CCM and AMI4CCM in TAO_IDL
822 USER VISIBLE CHANGES BETWEEN TAO-1.7.8 and TAO-1.7.9
823 ====================================================
825 . TAO's default makefiles (traditional ACE/GNU, not autoconf/automake)
826   now support installation with "make install".
827   Please see the ACE-INSTALL.html file for instructions.
829 . Refactored several parts of TAO_IDL
831 USER VISIBLE CHANGES BETWEEN TAO-1.7.7 and TAO-1.7.8
832 ====================================================
834 . Added -ORBHandleLoggingStrategyEvents option. Given
835   that ORB is run in user application this option allows
836   to easily add log file rotation.
838 . Added a new option -ORBIgnoreDefaultSvcConfFile.
839   This allows TAO to ignore only svc.conf file while
840   processing normally other user provided configuration
841   files or directives.
843 USER VISIBLE CHANGES BETWEEN TAO-1.7.6 and TAO-1.7.7
844 ====================================================
846 . Add IDL3+ support to TAO_IDL
848 . Cleanup in TAO_IDL. Part of this cleanup closes
849   (Bugzilla 2200).
851 USER VISIBLE CHANGES BETWEEN TAO-1.7.5 and TAO-1.7.6
852 ====================================================
854 . Added support for iPhone/iPod Touch/iPad. The following
855   environment variables are needed:
857   IPHONE_TARGET, should be set to either SIMULATOR or
858   HARDWARE. Set to HARDWARE if you want to deploy
859   on the iPhone/iPod Touch/iPad device.
861   IPHONE_VERSION, should be set to 3.1.2 or 3.2. One can
862   set the version to any future or past versions, but
863   only 3.1.2 and 3.2 have been tried.
865   Note that one has to compile ACE/TAO statically as
866   it is believed that the iPhone OS does not support
867   dynamic loading of external libraries. The usual
868   procedure of cross compiling ACE/TAO applies
869   (such as setting HOST_ROOT environment variable).
871 . Added support for IDL template modules in the IDL
872   compiler front end. This is partly tested, some
873   parts do work, some not yet
875 . Fixed bug in optional ostream operator generation
876   for IDL arrays.
878 . Added member validation feature to LoadBalancer.
880 . Add support for valuetype repository id and value
881   on both input and output streams.
883 . Added support for Embarcadero C++ Builder 2010
885 . Added method TAO_Leader_Follower::set_new_leader_generator().
887 . Fixed missing request id in logging of LocateRequest/LocateReply &
888   CancelRequest.
890 . Fixed problems with ORB shutdown in combination with active
891   requests.
893 USER VISIBLE CHANGES BETWEEN TAO-1.7.4 and TAO-1.7.5
894 ====================================================
896 . Converted a lot of TAO tests to use the new test framework
898 . Fix problem in the IDL compiler where set/get methods for
899   attributes in a local interface derived from a non local interface
900   where not regenerated as pure virtual
902 . Fixed some bugs concerning spaces within roots, to allow TAO_IDL
903   to be used by user projects that are installed on windows paths
904   such as "c:\Project Files\..." or "c:\Documents and Settings\.."
905   etc.
907 . The IDL3+ keywords porttype/port/mirrorport are now fully
908   implemented and tested
910 . Fixed bug in code generation for components, where a derived
911   component or home with more than one generation of ancestors
912   was missing inherited operations in its operation table
914 . Merged in changes from OCI's distribution which originate from
915   OCI request ticket [RT 13596, RT 13704].
917   - Added queue-overflow statistics to the Notification Service MC.
918   - Modified Notification Service MC to work in static builds.
919   - Corrected an error that caused Notification Service MC statistics
920     to fail when -AllocateTaskPerProxy is used.
921   - QueueDepth have been changed to measure the number of entries
922     rather than attempting unsuccessfully to estimate the amount of
923     memory used by the queue.
924   - Added TAO_EXPLICIT_NEGOTIATE_CODESETS macro to improve the ease
925     of including optional codeset support to Notify_Service in static
926     builds.
927   - Added new MPC features (notify_monitor_control and
928     negotiate_codesets).
929   - fixed ACE_Logging_Stragey service loading issue in static builds.
931 USER VISIBLE CHANGES BETWEEN TAO-1.7.3 and TAO-1.7.4
932 ====================================================
934 . Initial support for IDL3+ in the TAO_IDL compiler front end.
935   IDL3+ is an extension to IDL3 driven by the DDS4CCM draft
936   standard. IDL3+ adds a porttype which is a logical grouping
937   of CCM ports and a concept of templates (like C++)
939 . Changed behaviour of -Glem and -Glfa
941 . Ported a large set of TAO tests to the new test framework
943 . Added a capability to throw BAD_PARAM exception in case
944   there is an attempt to access sequence elements above
945   sequence length. By default this capability is turned on
946   in debug builds with defining TAO_CHECKED_SEQUENCE_INDEXING.
947   BAD_PARAM exception is also thrown in case a new sequence
948   length for bounded sequence is greater than the bound
949   defined in IDL.
951 USER VISIBLE CHANGES BETWEEN TAO-1.7.2 and TAO-1.7.3
952 ====================================================
954 . Merged in changes from OCI's distribution which
955   originate from OCI request ticket [RT 12994]. Added
956   following ORB options.
958     -ORBForwardOnceOnObjectNotExist [0|1]
959     -ORBForwardOnceOnCommFailure [0|1]
960     -ORBForwardOnceOnTransient [0|1]
961     -ORBForwardOnceOnInvObjref [0|1]
963   The -ORBForwardOnceOnObjectNotExist ORB option is added
964   to avoid side effect from
965   -ORBForwardInvocationOnObjectNotExist that could cause
966   the request fall into forward loop in some use cases
967   (e.g. client sends request while servant is deactivated).
968   The other options are added for the same purpose to avoid
969   possible forward loop upon specified exceptions.
971 . Corrected TAO_IDL dds code generation to count WChar size for wstring
972   marshal size.
974 USER VISIBLE CHANGES BETWEEN TAO-1.7.1 and TAO-1.7.2
975 ====================================================
977 . Extended IDL compiler to take over all code generation from
978   the CIAO CIDL compiler, which has been eliminated.
979   See $TAO_ROOT/docs/compiler.html for details.
981 . Added code generation for export header files. See
982   $TAO_ROOT/docs/compiler.html for details.
984 USER VISIBLE CHANGES BETWEEN TAO-1.7.0 and TAO-1.7.1
985 ====================================================
987 . Improved Unicode compatibility.
989 . Improved service configuration processing.
991 USER VISIBLE CHANGES BETWEEN TAO-1.6.9 and TAO-1.7.0
992 ====================================================
994 . Merged in changes from OCI's distribution which originate from
995   OCI request ticket [RT 12912]. In their totality, the changes
996   added new features for IMR to support the capability of client
997   automatically reconnects servers within same port range upon
998   server restart. The ServerId is added to ServerInfo in IMR to
999   help identify server process. The -UnregisterIfAddressReused
1000   option is added to IMR to enable the address reuse checking
1001   upon server registering. The servers that address is reused
1002   are unregistered from IMR. The -ORBForwardInvocationOnObjectNotExist
1003   option is added to forward request to next available profile
1004   upon receiving OBJECT_NOT_EXIST exception reply.
1006 . The -ORBRunThreads of the notification service has been renamed
1007   to -RunThreads and the notification service can now be loaded
1008   as dll.
1010 . Updated ZIOP to match the OMG Beta 2 specification
1012 . Added a new utility, tao_logWalker, see utils/logWalker for details.
1013   This tool analises a collection of log files containing output of
1014   TAO running with -ORBDebuglevel 10, and generates a report showing
1015   process, thread and invocation summaries.
1017 . Fixed bug in Notification Service that the filter constraint expressions
1018   are ignored when event type domain_name or type_name is specified
1019   (see bug 3688).
1021 . The MCPP version optionally used by TAO_IDL has been updated to 2.7.2.
1022   Efforts have been taken to port this to as many platforms as possible,
1023   however, since it is not currently the default configuration it may
1024   not work across all platforms.
1026 USER VISIBLE CHANGES BETWEEN TAO-1.6.8 and TAO-1.6.9
1027 ====================================================
1029 . Reply Dispatchers are refactored. No deadlock occurs when an
1030   (a)synchronous CORBA call is made during dispatching a reply.
1032 . Fixed IDL compiler bug that in some cases caused code generation for
1033   inherited operations to be skipped.
1035 . The Transport Cache Size maximum is now a hard maximum.
1037 . Fixed several bugs related to the purging of transports when the cache
1038   is almost full.
1040 . New TAO-specific feature of Notification service improves management
1041   of proxies when peer goes away without disconnecting from proxy.  See
1042   orbsvcs/Notify_Service/README for details in the svc.conf section.
1044 . Improved Notification topology persistence, now persists filters.
1046 . Updated ZIOP to match the beta 1 OMG specification.
1048 USER VISIBLE CHANGES BETWEEN TAO-1.6.7 and TAO-1.6.8
1049 ====================================================
1051 . Fixed race condition when multiple threads make a connection to the
1052   same server (bugzilla 3543)
1054 . Updated several tests to the new test framework
1056 . Fixed several memory leaks and make sure the TAO singletons are
1057   destructed when the TAO DLL gets unloaded
1059 . Improved WinCE unicode support and extended the number of tests that
1060   can be run with WinCE
1062 . Fixed some race conditions in the transport cache. There are several
1063   known issues resolved in the transport cache when it starts purging.
1065 . Fixed memory leak in string and object reference sequences.
1067 . Bugs fixed: 3078, 3499, 3524, 3543, 3549, 3557, 3559.
1070 USER VISIBLE CHANGES BETWEEN TAO-1.6.6 and TAO-1.6.7
1071 ====================================================
1073 . Added a fix for bug 2415.  Added -DefaultConsumerAdminFilterOp and
1074   -DefaultSupplierAdminFilterOp TAO_CosNotify_Service options for setting
1075   the default filter operators.
1077 . The full TAO distribution compiles with unicode enabled. Work is ongoing
1078   to make the TAO runtime results comparable with the ascii builds.
1080 . Added two new ORB parameters, -ORBIPHopLimit and -ORBIPMulticastLoop. The
1081   first one controls number of hops an IPv4/IPv6 packet can outlive. The
1082   second one is related to MIOP only and it takes boolean value which
1083   directs whether to loop multicast packets to the originating host or not.
1085 . Added the "TAO" and "TAO/orbsvcs" OCI Development Guide Examples under the
1086   directories /DevGuideExamples and /orbsvcs/DevGuideExamples.  NOTE this is
1087   an ongoing port of the original version x.5.x examples and some are not yet
1088   100% compatiable with the current version of TAO.
1090 . Split CosLifeCycle library into separate client stub and server
1091   skeleton libraries.  Fixes bugzilla issue #2409.
1093 . Split CosTime library into separate client stub, server skeleton,
1094   and server implementation libraries.  Fixes bugzilla issue #3433.
1096 . Avoid core dumps when evaluating TCL and ETCL expressions containing
1097   divisions by zero.  Partial fix for bugzilla issue #3429.
1099 USER VISIBLE CHANGES BETWEEN TAO-1.6.5 and TAO-1.6.6
1100 ====================================================
1102 . Added a new text based monitor to the Notify_Service to keep track of
1103   consumers that were removed due to a timeout.
1105 . Repaired the -ORBMuxedConnectionMax <limit> option on the resource factory.
1106   This service configurator option defines an upper limit to the number of
1107   connections an orb will open to the same endpoint.
1109 . Repaired a problem that caused the ORB to open too many connections to
1110   an endpoint.
1112 . Added a -Timeout option to the Notify_Service to allow the user to apply a
1113   relative round-trip timeout to the ORB.  This option requires that the
1114   'corba_messaging' MPC feature be enabled during building of the
1115   Notify_Service, which it is by default.
1117 . Added ZIOP support to TAO. ZIOP adds the ability to compress the
1118   application data on the wire. This is a join effort of Remedy IT, Telefonica,
1119   and IONA. We are working on getting this standardized through the OMG.
1120   Until this has been formally standardized we don't guarantee
1121   interoperability with other ORBs and between different versions of
1122   TAO that support ZIOP, this is done after this has been accepted
1123   by the OMG. If you want to experiment with ZIOP you need to add
1124   TAO_HAS_ZIOP 1 as define to your config.h file. See TAO/tests/ZIOP
1125   for an example how to use it. All policies are not checked on all
1126   places so it can happen that the ORB sends uncompressed data when
1127   it could have compressed it. This is because of limitations in the
1128   policy mechanism in the ORB which will take a few weeks to rework.
1129   Also note that ZIOP doesn't work together with RTCORBA
1131 . Added a -m option to the ImplRepo (ImR, Implementation Repository) Activator,
1132   which specifies the maximum number of environment variables which will be
1133   passed to the child process.  The default (and previous behavior) is 512.
1135 USER VISIBLE CHANGES BETWEEN TAO-1.6.4 and TAO-1.6.5
1136 ====================================================
1138 . Updated TAO to comply with the IDL to C++ mapping v1.2. As a result
1139   CORBA::LocalObject is now refcounted by default
1141 . Added a new ORB parameter, -ORBAcceptErrorDelay, that controls the amount
1142   of time to wait before attempting to accept new connections when a
1143   possibly transient error occurs during accepting a new connection.
1145 . Fixed a bug which could lead to an ACE_ASSERT at runtime when a TAO
1146   is used from a thread that is not spawned using ACE
1148 . Added new Monitoring lib that can be used to retrieve values from
1149   the new Monitoring framework in ACE. This is disabled by default
1150   because it is not 100% finished yet, with the next release it
1151   will be enabled by default
1153 . Extended the -ORBLaneListenEndpoints commandline option to support
1154   *, for details see docs/Options.html
1156 . VxWorks 6.x kernel mode with shared library support
1158 USER VISIBLE CHANGES BETWEEN TAO-1.6.3 and TAO-1.6.4
1159 ====================================================
1161 . Service Context Handling has been made pluggable
1163 . Improved CORBA/e support and as result the footprint decreased when
1164   CORBA/e has been enabled
1166 . Added the ability to remove consumer and supplier proxies and consumer and
1167   supplier admins through the Notify Monitor and Control interface.
1169 . Changed Interface Repository's IOR output file from being
1170   world writable to using ACE_DEFAULT_FILE_PERMS.
1172 . Add support for a location forward with a nil object reference.
1174 USER VISIBLE CHANGES BETWEEN TAO-1.6.2 and TAO-1.6.3
1175 ====================================================
1177 . Fixed send side logic (both synchronous and asynchronous) to honor
1178   timeouts. An RTT enabled two-way invocation could earlier hang
1179   indefinately if tcp buffers were flooded.
1181 . Bug fix for cases where the IDL compiler would abort but with an
1182   exit value of 0.
1184 . Bug fix in IDL compiler's handling of typedef'd constants having
1185   a bitwise integer expression as the value.
1187 . Bug fix that ensures valuetypes and their corresponding supported
1188   interfaces have parallel inheritance hierarchies.
1190 . Fix for possible out-of-order destruction of Unknown_IDL_Type's
1191   static local lock object (bugzilla 3214).
1193 . Added list() iterator functionality for the Naming Service when
1194   using the -u persistence option.
1196 . Various bug fixes to the IFR service and compiler.
1198 . New option (-T) to IFR compiler that permits duplicate typedefs with
1199   warning.  Although not encouraged, this allows IDL that used to pass
1200   through the IFR compiler to still pass through rather than having to
1201   be changed.
1203 . Fix crashing of _validate_connection on an invalid object reference
1205 . Add support for TAO on VxWorks 5.5.1
1207 . _get_implementation has been removed from CORBA::Object, it was
1208   deprecated in CORBA 2.2
1210 . Improved CORBA/e support
1212 . Fixed SSLIOP memory leaks
1214 USER VISIBLE CHANGES BETWEEN TAO-1.6.1 and TAO-1.6.2
1215 ====================================================
1217 . Added support for handling Location Forward exceptions caught when using
1218   AMI with DSI. These exceptions may also be raised from within DSI servants
1219   using AMH.
1221 . Added -RTORBDynamicThreadRunTime which controls the lifetime of dynamic
1222   RTCORBA threads
1224 . Changed the PI code so that send_request is also called at the moment
1225   we don't have a transport (bugzilla 2133)
1227 . Fixed memory leak that occured for each thread that was making CORBA
1228   invocations
1230 . Updated several tests to work correctly on VxWorks
1232 . Removed support for pluggable messaging. As a result the code in the
1233   core of TAO is much cleaner and we are about 5 to 10% faster
1235 . Improved CORBA/e support
1237 . Added gperf's exit code to the error message output if it exits
1238   unsuccessfully when spawned by the IDL compiler to generate an
1239   interface's operation table
1241 . Fixed bug in Interface Repository's handling of base valuetypes
1242   and base components (Bugzilla 3155)
1244 . Fixed code generation bug that occurs when there is both a C++
1245   keyword clash in the IDL and AMI 'implied IDL' code generation
1247 . Fixed IDL compiler bug wherein some cases of illegal use of a
1248   forward declared struct or union wasn't caught
1250 . Improved support for VxWorks 6.4 kernel and rtp mode
1252 USER VISIBLE CHANGES BETWEEN TAO-1.6 and TAO-1.6.1
1253 ====================================================
1255 . Made TAO more compliant to CORBA/e micro
1257 . Fixed invalid code generation by the IDL compiler when the options -Sa -St
1258   and -GA are combined
1260 USER VISIBLE CHANGES BETWEEN TAO-1.5.10 and TAO-1.6
1261 =====================================================
1263 . Added a new interface that allows monitoring of activities within the
1264   Notification Service.  Completely configurable through the Service
1265   Configurator, the monitoring capabilities are only in effect when chosen
1266   by the user.  When the monitoring capabilities are enabled, an outside
1267   user can connect to a service that allows querying statistics gathered by
1268   the Notification Service.
1270 . Moved the BufferingConstraintPolicy to the Messaging lib
1272 . Made it possible to disable not needed IOR parsers to reduce footprint
1274 . Reworked several files to get a smaller footprint with CORBA/e and
1275   Minimum CORBA. This could lead to a reduction of more then 20% then
1276   with previous releases
1278 . Removed the Domain library, it was not used at all and only
1279   contained generated files without implementation
1281 USER VISIBLE CHANGES BETWEEN TAO-1.5.9 and TAO-1.5.10
1282 =====================================================
1284 . Added support for forward declared IDL structs and unions to the
1285   Interface Repository loader
1287 . A new securty option is available using the Access_Decision interface
1288   defined by the CORBA Security Level 2 specification. This enables the
1289   implementation of servers using mixed security levels, allowing some
1290   objects to grant unrestricted access while others require secure
1291   connections. See orbsvcs/tests/Security/mixed_security_test for
1292   details on using this feature.
1294 . Removed GIOP_Messaging_Lite support for all protocols
1296 . Fixed a hanging issue in persistent Notify Service during disconnection.
1298 . Added IPv6 support to DIOP
1300 . Added -Gos option to the IDL compiler to generate ostream
1301   operators for IDL declarations
1303 USER VISIBLE CHANGES BETWEEN TAO-1.5.8 and TAO-1.5.9
1304 ====================================================
1306 . When using AMI collocated in case of exceptions they are deliverd
1307   to the reply handler instead of passed back to the caller
1309 . Added support for IPv6 multicast addresses when federating RTEvent
1310   channels.
1312 . Fixed a bug in the IDL compiler's handling of octet constants where
1313   the rhs consists of integer literals and infix operators (Bugzilla 2944).
1315 . TAO_IDL enhancements for built in sequence support in TAO DDS.
1317 . Provide support for TAO DDS zero-copy read native types.
1319 . TAO_IDL fix for lock-up and incorrect error message generation for
1320   missing definitions within local modules. This fix also stops the
1321   erronious look-up in a parent scoped module (with the same name as
1322   a locally scoped module) that should have been hidden by the local
1323   scope definition.
1325 . The TAO_IORManip library now has a filter class that allows users to
1326   create new object references based on existing multi-profile object
1327   references by filtering out profiles using user defined criteria.  The
1328   use of -ORBUseSharedProfile 0 is required for this to function.
1330 . A problem in TAO_Profile::create_tagged_profile was fixed. This problem
1331   triggered only when MIOP in multi-threaded application was used.
1333 . Added IPv6 support in MIOP so that IPv6 multicast addresses can be used in
1334   addition to those IPv4 class D addresses. DSCP support is implemented in
1335   MIOP as well. However, since MIOP only allows one way communication then it
1336   makes sense to use DSCP on the client side only.
1338 USER VISIBLE CHANGES BETWEEN TAO-1.5.7 and TAO-1.5.8
1339 ====================================================
1341 . Fixed bug in IDL compiler related to abstract interfaces
1343 . Fixed several issues in the AMI support
1345 . Added new -ORBAMICollocation 0 which disables AMI collocated calls
1347 . Improved a lot of test scripts to work with a cross host test
1348   environment where client and server are run on different hosts.
1349   This is used for automated testing with VxWorks
1351 . Fixed handled of a forward request when doing a locate
1352   request call
1354 . Added an option, -a, to the Event_Service to use the thread-per-consumer
1355   dispatching strategy instead of the default dispatching strategy.
1357 . Improved wide character compilation support.
1359 . Fixed IDL compiler to run on both OpenVMS Alpha and OpenVMS IA64.
1361 . Fixed memory leaks in the ImpleRepo_Service.
1363 . Fixed a bug in the IDL compiler relating to include paths.
1365 . Fixed Trader Service issues related to CORBA::Long and CORBA::ULong.
1367 USER VISIBLE CHANGES BETWEEN TAO-1.5.6 and TAO-1.5.7
1368 ====================================================
1370 . Removed ACE_THROW_RETURN.
1372 . Fixed a memory crash problem when using ETCL IN operator with
1373   Notify Service filter.
1375 . Remove exception specifications from ORB mediated operations (C++
1376   mapping requirement)
1378 . New diffserv library to specify diffserv priorities
1379   independent of RTCORBA
1381 . Addressed Coverity errors in core TAO libraries, TAO_IDL compiler,
1382   stubs and skeletons generated by TAO_IDL and the TAO Notification
1383   Service.
1385 . Extended current DynamicInterface to allow DII+AMI+DSI+AMH.
1386   (Thanks to OMC <www.omesc.com> for the sponsorship.)
1388 . Fixed bug in IDL compiler code generation for a comma-separated list of
1389   sequence typedefs.
1391 . TAO no longer sets the unexpected exception handler.
1393 USER VISIBLE CHANGES BETWEEN TAO-1.5.5 and TAO-1.5.6
1394 ====================================================
1396 . Removed all exception environment macros except ACE_THROW_RETURN
1397   and ACE_THROW_SPEC
1399 USER VISIBLE CHANGES BETWEEN TAO-1.5.4 and TAO-1.5.5
1400 ====================================================
1402 . Added an IDL compiler option to generate an explicit instantiation
1403   and export of template base classes generated for IDL sequences,
1404   sometimes necessary as a workaround for a Visual Studio compiler bug
1405   (Bugzilla 2703).
1407 . Beefed up error checking in the IDL compiler when processing
1408   #pragma version directives.
1410 . Modified IDL compiler's handling of a syntax error to eliminate
1411   the chance of a crash (Bugzilla 2688).
1413 . Fixed a bug in code generation for a valuetype when it inherits
1414   an anonymous sequence member from a valuetype in another IDL file.
1416 . Extended tests in tests/IDL_Test to cover generated code for
1417   tie classes.
1419 . Modified tao_idl to emit code to set the exception data in the
1420   Messaging::ExceptionHolder in the AMI _excep operation.  This has the
1421   effect of allowing user defined exceptions to be recognized when
1422   raising an exception without collocation.  This fixes Bug 2350.
1424 . Added hooks to enable custom Object to IOR conversion or allowing local
1425   objects (such as Smart Proxies) to be converted to an IOR string.
1427 . Removed warning issued when using corbaloc with a default object key.
1429 . Added implementation of Dynamic Any methods insert_*_seq() and
1430   get_*_seq() (spec-defined for sequences of IDL basic types),
1431   as well as implementation of insert and get methods for abstract
1432   interfaces.
1434 . Added support for CORBA/e compact
1436 . Added support for CORBA/e micro
1438 . Fixed issues relating to the CosTrading Server library.  The constraint
1439   language lexer now allow negative floating point values, 64-bit signed and
1440   unsigned integers (which can currently be represented as octal or decimal).
1441   Also, fixed a bug where negative integers were being stored and compared as
1442   unsigned integers which resulted in -3 > 0 evaluating to true.
1444 . Added Compression module that delivers the infrastructure
1445   classes with which data can be compressed. This can be used
1446   by regular applications but then also by the ORB in the future.
1448 . Removed support for -Ge 0 and -Ge 1 from the IDL compiler. In practice
1449   this means that the IDL compiler doesn't generate any environment macros
1450   anymore.
1452 . Fixed a problem where TAO mistakenly considered ALL messages
1453   with zero-length payload to be errors and was thus not properly
1454   parsing and handling the GIOP CloseConnection message.  This is
1455   tested via Bug_2702_Regression.
1457 . Added an optimization to servant activation to eliminate calls to
1458   check_bounds() on the object key sequence.  This has been observed
1459   to yield a 30% decrease in activation time for debug builds on VC71
1460   and linux gcc.
1462 . Merged in changes from OCI's distribution which originate from
1463   OCI request tickets [RT 8449] and [RT 8881]. In their totality,
1464   these changes add a feature whereby the notification service
1465   implementation can utilize a separate ORB for dispatching events to
1466   consumers.
1468 . Contributed the Transport::Current support - a TAO-specific
1469   feature providing IDL interfaces which enables users to obtain
1470   information about the Transports used to send or receive a
1471   message.  The basic intent is to provide (typically) a
1472   read-only interface to obtaining data like the number of bytes
1473   transferred or the number of messages sent and received.
1474   Since specific Transports may have very different
1475   characteristics, a simple generic implementation for
1476   Transport::Current is insufficient.  This implementation also
1477   provides support for specific Transport implementations. See
1478   the TC_IIOP implementation, which is an IIOP-specific
1479   Transport::Current. It extends the generic interface with
1480   operations providing information about IIOP endpoints, like
1481   host and port.  By default, TAO builds with support for this feature.
1482   Define "transport_current=0" in your default.features file to disable
1483   it. For more details of how the feature is intended
1484   to be used, see docs/transport_current/index.html
1486 USER VISIBLE CHANGES BETWEEN TAO-1.5.3 and TAO-1.5.4
1487 ====================================================
1489 . Added support for ACE_Dev_Poll_Reactor to Advanced_Resource_Factory.
1491 . Improved tao_idl performance, particularly over networked
1492   filesystems.
1494 . Added new option for the RTEC, -ECDispatchingThreadsFlags, that
1495   allows the user to pass in a list of thread creation flags and
1496   priority for dispatching threads.  These can be used for either the
1497   MT dispatching strategy or the TPC dispatching strategy.  See
1498   docs/ec_options.html for usage information.
1500   Also added -ECDebug option to enable debugging output from the RTEC.
1501   Only the option and variable was added, but no messages.  Therefore,
1502   at the moment, this does not generate much output.
1504 . Resolved Bugzilla #2651 to eliminate incompatibility with the new
1505   mechanism, allowing per-ORB configurations.
1507 . Fixed Bugzilla #2686, which involved correctly managing memory during
1508   exceptional situations.  Throwing an exception during the creation of the
1509   Root POA would cause a leak of a TAO_Adapter and POA manager related
1510   objects.
1512 . Fixed Bugzilla #2699, by uninlining generated code for the
1513   TIE template classes. Inlining of virtual functions in this
1514   code was causing problems with RTTI on some compilers. As a side
1515   result, the idl compiler doesn't generate a S_T.inl file anymore.
1517 . Fixed a bug where calling _set_policy_overrides() on a collocated servant
1518   would return an unusable object reference.
1520 . Addressed a number of Coverity errors (CHECKED_RETURN, DEADCODE, LOCK,
1521   USE_AFTER_FREE, RESOURCE_LEAK, FORWARD_NULL).  In particular, missing
1522   return value checks and unreachable code in the ACE CDR stream
1523   implementation were addressed.  Memory and resource management in the ACE
1524   Configuration classes was corrected.  A potential deadlock upon error was
1525   fixed in ACE_OS::rw_unlock().  Missing return value checks were addressed
1526   in ACE_OS::open() on Windows and ACE_Thread_Manager::wait().  A potential
1527   dereference of a null pointer in ACE_OS::scandir_emulation() was
1528   corrected.  Lastly, the ACE_UUID::lock() accessor interface and
1529   implementation was cleaned up so that it would not return a lock whose
1530   memory had been freed.
1532 USER VISIBLE CHANGES BETWEEN TAO-1.5.2 and TAO-1.5.3
1533 ====================================================
1535 . Added new options, -CECConsumerOperationTimeout and
1536   -CECSupplierOperationTimeout, to the CosEvent service.  See Bugzilla #2594
1537   and $TAO_ROOT/docs/cec_options.html for details.  The purpose of these
1538   options is to use the relative round-trip timeout feature from the TAO
1539   Messaging library to detect clients that are "hung" in push() or pull()
1540   operations but would otherwise not be detetcted as "bad" by the
1541   -CECReactive*Control options (since they have a thread available in
1542   orb->run()).
1544 . The Tk/Fl/Qt/Xt resource factories have been moved to subdirectories
1545   to make maintenance easier. If you are using these you have to update
1546   your include paths.
1548 . Fixed a compatibility problem between TAO and ORBs using Valuetype ID
1549   indirection, such as JacORB. This problem was inadvertently introduced
1550   in 1.5.2.
1552 . Oneway requests when using SYNC_NONE, SYNC_DELAYED_BUFFERING, or
1553   SYNC_EAGER_BUFFERING will be queued until the connection is completed.
1554   Connection completion occurs when one of the following occurs:
1555    a) A one-way request that does NOT use one of the sync-scopes mentioned
1556         above is sent via the same transport
1557    b) A two-way request is sent via the same transport
1558    c) orb->run() is called
1559   Applications that do not currently do one of the above will no longer
1560   establish a connection and therefore no data will be sent.
1562 . Fixed a problem with location forward objects being raised by colocal
1563   ServerInterceptors. This problem did not occure interacting with remote
1564   servers.  Now the raised object-reference will take effect on the object
1565   reference being held by client.
1567 . Fixed a problem with properly shutting down socket connections by
1568   explicitly calling release_os_resources from the destructor of protocol
1569   specific connection handlers. Maintainers of third-party (non-DOC)
1570   pluggable protocols must verify they are releasing any resources they
1571   acquired. The base Connection_Handler destructor can't do it for them.
1573 . Added COIOP as pluggable protocol. This stands for Collocated Only IOP
1574   and it only allows collocated calls. Can be used for embedded systems that
1575   do use corba but don't make any remote calls.
1577 . Notication service works with Microsoft Visual C++ 8.
1579 . Fixed Bugzilla #2582, related to IDL compiler generation of arg traits
1580   template specialization for typedefs.
1582 . Fixed Bugzilla #2583, a bug in the recursive check for local type
1583   containment that controls CDR operator generation in the IDL compiler.
1585 . Addressed Bugzilla #2603, which called for a -oS option for the IDL
1586   compiler to set the output directory for skeleton files.
1588 . Fixed Bugzilla #2634, which reported a bug in code generation for some
1589   escaped IDL identifiers.
1591 . Eliminated the dependency of the TAO Interface Repository IDL3 test on
1592   CIAO libraries.
1594 . Added output message to the IDL compiler, containing the name of the IDL
1595   file being processed.
1597 . Fixed IDL compiler to recognize CORBA::AbstractBase as a pseudo object.
1599 . Fixed a regression on Bugzilla #2074 caused by a reference
1600   counting problem on the Connection Handler.  This change
1601   affects all pluggable transport protocol implementations.
1602   Maintainers of third-party (non-DOC) pluggable protocols will
1603   need to make similar changes to their *_Connection_Handler
1604   implementations.
1606 . Fixed parsing of explicitly wildcarded IIOP endpoints.
1607   These might be iiop://[::]:, iiop://[]: or iiop://0.0.0.0:
1608   The first two examples are useful only when IPv6 is supported.
1609   The last example forces only IPv4 endpoints even when IPv6 is
1610   supported. Use iiop://: to get both IPv4 and IPv6 endpoints.
1612 . Fixed Bugzilla #2651 to properly handle order of destruction
1613   of Codeset Manager instances owned by the Default Resource
1614   Factory.  The ORB_Core is now responsible for managing the
1615   lifecycle of the Codeset Manager instance instead of the
1616   Resource Factory.  The Resource Factory now gives up ownership
1617   of the objects it creates.
1619 . Fixed Bugzilla #2545 so collocated DII oneway requests do not
1620   crash in get_in_arg().
1622 . Added a new "-b" option to the IDL compiler to control whether
1623   or not arguments on oneway invocations are "cloneable".  If the
1624   arguments are cloneable, and Custom Servant Dispatching (CSD)
1625   strategy is in use, the arguments for collocated oneways can be
1626   cloned during the copy of the TAO_Server_Request, which gives a
1627   performance improvement over the old method of copying the
1628   arguments using marshaling.
1630 . Fixed Bugzilla #2604 so the Implementation Repository can
1631   properly keep track of servers it launched in PER_CLIENT
1632   activation mode.
1634 . Fixed build warnings from some 64-bit compilers in code in which
1635   unsigned long and ACE_CDR::ULong were mixed.
1637 . Added various performance enhancements.  Many thread mutex/integer
1638   reference counts were replaced with ACE_Atomic_Op<unsigned long>.  Some
1639   buffers are allocated on the stack instead of the heap where possible.
1641 USER VISIBLE CHANGES BETWEEN TAO-1.5.1 and TAO-1.5.2
1642 ====================================================
1644 . To be able to support CORBA/e the pidl files within the core libs are
1645   now compiled during the building of the core libs. This means that gperf
1646   and TAO_IDL must be build before you can build the core libs!
1648 . Changed NT_Naming_Service project to require new MPC feature variable
1649   "winnt".  Avoids building and installing this on non-Windows systems.
1650   Fixes bugzilla bug #2412.
1652 . Changed NT_Notify_Service project to require new MPC feature variable
1653   "winnt".  Avoids building and installing this on non-Windows systems.
1654   Fixes bugzilla bug #2411.
1656 . Changed Telecom Log Service plug-in Strategy Interface.
1658   Added get_record_attribute(), set_record_attribute(), and
1659   set_records_attribute(); removed remove(), retrieve(), and update().
1660   This will allow plug-in Strategies to handle these high-level
1661   operations more efficiently.
1663   Added get_gauge() and reset_gauge(), to maintain "gauge" used for
1664   capacity threshold alarms when log channel's LogFullActionType is
1665   DsLogAdmin::wrap.  This resolves bugzilla 2420.
1667 . Allow different ORB instances to use a different sets of Service
1668   Objects in their own Service Repository instances. This resolves
1669   bugzilla #2486.
1671 . Integrate new sequence implementation made by Carlos O'Ryan. This
1672   also includes a rework of the TAO_String_Managers and CORBA::(W)String
1673   implementations.
1675 . Store Value Factories per orb instead of per process and made the
1676   storage thread safe.
1678 . Add on demand write functionality that writes out GIOP fragments to
1679   reduce the memory usage
1681 . The TIE files (_S.*) are not generated by default anymore by the
1682   IDL compiler. If you need these for your project, add -GT to the
1683   idl compiler flags.
1685 . Added optional support for implicitly typed values. When the Valuetype
1686   library is compiled with TAO_HAS_OPTIMIZED_VALUETYPE_MARSHALING defined
1687   TAO will skip the marshaling of the value's type when it is allowed to
1688   do so. It is allowed by the spec to do so when the value's actual type
1689   matches the formal type for the parameter through which the value is
1690   passed. As older versions of TAO did not correctly unmarshal implicitly
1691   typed values, the default behavior is for TAO to always marshal the
1692   type id for values.
1694 . Added support for CORBA specified truncatable valuetypes.
1696 . Added support for CORBA specified POAManagerFactory.
1698 . Added TAO-proprietary EndpointPolicy. This is used as a filter to limit
1699   which of an ORBs endpoints are inserted into an object reference. The
1700   endpoint policy is applied to POAManagers created via the POAManagerFactory
1701   and affect all POAs associated with that POAManager.
1703 . Added a client-side connection optimization, the Parallel Connect Strategy
1704   This strategy makes the client evaluate all endpoints in profile at the same
1705   time when trying to connect to the server. For this to work the server must
1706   be run with -ORBUseSharedProfile 1 and the client must be run with
1707   -ORBUseParallelConnect 1.
1709 . Fixed several bugs related to asynchronous connection establishment. These
1710   are represented by the AMI_Buffering tests and bug 2417's regression test.
1712 . Refactored PICurrent, removing PICurrent_Copy_Callback classes, subsuming
1713   this functionality inside PICurrent_Impl where it can be controlled
1714   correctly. The copying of PICurrent objects still performs lazy/deferred
1715   copying where possible, only taking a real physical copy when modifications
1716   are attempted. Interest in PICurrent objects where lazy copies have been
1717   taken can now be correctly reversed when the lazy copy is destroyed fixing
1718   a range of call-back bugs that were performed on already destroyed objects.
1719   (For detail see bugzilla 2552.)
1721 . Updated/Enhanced TAO/utils/nslist utilities nslist,nsadd and nsdel.
1722   These tools now allow for full ID.Kind processing (the separating character
1723   is user controlled, defaulting to .) and sub-context path processing (the
1724   separating character is also user controlled, defaulting to /).
1725   nsadd allows for (re)binding naming contexts in addition to final objects
1726   nsdel allows for destroying naming contexts when unbinding.
1727   nslist output has been prittyfide with user controlled character drawing
1728   of the naming context tree or sub-tree of full or limited depth.
1729   For full usage details execute these utilities with a ? parameter.
1731 . Add the ability to use the sendfile API to send out data
1732   on the transport
1735 USER VISIBLE CHANGES BETWEEN TAO-1.5 and TAO-1.5.1
1736 ====================================================
1738 . Fixed LOCATION_FORWARD_PERM handling. See bugzilla #1777 for full details.
1740 . Fixed bug in detecting name clashes between existing identifiers and
1741   extra code generated for AMI and AMH.
1743 . Fixed bug in connection closure. See bugzilla # 2391
1745 . Added support for the --enable-fl-reactor configure option to the
1746   autoconf build infrastructure to build the TAO_FlResource library.
1748 . Added support for the --enable-qt-reactor configure option to the
1749   autoconf build infrastructure to build the TAO_QtResource library.
1751 . Added support for the --enable-xt-reactor configure option to the
1752   autoconf build infrastructure to build the TAO_XtResource library.
1754 . Fixed a race condition involving two threads active in the same
1755   connection handler at the same time. See bug# 1647 for details.
1757 . Changed #include "..." preprocessor directives to use fully
1758   qualified (from $(ACE_ROOT), $(TAO_ROOT), or $(TAO_ROOT)/orbsvcs)
1759   paths.  We had been depending on non-standard behavior where files
1760   #included with "..." are first looked for in the current directory
1761   and then in the same directories used by #include <...>.  See bug
1762   #2448 for details.
1764 USER VISIBLE CHANGES BETWEEN TAO-1.4.10 and TAO-1.5.0
1765 ====================================================
1767 . Fixed Transport to handle incoming fragmented messages propperly, abstract
1768   interfaces TAO_Pluggable_Messaging and TAO_Transport have been
1769   modified. Custom transport/messaging implementations require
1770   interface modification.
1772 . Fix collocation optimisation when a location forward is received directing a
1773   client to a collocated object.
1775 . Prevent an OBJ_ADAPTER exception when using an object reference containing
1776   an ObjectID that corresponds to a collocated IORTable entry.
1778 . Reverted solution that allowed POA-level control over access to
1779   security-enabled objects due to conflicts with the specification,
1780   i.e. the  Security::SecQoP* are not server-side policies.
1782 . When suppressing any and typecodes during IDL compilation this will not
1783   trigger compile errors due to missing any insert operations
1785 . Bug fix in IFR when creating typecodes for nested structs and unions.
1787 . Added support for the --enable-tk-reactor configure option to the
1788   autoconf build infrastructure to build the TAO_TkResource library.
1790 IDL COMPILER
1791 ------------
1793 . Fix problem with missing includes in the skeleton files for imported arg
1794   trait declarations.
1796 USER VISIBLE CHANGES BETWEEN TAO-1.4.9 and TAO-1.4.10
1797 ====================================================
1799 . Fixed a bug, which allowed security unaware clients to make
1800   invocations on secure objects, when the ORB was configured with
1801   support for Security::SecQoPNoProtection.
1803 . Fixed Bugzilla #2145, which was preventing the building of
1804   the IDL compiler on HPUX.
1806 . Added boxed valuetype support to the Interface Repository
1807   loader.
1809 . Fixed several bugs in the PICurrent implementation
1811 . Fixed GOA factory name
1813 . Fixed -ORBConnectionHandlerCleanup arguments to accept 0 and 1.
1815 . Improved Portable Interceptor implementation.
1817 . Autoconfig improvements.
1819 . Improved Real-time CORBA support for dynamic threads.
1821 IDL COMPILER:
1822 -------------
1824 . Some bug fixes. See bug #2375 and #2390.
1826 USER VISIBLE CHANGES BETWEEN TAO-1.4.8 and TAO-1.4.9
1827 ====================================================
1829 . Added new endpoint selector implementation - Optimized
1830   Connection Endpoint Selector. A member of the tao/Strategies library,
1831   use svc.conf file to load the OC_Endpoint_Factory object. See
1832   tests/AlternateIIOP/svc.conf for an example.
1834 . Continued splitting ORB Services into stub, skeleton, and
1835   implementation libraries.  Changes to the Concurrency Service,
1836   Property Service, and RTEventLog Admin Service (TAO's RTEvent
1837   varient of the OMG Telecom Log Service) have been committed.
1839 . Added a new ORB run-time option "-ORBUseLocalMemoryPool [0|1]" which
1840   controls an individual application's use of TAO's Local Memory Pool.
1841   TAO can use a local memory pool to satisfy some of its needs for
1842   heap storage, as it is often more efficient than using the
1843   platform's default memory allocator. The pool will always grow as
1844   large as necessary to satisfy memory allocations, but it will never
1845   shrink. This means that sometimes a process can retain memory that
1846   it no longer needs. If the default allocator is used then TAO gives
1847   memory back as soon as it is not needed.
1848   The UseLocalMemoryPool option selects between using the local memory
1849   pool or using the default allocator, where 0 means don't use the pool,
1850   1 means use the pool. The default is still controlled by the original
1851   compile-time option controlled by the #define TAO_USE_LOCAL_MEMORY_POOL
1852   which defaults to 1 if not specified.
1854 . Add a property -ORBKeepalive to allow a user to specify that
1855   SO_KEEPALIVE is set on IIOP connections. See docs/Options.html
1856   and Bugzilla #2374.
1858 . Add support for RTCORBA::TCPPrototocolProperties::keep_alive, when
1859   RTCORBA is used, and the application is using a Server or Client
1860   ProtocolPolicy.
1862 . Refined the Telecom Log Service Strategy Interface.  Added methods
1863   to fetch/store capacity alarm thresholds, log QoS, and "week mask".
1864   Rework locking to avoid race conditions and to improve performance.
1866 IDL COMPILER:
1867 -------------
1869 . Fixed bug in computation of repository ids for predefined types.
1871 . Fixed bug in the handling of TAO_IDL_INCLUDE_DIR.
1873 Interface Repository:
1874 ---------------------
1876 . Fixed bug in the lookup of a valuetype member's type using its
1877   repository id.
1879 . Fixed bug in IFR loader in checking for pre-existence before
1880   creating an entry corresponding to an IDL typedef.
1882 . Fixed bug in lookup when checking for a local name clash.
1884 . Fixed bug in the describe_interface() operation when the IDL
1885   interface being described has multiple parents.
1887 USER VISIBLE CHANGES BETWEEN TAO-1.4.7 and TAO-1.4.8
1888 ====================================================
1890 . Fixed bugs in code generation for interfaces that inherit from both
1891   concrete and abstract interfaces.
1893 . Subset Anys and TypeCodes to a separate library. If you use Any/TypeCode
1894   or one of the core TAO libs uses it you should link the AnyTypeCode
1895   library with your application
1897 . PICurrent is moved to the PI library
1899 . POACurrent has been moved back from PI_Server to PortableServer
1901 . Added IPv6 support for IIOP
1903 . When Any and TypeCode generation is suppressed when compiling IDL
1904   no typecodes are generated anymore for user exceptions, they are not
1905   needed for the operation of the ORB
1907 . When making AMI invocation and the send blocks we buffer the message
1908   and send it out when the transport is available again
1910 . Emulated C++ exceptions are not maintained anymore. We are keeping
1911   the macros in the TAO code until x.5.1 is out, if nobody sponsors
1912   maintenance at that moment the macros will be removed from TAO.
1913   See also http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2256
1915 . Support the latest AMI mapping, the old mapping will be kept working
1916   until 1.5.1 has been released. If you need the old mapping add
1917   the define TAO_HAS_DEPRECATED_EXCEPTION_HOLDER to your config.h
1918   file before you build TAO and the TAO_IDL compiler
1920 . Added CodecFactory::create_codec_with_codesets to create a codec with
1921   a specific codeset. See OMG issue 6050 for the background.
1923 . PortableInterceptor::IORInterceptor has been splitted in IORInterceptor
1924   and IORInterceptor_3_0. If you use IORInterceptors read the ChangeLog for
1925   the details, maybe you have to update your code!
1927 . Added the new Custom Servant Dispatching (CSD) feature to provide user
1928   applications with the ability to implement and "plug-in" custom strategies
1929   to handle the dispatching of requests to servants. This new feature is not
1930   currently tested for VxWorks. See TAO release notes for more information.
1932 . Added support for an TAO "versioned" namespace.  When enabled, TAO
1933   library sources will be placed within a namespace of the user's
1934   choice or a namespace of the form TAO_1_4_7 by default, where
1935   "1_4_7" is the TAO major, minor and beta versions.  The default may
1936   be overridden by defining the TAO_VERSIONED_NAMESPACE_NAME
1937   preprocessor symbol.  Enable overall versioned namespace support by
1938   adding "versioned_namespace=1" to your MPC default.features file.
1940 . Changed generated signatures of some valuetype member
1941   accessor/mutator pairs to be consistent with IN
1942   parameter semantics.
1944 . Added spec-required generation of member-initializing
1945   constructor for valuetypes. See C++ mapping (03-06-03)
1946   section 1.17.2. Closes Bugzilla #2270.
1948 . Added default include paths $TAO_ROOT, $TAO_ROOT/tao,
1949   $TAO_ROOT/orbsvcs, and $CIAO_ROOT/ciao to IDL compiler
1950   execution, eliminating the need to add them explicitly
1951   to the command line.
1953 . Added immediate exits to IDL compiler when some name clash
1954   errors are encountered, avoiding a crash if parsing is
1955   continued. Closes Bugzilla #2281.
1957 . Changed the behavior of the _default() method (generated
1958   for IDL unions that have an explicit or implicit default
1959   case label) to clean up memory used by the freed member,
1960   if necessary.
1962 . Fixed bug in IDL compiler when handling a native exception
1963   in an operation declared in Messaging::ExceptionHolder.
1965 . Although not presently supported by CIAO, added error
1966   checking to the IDL compiler's parsing of IDL home
1967   primary keys, which constrain the basic valuetype
1968   syntax in several ways.
1970 . Fixed order of generated base class stub constructor calls
1971   when the IDL interface has both concrete and abstract parents.
1973 . Fixed a bug in the handling of forward declared interfaces
1974   that have both concrete and abstract parents.
1976 . Fixed the command line parsing to preserve the literal
1977   quotes if they are used in an include path that has a space.
1978   Closes Bugzilla #2219.
1980 . Many changes related to refactoring of Anys and Typecodes
1981   into a separate library (POC is Johnny Willemsen
1982   <jwillemsen@remedy.nl>).
1984 . Merging of many Notification Service changes/fixes from OCITAO to
1985   the DOC version.  These generally addressed stability issues such as
1986   memory leaks, thread leaks, etc.
1988 . Introduction of the versioned namespaces changed the name of the
1989   factory function used for dynamically loading the Notification
1990   Service persistence mechanisms.  See the service configurator file
1991   in orbsvcs/tests/Notify/XML_Persistence for an example.
1993 USER VISIBLE CHANGES BETWEEN TAO-1.4.6 and TAO-1.4.7
1994 ====================================================
1996 . The Telecom Logging Service now supports dynamically loaded Strategies
1997   which can be used to implement a persistent log record store.  If none
1998   are specified, a default in-memory hash table implementation is used.
2000 . The CodecFactory is moved to its own library. If you use this in your
2001   application include tao/CodecFactory/CodecFactory.h and link the
2002   TAO_CodecFactory with your app
2004 . The ORBInitializer registry, PolicyFactory registry and ORBInitInfo
2005   are moved to the new PI library. If you use these clases include
2006   tao/PI/PI.h in your application code and link the new TAO_PI
2007   library with your application.
2009 . All server side PortableInterceptor support is moved to the new
2010   TAO_PI_Server library. If you use this, include tao/PI_Server/PI_Server.h
2011   in your application code and link the new TAO_PI_Server lib
2013 . A new set of examples and support code that show how to set up a
2014   multicast-based federation of  Notification Services is now available
2015   in $TAO_ROOT/orbsvcs/examples/Notify/Federation.
2017 . Hard coded loading of services with Service Configurator now uses the
2018   ACE_DYNAMIC_SERVICE_DIRECTIVE macro which also works when the xml
2019   version of service config is enabled.
2021 . The Codeset negotiation support is in its own library. The hooks are
2022   still present in the ORB Core to dynamically load the codeset support
2023   if needed. This behavior is overridden by the new ORB_init option
2024   -ORBNegotiateCodesets 0.
2026 . The Boxed Value Type as specified by the OMG is now accepted by the
2027   TAO_IDL compiler.
2029 . TAO clients now parse the OMG specified TAG_ALTERNATE_IIOP_ADDRESS
2030   profile component. To generate IORs using that component, add the
2031   new ORB_init option, -ORBUseSharedProfiles 1.
2033 . Refactored TAO's codeset negotiation feature to be optionally loadable.
2034   The implementation is now in a separate library, TAO_Codeset. Applications
2035   not wishing to use codeset support may pass -ORBNegotiateCodesets 0 to
2036   ORB_init() to avoid loading the library. When building dynamic applications
2037   codeset negotiation is available by default. For static applications, the
2038   default is to *not* include codeset negotiation. Staticly linked apps
2039   needing codeset negotiation support must do two things:
2040   - Define the new MPC feature "negotiate_codesets=1" in default.features
2041     and regenerate makefiles
2042   - Add "#include <tao/Codeset/Codeset.h>" somewhere in their application
2043     source. Placing this in the source file that includes calling ORB_init()
2044     is probably the best place.
2046 . Added CORBA::Object::_repository_id() and CORBA::Object::_get_orb()
2047   as described by the spec.
2049 USER VISIBLE CHANGES BETWEEN TAO-1.4.5 and TAO-1.4.6
2050 ====================================================
2052 . The RTOldEvent library has been removed. The RTEvent library has been
2053   split in a stub/skel and serv library.
2055 . Support for bi-directional communication over SSLIOP.
2057 . Servants are now always reference counted, in accordance with changes
2058   to the CORBA specification.
2060 . Added a -x option to catior that works like -f except that it reads
2061   the IOR from standard input rather than from a file. This makes catior
2062   much more like the unix "cat" command, and enables it to be used in a
2063   pipeline.
2065 . Changed the precedence rules for the -ORBListenEndpoints (aka
2066   -ORBEndpoint) so that the host identifier (either hostname or IP
2067   address) that appears in IIOP profiles is determined thus:
2069     1. value from hostname_in_ior (if specified);
2070     2. setting of -ORBDottedDecimalAddresses option;
2071     3. value for hostname in -ORBListenEndpoints specification;
2072     4. whatever TAO magically comes up with based on system
2073        configuration
2075   A new test (TAO/tests/IOR_Endpoint_Hostnames) verifies the
2076   operation of this feature.
2078 . Changed the way that Bidirectional endpoint processing happens when
2079   -ORBDottedDecimalAddresses 1 is in effect. The previous behavior
2080   always used the setting of the receiver, but that caused problems when
2081   the sender and receiver were not using the same dotted decimal
2082   addresses setting.  Bidirectional endpoint processing now uses
2083   whatever the sender provides as the hostname since that's also what
2084   will be in that sender's IORs.
2086 . Added a configuration property -ORBIMREndpointsInIOR [0|1] that
2087   controls whether ImR endpoints are written into persistent IORs. See
2088   $(TAO_ROOT)/docs/Options.html and bugzilla #2123 for usage.
2090 . Increment the refcount on the servant in the id_to_servant and
2091   reference_to_servant methods of the POA.
2093 . Improved g++ 4.0 support.  A number of RTTI related problems have been
2094   fixed, in addition to removal of duplicate internal ORB related
2095   singleton instances.
2097 . Fixed assertion that occured in some thru-POA collocated calls.
2099 . Fixed CORBA::UnknownUserException Any insertion problem.
2101 . Fixed TypeCode equivalence failure when comparing aliased and
2102   unaliased TypeCodes of the same type.
2104 USER VISIBLE CHANGES BETWEEN TAO-1.4.4 and TAO-1.4.5
2105 ====================================================
2107 . The POA is rewritten so that it uses strategies for its implementation.
2109 . The ImR handling is moved to the new ImR_Client library. If your server
2110   needs to register itself to the ImR you have to link the new ImR_Client
2111   library
2113 . The MIOP part of the POA is moved to the GOA. See the latest version of the
2114   MIOP specification. You have to link now with the PortableGroup
2115   library and retrieve a GOA instead of the RootPOA.
2117 . Implemented several missing parts of POA functionality as described
2118   by the latest corba specification. Missing functionality, incorrect
2119   exceptions, incorrect minor codes and much more.
2121 . Splitted the huge PortableServer.pidl file in several smaller files
2122   and regenerated all the generated files in the repository.
2124 . Move TAO_ORB_Manager from PortableServer to Utils library, this is a
2125   helper class.
2127 . The POA has been split in Root_POA and Regular_POA, on this we will more
2128   in the future so that the Root_POA just pulls in the minimal set of things
2129   needed.
2131 . The RootPOA now has "RootPOA" as its adapter name, previously it had
2132   an empty string.  This is required by the CORBA specification, you can
2133   overrule this by defining TAO_DEFAULT_ROOTPOA_NAME if you want to
2134   reduce the "RootPOA" string to be shorter, e.g., "".
2136 . Added support for GNU G++ 4.0.  Additional details in ACE `NEWS' file.
2138 . Explicit template support has been dropped for TAO and it is not possible
2139   to use it anymore.
2141 . CORBALOC/CORBANAME patched a memory leak and fixed performance related
2142   to the use of defaulted object keys.
2144 . Added support for Visual Age on AIX
2146 . Made it possible to run most ORB core test with VxWorks in a cross host
2147   scenario where one part of the test runs on the host and the other part
2148   of the test runs on the VxWorks target
2150 . The skeletons generated by the TAO_IDL compiler have been refactored
2151   to significantly reduce the size of server applications.  Please see
2153   http://www.dre.vanderbilt.edu/Stats/
2155   for metrics that illustrate the magnitude of the reduction.
2157 . New TypeCode implementation that reduces the size of TypeCodes in
2158   memory at run-time.
2160 USER VISIBLE CHANGES BETWEEN TAO-1.4.3 and TAO-1.4.4
2161 ====================================================
2163 . Reimplemented the way that TAO_Transport deals with GIOP headers.  In
2164   some cases partial GIOP message headers were read and used as if a full
2165   GIOP header were received. [Bug 1681]
2167 . GIOP fragment handling has changed where a single large allocation and
2168   copy occurs at the end of a fragment chain instead of an allocation and
2169   copy for every fragment received.
2171 . The tao-config script has been replaced by pkg-config metadata files
2172   which are installed in ${prefix}/lib/pkgconfig by the automake build.
2174 . SHMIOP respects now the dotted decimal addresses setting. When this is
2175   set it uses ip addresses instead of hostnames.
2177 . Removed the usage of the ACE_x_cast macros, we are using the C++ casts
2178   from now on.  The TAO core libraries will be updated before the x.4.5
2179   release.
2181 . Removed MPC code that creates unused and unnecessary subfolders in
2182   Visual Studio projects and makefiles.
2184 . Fixed unclosed temporary file created by the IDL compiler on platforms that
2185   lack mkstemp. [BUGID:2026]
2187 . Fixed IDL compiler bug related to handling null object references in a
2188   sequence. [BUGID:2027]
2190 . Made behavior when marshaling null value of an abstract interface similar
2191   to the behavior of CORBA::Object.
2193 . Made use of 'true' and 'false' with CORBA::Boolean more consistent in TAO
2194   source code and generated code.
2196 . Fixed bug in code generation for typedefs of IDL arrays that are not declared
2197   at global scope or in a module (i.e., in an interface, valuetype, eventtype
2198   or home).
2200 . Fixed bug in code generation of parent operations in AMI ReplyHandler
2201   interfaces.
2203 . Changed remaining instances of C-style casts in generated code to the
2204   appropriate C++-style cast.
2206 . Fixed typo in code generation of bounded sequences of CORBA::Object.
2208 . Fixed bug in code generation for attributes which are unaliased bounded
2209   (w)strings.
2211 . Changed implementation of TAO::Unknown_IDL_Type (a subclass of TAO::Any_Impl
2212   used when an Any is first decoded from the wire or created from a Dynamic
2213   Any) to contain its value in a TAO_InputCDR stream rather than an
2214   ACE_Message_Block*, thus cleaning up alignment and memory management code
2215   related to this type.
2217 USER VISIBLE CHANGES BETWEEN TAO-1.4.2 and TAO-1.4.3
2218 ====================================================
2220 . New pluggable protocol for GIOP over HTBP, known as HTIOP.  Source in
2221   orbsvcs/orbsvcs/HTIOP.
2223 . All TAO-specific vendor IDs are now found in the "TAO" namespace.
2224   Documentation for these constants has also been improved in a number
2225   of cases.
2227 . Further reduced inter-header dependencies, which should improve
2228   compilation times for TAO and TAO applications.
2230 . Fixed memory leak in CDR encapsulation Codec's encode_value() method.
2232 . Modified PerlACE scripts for Tests/test environment to allow
2233   per-platform customization of process startup delay.  Used the changes
2234   in various run_test scripts.
2236 . SyncScope::NONE blocks during connects [Bug 1476].
2238 . Improved compatibility with JDK orb.
2240 . Added Wait on LF No Upcalls (MT_NOUPCALLS) wait strategy.  However,
2241   recent experiences with it indicate there may be problems in scenarios
2242   other than its original motivating case (see ChangeLog).  This feature
2243   should be considered EXPERIMENTAL, and use it at your own risk.
2245 . New CORBALOC parsing is available. This feature allows TAO clients to
2246   use any third-party pluggable protocol in corbaloc strings.
2248 . Fixed bug that caused memory fault when incoming object reference
2249   contains an unknown profile.
2251 . Fixed problem in some modules when platform lacks unsigned long long
2252   support.
2254 . Modified catior to allow decoding of additional protocols.
2256 . The PortableServer library isn't depended anymore on the
2257   ObjRefTemplate and IORInterceptor libraries.  ObjRefTemplate and
2258   IORInterceptor are loaded on demand and depend on PortableServer.
2260 . IDL compiler can be built for environments that lack unsigned long
2261   long.
2263 . Reduced the amount of code generated by the TAO_IDL compiler when
2264   using forward declarations.
2266 . Naming Service implementation memory leak fixes.
2268 . Split ORB Services into stub, skeleton, and implementation libraries.
2269   Changes to the Naming, Trading, Event, Notification, and Logging
2270   Services have been committed.
2272 . Common utilities (tao_imr, tao_ifr, nslist, nsadd, nsdel,
2273   NamingViewer) now installed in $ACE_ROOT/bin.
2275 . Changed #includes of orbsvcs header files to be consistent.  The
2276   pathname now always contains a "orbsvcs/" prefix.
2278 . Notification Service EventReliability and ConnectionReliability QoS
2279   have been added to bring the DOC version of Notification Service
2280   into feature parity (in this area) with OCITAO's 1.3a version of the
2281   Notification Service.  Note that due to changes between 1.3a's
2282   source base and DOC's 1.4.3 source base, this is a re-implementation
2283   of the changes and not a simple port.
2285   In addition to the changes made directly to the Notification Service
2286   a number of test and example programs have been created for the
2287   reliable notification service. These programs may be found in
2288   subdirectories of $TAO_ROOT/orbsvcs/tests/Notify. A README file
2289   in each directory provides more detailed information, and a run_test.pl
2290   script is included to run the example or test.
2292 . A change has been made to the Notification Service IDL to improve build
2293   times and reduce the Notification Service footprint. The change suppresses
2294   the generation proxy and stub code for the many interfaces that are
2295   specified by the OMG, but are not implemented in TAO.
2297 . Implementation Repository refactored to allow the locator and
2298   activator to be used as services in the ACE Service Configurator
2299   framework.  The locator and activator services have been split into
2300   separate libraries and executables.  There have also been
2301   miscellaneous bugs fixed and performance enhancements made.
2303 . Fixed Load Balancer binary generation problem.  Libraries were being
2304   created rather than executables.
2306 . Work around MSVC++ 6 namespace brain damage in new Security/SSLIOP
2307   code.
2309 . Fixed memory management problem in SecurityLevel3 code.
2312 USER VISIBLE CHANGES BETWEEN TAO-1.4.1 and TAO-1.4.2
2313 ====================================================
2315 . Overall
2316   - Support for g++ 3.4.1.
2317   - Support added for latest HP aCC compiler.
2318   - Improved Doxygen documentation.
2319   - Reduced header file dependencies, which should speedup compilation
2320     and help minimize static footprint.
2322 . ORB
2323   - Fixed memory leak in DII exception handling.
2324   - Fixed insertion of label values when creating a union type code
2325     with create_union_tc().
2326   - Support for retrieving AMI and AMH reply handlers from a local
2327     memory pool.
2328   - Fixed location forwarding to collocated objects.
2330 . POA
2331    It is now possible to pass user-defined policies unknown to the
2332     POA with corresponding registered policy factories to the
2333     POA::create_POA() method via its policy list parameter, as
2334     required by the CORBA specification.
2336 . TAO_IDL
2337   - Closed security hole on platforms that support mkstemp() function.
2338   - Fixed potential buffer overrun problem.
2339   - A number of scoped name bugs have been fixed, including some
2340     workarounds for MSVC++ 6 scope resolution problems.
2341   - Fixed mixing of *Implicit and *Explicit inheritance lines when the
2342     there is a chain of inheritance in component homes.
2343   - Improved error checking of component and home declarations.
2344   - Code generation for valuetypes that support one or more abstract
2345     interfaces.
2346   - Added new "-GA" option that causes CORBA::Any operators and
2347     TypeCode bodies to be generated in a separate "fooA.cpp" file.
2348     Helps reduce footprint for applications that do not use Anys or
2349     TypeCodes.
2350   - Added required _downcast() method to generated value factories.
2351   - Disabled generation of implementation class for abstract
2352     interfaces.
2353   - Removed support for reading an IDL file from stdin.  This feature
2354     is legacy code used for debugging the IDL compiler in the early
2355     days of its implementation, and is not useful in application
2356     situations.
2357   - Generated stub/skeleton inline files now end in ".inl" instead of
2358     ".i".  The latter is generally used as the extension for
2359     pre-processed C sources.
2360   - Process multiple IDL files in a single execution by iteration
2361     in a single process, rather than spawning a process for each
2362     file as before.
2363   - Added the remaining spec-defined sequences of predefined types
2364     to the CORBA namespace in TAO.
2366 . Added CPU utilization load monitor to TAO's Cygnus load balancer.
2368 . Added basic CSIv2 support, which is the latest CORBA Security
2369   architecture specification.
2371 USER VISIBLE CHANGES BETWEEN TAO-1.4 and TAO-1.4.1
2372 ==================================================
2376 .  Changed the name of a parameter to the TAO type code
2377    internal method to avoid a name clash with STL.
2379 . Added the spec-required ostream insertion operator for
2380   CORBA::Exception* to go with the existing ostream
2381   insertion operator for CORBA::Exception&.
2383 . Moved the above ostream insertion operators into the
2384   CORBA namespace, so they cannot be accidentally hidden by an
2385   application.
2387 . Moved the declaration of Any operators for some ORB
2388   types so that the corresponding definitions may
2389   remain unlinked if the Any operators are not used in
2390   an application.
2392 . Fixed typo in type code factory code that is compiled
2393   only when ACE_SWAP_ON_WRITE is defined.
2395 . Several fixes to MakeProjectCreator (MPC) files, which
2396   generate GNU makefiles, Borland makefiles, and Microsoft
2397   Visual Studio project files.
2399 . Fixed Any insertion and extraction operators for bounded
2400   strings and wstrings to prevent an error if they are
2401   inserted as bounded with bound 0 and extracted as
2402   unbounded, or vice versa.
2404 . Deprecated the TAO-specific _type() method for exceptions.
2405   which is no longer used anywhere in TAO, and is retained
2406   solely for backward compatibility.
2408 . Fixed bug in TAO_SSLIOP pluggable protocol that prevented large
2409   requests from being sent.  [Bug 1429]
2411 . Cleaned up interceptor memory leaks that occurred when
2412   CORBA::ORB::destroy() was called.
2414 . Fixed problem where a ServerRequestInterceptor could be called after
2415   the ORB was shutdown.  [Bug 1642]
2417 . Overhauled PICurrent support to fix several problems. [Bug 1215, 1738]
2419 . SSLIOP documentation is now available.
2421 . Fixed memory leaks in servers when the ORB is operating in a
2422   thread-per-connection  mode. This problem showed up when clients
2423   keep connecting and disconnecting from the servers.
2425 . Fixed memory leaks in AMI clients that connect to a servers over
2426   unreliable connections that keeps getting dropped.
2428 . Fixed a race connection in Any_Impl implementation.
2430 . Fixed a byte order problem with DSI gateways
2432 . Added support for OVATION to work with this BFO of TAO.
2434 IDL COMPILER
2435 -------------
2437 . Changed the names of some local variables in generated
2438   operation code, to reduce that chance of a name clash.
2440 . Fixed bug where a #pragma version directive is sometimes
2441   not reflected in the generated repository id.
2443 . Disambiguated generated template instantiations for array
2444   _var, _out and _forany classes, when two or more arrays
2445   have the same element type and bound.
2447 . Added check for a name clash between a valuetype member
2448   and the first segment of a scoped name referenced in
2449   the valuetype.
2451 . Fixed incorrect code generation for the CDR operator of a
2452   struct/union/exception with an undefined forward declared
2453   interface member.
2455 . Fixed incorrect code generation for operation arguments
2456   that are typedefs of char, octet and boolean.
2458 . Fixed bug in handling complex recursive types.
2460 . Added -GId command line option to generate line and
2461   file debug info in *I.* files, similar to what is
2462   already generated in *C.* and *S.* files. This debug
2463   info generation is now off by default in *I.* files.
2465 . Fixed the handling of included orb.idl file to generate
2466   corresponding C++ includes for the files orb.idl
2467   itself includes, which contain spec-required declarations
2468   of sequences of basic CORBA types.
2470 . Fixed generation of ORB file includes triggered by the
2471   presence of one or more abstract interfaces in an IDL file.
2473 . Added check to the generation of _setup_collocation()
2474   method for abstract interfaces, to make it more robust.
2476 . Added a version of the realpath() system function that
2477   can be used with LynxOS, which does not have a native
2478   version.
2480 . Fixed code generation for bounded strings and wstrings
2481   when they appear anonymously (without a typedef) as operation
2482   parameters.
2484 . Fixed code generation of flat names for AMI-related types.
2486 . Fixed errors in code generation of sequences of components
2487   and eventtypes.
2489 . Fixed code generation of CDR operators for aggregate types
2490   that contain one or more abstract interfaces.
2492 . Fixed bogus errors produced when there are repeated forward
2493   declarations of an interface.
2495 . Fixed errors in some use cases of the propagation of a #pragma
2496   prefix directive to nested scopes in generated repository ids.
2498 . Fixed errors in code generation for attributes in Asynchronous
2499   Method Handler (AMH) classes.
2501 . Fixed a bug that caused the IDL compiler to crash when it sees
2502   certain kinds of illegal IDL.
2504 . Fixed problems in the interaction of checks for local interface
2505   and for null object reference when marshaling an interface
2506   member of an aggregate type.
2508 . Fixed generation of operations inherited by a local interface
2509   from a non-local one - these operations must be regenerated
2510   as pure virtual.
2512 . Added a space between some generated template parameter
2513   opening brackets and a leading double colon of a fully
2514   scoped name, since some compilers would read "<:" as
2515   the digraph character for ']'.
2517 . Fixed bug in code generation for an array of typedef of
2518   string and wstring.
2520 . Fixed a bug in the generation of repository ids for
2521   explicit, implicit and equivalent interfaces for component
2522   homes.
2524 . Fixed bugs in the generation of marshaling and demarshaling
2525   code for aggregate types with component or eventtype members.
2527 ORB SERVICES:
2528 -------------
2530 IFR:
2533 . Fixed bug in creating entries for attributes, which in CORBA 3.x may
2534   have separate get- and set- exceptions lists.
2536 . Added some method overrides to disambiguate multiple inheritance
2537   problems some compilers would have in classes added to support CORBA
2538   3.0 extensions.
2540 . Fixed bugs in entering attributes of abstract and local interfaces,
2541   and in querying for attributes of components.
2543 . Added a "-m" option to IFR_Service to enable multicast discovery of
2544   the service.
2546 LOAD BALANCING
2547 --------------
2549 . Added two new strategies, namely LoadAverage and LoadMinimum.
2551 NOTIFICATION SERVICE:
2552 ---------------------
2553 . Corrected the implementation to add the caller's <subscribed_types>
2554   to the Admin Object's types. This solves the problem that if a
2555   proxy's connect_structured_push_consumer() is called *AFTER* the
2556   proxy's subscription_change(), then the subscriptions do not work.
2558 . Added the -NoUpdates option to the Notification svc.conf
2559   options. If this option is specified, the
2560   subscription_change/offer_change messages are NOT sent to proxy
2561   objects.  This option is useful to turn off entire updates for
2562   applications that do not reply on subscription_change/offer_change
2563   messages.
2566 USER VISIBLE CHANGES BETWEEN TAO-1.3.6 and TAO-1.4
2567 ==================================================
2569 IDL COMPILER:
2570 -------------
2571 . Fixed bug related to the order of #pragma prefix and #include
2572   directives
2574 . Fixed bug in generation of copy constructor for AMH interface
2575   classes.
2577 . Fixed incorrect handling of a parameter name in an AMI sendc_xxx
2578   operation that clashes with a C++ keyword.
2580 . Readded the generation of _unchecked_narrow () back into the stub
2581   code since it is required by the latest OMG CORBA specification.
2583 CORE ORB
2584 -------
2586 . SCIOP endpoints are not created by default. They need explicit
2587   specification of -ORBEndpoint sciop:// at startup.
2589 . Fixed a bug that caused the ORB to dump a core when server side
2590   interceptors returns an exception and if the operation parameters
2591   contains a sequence an out parameter.
2593 . Fixed a bug that caused extraction of basic data types that are
2594   aliased from an Any.
2596 . Added a couple of regressions tests for some of AMH features.
2598 . Lots of other bug fixes (see the bottom of this message for a
2599   complete list of bugzilla bugids fixed in this beta).
2601 . Fixed a problem with dynamic loading of the ORB. This was introduced
2602   by "magic" static constructors in the TAO PortableServer headers
2603   where dynamic loading/unloading of the ORB failed.
2605 . Added an option, -ORBDisableRTCollocation which allows users to
2606   disable the RT collocation technique used by TAO and fall back on the
2607   default collocation technique used for the vanilla ORB.
2609 . Prevent the TP_Reactor used within TAO from exiting when it receives
2610   a EINTR during select ().
2612 ORB SERVICES
2613 ------------
2615 . Added new security variable so that libTAO_Security could be built
2616   independently of libTAO_SSLIOP, and set the default to true.
2618 . An initial implementation of the FTCORBA spec has been added to
2619   TAO. This release features an initial cut of ReplicationManager,
2620   FaultNotifier, and a FaultDetector. Please see
2622   $TAO_ROOT/orbsvcs/tests/FT_App/README
2624   for a simple example that uses the different FTCORBA features that
2625   have been implemented in TAO.
2627 . Fixed a bug, in PG_ObjectGroupManager::remove_member () methods
2628   which caused the group entry to be available in the location_map
2629   when a member of the object group is removed.