]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/Car.pm
Best lap handling.
[slotcarman.git] / SCX / Car.pm
index 8446592f90b68dfb400d2b050c67c74341ac5ac8..f4a38a0436b258016b5e38e68db07e05f9dde1dc 100644 (file)
@@ -12,6 +12,7 @@ sub new {
                throttle => -1,
                fuel => -1,
                order => $args->{order},
+               track => $args->{track},
        };
 
        bless $self, $class;
@@ -24,6 +25,8 @@ sub new {
 
 sub gui { return shift->{gui}; }
 
+sub track { return shift->{track}; }
+
 sub set_throttle {
        my ($self, $val) = @_;
 
@@ -79,7 +82,7 @@ sub set_lap {
                        && $self->{lap} == $lap_nr);
 
        $self->{lap} = $lap_nr;
-       $self->gui->set_lap($self->{order}, defined $lap_nr ? $lap_nr : 'N/A');
+       $self->gui->set_lap($self->{order}, defined $lap_nr ? $lap_nr : '--');
 }
 
 sub set_laptime {
@@ -92,12 +95,16 @@ sub set_laptime {
                        || $self->{best_lap} > $lap_time
                        )) {
 
-                       $self->gui->set_best_lap($self->{order}, $lap_time);
                        $self->{best_lap} = $lap_time;
+                       my $global = $self->{track}->check_best_lap($lap_time,
+                               $self->{driver}
+                       );
+                       $self->gui->set_best_lap($self->{order}, $lap_time,
+                               $global);
                }
                
        } else {
-               $self->gui->set_best_lap($self->{order}, 'N/A');
+               $self->gui->set_best_lap($self->{order}, '--');
                $self->{best_lap} = undef;
        }
 
@@ -108,7 +115,7 @@ sub set_laptime {
        $self->{laptime} = $lap_time;
 
        $self->gui->set_laptime($self->{order}, defined $lap_time
-               ? $lap_time : 'N/A');
+               ? $lap_time : '--');
 }
 
 sub set_driver {
@@ -119,7 +126,7 @@ sub set_driver {
                        && $self->{driver} == $driver_name);
 
        $self->{driver} = $driver_name;
-       $self->gui->set_driver($self->{order}, $driver_name || 'N/A');
+       $self->gui->set_driver($self->{order}, $driver_name || '--');
 }
 
 sub enter_pit_lane {
@@ -129,5 +136,23 @@ sub enter_pit_lane {
        $self->gui->enter_pit_lane;
 }
 
+sub set_order {
+       my ($self, $pos) = @_;
+
+       $self->{order} = $pos;
+       
+       $self->gui->set_driver($self->{order}, $self->{driver}
+               || '--');
+       $self->gui->set_car_icon($self->{order}, $self->{car_icon});
+       $self->gui->set_throttle($self->{order}, $self->{throttle});
+       $self->gui->set_lap($self->{order}, defined $self->{lap}
+               ? $self->{lap} : '--');
+       $self->gui->set_laptime($self->{order}, defined $self->{laptime}
+               ? $self->{laptime} : '--');
+       $self->gui->set_best_lap($self->{order}, defined $self->{best_lap}
+               ? $self->{best_lap} : '--');
+       $self->gui->set_fuel($self->{order}, $self->{fuel});
+}
+       
 1;