-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTAD-bcp.h
104 lines (82 loc) · 2.25 KB
/
TAD-bcp.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct bcp{
int id;
int tempo_cpu;
int prioridade;
int tempo_chegada;
int filaIO[100];
int tempo_inicio;
int tempo_executado;
int tempoIO;
int tempo_fim;
int tempo_espera;
struct bcp* prox;
struct bcp* ant;
}BCP;
BCP* newBCP(); // Cria uma Sentinela para a Lista Duplamente Encadeada
void addBCP(BCP* unidade ,char* newline);// Popula Struct do BCP com as informações do TXT
void addBCPLista(BCP* processo,BCP** lista);// Adiciona um Determinado Processo a uma Lista
void delBCP(BCP* p); // Desvincula o Processo daquela Lista
/* Sentinela */
BCP* newBCP(){
BCP* bcp = (BCP*)malloc(sizeof(BCP));
bcp->id = -10;
bcp->tempo_chegada = -10;
bcp->prox = bcp;
bcp->ant = bcp;
return bcp;
}
/* Pega informações do TXT */
void addBCP(BCP* unidade ,char* newline){
/* Insere em um vetor as informações da linha */
int tmp[100];
int i = 0;
char delim[] = " ";
char *ptr = strtok(newline, delim);
while(ptr != NULL){
tmp[i] = atoi (ptr);
ptr = strtok(NULL, delim);
i++;
}
i--;
BCP* novo = (BCP*)malloc(sizeof(BCP));
/*Começo do Parsing de cada new Line*/
novo->id = tmp[0];
novo->tempo_cpu = tmp[1];
novo->prioridade = tmp[2];
novo->tempo_chegada = tmp[3];
for (int j=0 ; j< 100;j++) novo->filaIO[j] = -10;
/* Se existir Lista de Eventos de I/O */
if (i > 3){
for(int j = 0; j<(i-3);j++){
novo->filaIO[j] = tmp[(i-2)+j];
}
}
/*Fim do Parsing*/
/* Setando o resto das Variaveis do BCP*/
novo->tempo_inicio = 0;
novo->tempo_executado = 0;
novo->tempoIO = 0;
novo->tempo_fim = 0;
novo->tempo_espera = 0;
/* Inserção da Lista Duplamente encadeada */
novo->ant = unidade->prox->ant;
novo->prox = unidade->prox;
unidade->prox->ant = novo;
unidade->prox = novo;
}
/*Adiciona um processo no final de uma Lista*/
void addBCPLista(BCP* processo, BCP** lista){
if((*lista) == NULL) *lista = newBCP();
processo->prox = (*lista)->ant->prox;
processo->ant = (*lista)->ant;
(*lista)->ant->prox = processo;
(*lista)->ant = processo;
}
/*Desvincula o Processo daquela Lista*/
void delBCP(BCP* p){
p->ant->prox = p->prox;
p->prox->ant = p->ant;
}