|
|
Classification: |
Java |
Category: |
JavaPhone |
Created: |
07/16/2001 |
Modified: |
09/11/2002 |
Number: |
FAQ-0715 |
Platform: |
Symbian OS v6.0 |
|
Question: I have associated a ConnectionListener with my local Terminal using the Terminal.addCallListener(...) method. I'd expect each call to result in two connectionCreated events but I only get one in the case of incoming calls and none in the case of outgoing calls. Is this a defect? What can I do about it?
Answer: This problem is a result of inconsistency/ambiguity in the JTAPI spec. When you associate a CallListener with your local Terminal, you will only pick up connectionCreated events for Connection objects which are associated with the local Terminal. But this can only occur through a TerminalConnection being brought into existence linking the Connection object and the local Terminal. And the semantics of the JTAPI object model require that the Connection object must be created before any linked TerminalConnection. So logically a ConnectionListener on a local Terminal can never detect local connectionCreated events.
It is an incidental detail of the Symbian JTAPI implementation that remote Connection ojects are created earlier for incoming than for outgoing calls. As a result, remote connectionCreated events are picked by a ConnectionListener on the local Terminal in the former but not the latter case. The behaviour for outgoing calls will be changed in v6.1 to bring it into conformance with that for incoming calls, i.e. generating a single connectionCreated event. But this remains an implementation detail and should not be relied upon. The recommended work around for this problem is to listen instead for terminalConnectionCreated events with a TerminalConnectionListener. Exactly two of these events are guaranteed to be received by a listener on the local Terminal, for each incoming or outgoing call which is handled. |
|
|