#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