1
0
mirror of https://gitlab.com/klmp200/LO41.git synced 2024-12-27 18:21:12 +00:00

Les ascenseurs sont intelligents... mais ils finissent pas trop leur travail quand même.

This commit is contained in:
Aethor 2018-06-21 18:22:02 +02:00
parent 479cbb6846
commit 12c4e1af19
2 changed files with 19 additions and 12 deletions

View File

@ -31,9 +31,9 @@ int get_next_call_Building(THIS(Building), int elevator_floor){
int next_target = -1; int next_target = -1;
for(i=0; i<FLOORS; i++){ for(i=0; i<FLOORS; i++){
if(waiting_floors[i] > 0){ if(waiting_floors[i] > 0){
if(abs(elevator_floor - waiting_floors[i]) < best_diff){ if(abs(elevator_floor - i) < best_diff){
best_diff = abs(elevator_floor - waiting_floors[i]); best_diff = abs(elevator_floor - i);
next_target = waiting_floors[i]; next_target = i;
} }
} }
} }
@ -198,13 +198,12 @@ void go_to_floor_Building(THIS(Building), int origin, int destination, Passenger
if (origin < 0 || origin >= FLOORS) {CRASH("You are trying to start from a non existing floor\n");} if (origin < 0 || origin >= FLOORS) {CRASH("You are trying to start from a non existing floor\n");}
if (destination < 0 || destination >= FLOORS) {CRASH("You are trying to reach a non existing floor\n");} if (destination < 0 || destination >= FLOORS) {CRASH("You are trying to reach a non existing floor\n");}
/*if(!this->waiting_passengers->contains(this->waiting_passengers, (void*) passenger, passenger->compare)){ this->waiting_floors[origin]++;//on ajoute à la liste des attentes
this->waiting_passengers->insert_tail(this->waiting_passengers, (void*) passenger, sizeof(Passenger));//todo : check if inside list
}*/
pthread_cond_wait(this->condition_floors[origin], this->mutex_cond_get_inside_elevator); pthread_cond_wait(this->condition_floors[origin], this->mutex_cond_get_inside_elevator);
elevator_number = this->get_inside_elevator(this, origin, passenger); elevator_number = this->get_inside_elevator(this, origin, passenger);
if (elevator_number != -1){ //passenger accepted in elevator if (elevator_number != -1){ //passenger accepted in elevator
this->waiting_floors[origin]--;//on retire de la liste des attentes
if (passenger->type == RESIDENT) if (passenger->type == RESIDENT)
printf("Le résident %s rentre dans l'ascenseur %s depuis l'étage %d\n", passenger->get_name(passenger), printf("Le résident %s rentre dans l'ascenseur %s depuis l'étage %d\n", passenger->get_name(passenger),
this->elevators[elevator_number]->name, origin); this->elevators[elevator_number]->name, origin);

View File

@ -107,18 +107,26 @@ void *runnable_Elevator(void * void_this){
SharedData * data = GET_INSTANCE(SharedData); SharedData * data = GET_INSTANCE(SharedData);
Building * building = data->main_building; Building * building = data->main_building;
int next_call;
int next_passenger_stop;
AGENT_OPTIONS AGENT_OPTIONS
printf("Je suis l'ascenseur %s\n", this->name); printf("Initialisation de l'ascenseur %s\n", this->name);
for (;;){ for (;;){
building->signal_elevator_at_floor(data->main_building, this->get_floor(this)); building->signal_elevator_at_floor(data->main_building, this->get_floor(this));
if(this->target_floor == this->get_floor(this)){ if(this->target_floor == this->get_floor(this)){
if(this->get_next_passenger_stop(this) != -1){ if((next_passenger_stop = this->get_next_passenger_stop(this)) != -1){
this->target_floor = this->get_next_passenger_stop(this); this->target_floor = next_passenger_stop;
}else if(building->get_next_call(building, this->floor) != -1){ }else if((next_call = building->get_next_call(building, this->floor)) != -1){
this->target_floor = building->get_next_call(building, this->floor); this->target_floor = next_call;
} }
}
if(this->get_floor(this) != this->target_floor){
printf("Ascenseur %s en route vers l'étage %d\n", this->name, this->target_floor);
printf("DEBUG : Next passenger stop : %d\n", next_passenger_stop);
printf("DEBUG : Next call from user : %d\n", next_call);
printf("\n\n");
} }
this->set_floor(this, this->target_floor); this->set_floor(this, this->target_floor);
} }