4

PERL 的线程模块似乎不适用于 Irssi。我无法获得更多信息,因为#Irssi 的人们从不回应。

我需要让脚本每 5 分钟检查一次数据库。现在我认为这可以通过 PERL 中的多线程实现,但是一旦包含模块 Irssi 就会抛出异常。

具有讽刺意味的是,如果我尝试构建一个 while 循环,该循环会在 Irssi 客户端挂起一段时间后自行终止。

有什么建议么?

代码

    use strict;
    use warnings;
    use threads;
    use Thread::Queue;

my $q = Thread::Queue->new();    # A new empty queue
    # Worker thread
    my $thr = threads->create(
        sub {
            # Thread will loop until no more work
            while (defined(my $item = $q->dequeue())) {
                # Do work on $item
            }
        }
    );

Irssi 中的错误(不是全部,但同样的,找不到包):

13:30| Can't locate package Irssi::ServerSetup for
          @Irssi::Irc::ServerSetup::ISA at
          /home/nullby7e/.irssi/scripts/test.pl line 27.
13:30|
13:30| Can't locate package Irssi::Nick for @Irssi::Irc::Nick::ISA at
          /home/nullby7e/.irssi/scripts/test.pl line 27.
13:30|
13:30| Can't locate package Irssi::ServerConnect for
          @Irssi::Irc::ServerConnect::ISA at
          /home/nullby7e/.irssi/scripts/test.pl line 27.
4

1 回答 1

0

我无法帮助您处理线程,但根据Irssi Perl 脚本参考,您需要该Irssi::timeout_add功能。

您可以在Irssi 的 Script Repository找到许多如何使用它的示例。基本用法是:

use Irssi;

sub check_database {
    ...
}

Irssi::timeout_add(5*60*1000, "check_database", undef);
于 2014-08-28T06:14:30.760 回答