2

我正在实现一个 Google Talk 侦听器,它会向我更新我所有联系人列表项的存在情况。

require 'xmpp4r'
require 'xmpp4r/roster'
require 'xmpp4r/roster/helper/roster'

sender_jid = Jabber::JID.new('email')
client = Jabber::Client.new(sender_jid)
client.connect('talk.google.com')
client.auth('password')

client.send(Jabber::Presence.new.set_type(':available'))

#Presence updates:
client.add_presence_callback do |pres|
  puts pres.from.to_s.split("/")[0] unless pres.nil?
  puts pres.show.to_s.inspect unless pres.nil?
end

Thread.stop
client.close

代码工作正常,线程继续在一个 gmail 帐户上收听,但在出现几个联系人后给了我这个错误:

client.rb:33:in `stop': deadlock detected (fatal)
    from client.rb:33:in `<main>'

出现此错误的另一个帐户有更多具有不同状态的联系人。似乎无法弄清楚为什么会这样。任何帮助都会很棒。

谢谢。

4

1 回答 1

3

通过记录器解决了问题。它抛出了一个死锁,因为有一个解析错误。我与无法解析的字符有某些联系。

似乎 xmpp4r 有一段时间没有更新了,我的解决方案是转移到一些人已经更新的 repo。

如果有人遇到类似问题,请查看: https ://github.com/whitehat101/xmpp4r

解析是通过 nokogiri 完成的。

更新:有一群新的维护者已经分叉了上面的许多更新+修复了其他问题: https ://github.com/xmpp4r/xmpp4r

于 2013-03-27T16:53:25.217 回答