-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathintersection_event_list.h
executable file
·85 lines (73 loc) · 3.46 KB
/
intersection_event_list.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
/**
* Copyright (c) 2013 the Massachusetts Institute of Technology
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
**/
#ifndef INTERSECTIONEVENTLIST_H_
#define INTERSECTIONEVENTLIST_H_
#include "./line.h"
#include "./intersection_detection.h"
#include <cilk/cilk.h>
struct IntersectionEventNode {
// This IntersectionEventNode does not own these Line* lines.
Line* l1;
Line* l2;
IntersectionType intersectionType;
struct IntersectionEventNode* next;
};
typedef struct IntersectionEventNode IntersectionEventNode;
// Compares the nodes by l1's line ID, then l1's line ID.
// -1 <=> node1 ordered before node2
// 0 <=> node1 ordered the same as node2
// 1 <=> node1 ordered after node2
int IntersectionEventNode_compareData(IntersectionEventNode* node1,
IntersectionEventNode* node2);
// Swaps the node1's and node2's data (l1, l2, intersectionType).
void IntersectionEventNode_swapData(IntersectionEventNode* node1,
IntersectionEventNode* node2);
struct IntersectionEventList {
IntersectionEventNode* head;
IntersectionEventNode* tail;
};
typedef struct IntersectionEventList IntersectionEventList;
static void identity(void *value) {
((IntersectionEventList *) value)->head = NULL;
((IntersectionEventList *) value)->tail = NULL;
}
static void reduce(void *left, void *right) {
if (((IntersectionEventList *) left)->tail == NULL) {
((IntersectionEventList *) left)->head = ((IntersectionEventList *) right)->head;
((IntersectionEventList *) left)->tail = ((IntersectionEventList *) right)->tail;
} else if (((IntersectionEventList *) right)->head != NULL) {
((IntersectionEventList *) left)->tail->next = ((IntersectionEventList *) right)->head;
((IntersectionEventList *) left)->tail = ((IntersectionEventList *) right)->tail;
}
((IntersectionEventList *) right)->head = NULL;
((IntersectionEventList *) right)->tail = NULL;
}
typedef IntersectionEventList cilk_reducer(identity, reduce) IntersectionEventListReducer;
// Appends a new node to the list with the data (l1, l2, intersectionType).
// Precondition: compareLines(l1, l2) < 0 must be true.
void IntersectionEventList_appendNode(
IntersectionEventListReducer* intersectionEventList, Line* l1, Line* l2,
IntersectionType intersectionType);
// Deletes all the nodes in the list.
void IntersectionEventList_deleteNodes(
IntersectionEventListReducer* intersectionEventList);
#endif // INTERSECTIONEVENTLIST_H_