summaryrefslogtreecommitdiff
path: root/TAO/docs/ORB_Internals.html
blob: 05ffb00c2a407dbf18019893bbeff69050006011 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
  <head>
    <!-- $Id$ -->
    <title>TAO ORB Internals</title>
  </head>

  <body>
    <h1>TAO ORB Internals</h1>

    <P>This document will describe how the ORB internals work, with
      special attention to the areas that are more poorly documented.
      For example: we will not document (at least initially) the
      pluggable protocols framework, the interpretive marshaling
      engine, the POA, the waiting strategies and the
      leader-follower.
    </P>
    <P>New ORB developers are expected to read this document and
      document here all the things that they find hard to understand,
      surprizing or event broken.
      New members of the ORB core team are expected to fill in details 
      that were not explained before.
    </P>

    <H3>Client Side event sequence</H3>

    <P>In this section we will document the sequence of calls and
      interactions on the client side.
      Only the synchronous case, without forwarding or exceptions is
      documented at this point.
    </P>

    <P>Assume the application invokes a method on an object reference, 
      in the generated stub for that method the following sequence is
      started:
    <UL>
      <LI>creates TAO_GIOP_Twoway_Invocation object
      </LI>
      <LI>calls start method on the invocation object
      </LI>

      <LI>TAO_GIOP_Twoway_Invocation::start:
	<UL>
	  <LI>finds the profile to use for this invocation
	  </LI>
	  <LI>passes the profile to Connector Registry to obtain 
	    TAO_Transport object (wrapper around Service_Handler)
	  </LI>
	  <LI>generates and marshalls GIOP & Request headers for this
	    invocation
	  </LI>
	</UL>
      </LI>
	
      <LI>marshalls request parameters
      </LI>
      <LI>calls invoke method on the invocation object
      </LI>
  
      <LI>TAO_GIOP_Twoway_Invocation::invoke:
	<UL>
	  <LI>sets TAO_Reply_Dispatcher (this is used to make both
	    synch and asynch requests look the same)
	  </LI>
	  <LI>sends the request
	  </LI>
	  <LI>waits on the TAO_Wait_Strategy
	  </LI>
	</UL>
      </LI>

      <LI>if there was a minor problem or location forward, tries
	    again: call TAO_GIO_Twoway_Invocation::start, etc.
      </LI>
      <LI>if everything went ok, demarshalls reply
      </LI>
    </UL>
  </P>

    <hr>
    <address><a href="mailto:coryan@cs.wustl.edu">Carlos O'Ryan</a></address>
<!-- Created: Fri Sep 10 16:34:44 CDT 1999 -->
<!-- hhmts start -->
Last modified: Fri Sep 10 18:00:18 CDT 1999
<!-- hhmts end -->
  </body>
</html>