This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
This interface can be implemented by a Handler to be notified about requests for channels that it is likely to be asked to handle.
Called by the ChannelDispatcher to indicate that channels have been requested, and that if the request is successful, they will probably be handled by this Handler. The ChannelDispatcher SHOULD only call this method on one handler per request.
This allows the UI to start preparing to handle the channels in advance (e.g. render a window with an "in progress" message), improving perceived responsiveness.
The use of "probably" is because you can't necessarily tell from
a channel request which handler will handle particular channels.
A reasonable heuristic would be to match the request against the
If the request succeeds and is given to the expected Handler,
the Requests_Satisfied parameter to
This lets the UI direct the channels to the window that it already opened.
If the request fails, the expected handler is notified by the
channel dispatcher calling its
This lets the UI close the window or display the error.
The channel dispatcher SHOULD remember which handler was notified,
and if the channel request succeeds, it SHOULD dispatch the channels
to the expected handler, unless the channels do not match that
handler's
Expected handling is for the UI to close the window it previously opened.
Handlers SHOULD NOT return an error from this method; errors returned from this method SHOULD NOT alter the channel dispatcher's behaviour.
Calls to this method are merely a notification.
Some of the properties of the ChannelRequest. To avoid race conditions, this dictionary MUST NOT include properties whose values could subsequently change. It SHOULD include as many properties as possible, given that constraint.
In particular, the properties
Called by the ChannelDispatcher to indicate that a request
previously passed to
Handlers SHOULD NOT return an error from this method; errors returned from this method SHOULD NOT alter the channel dispatcher's behaviour.
Calls to this method are merely a notification.
The name of the D-Bus error with which the request failed.
If this is org.freedesktop.Telepathy.Error.NotYours
,
this indicates that the request succeeded, but all the resulting
channels were given to some other handler.