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: 348 $' =~ /(\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 11:09:34 -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;
}
last if /^__friends__/;
my %meta;
foreach my $key (qw/id account nick type/) {
- s/^$key:(\S+)\s*//;
- $meta{$key} = $1;
+ if (s/^$key:(\S+)\s*//) {
+ $meta{$key} = $1;
+ }
}
next if exists $meta{id} and exists $tweet_cache{ $meta{id} };
sub sig_complete {
my ( $complist, $window, $word, $linestart, $want_space ) = @_;
- # /twitter_reply gets a nick:num
- if ( $linestart =~ /^\/twitter_reply(?:_as)?\s*$/ ) {
+ if (
+ $linestart =~ /^\/twitter_reply(?:_as)?\s*$/
+ or ( Irssi::settings_get_bool("twirssi_use_reply_aliases")
+ and $linestart =~ /^\/reply(?:_as)?\s*$/ )
+ )
+ { # /twitter_reply gets a nick:num
@$complist = grep /^\Q$word/i, sort keys %{ $id_map{__indexes} };
}
Irssi::settings_add_str( "twirssi", "twitter_passwords", undef );
Irssi::settings_add_str( "twirssi", "twirssi_replies_store",
".irssi/scripts/twirssi.json" );
-Irssi::settings_add_bool( "twirssi", "tweet_to_away", 0 );
-Irssi::settings_add_bool( "twirssi", "show_reply_context", 0 );
-Irssi::settings_add_bool( "twirssi", "show_own_tweets", 1 );
-Irssi::settings_add_bool( "twirssi", "twirssi_debug", 0 );
-Irssi::settings_add_bool( "twirssi", "twirssi_first_run", 1 );
-Irssi::settings_add_bool( "twirssi", "twirssi_track_replies", 1 );
+Irssi::settings_add_bool( "twirssi", "tweet_to_away", 0 );
+Irssi::settings_add_bool( "twirssi", "show_reply_context", 0 );
+Irssi::settings_add_bool( "twirssi", "show_own_tweets", 1 );
+Irssi::settings_add_bool( "twirssi", "twirssi_debug", 0 );
+Irssi::settings_add_bool( "twirssi", "twirssi_first_run", 1 );
+Irssi::settings_add_bool( "twirssi", "twirssi_track_replies", 1 );
+Irssi::settings_add_bool( "twirssi", "twirssi_use_reply_aliases", 0 );
$window = Irssi::window_find_name( Irssi::settings_get_str('twitter_window') );
if ($window) {
Irssi::command_bind( "twitter_logout", "cmd_logout" );
Irssi::command_bind( "twitter_switch", "cmd_switch" );
Irssi::command_bind( "twirssi_upgrade", "cmd_upgrade" );
+ if ( Irssi::settings_get_bool("twirssi_use_reply_aliases") ) {
+ Irssi::command_bind( "reply", "cmd_reply" );
+ Irssi::command_bind( "reply_as", "cmd_reply_as" );
+ }
Irssi::command_bind(
"twirssi_dump",
sub {
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(