Added freeurl.
[doldaconnect.git] / common / http.c
1 /*
2  *  Dolda Connect - Modular multiuser Direct Connect-style client
3  *  Copyright (C) 2007 Fredrik Tolf (fredrik@dolda2000.com)
4  *  
5  *  This program is free software; you can redistribute it and/or modify
6  *  it under the terms of the GNU General Public License as published by
7  *  the Free Software Foundation; either version 2 of the License, or
8  *  (at your option) any later version.
9  *  
10  *  This program is distributed in the hope that it will be useful,
11  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  *  GNU General Public License for more details.
14  *  
15  *  You should have received a copy of the GNU General Public License
16  *  along with this program; if not, write to the Free Software
17  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18 */
19
20 #include <stdlib.h>
21 #include <stdio.h>
22 #include <unistd.h>
23 #include <string.h>
24 #include <sys/socket.h>
25
26 #ifdef HAVE_CONFIG_H
27 #include <config.h>
28 #endif
29 #include <utils.h>
30 #include <http.h>
31
32 void freeurl(struct hturlinfo *ui)
33 {
34     free(ui->host);
35     free(ui->path);
36     free(ui->query);
37     free(ui);
38 }
39
40 struct hturlinfo *parseurl(char *url)
41 {
42     char *p, *p2, *p3;
43     struct hturlinfo *ui;
44     
45     if(strncmp(url, "http://", 7))
46         return(NULL);
47     ui = memset(smalloc(sizeof(*ui)), 0, sizeof(*ui));
48     p = url + 7;
49     if((p2 = strchr(p, '/')) != NULL)
50         *(p2++) = 0;
51     if((p3 = strrchr(p, ':')) != NULL) {
52         *(p3++) = 0;
53         ui->port = atoi(p3);
54     }
55     ui->host = sstrdup(p);
56     if(p2 == NULL) {
57         ui->path = sstrdup("/");
58     } else {
59         p = p2;
60         if((p2 = strchr(p, '?')) != NULL)
61             *(p2++) = 0;
62         ui->path = sstrdup(p);
63     }
64     if(p2 == NULL) {
65         ui->query = sstrdup("");
66     } else {
67         ui->query = sstrdup(p2);
68     }
69     return(ui);
70 }