blob: 30b9d6403348e64cc4ca90231737206949e1060a (
plain)
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
|
#include "emb-polyline.h"
#include "emb-logging.h"
#include <stdlib.h>
/**************************************************/
/* EmbPolylineObject */
/**************************************************/
EmbPolylineObject* embPolylineObject_create(EmbPointList* pointList, EmbColor color, int lineType)
{
EmbPolylineObject* heapPolylineObj = 0;
if(!pointList) { embLog_error("emb-polyline.c embPolylineObject_create(), pointList argument is null\n"); return 0; }
heapPolylineObj = (EmbPolylineObject*)malloc(sizeof(EmbPolylineObject));
if(!heapPolylineObj) { embLog_error("emb-polyline.c embPolylineObject_create(), cannot allocate memory for heapPolylineObj\n"); return 0; }
heapPolylineObj->pointList = pointList;
/* TODO: layer */
heapPolylineObj->color = color;
heapPolylineObj->lineType = lineType;
return heapPolylineObj;
}
void embPolylineObject_free(EmbPolylineObject* pointer)
{
embPointList_free(pointer->pointList);
pointer->pointList = 0;
free(pointer);
pointer = 0;
}
/**************************************************/
/* EmbPolylineObjectList */
/**************************************************/
EmbPolylineObjectList* embPolylineObjectList_create(EmbPolylineObject* data)
{
EmbPolylineObjectList* heapPolylineObjList = 0;
if(!data) { embLog_error("emb-polyline.c embPolylineObjectList_create(), data argument is null\n"); return 0; }
heapPolylineObjList = (EmbPolylineObjectList*)malloc(sizeof(EmbPolylineObjectList));
if(!heapPolylineObjList) { embLog_error("emb-polyline.c embPolylineObjectList_create(), cannot allocate memory for heapPolylineObjList\n"); return 0; }
heapPolylineObjList->polylineObj = data;
heapPolylineObjList->next = 0;
return heapPolylineObjList;
}
EmbPolylineObjectList* embPolylineObjectList_add(EmbPolylineObjectList* pointer, EmbPolylineObject* data)
{
if(!pointer) { embLog_error("emb-polyline.c embPolylineObjectList_add(), pointer argument is null\n"); return 0; }
if(!data) { embLog_error("emb-polyline.c embPolylineObjectList_add(), data argument is null\n"); return 0; }
if(pointer->next) { embLog_error("emb-polyline.c embPolylineObjectList_add(), pointer->next should be null\n"); return 0; }
pointer->next = (EmbPolylineObjectList*)malloc(sizeof(EmbPolylineObjectList));
if(!pointer->next) { embLog_error("emb-polyline.c embPolylineObjectList_add(), cannot allocate memory for pointer->next\n"); return 0; }
pointer = pointer->next;
pointer->polylineObj = data;
pointer->next = 0;
return pointer;
}
int embPolylineObjectList_count(EmbPolylineObjectList* pointer)
{
int i = 1;
if(!pointer) return 0;
while(pointer->next)
{
pointer = pointer->next;
i++;
}
return i;
}
int embPolylineObjectList_empty(EmbPolylineObjectList* pointer)
{
if(!pointer)
return 1;
return 0;
}
void embPolylineObjectList_free(EmbPolylineObjectList* pointer)
{
EmbPolylineObjectList* tempPointer = pointer;
EmbPolylineObjectList* nextPointer = 0;
while(tempPointer)
{
nextPointer = tempPointer->next;
embPolylineObject_free(tempPointer->polylineObj);
tempPointer->polylineObj = 0;
free(tempPointer);
tempPointer = nextPointer;
}
pointer = 0;
}
/* kate: bom off; indent-mode cstyle; indent-width 4; replace-trailing-space-save on; */
|