104 lines
2.4 KiB
Perl
Executable File
104 lines
2.4 KiB
Perl
Executable File
#! /usr/bin/perl
|
|
# ex:ts=8 sw=4:
|
|
# $OpenBSD: dpb-replay,v 1.6 2018/07/25 12:43:45 espie Exp $
|
|
#
|
|
# Copyright (c) 2013 Marc Espie <espie@openbsd.org>
|
|
#
|
|
# Permission to use, copy, modify, and distribute this software for any
|
|
# purpose with or without fee is hereby granted, provided that the above
|
|
# copyright notice and this permission notice appear in all copies.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
use strict;
|
|
use warnings;
|
|
use FindBin;
|
|
|
|
my $ports1;
|
|
BEGIN {
|
|
$ports1 = $ENV{PORTSDIR} || '/usr/ports';
|
|
}
|
|
use lib ("$ports1/infrastructure/lib", "$FindBin::Bin/../lib");
|
|
use DPB::MiniCurses;
|
|
use OpenBSD::State;
|
|
|
|
package DPBReplay::State;
|
|
our @ISA = (qw(OpenBSD::State));
|
|
|
|
sub handle_options
|
|
{
|
|
my $state = shift;
|
|
$state->SUPER::handle_options('cs:e:', '[-c] [-s speedup] [-e regexp] file');
|
|
if ($state->opt('c')) {
|
|
$state->{color} = 1;
|
|
}
|
|
if ($state->opt('e')) {
|
|
my $e = $state->opt('e');
|
|
$state->{regexp} = qr{$e};
|
|
}
|
|
}
|
|
|
|
package Term;
|
|
our @ISA = qw(DPB::MiniCurses);
|
|
|
|
sub new
|
|
{
|
|
my ($class, $state) = @_;
|
|
my $self = bless {state => $state}, $class;
|
|
$self->create_terminal;
|
|
return $self;
|
|
}
|
|
|
|
package main;
|
|
use Time::HiRes (qw(time sleep));
|
|
|
|
my $state = DPBReplay::State->new;
|
|
$state->handle_options;
|
|
|
|
if (@ARGV == 0) {
|
|
$state->usage("Missing term-report file");
|
|
}
|
|
|
|
my $file = shift;
|
|
my $speedup = $state->opt('s') // 10;
|
|
$speedup += 0.0;
|
|
my $term = Term->new($state);
|
|
|
|
open(my $fh, '<', $file);
|
|
|
|
my $start_ts;
|
|
my $start_time = time();
|
|
my $msg = '';
|
|
my $display = defined $state->{regexp} ? 0 : 1;
|
|
while(<$fh>) {
|
|
if (m/^\@\@\@(\d+)$/) {
|
|
chomp;
|
|
my $ts = int($1);
|
|
if (!$display && $msg =~ m/$state->{regexp}/) {
|
|
$display = 1;
|
|
}
|
|
if ($display) {
|
|
$start_ts //= $ts;
|
|
|
|
my $now = time();
|
|
my $sleep = ($ts-$start_ts)/$speedup -
|
|
($now - $start_time);
|
|
if ($sleep > 0) {
|
|
sleep($sleep);
|
|
}
|
|
my $method = $term->{write};
|
|
$term->$method($msg);
|
|
$term->{msg} = $msg;
|
|
}
|
|
$msg = '';
|
|
} else {
|
|
$msg .= $_;
|
|
}
|
|
}
|
|
close($fh);
|