Bug 29523

Summary: improve documentation for TpAccountChannelRequest
Product: Telepathy Reporter: Danielle Madeley <danielle>
Component: tp-glibAssignee: Simon McVittie <smcv>
Status: RESOLVED FIXED QA Contact: Telepathy bugs list <telepathy-bugs>
Severity: normal    
Priority: medium    
Version: git master   
Hardware: Other   
OS: All   
Whiteboard:
i915 platform: i915 features:

Description Danielle Madeley 2010-08-12 00:44:18 UTC
* tp_account_channel_request_new() would benefit from an example; and the @user_action_time should give hints for what value to get from GTK+, or what value to use otherwise.

* An explanation of how {create,ensure}_and_handle work could be useful for some people.

* ::re-handled should be better explained, also potentially with an example.
Comment 1 Guillaume Desmottes 2010-08-12 03:06:39 UTC
Empathy defines these constants:
#define EMPATHY_DISPATCHER_NON_USER_ACTION  (G_GINT64_CONSTANT (0))
#define EMPATHY_DISPATCHER_CURRENT_TIME  G_MAXINT64

cf http://telepathy.freedesktop.org/spec/generic-types.html#User_Action_Timestamp

What about introducing those in tp-glib so we can refer them directly in the doc?
Comment 2 Danielle Madeley 2010-08-12 03:08:40 UTC
That makes sense to me!
Comment 3 Simon McVittie 2010-08-12 04:12:09 UTC
For the user action time constants, how's this?

tp_channel_dispatch_operation_handle_with_time_async() does document how to get a user action time from Gdk; we should put this in one place (perhaps move it to ACR) and have everywhere else reference it.

Similarly, #TpHandleChannelsContext:user-action-time does (mostly) document what handlers should do with the UAT when they get it. We should put this in one place (or leaving it where it is might be appropriate), mention gtk_window_present_with_time(), and have everywhere else reference it.

In principle we ought to have a telepathy-gdk with this stuff in, but that's rather annoying, particularly with the Gtk2/Gtk3 switch, Clutter, and other GUI uncertainties...
Comment 4 Guillaume Desmottes 2010-08-12 04:27:32 UTC
looks good to me.
Comment 5 Simon McVittie 2010-08-12 05:59:57 UTC
I've updated the branch with more docs and more user action time stuff. It turns out that CurrentTime = 0 is part of the X11 protocol, and there are matching constants in both Gdk and Clutter, so I think tp_user_action_time_from_x11() is useful.

(In reply to comment #0)
> * tp_account_channel_request_new() would benefit from an example

Not done here; I think the best example would probably be to add higher-level API (I'm not quite sure what shape that should be yet), include "this is equivalent to tp_account_channel_request_new() with this @request" in its docs, and add those to tp_account_channel_request_new() as a "see also".

> * An explanation of how {create,ensure}_and_handle work could be useful for
> some people.

I've added brief explanations of how they work behind the scenes.

> * ::re-handled should be better explained, also potentially with an example.

I explained why it's like it is, but didn't add an example. Example handlers would be a great place to show off g-i, actually - we can add pygtk examples without actually having to (build-)depend on Gtk :-)
Comment 6 Guillaume Desmottes 2010-08-12 06:05:26 UTC
If someone want to add a proper example of TpAccountChannelRequest I started writing one (for testing purpose):
http://git.collabora.co.uk/?p=user/cassidy/telepathy-glib;a=shortlog;h=refs/heads/request-example

(Note all the code needed just to get accounts and connection ready if you are wondering why I'd like to have bug #29529 ;) )
Comment 7 Guillaume Desmottes 2010-08-12 06:47:19 UTC
++
Comment 8 Simon McVittie 2010-08-17 03:06:24 UTC
Fixed in git for 0.11.13
Comment 9 Danielle Madeley 2010-08-19 21:32:58 UTC
The documentation doesn't currently discuss the purpose of @context. i.e. if you pass a pointer to store the context in, are you then responsible for calling accept/fail/delay? (It seems you are not, which makes me wonder the purpose of providing the context).

Similarly in the re-handled signal.
Comment 10 Simon McVittie 2010-08-24 09:47:03 UTC
(In reply to comment #9)
> The documentation doesn't currently discuss the purpose of @context. i.e. if
> you pass a pointer to store the context in, are you then responsible for
> calling accept/fail/delay? (It seems you are not, which makes me wonder the
> purpose of providing the context).

The purpose is so you can call methods on @context to retrieve information from Handler_Info, but it's impossible to give a concrete example because we don't define any keys yet.

For instance, if we were to define a Handler_Info key "approver" that's the unique name of the process that called HandleWith(), I'd add:

    const gchar *tp_handle_channels_context_get_approver (TpHCC *);

and that'd be the first example of a use for @context.
Comment 11 Danielle Madeley 2010-08-24 15:36:55 UTC
Then we should add this, because at the moment you might naïvely believe that you need to use it if you want to delay or fail the handler.
Comment 12 Simon McVittie 2010-08-25 04:03:58 UTC
Like I said, I can't give a concrete example of a key in Handler_Info because we don't have any yet, but I've added an accessor for Handler_Info itself and some more explanation in the docs:

http://git.collabora.co.uk/?p=user/smcv/telepathy-glib-smcv.git;a=shortlog;h=refs/heads/trivia

What do you think?

Also, closing Bug #25073 would make this less hypothetical by defining the first key in Handler_Info.
Comment 13 Danielle Madeley 2010-08-25 05:34:50 UTC
Looks good :)
Comment 14 Simon McVittie 2010-08-25 06:31:19 UTC
Fixed (again) in git for 0.11.14

Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.