root / logic / trunk / src / init / devicelist.c @ 29
History | View | Annotate | Download (3.88 KB)
1 |
#include "devicelist.h" |
---|---|
2 |
//#include "buf.h"
|
3 |
#include <string.h> |
4 |
#include <mxml.h> |
5 |
|
6 |
device *hDevice; //device list
|
7 |
|
8 |
int setDeviceList()
|
9 |
{ |
10 |
device *curr, *head; |
11 |
head = NULL;
|
12 |
|
13 |
FILE *fp; |
14 |
mxml_node_t *tree, *node; |
15 |
|
16 |
if(fp = fopen("./src/init/devicetree.xml", "r")) //TODO !hardcoded |
17 |
{ |
18 |
printf("File read!\n");
|
19 |
} |
20 |
else
|
21 |
printf("Error!");
|
22 |
|
23 |
tree = mxmlLoadFile(NULL, fp, MXML_IGNORE_CALLBACK);
|
24 |
node = tree; |
25 |
fclose(fp); |
26 |
|
27 |
/* //structure of XML tree
|
28 |
?xml
|
29 |
|
|
30 |
devicetree
|
31 |
|
|
32 |
dev1 - dev2 - ...
|
33 |
| |
|
34 |
| |
|
35 |
| ID - name - minvalue - maxvalue - action - param
|
36 |
ID - name - minvalue - maxvalue - action - param
|
37 |
/**/
|
38 |
//getting to the correct level of the xml tree (descend 2 levels)
|
39 |
node=node->child->child; |
40 |
// printf("hDevice %d\n", hDevice);
|
41 |
|
42 |
// fill the list of known devices
|
43 |
// sorry for the ugly chunk of code, but I had to allocate memory
|
44 |
// for each string separately in order to keep it scalable
|
45 |
while(node!=NULL) |
46 |
{ |
47 |
curr = (device *)malloc(sizeof(device));
|
48 |
|
49 |
curr->id = (char *)malloc(sizeof(node->value.element.attrs->value)*strlen(node->value.element.attrs->value)); |
50 |
strcpy(curr->id, node->value.element.attrs->value); |
51 |
printf("id:\t %s\n", curr->id );
|
52 |
printf("----------------------------------------------\n");
|
53 |
//*
|
54 |
// getting data for individual device
|
55 |
mxml_node_t *mxml_deviceNode; |
56 |
mxml_deviceNode=node->child; |
57 |
//TODO malloc()
|
58 |
curr->name = (char *)malloc(sizeof(mxml_deviceNode->value.element.attrs->value)*strlen(node->value.element.attrs->value)); |
59 |
strcpy(curr->name, mxml_deviceNode->value.element.attrs->value); |
60 |
mxml_deviceNode= mxml_deviceNode->next; |
61 |
printf("name:\t %s\n", curr->name );
|
62 |
|
63 |
curr->readitv = atoi(mxml_deviceNode->value.element.attrs->value); |
64 |
mxml_deviceNode= mxml_deviceNode->next; |
65 |
printf("readitv:\t %d s\n", curr->readitv );
|
66 |
|
67 |
curr->action = (char *)malloc(sizeof(mxml_deviceNode->value.element.attrs->value)*strlen(node->value.element.attrs->value)); |
68 |
strcpy(curr->action, mxml_deviceNode->value.element.attrs->value); |
69 |
mxml_deviceNode= mxml_deviceNode->next; |
70 |
printf("action:\t %s\n", curr->action );
|
71 |
|
72 |
curr->param = (char *)malloc(sizeof(mxml_deviceNode->value.element.attrs->value)*strlen(node->value.element.attrs->value)); |
73 |
strcpy(curr->param, mxml_deviceNode->value.element.attrs->value); |
74 |
printf("param:\t %s\n", curr->param );
|
75 |
|
76 |
// done
|
77 |
/*
|
78 |
// TA DEL KODE V TEM KOMENTARJU NE BO UPORABLJEN, IGNORE!
|
79 |
// TODO create buffer
|
80 |
curr->buf = init_buf((int)(HISTORY_LENGTH/curr->readitv));
|
81 |
// -------------- buffer test-----------------------------!
|
82 |
//printf("curr buf_size %d\n", curr->buf->buffer_size);
|
83 |
//printf("curr buf_load %d\n", curr->buf->buffer_load);
|
84 |
//printf("buf_pos %d\n", &curr->buf);
|
85 |
//*
|
86 |
int num;
|
87 |
buf_put(10, curr->buf);
|
88 |
//printf("num %d\n",*curr->buf->start_el );
|
89 |
buf_get(&num, curr->buf);
|
90 |
printf("num %d\n",num);
|
91 |
// -------------- buffer test end-------------------------!
|
92 |
/**/
|
93 |
// moving to the next XML node
|
94 |
node=node->next; |
95 |
|
96 |
curr->nxt = head; |
97 |
head = curr; |
98 |
} |
99 |
hDevice=head; // handle to device list
|
100 |
//delete obsolete xml tree
|
101 |
mxmlDelete(tree); |
102 |
mxmlDelete(node); |
103 |
/*
|
104 |
// TODO delete - test
|
105 |
curr=head;
|
106 |
printf("test device list\n");
|
107 |
// DEBUG
|
108 |
while(curr)
|
109 |
{
|
110 |
printf("name:\t %s\n", curr->name );
|
111 |
printf("id:\t %s\n", curr->id );
|
112 |
printf("readitv:\t %d s\n", curr->readitv );
|
113 |
printf("action:\t %s\n", curr->action );
|
114 |
printf("param:\t %s\n", curr->param );
|
115 |
curr=curr->nxt;
|
116 |
}
|
117 |
/**/
|
118 |
return 1; |
119 |
} |
120 |
|
121 |
/*
|
122 |
void updateDeviceList(device_d *deviceList)
|
123 |
{
|
124 |
|
125 |
}
|
126 |
/**/
|