From: Olivier Valentin <valen...@free.fr> --- frontends/framebuffer/fetch.c | 6 ++++-- frontends/gtk/fetch.c | 6 ++++-- frontends/gtk/gui.c | 9 ++++++--- utils/filepath.c | 35 +++++++++++++++++++++++++---------- utils/filepath.h | 14 +++++++++++++- 5 files changed, 52 insertions(+), 18 deletions(-)
diff --git a/frontends/framebuffer/fetch.c b/frontends/framebuffer/fetch.c index f917bddf3..9d76f0818 100644 --- a/frontends/framebuffer/fetch.c +++ b/frontends/framebuffer/fetch.c @@ -48,14 +48,16 @@ */ static nsurl *get_resource_url(const char *path) { - char buf[PATH_MAX]; + char *buf; nsurl *url = NULL; if (strcmp(path, "favicon.ico") == 0) path = "favicon.png"; - if (filepath_sfind(respaths, buf, PATH_MAX, path) == NSERROR_OK) + if (filepath_find(respaths, path, &buf) == NSERROR_OK) { netsurf_path_to_nsurl(buf, &url); + free(buf); + } return url; } diff --git a/frontends/gtk/fetch.c b/frontends/gtk/fetch.c index 98682ffc4..91219ad96 100644 --- a/frontends/gtk/fetch.c +++ b/frontends/gtk/fetch.c @@ -250,15 +250,17 @@ const char *fetch_filetype(const char *unix_path) static nsurl *nsgtk_get_resource_url(const char *path) { - char buf[PATH_MAX]; nsurl *url = NULL; /* favicon.ico -> favicon.png */ if (strcmp(path, "favicon.ico") == 0) { nsurl_create("resource:favicon.png", &url); } else { - if (filepath_sfind(respaths, buf, PATH_MAX, path) == NSERROR_OK) + char *buf; + if (filepath_find(respaths, path, &buf) == NSERROR_OK) { netsurf_path_to_nsurl(buf, &url); + free(buf); + } } return url; diff --git a/frontends/gtk/gui.c b/frontends/gtk/gui.c index 2c5558ddb..725c55b2a 100644 --- a/frontends/gtk/gui.c +++ b/frontends/gtk/gui.c @@ -910,7 +910,7 @@ static nserror nsgtk_add_named_icons_to_theme(void) */ static nserror nsgtk_setup(int argc, char** argv, char **respath) { - char buf[PATH_MAX]; + char *buf; char *resource_filename; char *addr = NULL; nsurl *url; @@ -987,8 +987,11 @@ static nserror nsgtk_setup(int argc, char** argv, char **respath) .pma = true, }); - filepath_sfinddef(respath, buf, PATH_MAX, "mime.types", "/etc/"); - gtk_fetch_filetype_init(buf); + res = filepath_finddef(respath, "mime.types", "/etc/", &buf); + if (res == NSERROR_OK) { + gtk_fetch_filetype_init(buf); + free(buf); + } save_complete_init(); diff --git a/utils/filepath.c b/utils/filepath.c index 82568e298..626dc2c89 100644 --- a/utils/filepath.c +++ b/utils/filepath.c @@ -160,29 +160,44 @@ nserror filepath_find(char **respathv, const char *filename, char **retstr) /* exported interface documented in filepath.h */ nserror -filepath_sfinddef(char **respathv, - char *filepath, - size_t size, - const char *filename, - const char *def) +filepath_finddef(char **respathv, + const char *filename, + const char *def, + char **retstr) { - char *allocatedfilepath; nserror ret; - if ((respathv == NULL) || (respathv[0] == NULL) || (filepath == NULL)) + if ((respathv == NULL) || (respathv[0] == NULL) || (retstr == NULL)) return NSERROR_INVALID; - ret = filepath_find(respathv, filename, &allocatedfilepath); + ret = filepath_find(respathv, filename, retstr); if ((ret != NSERROR_OK) && (def != NULL)) { /* search failed, return the path specified */ if (def[0] == '~') { - ret = filepath_printpath(&allocatedfilepath, "%s/%s/%s", getenv("HOME"), def + 1, filename); + ret = filepath_printpath(retstr, "%s/%s/%s", getenv("HOME"), def + 1, filename); } else { - ret = filepath_printpath(&allocatedfilepath, "%s/%s", def, filename); + ret = filepath_printpath(retstr, "%s/%s", def, filename); } } + return ret; +} + + +/* exported interface documented in filepath.h */ +nserror +filepath_sfinddef(char **respathv, + char *filepath, + size_t size, + const char *filename, + const char *def) +{ + nserror ret; + char *allocatedfilepath; + + ret = filepath_finddef(respathv, filename, def, &allocatedfilepath); + if (ret == NSERROR_OK) { if (strlen(allocatedfilepath) >= size) ret = NSERROR_NOSPACE; diff --git a/utils/filepath.h b/utils/filepath.h index c44f5af7e..f9316c997 100644 --- a/utils/filepath.h +++ b/utils/filepath.h @@ -68,12 +68,24 @@ nserror filepath_find(char **respathv, const char *filename, char **retstr); /** * Searches an array of resource paths for a file optionally forcing a default. * - * Similar to filepath_sfind except if no resource is found the default + * Similar to filepath_find except if no resource is found the default * is used as an additional path element to search, if that still * fails the returned path is set to the concatination of the default * path and the filename. * * @param respathv The resource path vector to iterate. + * @param filename The filename of the resource to search for. + * @param def The default path to use. + * @param retstr The result string containing the path. + * @return NSERROR_OK on success or error code on failure. + */ +nserror filepath_finddef(char **respathv, const char *filename, + const char *def, char **retstr); + +/** + * Variant of filepath_finddef returning the result in a prealocated buffer. + * + * @param respathv The resource path vector to iterate. * @param filepath The buffer to place the result in. * @param size The size of the filepath buffer. * @param filename The filename of the resource to search for. -- 2.45.2