checkpoint diffs
[carveJwlIkooP6JGAAIwe30JlM.git] / world_entity.c
index 3fd7ac63473459781b85ed7a348038247eb545a7..834ede636ab83ec8c6e4d235959e2b352c06f880 100644 (file)
@@ -629,6 +629,25 @@ static void world_entity_start( world_instance *world, vg_msg *sav ){
             route->flags |= vg_msg_getkvu32( &route_info, "flags", 0 );
             route->best_laptime =
                vg_msg_getkvf64( &route_info, "best_laptime", 0.0 );
+
+            f32 sections[ route->checkpoints_count ];
+            vg_msg_cmd cmd;
+            if( vg_msg_getkvcmd( &route_info, "sections", &cmd ) ){
+               vg_msg_cast( cmd.value, cmd.code, sections,
+                            k_vg_msg_f32 |
+                            vg_msg_count_bits(route->checkpoints_count) );
+            }
+            else{
+               for( u32 j=0; j<route->checkpoints_count; j ++ )
+                  sections[j] = 0.0f;
+            }
+
+            for( u32 j=0; j<route->checkpoints_count; j ++ ){
+               ent_checkpoint *cp = mdl_arritm( &world->ent_checkpoint,
+                     route->checkpoints_start + j );
+
+               cp->best_time = sections[j];
+            }
          }
       }
    }
@@ -653,6 +672,18 @@ static void world_entity_serialize( world_instance *world, vg_msg *sav ){
          {
             vg_msg_wkvu32( sav, "flags", route->flags );
             vg_msg_wkvf64( sav, "best_laptime", route->best_laptime );
+
+            f32 sections[ route->checkpoints_count ];
+
+            for( u32 j=0; j<route->checkpoints_count; j ++ ){
+               ent_checkpoint *cp = mdl_arritm( &world->ent_checkpoint,
+                     route->checkpoints_start + j );
+
+               sections[j] = cp->best_time;
+            }
+
+            vg_msg_wkvnum( sav, "sections", k_vg_msg_f32, 
+                           route->checkpoints_count, sections );
          }
          vg_msg_end_frame( sav );
       }