use strict;
use Irssi;
use Irssi::Irc;
-use Net::Twitter;
use HTTP::Date;
use HTML::Entities;
use File::Temp;
use Data::Dumper;
$Data::Dumper::Indent = 1;
+BEGIN {
+ $ENV{JSON_ANY_ORDER} = "JSON Syck DWIW";
+ require JSON::Any;
+ import JSON::Any;
+ require Net::Twitter;
+ import Net::Twitter;
+}
+
use vars qw($VERSION %IRSSI);
-$VERSION = "1.7.2";
-my ($REV) = '$Rev: 350 $' =~ /(\d+)/;
+$VERSION = "1.7.3";
+my ($REV) = '$Rev: 352 $' =~ /(\d+)/;
%IRSSI = (
authors => 'Dan Boger',
contact => 'zigdon@gmail.com',
. 'Can optionally set your bitlbee /away message to same',
license => 'GNU GPL v2',
url => 'http://tinyurl.com/twirssi',
- changed => '$Date: 2009-01-06 14:59:49 -0800 (Tue, 06 Jan 2009) $',
+ changed => '$Date: 2009-01-08 13:46:50 -0800 (Thu, 08 Jan 2009) $',
);
my $window;
};
if ($@) {
- print $fh "type:error Error during friends list update. Aborted.\n";
+ print $fh "type:debug Error during friends list update. Aborted.\n";
return;
}
}
if ($error) {
- print $fh "type:error Update encountered errors. Aborted\n";
+ print $fh "type:debug Update encountered errors. Aborted\n";
print $fh $last_poll;
} else {
print $fh $new_poll;
};
if ($@) {
- print $fh "type:error Error during friends_timeline call. Aborted.\n";
+ print $fh "type:debug Error during friends_timeline call. Aborted.\n";
return 1;
}
unless ( ref $tweets ) {
if ( $obj->can("get_error") ) {
- print $fh "type:error API Error during friends_timeline call: ",
+ print $fh "type:debug API Error during friends_timeline call: ",
JSON::Any->jsonToObj( $obj->get_error() ), " Aborted.\n";
} else {
print $fh
- "type:error API Error during friends_timeline call. Aborted.\n";
+ "type:debug API Error during friends_timeline call. Aborted.\n";
}
return 1;
}
and not exists $friends{ $t->{in_reply_to_screen_name} } )
{
$nicks{ $t->{in_reply_to_screen_name} } = time;
- my $context = $obj->show_status( $t->{in_reply_to_status_id} );
+ my $context;
+ eval {
+ $context = $obj->show_status( $t->{in_reply_to_status_id} );
+ };
+
if ($context) {
my $ctext = decode_entities( $context->{text} );
$ctext =~ s/%/%%/g;
$context->{id}, $username,
$context->{user}{screen_name}, $ctext;
$reply = "reply";
+ } elsif ($@) {
+ print $fh "type:debug request to get context failed: $@";
} else {
- print "Failed to get context from $t->{in_reply_to_screen_name}"
+ print $fh "type:debug Failed to get context from $t->{in_reply_to_screen_name}"
if &debug;
}
}
};
if ($@) {
- print $fh "type:error Error during replies call. Aborted.\n";
+ print $fh "type:debug Error during replies call. Aborted.\n";
return 1;
}
};
if ($@) {
- print $fh "type:error Error during direct_messages call. Aborted.\n";
+ print $fh "type:debug Error during direct_messages call. Aborted.\n";
return 1;
}
my %meta;
foreach my $key (qw/id account nick type/) {
if (s/^$key:(\S+)\s*//) {
- $meta{$key} = $1;
+ $meta{$key} = $1;
}
}
Irssi::command_bind(
"twirssi_version",
sub {
- ¬ice(
-"Twirssi v$VERSION (r$REV); Net::Twitter v$Net::Twitter::VERSION. "
- . "See details at http://tinyurl.com/twirssi" );
+ ¬ice("Twirssi v$VERSION (r$REV); "
+ . "Net::Twitter v$Net::Twitter::VERSION. "
+ . "JSON in use: "
+ . JSON::Any::handler()
+ . ". See details at http://twirssi.com/" );
}
);
Irssi::command_bind(