-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patheventos.h
59 lines (48 loc) · 1.93 KB
/
eventos.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
/**
* @file eventos.h
* @brief Fila de eventos usada na simulação.
Não é fila FIFO, a ordem é dada pelo valor de tempo dos eventos.
*/
#ifndef EVENTOS_H
#define EVENTOS_H
#include "estruturas.h"
#include "sinais.h"
typedef struct st_transicao Transicao;
/**
* @brief Estrutura que representa uma transição do valor lógico de um fio.
Um lista é formada pelo encadeamento dessas transições.
Esta lista é referenciada pelo seu primeiro elemento, e temos que o último precede um NULL.
*/
struct st_transicao {
Componente fio; // Indica o componente sobre o qual o evento se origina, apenas fios
ValorLogico novoValor; // Novo valor lógico a ser setado
Transicao* proximo;
};
typedef struct st_evento Evento;
/**
* @brief Estrutura para um evento. Um lista é formada pelo encadeamento desses eventos.
Como toda inserção nessa lista é ordenada por tempo, temos assim uma fila de eventos.
Esta fila é referenciada pelo seu primeiro elemento, e temos que o último precede um NULL.
*/
struct st_evento {
Tempo quando; // Indica o instante de ocorrência do evento
Transicao* listaTransicao;
Transicao* ultimaTransicao;
Evento* proximo;
};
/**
* @brief Adiciona à fila um evento no tempo t que faz a transição do valor de comp para o novoValor.
Mas se houver já na fila evento marcado para t, apenas adiciona à lista de transições
desse evento, a nova transição.
*/
void insereEvento(Evento **fila, Tempo t, Componente comp, ValorLogico novoValor);
/**
* @brief Retorna uma lista das transições que ocorrem exatamente em determinado tempo t.
Se não houver evento nesse tempo t, retornará NULL.
*/
Transicao* getTransicoesEm(Evento* fila, Tempo t);
/**
* @brief Remove da fila o evento mais próximo e devolve a lista de transições referente.
*/
Transicao* popEvento(Evento **fila);
#endif // EVENTOS_H