X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=Context.pm;h=8a0a911a3b2abbaca49a0e8995dc853540c8b19d;hb=3494b00f46396cfe17a7ab19de2385eb2b4df2c8;hp=02aac95a7ba84819a49e6713acc7c241bec48d85;hpb=e8c94cdebefdc428ea92fde6db63f18d3e8399b2;p=NDIRC.git
diff --git a/Context.pm b/Context.pm
index 02aac95..8a0a911 100644
--- a/Context.pm
+++ b/Context.pm
@@ -107,6 +107,29 @@ sub message {
$msg =~ s`(.*?)`${\(chr(2))}$1${\(chr(15))}`gi;
$msg =~ s`(.*?)`${\(chr(3))}$1$2${\(chr(15))}`gi;
+ #Split the message, using the, slightly modified, algorithm from splitlong.pl in the irssi distribution.
+ if ($command eq 'privmsg'){
+ my $lend = ' ...';
+ my $lstart = '... ';
+ my $maxlength = $self->server->{msg_length} - bytes::length("privmsg $target :" . $self->server->nick_name());
+ my $maxlength2 = $maxlength - bytes::length($lend);
+
+ if (bytes::length($msg) > ($maxlength)) {
+ my @spltarr;
+
+ while (bytes::length($msg) > ($maxlength)) {
+ my $pos = rindex($msg, " ", $maxlength2);
+ push @spltarr, substr($msg, 0, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos) . $lend;
+ $msg = $lstart . substr($msg, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos+1);
+ }
+
+ push @spltarr, $msg;
+ for (@spltarr) {
+ $self->command($command, $target, $_);
+ }
+ return;
+ }
+ }
$self->command($command, $target, $msg);
}