mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-24 11:22:06 +03:00
Ensure urldb_add_path always has a path.
Extract hostname from url authority returned by url_get_components. svn path=/trunk/netsurf/; revision=2958
This commit is contained in:
parent
bd0dff9098
commit
09d2b99973
@ -120,7 +120,7 @@ struct auth_data {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct cache_internal_data {
|
struct cache_internal_data {
|
||||||
char filename[12]; /**< Cached filename, or first byte 0 for none */
|
char filename[12]; /**< Cached filename, or first byte 0 for none */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct url_internal_data {
|
struct url_internal_data {
|
||||||
@ -425,7 +425,7 @@ void urldb_load(const char *filename)
|
|||||||
(port ? ports : ""),
|
(port ? ports : ""),
|
||||||
s);
|
s);
|
||||||
|
|
||||||
p = urldb_add_path(scheme, port, h, s, NULL, NULL,
|
p = urldb_add_path(scheme, port, h, s, NULL, NULL,
|
||||||
url);
|
url);
|
||||||
if (!p) {
|
if (!p) {
|
||||||
LOG(("Failed inserting '%s'", url));
|
LOG(("Failed inserting '%s'", url));
|
||||||
@ -710,6 +710,7 @@ bool urldb_add_url(const char *url)
|
|||||||
struct host_part *h;
|
struct host_part *h;
|
||||||
struct path_data *p;
|
struct path_data *p;
|
||||||
char *colon;
|
char *colon;
|
||||||
|
const char *host;
|
||||||
unsigned short port;
|
unsigned short port;
|
||||||
url_func_result ret;
|
url_func_result ret;
|
||||||
struct url_components components;
|
struct url_components components;
|
||||||
@ -721,8 +722,15 @@ bool urldb_add_url(const char *url)
|
|||||||
if (ret != URL_FUNC_OK)
|
if (ret != URL_FUNC_OK)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
/* Extract host part from authority */
|
||||||
|
host = strchr(components.authority, '@');
|
||||||
|
if (!host)
|
||||||
|
host = components.authority;
|
||||||
|
else
|
||||||
|
host++;
|
||||||
|
|
||||||
/* get port and remove from authority */
|
/* get port and remove from authority */
|
||||||
colon = strrchr(components.authority, ':');
|
colon = strrchr(host, ':');
|
||||||
if (!colon) {
|
if (!colon) {
|
||||||
port = 0;
|
port = 0;
|
||||||
} else {
|
} else {
|
||||||
@ -734,21 +742,22 @@ bool urldb_add_url(const char *url)
|
|||||||
if (strcasecmp(components.scheme, "file") == 0)
|
if (strcasecmp(components.scheme, "file") == 0)
|
||||||
h = urldb_add_host("localhost");
|
h = urldb_add_host("localhost");
|
||||||
else
|
else
|
||||||
h = urldb_add_host(components.authority);
|
h = urldb_add_host(host);
|
||||||
if (!h) {
|
if (!h) {
|
||||||
url_destroy_components(&components);
|
url_destroy_components(&components);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get path entry */
|
/* Get path entry */
|
||||||
p = urldb_add_path(components.scheme, port, h, components.path,
|
p = urldb_add_path(components.scheme, port, h,
|
||||||
|
components.path ? components.path : "",
|
||||||
components.query, components.fragment, url);
|
components.query, components.fragment, url);
|
||||||
if (!p) {
|
if (!p) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
url_destroy_components(&components);
|
url_destroy_components(&components);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1578,8 +1587,8 @@ struct path_data *urldb_add_path_node(const char *scheme, unsigned int port,
|
|||||||
* \return Pointer to leaf node, or NULL on memory exhaustion
|
* \return Pointer to leaf node, or NULL on memory exhaustion
|
||||||
*/
|
*/
|
||||||
struct path_data *urldb_add_path(const char *scheme, unsigned int port,
|
struct path_data *urldb_add_path(const char *scheme, unsigned int port,
|
||||||
const struct host_part *host, const char *path, const char *query,
|
const struct host_part *host, const char *path,
|
||||||
const char *fragment, const char *url)
|
const char *query, const char *fragment, const char *url)
|
||||||
{
|
{
|
||||||
struct path_data *d, *e;
|
struct path_data *d, *e;
|
||||||
char *buf, *copy;
|
char *buf, *copy;
|
||||||
@ -1605,10 +1614,10 @@ struct path_data *urldb_add_path(const char *scheme, unsigned int port,
|
|||||||
copy += strlen(path);
|
copy += strlen(path);
|
||||||
}
|
}
|
||||||
if (query) {
|
if (query) {
|
||||||
*copy++ = '?';
|
*copy++ = '?';
|
||||||
strcpy(copy, query);
|
strcpy(copy, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* skip leading '/' */
|
/* skip leading '/' */
|
||||||
segment = buf;
|
segment = buf;
|
||||||
if (*segment == '/')
|
if (*segment == '/')
|
||||||
@ -3364,7 +3373,7 @@ bool urldb_set_cache_data(const char *url, const struct content *content) {
|
|||||||
p = urldb_find_url(url);
|
p = urldb_find_url(url);
|
||||||
if (!p)
|
if (!p)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
/* new filename needed */
|
/* new filename needed */
|
||||||
if (p->cache.filename[0] == 0) {
|
if (p->cache.filename[0] == 0) {
|
||||||
filename = filename_request();
|
filename = filename_request();
|
||||||
@ -3372,7 +3381,7 @@ bool urldb_set_cache_data(const char *url, const struct content *content) {
|
|||||||
return false;
|
return false;
|
||||||
sprintf(p->cache.filename, filename);
|
sprintf(p->cache.filename, filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* todo: save content, set cache data etc */
|
/* todo: save content, set cache data etc */
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -3392,7 +3401,7 @@ char *urldb_get_cache_data(const char *url) {
|
|||||||
p = urldb_find_url(url);
|
p = urldb_find_url(url);
|
||||||
if (!p)
|
if (!p)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* no file cache */
|
/* no file cache */
|
||||||
if (p->cache.filename[0] == 0)
|
if (p->cache.filename[0] == 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user