blob: 7a7365ee2f21f2de289879b21548127a50f2130d (
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
|
#ifndef MAGI_INCLUDED_COOKIE
#define MAGI_INCLUDED_COOKIE
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Cookie
*/
struct magi_cookie {
char * name; /* name: free(name) is valid. */
char * data; /* data: free(data) is valid. */
/* Following is used in Cookie2: */
char * path; /* path: free(path) is valid. */
char * domain; /* domain: free(domain) is valid. */
char * port; /* port: free(port) is valid. */
};
/* Null is valid "struct magi_cookie_list *" object. */
struct magi_cookie_list {
struct magi_cookie_list * next;
struct magi_cookie item;
};
/* Returns null in case of error. */
int magi_parse_cookie(struct magi_cookie_list ** list, const char * input);
/*
* Adds *item to the begining of *list, item and list are dereferencable;
* Returns null in case of error.
*/
int magi_cookie_list_add(struct magi_cookie_list ** list,
struct magi_cookie * item);
/*
* Searchs for first node in list: node.name == name, name is C-string;
* Returns node.data if succeed, otherwise result is null.
*/
char * magi_cookie_list_get(struct magi_cookie_list * list, const char * name);
/*
* Destroys list; list is not valid after destruction.
*/
void magi_cookie_list_destroy(struct magi_cookie_list * list);
#endif
|