The file and directory organization for TAO services can be confusing at first glance (and even on subsequent ones to be honest), so we felt like some rationale and explanation of the directory hierarchy was needed.
For general sanity all TAO services files are located under
      $TAO_ROOT/orbsvcs.
It is expected that clients use more
      than one service at the same time
      (in fact some of the services already do, for instance the
      Event Service uses the Naming Service and the
      Scheduling Service).
      For this reason all the services stubs are grouped in one
      library.
      This library is located in
      $TAO_ROOT/orbsvcs/orbsvcs.
      Usually the include path is only $TAO_ROOT/orbsvcs,
      so files are included like this:
#include "orbsvcs/CosNamingC.h"
To simplify the IDL generation the skeletons are also on the library, this is not a problem for client programs and most services need to link the library anyway (since they use other services.) Further, the current support for collocation requires that clients link the skeleton files anyway.
In the future we intend to use ACE Service Configurator to give
      the users control over collocation of the services implementation.
      As a first cut all the service implementations are included in the
      orbsvcs library $TAO_ROOT/orbsvcs/orbsvcs.
      Since there are serveral services and each one is implemented
      using several files we have given a different directory to each
      service.
      This structure could also simplify a future split into several
      libraries (if it proves necessary).
    
The complete list of directories is:
| Service | Implementation Sub-directory | 
|---|---|
| A/V Streams Service | orbsvcs/AV | 
| Concurrency Service | orbsvcs/Concurrency | 
| Event Service | orbsvcs/CosEvent | 
| Real-time Event Service | orbsvcs/Event | 
| LifeCycle Service | orbsvcs/LifeCycle | 
| Logging Service | orbsvcs/Log | 
| Naming Service | orbsvcs/Naming | 
| Property Service | orbsvcs/Property | 
| Scheduling Service | orbsvcs/Sched | 
| Trading Service | orbsvcs/Trader | 
| Time Service | orbsvcs/Time | 
Note that in the current version of TAO we still have standalone
      binaries for some of the services.  However, some applications
      may want to control what process implements a particular service.
      Therefore, it has proved useful for
      debugging purposes to keep the most used services separated.
      The binaries in question are located in
      $TAO_ROOT/orbsvcs, and the list includes:
    
In the future we plan to use a single binary and ACE Service Configurator and keep a single binary.
The Implementation Repository is a unique service in that it
      starts server executables, and it doesn't make sense to collocate
      it in another server. Because of this, only the IDL files are
      located in $TAO_ROOT/orbsvcs/orbsvcs. The other
      files are all located in
      $TAO_ROOT/orbsvcs/ImplRepo_Service.
Finally the tests and example programs are located in
      $TAO_ROOT/orbsvcs/tests;
      once more each may involves more than a single binary,
      so each one is kept in its own directory;
      the following list describes the contents of each one:
    
| Test directory | Purpose | 
|---|---|
| AVStreams | A complete A/V server and client. | 
| Concurrency | Test the Concurrency Service. | 
| CosEC_Basic | Test the basic functionality of the standard Event Service. | 
| CosEC_Multiple | Simple example that connects multiple consumers and/or suppliers to the standard event service. It can be used to show how composing a standard event-service and the real-time event service provides filtering capabilities. | 
| EC_Basic | Test the basic functionality of the real-time Event Service. | 
| EC_Custom_Marshal | Show how the Real-time event service can send user defined data using custom marshaling. | 
| EC_Mcast | Multiple real-time event channels can communicate using multicast, this example shows how to do it. | 
| EC_Multiple | Connect two Real-time Event Channels using the EC_Gateway,
	  measure latency, utilization and minimum spacing. | 
| EC_Throughput | Measure throughput and latency for collocated and remote real-time event services. | 
| Event_Latency | Test the Real-time Event Service and measure end-to-end latency, it also uses the Scheduling and Naming services. | 
| ImplRepo | Tests used to test the functionality of the Implementation Repository Service. | 
| Logger | An example logging service using the Naming Service to locate a factory. | 
| Naming | This is an obsolete directory. | 
| Property | Testing for the Property Service. | 
| Sched | A test of the Scheduling Service. | 
| Simple_Naming | A number of Naming Service tests: from very simple to more fancy. | 
| Simulator | Prototype implementation of DOVE (DOVE Agent, DOVE Browser, DOVE MIB, DOVE Application). The DOVE Agent consists of the Event Channel, which is then connected to a DOVE Browser implemented in Java. | 
| Trading | Tests for the Trading Service. | 
| Time | A test for the Time Service. | 
You may you to check TAO release notes for up to date information on status, changes, future work, etc.