--- rxvt-unicode/src/perl/readline 2006/01/22 20:39:47 1.6 +++ rxvt-unicode/src/perl/readline 2006/02/20 20:48:11 1.10 @@ -4,39 +4,58 @@ my $termios = new POSIX::Termios; +sub on_init { + my ($self) = @_; + + $self->{enabled} = 1; + + push @{ $self->{term}{option_popup_hook} }, sub { + ("readline" => $self->{enabled}, sub { $self->{enabled} = shift }) + }; + + () +} + sub on_button_press { my ($self, $event) = @_; - return - if $self->current_screen || $self->hidden_cursor; + $self->current_screen || $self->hidden_cursor || !$self->{enabled} + and return; + + my $mask = $self->ModLevel3Mask | $self->ModMetaMask + | urxvt::ShiftMask | urxvt::ControlMask; + + ($event->{state} & $mask) == urxvt::ShiftMask + or return; $termios->getattr ($self->pty_fd) or return; - return - if $termios->getlflag & &POSIX::ICANON; + $termios->getlflag & &POSIX::ICANON + and return; my ($row, $col) = $self->screen_cur; my $line = $self->line ($row); my $cur = $line->offset_of ($row, $col); my $ofs = $line->offset_of ($event->{row}, $event->{col}); - if ($ofs >= 0 && $ofs < $line->l) { - my $diff = $ofs - $cur; - my $move; - - if ($diff < 0) { - ($ofs, $cur) = ($cur, $ofs); - $move = "\x1b[D"; - } else { - $move = "\x1b[C"; - } + $ofs >= 0 && $ofs < $line->l + or return; - my $skipped = substr $line->t, $cur, $ofs - $cur; - $skipped =~ s/\x{ffff}//g; + my $diff = $ofs - $cur; + my $move; - $self->tt_write ($move x length $skipped); + if ($diff < 0) { + ($ofs, $cur) = ($cur, $ofs); + $move = "\x1b[D"; + } else { + $move = "\x1b[C"; } - () + my $skipped = substr $line->t, $cur, $ofs - $cur; + $skipped =~ s/\x{ffff}//g; + + $self->tt_write ($move x length $skipped); + + 1 }