X-Git-Url: https://ruin.nu/git/?p=NDIRC.git;a=blobdiff_plain;f=Context.pm;h=8a0a911a3b2abbaca49a0e8995dc853540c8b19d;hp=02aac95a7ba84819a49e6713acc7c241bec48d85;hb=82c9be26b28b12fded144d363ef81a6047e20d11;hpb=921132036eac2233472b1b315e4ee39f5ab17fbd
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);
}