X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2Fconsole.pl;h=205d52f379d37b19cf9cba49093f400a00f3a6ff;hb=517695ec47b0ab768da54c7b0830de9ed0dd4914;hp=eae1c0ff4451a477af22765c3d36cfd3f00bc538;hpb=d4af9b75c46cddd2cc830961eb615975ed260a9e;p=spider.git diff --git a/perl/console.pl b/perl/console.pl index eae1c0ff..205d52f3 100755 --- a/perl/console.pl +++ b/perl/console.pl @@ -224,6 +224,9 @@ sub addtotop { while (@_) { my $inbuf = shift; + if ($inbuf =~ s/\x07+$//) { + beep(); + } push @shistory, $inbuf; shift @shistory if @shistory > $maxshist; } @@ -240,6 +243,7 @@ sub rec_socket if (defined $msg) { my ($sort, $call, $line) = $msg =~ /^(\w)([^\|]+)\|(.*)$/; + $line =~ s/[\x00-\x06\x08\x0a-\x19\x1b-\x1f\x80-\x9f]/./g; # immutable CSI sequence + control characters if ($sort && $sort eq 'D') { $line = " " unless length($line); addtotop($line); @@ -367,7 +371,7 @@ sub rec_stdin $pos = 0; } elsif ($r eq KEY_END || $r eq "\005") { $pos = $lth; - } elsif ($r eq KEY_BACKSPACE || $r eq "\010" || $r eq "\0177") { + } elsif ($r eq KEY_BACKSPACE || $r eq "\010" || $r eq "\x7f") { if ($pos > 0) { my $a = substr($inbuf, 0, $pos-1); my $b = substr($inbuf, $pos) if $pos < $lth; @@ -482,7 +486,7 @@ $SIG{__DIE__} = \&sig_term; $conn->send_later("A$call|$connsort width=$cols"); $conn->send_later("I$call|set/page $maxshist"); -$conn->send_later("I$call|set/nobeep"); +#$conn->send_later("I$call|set/nobeep"); #Msg->set_event_handler(\*STDIN, "read" => \&rec_stdin);