Le jeudi 11 octobre 2012 à 21:29 +0200, Rainer Dorsch a écrit :
> Am Tuesday 09 October 2012 schrieb Guillaume Desmottes:
> > Le lundi 08 octobre 2012 à 22:19 +0200, Rainer Dorsch a écrit :
> > > Am Monday 08 October 2012 schrieb Guillaume Desmottes:
> > > > Le vendredi 05 octobre 2012 à 23:47 +0200, Rainer Dorsch a écrit :
> > > > > I am struggling somewhat with the empathy logs. I can only select
> > > > > Empathy.FileTransfer in the Empathy debug view. For reference I
> > > > > uploaded some logs to
> > > > >
> > > > > http://bokomoko.de/~rd/telepathy/
> > > >
> > > > Looking at this log you are connected using [email protected]
> > > > and receive a location from [email protected], but you say that
> > > > Empathy doesn't display any location for [email protected] is that
> > > > right?
> > >
> > > Yes, that is correct.
> >
> > Sounds like, at least, like an Empathy bug then. Please report one. :)
>
> I opened a bug report
>
> https://bugs.freedesktop.org/show_bug.cgi?id=55884
>
> BTW, since the location seems to be transfered correctly, how much is missing
> to build a cmd line jabber client, which could write the location to disk
> (e.g. as gpx)? If you think less than a day of work, can you give me some
> pointers to get started (e.g. is there a hello world like app, which logs
> into
> a jabber server and logs the conversation, account information hardcoded is
> fine as a hello world like starting point...)
It shouldn't be too hard. Actually I already have a small test script
listing the location of all your contacts.
Check telepathy-glib API reference if you want to tweak it.
G.
#!/usr/bin/env python
import os
import datetime
from gi.repository import GObject
GObject.threads_init()
from gi.repository import TelepathyGLib as Tp
def display_location(account, contact):
assert contact.has_feature(Tp.ContactFeature.LOCATION)
location = contact.get_location()
if len(location) == 0:
return
try:
timestamp = location['timestamp']
d = datetime.datetime.fromtimestamp(timestamp)
timestamp = d.strftime('%c')
except KeyError:
timestamp = ''
print "%s" % contact.get_identifier()
print "\ton %s" % account.get_path_suffix()
print "\t%s" % timestamp
print "\t%r" % location
print ""
def manager_prepared_cb(manager, result, loop):
manager.prepare_finish(result)
for account in manager.get_valid_accounts():
connection = account.get_connection()
if connection is None:
continue
self_contact = connection.get_self_contact()
display_location(account, self_contact)
# Verify account is online and received its contact list. If state is not
# SUCCESS this means we didn't received the roster from server yet and
# we would have to wait for the "notify:contact-list-state" signal. */
if connection.get_contact_list_state() == Tp.ContactListState.SUCCESS:
contacts = connection.dup_contact_list()
for contact in contacts:
display_location(account, contact)
loop.quit()
if __name__ == '__main__':
Tp.debug_set_flags(os.getenv('EXAMPLE_DEBUG', ''))
loop = GObject.MainLoop()
manager = Tp.AccountManager.dup()
factory = manager.get_factory()
factory.add_account_features([Tp.Account.get_feature_quark_connection()])
factory.add_connection_features([Tp.Connection.get_feature_quark_contact_list()])
factory.add_contact_features([Tp.ContactFeature.LOCATION])
manager.prepare_async(None, manager_prepared_cb, loop)
loop.run()
_______________________________________________
telepathy mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/telepathy