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:
parent
479cbb6846
commit
12c4e1af19
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user