]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/Track.pm
WIP: Towards internal timekeeping.
[slotcarman.git] / SCX / Track.pm
index 21f3ab499f70061e98e624f68be3dec763c5f983..09db4b708690c753f4b2e9f549fb893c8c1745ce 100644 (file)
@@ -88,20 +88,18 @@ sub race_setup {
                $self->{gui}->rounds('0');
                $self->{race_rounds} = 0;
        }
-       $self->{race_time} = 0;
        $self->{best_lap} = undef;
 
        $self->{gui}->show_semaphore(undef);
        $self->{race_running} = 0;
        $self->{start_in_progress} = 0;
 
-       $self->{gui}->time('00:00');
-       $self->{gui}->best_lap('0.00');
+       $self->{gui}->time(undef);
+       $self->{gui}->best_lap(undef);
 
        for my $car (0..5) {
+               $self->car($car)->reset;
                $self->car($car)->set_order($car);
-               $self->car($car)->set_lap(0);
-               $self->car($car)->set_laptime(undef);
        }
 }
 
@@ -113,7 +111,7 @@ sub check_best_lap {
        if (!defined $self->{best_lap}
                || $time < $self->{best_lap}) {
                $self->{best_lap} = $time;
-               $self->{gui}->best_lap(sprintf("%.2f", $time), $who);
+               $self->{gui}->best_lap($time, $who);
                return 1;
        }
        return 0;
@@ -128,10 +126,24 @@ sub qualification_start {
                $self->car($car)->set_laptime(undef);
        }
 
-       $self->{qualification_running};
+       $self->{qualification_running} = 1;
        $self->{gui}->lap('Qualification');
-       $self->{gui}->time('00:00');
-       $self->{gui}->best_lap('0:00');
+       $self->{gui}->time(undef);
+       $self->{gui}->best_lap(undef);
+}
+
+sub packet_received {
+       my ($self, $time) = @_;
+
+       if ($self->{race_running}) {
+               $self->gui->time($time - $self->{race_running_since});
+       }
+}
+
+sub recalc_order {
+       my ($self) = @_;
+
+       # FIXME: Implement me
 }
 
 1;