Summary: | Drop support for legacy interfaces where it does not break ABI | ||
---|---|---|---|
Product: | Telepathy | Reporter: | Xavier Claessens <xclaesse> |
Component: | tp-glib | Assignee: | Telepathy bugs list <telepathy-bugs> |
Status: | RESOLVED FIXED | QA Contact: | Telepathy bugs list <telepathy-bugs> |
Severity: | normal | ||
Priority: | medium | Keywords: | patch |
Version: | unspecified | ||
Hardware: | Other | ||
OS: | All | ||
URL: | http://cgit.collabora.com/git/user/xclaesse/telepathy-glib.git/log/?h=cleanup | ||
Whiteboard: | |||
i915 platform: | i915 features: |
Description
Xavier Claessens
2011-10-21 09:53:02 UTC
Here is a branch already removing ~3500 lines of code: http://cgit.collabora.com/git/user/xclaesse/telepathy-glib.git/log/?h=cleanup Could also remove fallback in TpChannel and make properties mandatory there. But there were recent spec changes there that are not yet in tp-python... The branch now makes properties mandatory for CORE and GROUP features of TpChannel. It also makes MembersChangedDetailed mandatory (otherwise, TpChannel fails to prepare). Those are supported by all CMs as far as I know. I'm pondering making TpConnection fail to prepare if it does not have immortal handles, but that would make definitely break python CMs, right? (In reply to comment #3) > I'm pondering making TpConnection fail to prepare if it does not have immortal > handles, but that would make definitely break python CMs, right? Now done + if (!tp_proxy_has_interface_by_id (context->connection, + TP_IFACE_QUARK_CONNECTION_INTERFACE_CONTACTS)) + { + GError *error = g_error_new_literal (TP_ERRORS, + TP_ERROR_SOFTWARE_UPGRADE_REQUIRED, + "Connection does not implement CONTACTS interface. Legacy CM " + "are not supported anymore"); + + WARNING ("%s", error->message); + contacts_context_fail (context, error); + g_clear_error (&error); + } (Thanks Firefox or whoever for removing indentation.) Should this not return from the function after g_clear_error? Also, "CMs" please. PROP_ACCOUNT = 1, - PROP_BREAK_PROPS = 2, PROP_DBUS_STATUS = 3, N_PROPS Probably not a problem, but still. + * return FALSE will invalidate the proxy. */ "returning FALSE" (sorry for the nit-pick) Other than these, this branch looks fine. I assume the tests all pass again given your work on them? I'm just thinking about where this branch should end up, master or next. Fixed all comments, rebased on master, and unit tests still pass. master or next is a good question though. Branch merged into next. |
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.