HomePort
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
httpd_url_parser.h
Go to the documentation of this file.
1 /*
2  * Copyright 2011 Aalborg University. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without modification, are
5  * permitted provided that the following conditions are met:
6  *
7  * 1. Redistributions of source code must retain the above copyright notice, this list of
8  * conditions and the following disclaimer.
9  *
10  * 2. Redistributions in binary form must reproduce the above copyright notice, this list
11  * of conditions and the following disclaimer in the documentation and/or other materials
12  * provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY Aalborg University ''AS IS'' AND ANY EXPRESS OR IMPLIED
15  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
16  * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL Aalborg University OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
19  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
20  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
21  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
22  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23  *
24  * The views and conclusions contained in the software and documentation are those of the
25  * authors and should not be interpreted as representing official policies, either expressed
26  */
27 
28 #ifndef HOMEPORT_HTTPD_URL_PARSER_H
29 #define HOMEPORT_HTTPD_URL_PARSER_H
30 
31 #include "hpd/hpd_types.h"
32 
33 typedef hpd_error_t (*up_string_cb)(void *data, const char* parsedSegment, size_t segment_length);
34 typedef hpd_error_t (*up_pair_cb)(void *data, const char* key, size_t key_length, const char* value, size_t value_length);
35 typedef hpd_error_t (*up_void_cb)(void *data);
36 
37 struct up;
38 
59 struct up_settings {
68 };
69 
70 #define UP_SETTINGS_DEFAULT {\
71  .on_begin = NULL, .on_protocol = NULL, .on_host = NULL, \
72  .on_port = NULL, .on_path_segment = NULL, .on_path_complete = NULL, \
73  .on_key_value = NULL, .on_complete = NULL }
74 
75 hpd_error_t up_create(struct up **instance, struct up_settings *settings, const hpd_module_t *context, void *data);
77 
78 hpd_error_t up_add_chunk(struct up *instance, const char *chunk, size_t chunk_size);
80 
81 #endif
struct up * instance
up_void_cb on_begin
up_string_cb on_path_complete
hpd_error_t(* up_void_cb)(void *data)
hpd_error_t(* up_string_cb)(void *data, const char *parsedSegment, size_t segment_length)
An URL Parser instance.
data value
hpd_error_t(* up_pair_cb)(void *data, const char *key, size_t key_length, const char *value, size_t value_length)
up_string_cb on_protocol
up_string_cb on_port
hpd_error_t up_complete(struct up *instance)
Informs the parser that the URL is complete.
hpd_error_t up_destroy(struct up *instance)
Destroy URL parser instance.
struct hp_settings settings
hpd_error_t up_add_chunk(struct up *instance, const char *chunk, size_t chunk_size)
Parse a chunk of an URL.
data key
up_pair_cb on_key_value
enum hpd_error hpd_error_t
Definition: hpd_types.h:167
up_string_cb on_complete
hpd_error_t up_create(struct up **instance, struct up_settings *settings, const hpd_module_t *context, void *data)
Create URL parser instance.
struct data data
up_string_cb on_path_segment
Settings struct for the URL Parser.
up_string_cb on_host