]> www.fi.muni.cz Git - slotcarman.git/commitdiff
WIP: Towards internal timekeeping.
authorJan "Yenya" Kasprzak <kas@fi.muni.cz>
Wed, 8 Dec 2010 12:13:50 +0000 (13:13 +0100)
committerJan "Yenya" Kasprzak <kas@fi.muni.cz>
Wed, 8 Dec 2010 12:13:50 +0000 (13:13 +0100)
SCX/Car.pm
SCX/Reader.pm
SCX/Track.pm
gui.pl

index 4ef5543c1d089909cd38ba9093d958b5e3dd0cdb..c6e2aaaa5d974d96f24c712e8ad279dadac9528d 100644 (file)
@@ -50,6 +50,11 @@ sub set_throttle {
                $self->{early_start} = 1;
                $self->gui->set_driver('Early start!');
        }
+
+       if ($self->{in_pit_lane} && defined $val && $val > 3) {
+               $self->leave_pit_lane;
+       }
+
        $self->gui->set_throttle($self->{order}, $val);
 }
 
@@ -82,7 +87,7 @@ sub set_lap {
        return if $self->same('lap', $lap_nr);
        $self->gui->set_lap($self->{order}, defined $lap_nr ? $lap_nr : '--');
        if ($self->track->{race_running} && $self->{lap} > 1) {
-               my $now = gettimeofday;
+               my $now = $self->{last_finish_time};
                my $avg = ($now - $self->track->{race_running_since})
                        / ($self->{lap} - 1);
                $self->{avg_lap} = $avg;
@@ -160,6 +165,36 @@ sub set_order {
                $self->gui->enter_pit_lane;
        }
 }
-       
+
+sub reset {
+       my ($self) = @_;
+
+       $self->set_lap(0);
+       $self->set_laptime(undef);
+       $self->{in_pit_lane} = 0;
+       $self->{early_start} = undef;
+}
+
+sub finish_line {
+       my ($self, $time, $regular) = @_;
+
+       return undef
+               if defined $self->{last_finish_time}
+               && $time - $self->{last_finish_time} < 2;
+
+       if ($regular) {
+               if (defined $self->{last_finish_time}) {
+                       $self->set_laptime($time - $self->{last_finish_time});
+               }
+       } else {
+               $self->enter_pit_lane;
+       }
+
+       $self->{last_finish_time} = $time;
+       $self->set_lap(++$self->{lap});
+
+       return 1;
+}
+
 1;
 
index 08c72881f1bd9041df605e6eac4c469d23726144..7498e0a179c430aa082ff0da3cf37f6e4b9ecc0a 100644 (file)
@@ -49,6 +49,8 @@ sub new {
 
        bless $self, $class;
 
+       $self->track->reset;
+
        return $self;
 }
 
@@ -64,6 +66,8 @@ sub read {
        die "Read error on $self->{portname}: $!"
                if !$bytes_read;
 
+       $self->{last_read_time} = gettimeofday;
+
        my @bytes = unpack("C*", $data);
 
        # print join(' ', map { sprintf(" %02x", $_) } @bytes), "\n";
@@ -94,6 +98,7 @@ sub read {
                my @packet = splice @bytes, 0, $PACKET_SIZE+1;
                my $rv = $self->handle_packet(@packet);
                $self->log_bytes(\@packet, $rv);
+               $self->track->packet_received($self->{last_read_time});
        }
        if (@bad_bytes) {
                while (@bytes && $bytes[0] != 0x55) {
@@ -112,7 +117,7 @@ sub log_bytes {
 
        $msg = defined $msg ? ' # ' . $msg : '';
 
-       my $now = gettimeofday;
+       my $now = $self->{last_read_time};
 
        if ($now - $self->{log_start} >= $LOG_ROTATE) {
                close $self->{logfh};
@@ -182,7 +187,7 @@ sub car_programming_packet {
                || $bytes[4] != 0xFF
                || $bytes[5] != 0xFF;
 
-       return $msg;
+       return $msg; # No need to handle this
 }
 
 sub reset_packet {
@@ -194,6 +199,8 @@ sub reset_packet {
                || $bytes[4] != 0xAA
                || $bytes[5] != 0xAA;
 
+       $self->track->reset;
+
        return $msg; # FIXME - to be implemented
 }
 
@@ -226,6 +233,8 @@ sub lap_time_packet {
                || $bytes[4] & 0x01
                || $bytes[5] & 0x01;
 
+=comment
+       # Moving to internal timekeeping
        my $nonzero = grep { $_ != 0 } @bytes;
 
        my $car = $bytes[0];
@@ -248,6 +257,7 @@ sub lap_time_packet {
                        # all-zeros packet is sent after the race setup
                }
        }
+=cut
 
        return $msg;
 }
@@ -270,7 +280,7 @@ sub race_setup_packet {
                        + $bytes[2] & 0x0F * 16
                        + $bytes[3] & 0x0F);
 
-       return $msg; # FIXME - to be implemented
+       return $msg;
 }
 
 
@@ -337,7 +347,7 @@ sub end_of_race_packet {
 
        $self->track->race_end;
 
-       return $msg; # FIXME - to be implemented
+       return $msg;
 }
 
 
@@ -354,7 +364,7 @@ sub race_start_packet {
 
        $self->track->race_start;
 
-       return $msg; # FIXME - to be implemented
+       return $msg;
 }
 
 
@@ -388,29 +398,29 @@ sub finish_line_packet {
        my $msg = 'Strange finish_line packet'
                if $fail;
 
-       my $pit_lane_entry;
-       my $too_fast;
+       my $regular = 1;
        my @cars_finished;
        for my $i (0..5) {
                my $byte = $bytes[$i];
 
-               $pit_lane_entry = 1 if $byte == 0xF0;
-               $too_fast = 1 if $byte == 0xFF;
+               $regular = 0
+                       if $byte != 0xAA && $byte != 0xE7 && $byte != 0xFE;
 
                push @cars_finished, $i if $byte == 0xE7;
        }
 
-       if ($pit_lane_entry) {
-               for my $car (@cars_finished) {
-                       $self->track->car($car)->enter_pit_lane;
-               }
-       } else {
-               for my $car (@cars_finished) {
-                       $self->track->car($car)->leave_pit_lane;
-               }
+       my $processed;
+       for my $car (@cars_finished) {
+               $processed ||= $self->track->car($car)->finish_line(
+                       $self->{last_read_time}, $regular
+               );
        }
 
-       return $msg; # FIXME - to be implemented
+       if ($processed) {
+               $self->track->recalc_order;
+       }
+
+       return $msg;
 }
 
 sub controller_status_packet {
index c1f66a3e8890307f2b9316042db1427d7dcdde10..09db4b708690c753f4b2e9f549fb893c8c1745ce 100644 (file)
@@ -98,9 +98,8 @@ sub race_setup {
        $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);
        }
 }
 
@@ -133,5 +132,19 @@ sub qualification_start {
        $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;
 
diff --git a/gui.pl b/gui.pl
index 7fcfc7f740fc400e74bf14b4b77b60ddff47b108..6d3295ee0fa8dcecf48960206d8b38dfdfb74c15 100755 (executable)
--- a/gui.pl
+++ b/gui.pl
@@ -37,20 +37,26 @@ if ($reader) {
        Glib::IO->add_watch(fileno($reader->fh), 'in', \&scx_read, $reader);
 } else {
        # Just display some random values
+
        $gui->rounds('5/13');
        $gui->time('53.4');
        $gui->best_lap('12.3');
 
-       $track->car(0)->set_lap(13);
-       $track->car(1)->set_lap(11);
-       $track->car(2)->set_lap(10);
-       $track->car(3)->set_lap(undef);
-       $track->car(4)->set_lap(undef);
-       $track->car(5)->set_lap(undef);
-
-       $track->car(0)->set_laptime(9.12322);
-       $track->car(1)->set_laptime(15.313);
-       $track->car(2)->set_laptime(5.989);
+       my $now = time;
+       $track->{race_running_since} = $now;
+       $track->{race_running} = 1;
+
+       $track->car(0)->finish_line($now + 2.5, 1);
+#      $track->car(0)->set_lap(13);
+#      $track->car(1)->set_lap(11);
+#      $track->car(2)->set_lap(10);
+#      $track->car(3)->set_lap(undef);
+#      $track->car(4)->set_lap(undef);
+#      $track->car(5)->set_lap(undef);
+
+#      $track->car(0)->set_laptime(9.12322);
+#      $track->car(1)->set_laptime(15.313);
+#      $track->car(2)->set_laptime(5.989);
 
        $track->car(0)->set_fuel(6);
        $track->car(1)->set_fuel(2);