mirror of
https://github.com/netsurf-browser/netsurf
synced 2024-12-17 09:42:38 +03:00
extend file table with mkdir all and make fs backing store use it.
enable fs backing store for RISC OS.
This commit is contained in:
parent
80bee65a71
commit
f1c2dde13b
66
amiga/misc.c
66
amiga/misc.c
@ -19,8 +19,10 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
|
||||||
#include <proto/dos.h>
|
#include <proto/dos.h>
|
||||||
#include <proto/exec.h>
|
#include <proto/exec.h>
|
||||||
@ -362,12 +364,76 @@ static nserror amiga_basename(const char *path, char **str, size_t *size)
|
|||||||
return NSERROR_OK;
|
return NSERROR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* @param fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
static nserror amiga_mkdir_all(const char *fname)
|
||||||
|
{
|
||||||
|
char *dname;
|
||||||
|
char *sep;
|
||||||
|
struct stat sb;
|
||||||
|
|
||||||
|
dname = strdup(fname);
|
||||||
|
|
||||||
|
sep = strrchr(dname, '/');
|
||||||
|
if (sep == NULL) {
|
||||||
|
/* no directory separator path is just filename so its ok */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
*sep = 0; /* null terminate directory path */
|
||||||
|
|
||||||
|
if (stat(dname, &sb) == 0) {
|
||||||
|
free(dname);
|
||||||
|
if (S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path to file exists and is a directory */
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
*sep = '/'; /* restore separator */
|
||||||
|
|
||||||
|
sep = dname;
|
||||||
|
while (*sep == '/') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
while ((sep = strchr(sep, '/')) != NULL) {
|
||||||
|
*sep = 0;
|
||||||
|
if (stat(dname, &sb) != 0) {
|
||||||
|
if (nsmkdir(dname, S_IRWXU) != 0) {
|
||||||
|
/* could not create path element */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_FOUND;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (! S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path element not a directory */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*sep = '/'; /* restore separator */
|
||||||
|
/* skip directory separators */
|
||||||
|
while (*sep == '/') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/* amiga file handling operations */
|
/* amiga file handling operations */
|
||||||
static struct gui_file_table file_table = {
|
static struct gui_file_table file_table = {
|
||||||
.mkpath = amiga_vmkpath,
|
.mkpath = amiga_vmkpath,
|
||||||
.basename = amiga_basename,
|
.basename = amiga_basename,
|
||||||
.nsurl_to_path = amiga_nsurl_to_path,
|
.nsurl_to_path = amiga_nsurl_to_path,
|
||||||
.path_to_nsurl = amiga_path_to_nsurl,
|
.path_to_nsurl = amiga_path_to_nsurl,
|
||||||
|
.mkdir_all = amiga_mkdir_all,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct gui_file_table *amiga_file_table = &file_table;
|
struct gui_file_table *amiga_file_table = &file_table;
|
||||||
|
@ -627,7 +627,7 @@ store_open(struct store_state *state,
|
|||||||
|
|
||||||
/** @todo mkdir only on write flag */
|
/** @todo mkdir only on write flag */
|
||||||
/* ensure path to file is usable */
|
/* ensure path to file is usable */
|
||||||
ret = filepath_mkdir_all(fname);
|
ret = netsurf_mkdir_all(fname);
|
||||||
if (ret != NSERROR_OK) {
|
if (ret != NSERROR_OK) {
|
||||||
LOG(("file path \"%s\" could not be created", fname));
|
LOG(("file path \"%s\" could not be created", fname));
|
||||||
free(fname);
|
free(fname);
|
||||||
@ -835,7 +835,9 @@ write_control(struct store_state *state)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = filepath_mkdir_all(fname);
|
LOG(("writing control file \"%s\"", fname));
|
||||||
|
|
||||||
|
ret = netsurf_mkdir_all(fname);
|
||||||
if (ret != NSERROR_OK) {
|
if (ret != NSERROR_OK) {
|
||||||
free(fname);
|
free(fname);
|
||||||
return ret;
|
return ret;
|
||||||
@ -881,6 +883,8 @@ read_control(struct store_state *state)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOG(("opening control file \"%s\"", fname));
|
||||||
|
|
||||||
fcontrol = fopen(fname, "rb");
|
fcontrol = fopen(fname, "rb");
|
||||||
|
|
||||||
free(fname);
|
free(fname);
|
||||||
|
@ -506,6 +506,15 @@ static nserror verify_file_register(struct gui_file_table *gft)
|
|||||||
if (gft->basename == NULL) {
|
if (gft->basename == NULL) {
|
||||||
return NSERROR_BAD_PARAMETER;
|
return NSERROR_BAD_PARAMETER;
|
||||||
}
|
}
|
||||||
|
if (gft->nsurl_to_path == NULL) {
|
||||||
|
return NSERROR_BAD_PARAMETER;
|
||||||
|
}
|
||||||
|
if (gft->path_to_nsurl == NULL) {
|
||||||
|
return NSERROR_BAD_PARAMETER;
|
||||||
|
}
|
||||||
|
if (gft->mkdir_all == NULL) {
|
||||||
|
return NSERROR_BAD_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
return NSERROR_OK;
|
return NSERROR_OK;
|
||||||
}
|
}
|
||||||
|
@ -1092,7 +1092,7 @@ static nserror create_config_home(char **config_home_out)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ensure all elements of path exist (the trailing / is required) */
|
/* ensure all elements of path exist (the trailing / is required) */
|
||||||
ret = filepath_mkdir_all(config_home);
|
ret = netsurf_mkdir_all(config_home);
|
||||||
if (ret != NSERROR_OK) {
|
if (ret != NSERROR_OK) {
|
||||||
free(config_home);
|
free(config_home);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1190,7 +1190,7 @@ static nserror create_cache_home(char **cache_home_out)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* ensure all elements of path exist (the trailing / is required) */
|
/* ensure all elements of path exist (the trailing / is required) */
|
||||||
ret = filepath_mkdir_all(cache_home);
|
ret = netsurf_mkdir_all(cache_home);
|
||||||
if (ret != NSERROR_OK) {
|
if (ret != NSERROR_OK) {
|
||||||
free(cache_home);
|
free(cache_home);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -26,5 +26,8 @@ NETSURF_USE_PLUGINS := NO
|
|||||||
# Valid options: YES, NO
|
# Valid options: YES, NO
|
||||||
NETSURF_USE_DRAW_EXPORT := YES
|
NETSURF_USE_DRAW_EXPORT := YES
|
||||||
|
|
||||||
|
# Enable building the source object cache filesystem based backing store.
|
||||||
|
NETSURF_FS_BACKING_STORE := YES
|
||||||
|
|
||||||
# Optimisation levels
|
# Optimisation levels
|
||||||
CFLAGS += -O2
|
CFLAGS += -O2
|
||||||
|
83
riscos/gui.c
83
riscos/gui.c
@ -53,6 +53,7 @@
|
|||||||
#include "desktop/netsurf.h"
|
#include "desktop/netsurf.h"
|
||||||
#include "content/urldb.h"
|
#include "content/urldb.h"
|
||||||
#include "content/hlcache.h"
|
#include "content/hlcache.h"
|
||||||
|
#include "content/backing_store.h"
|
||||||
|
|
||||||
#include "riscos/gui.h"
|
#include "riscos/gui.h"
|
||||||
#include "riscos/wimputils.h"
|
#include "riscos/wimputils.h"
|
||||||
@ -335,22 +336,6 @@ static nserror set_defaults(struct nsoption_s *defaults)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create directory structure for a path
|
|
||||||
*
|
|
||||||
* Given a path of x.y.z directories x and x.y will be created
|
|
||||||
*
|
|
||||||
* \param path the directory path to create
|
|
||||||
*/
|
|
||||||
static void ro_gui_create_dir(char *path)
|
|
||||||
{
|
|
||||||
char *cur = path;
|
|
||||||
while ((cur = strchr(cur, '.'))) {
|
|
||||||
*cur = '\0';
|
|
||||||
xosfile_create_dir(path, 0);
|
|
||||||
*cur++ = '.';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -367,23 +352,23 @@ static void ro_gui_create_dirs(void)
|
|||||||
die("Failed to find NetSurf Choices save path");
|
die("Failed to find NetSurf Choices save path");
|
||||||
|
|
||||||
snprintf(buf, sizeof(buf), "%s", path);
|
snprintf(buf, sizeof(buf), "%s", path);
|
||||||
ro_gui_create_dir(buf);
|
netsurf_mkdir_all(buf);
|
||||||
|
|
||||||
/* URL */
|
/* URL */
|
||||||
snprintf(buf, sizeof(buf), "%s", nsoption_charp(url_save));
|
snprintf(buf, sizeof(buf), "%s", nsoption_charp(url_save));
|
||||||
ro_gui_create_dir(buf);
|
netsurf_mkdir_all(buf);
|
||||||
|
|
||||||
/* Hotlist */
|
/* Hotlist */
|
||||||
snprintf(buf, sizeof(buf), "%s", nsoption_charp(hotlist_save));
|
snprintf(buf, sizeof(buf), "%s", nsoption_charp(hotlist_save));
|
||||||
ro_gui_create_dir(buf);
|
netsurf_mkdir_all(buf);
|
||||||
|
|
||||||
/* Recent */
|
/* Recent */
|
||||||
snprintf(buf, sizeof(buf), "%s", nsoption_charp(recent_save));
|
snprintf(buf, sizeof(buf), "%s", nsoption_charp(recent_save));
|
||||||
ro_gui_create_dir(buf);
|
netsurf_mkdir_all(buf);
|
||||||
|
|
||||||
/* Theme */
|
/* Theme */
|
||||||
snprintf(buf, sizeof(buf), "%s", nsoption_charp(theme_save));
|
snprintf(buf, sizeof(buf), "%s", nsoption_charp(theme_save));
|
||||||
ro_gui_create_dir(buf);
|
netsurf_mkdir_all(buf);
|
||||||
/* and the final directory part (as theme_save is a directory) */
|
/* and the final directory part (as theme_save is a directory) */
|
||||||
xosfile_create_dir(buf, 0);
|
xosfile_create_dir(buf, 0);
|
||||||
}
|
}
|
||||||
@ -2337,6 +2322,33 @@ static nserror riscos_basename(const char *path, char **str, size_t *size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* Given a path of x.y.z directories x and x.y will be created.
|
||||||
|
*
|
||||||
|
* @param fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
static nserror riscos_mkdir_all(const char *fname)
|
||||||
|
{
|
||||||
|
char *dname;
|
||||||
|
char *cur;
|
||||||
|
|
||||||
|
dname = strdup(fname);
|
||||||
|
|
||||||
|
cur = dname;
|
||||||
|
while ((cur = strchr(cur, '.'))) {
|
||||||
|
*cur = '\0';
|
||||||
|
xosfile_create_dir(dname, 0);
|
||||||
|
*cur++ = '.';
|
||||||
|
}
|
||||||
|
|
||||||
|
free(dname);
|
||||||
|
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find screen size in OS units.
|
* Find screen size in OS units.
|
||||||
*/
|
*/
|
||||||
@ -2382,6 +2394,7 @@ static struct gui_file_table riscos_file_table = {
|
|||||||
.basename = riscos_basename,
|
.basename = riscos_basename,
|
||||||
.nsurl_to_path = ro_nsurl_to_path,
|
.nsurl_to_path = ro_nsurl_to_path,
|
||||||
.path_to_nsurl = ro_path_to_nsurl,
|
.path_to_nsurl = ro_path_to_nsurl,
|
||||||
|
.mkdir_all = riscos_mkdir_all,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct gui_fetch_table riscos_fetch_table = {
|
static struct gui_fetch_table riscos_fetch_table = {
|
||||||
@ -2403,11 +2416,30 @@ static struct gui_browser_table riscos_browser_table = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
static char *get_cachepath(void)
|
||||||
|
{
|
||||||
|
char *cachedir;
|
||||||
|
char *cachepath = NULL;
|
||||||
|
nserror ret;
|
||||||
|
|
||||||
|
cachedir = getenv("Cache$Dir");
|
||||||
|
if ((cachedir == NULL) || (cachedir[0] == 0)) {
|
||||||
|
LOG(("cachedir was null"));
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
ret = netsurf_mkpath(&cachepath, NULL, 2, cachedir, "NetSurf");
|
||||||
|
if (ret != NSERROR_OK) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return cachepath;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Normal entry point from RISC OS.
|
* Normal entry point from RISC OS.
|
||||||
*/
|
*/
|
||||||
int main(int argc, char** argv)
|
int main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
|
char *cachepath;
|
||||||
char path[40];
|
char path[40];
|
||||||
int length;
|
int length;
|
||||||
os_var_type type;
|
os_var_type type;
|
||||||
@ -2423,6 +2455,7 @@ int main(int argc, char** argv)
|
|||||||
.file = &riscos_file_table,
|
.file = &riscos_file_table,
|
||||||
.utf8 = riscos_utf8_table,
|
.utf8 = riscos_utf8_table,
|
||||||
.search = riscos_search_table,
|
.search = riscos_search_table,
|
||||||
|
.llcache = filesystem_llcache_table,
|
||||||
};
|
};
|
||||||
|
|
||||||
ret = netsurf_register(&riscos_table);
|
ret = netsurf_register(&riscos_table);
|
||||||
@ -2473,10 +2506,14 @@ int main(int argc, char** argv)
|
|||||||
die("Failed to locate Messages resource.");
|
die("Failed to locate Messages resource.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* obtain cache path */
|
||||||
|
cachepath = get_cachepath();
|
||||||
|
|
||||||
/* common initialisation */
|
/* common initialisation */
|
||||||
ret = netsurf_init(path, NULL);
|
ret = netsurf_init(path, cachepath);
|
||||||
|
free(cachepath);
|
||||||
if (ret != NSERROR_OK) {
|
if (ret != NSERROR_OK) {
|
||||||
die("NetSurf failed to initialise");
|
die("NetSurf failed to initialise core");
|
||||||
}
|
}
|
||||||
|
|
||||||
artworks_init();
|
artworks_init();
|
||||||
|
73
utils/file.c
73
utils/file.c
@ -23,6 +23,9 @@
|
|||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "desktop/gui_factory.h"
|
#include "desktop/gui_factory.h"
|
||||||
|
|
||||||
@ -194,6 +197,69 @@ static nserror posix_path_to_nsurl(const char *path, struct nsurl **url_out)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* @param fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
static nserror posix_mkdir_all(const char *fname)
|
||||||
|
{
|
||||||
|
char *dname;
|
||||||
|
char *sep;
|
||||||
|
struct stat sb;
|
||||||
|
|
||||||
|
dname = strdup(fname);
|
||||||
|
|
||||||
|
sep = strrchr(dname, '/');
|
||||||
|
if (sep == NULL) {
|
||||||
|
/* no directory separator path is just filename so its ok */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
*sep = 0; /* null terminate directory path */
|
||||||
|
|
||||||
|
if (stat(dname, &sb) == 0) {
|
||||||
|
free(dname);
|
||||||
|
if (S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path to file exists and is a directory */
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
*sep = '/'; /* restore separator */
|
||||||
|
|
||||||
|
sep = dname;
|
||||||
|
while (*sep == '/') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
while ((sep = strchr(sep, '/')) != NULL) {
|
||||||
|
*sep = 0;
|
||||||
|
if (stat(dname, &sb) != 0) {
|
||||||
|
if (nsmkdir(dname, S_IRWXU) != 0) {
|
||||||
|
/* could not create path element */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_FOUND;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (! S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path element not a directory */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*sep = '/'; /* restore separator */
|
||||||
|
/* skip directory separators */
|
||||||
|
while (*sep == '/') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* default to using the posix file handling
|
* default to using the posix file handling
|
||||||
*/
|
*/
|
||||||
@ -202,6 +268,7 @@ static struct gui_file_table file_table = {
|
|||||||
.basename = posix_basename,
|
.basename = posix_basename,
|
||||||
.nsurl_to_path = posix_nsurl_to_path,
|
.nsurl_to_path = posix_nsurl_to_path,
|
||||||
.path_to_nsurl = posix_path_to_nsurl,
|
.path_to_nsurl = posix_path_to_nsurl,
|
||||||
|
.mkdir_all = posix_mkdir_all,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct gui_file_table *default_file_table = &file_table;
|
struct gui_file_table *default_file_table = &file_table;
|
||||||
@ -230,3 +297,9 @@ nserror netsurf_path_to_nsurl(const char *path, struct nsurl **url)
|
|||||||
{
|
{
|
||||||
return guit->file->path_to_nsurl(path, url);
|
return guit->file->path_to_nsurl(path, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* exported interface documented in utils/file.h */
|
||||||
|
nserror netsurf_mkdir_all(const char *fname)
|
||||||
|
{
|
||||||
|
return guit->file->mkdir_all(fname);
|
||||||
|
}
|
||||||
|
16
utils/file.h
16
utils/file.h
@ -106,6 +106,14 @@ struct gui_file_table {
|
|||||||
* code on faliure.
|
* code on faliure.
|
||||||
*/
|
*/
|
||||||
nserror (*path_to_nsurl)(const char *path, struct nsurl **url);
|
nserror (*path_to_nsurl)(const char *path, struct nsurl **url);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* @param[in] fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
nserror (*mkdir_all)(const char *fname);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Default (posix) file operation table. */
|
/** Default (posix) file operation table. */
|
||||||
@ -156,4 +164,12 @@ nserror netsurf_nsurl_to_path(struct nsurl *url, char **path_out);
|
|||||||
*/
|
*/
|
||||||
nserror netsurf_path_to_nsurl(const char *path, struct nsurl **url);
|
nserror netsurf_path_to_nsurl(const char *path, struct nsurl **url);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* @param fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
nserror netsurf_mkdir_all(const char *fname);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -325,60 +325,3 @@ void filepath_free_strvec(char **pathv)
|
|||||||
free(pathv);
|
free(pathv);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* exported interface documented in filepath.h */
|
|
||||||
nserror filepath_mkdir_all(const char *fname)
|
|
||||||
{
|
|
||||||
char *dname;
|
|
||||||
char *sep;
|
|
||||||
struct stat sb;
|
|
||||||
|
|
||||||
dname = strdup(fname);
|
|
||||||
|
|
||||||
sep = strrchr(dname, '/');
|
|
||||||
if (sep == NULL) {
|
|
||||||
/* no directory separator path is just filename so its ok */
|
|
||||||
free(dname);
|
|
||||||
return NSERROR_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
*sep = 0; /* null terminate directory path */
|
|
||||||
|
|
||||||
if (stat(dname, &sb) == 0) {
|
|
||||||
free(dname);
|
|
||||||
if (S_ISDIR(sb.st_mode)) {
|
|
||||||
/* path to file exists and is a directory */
|
|
||||||
return NSERROR_OK;
|
|
||||||
}
|
|
||||||
return NSERROR_NOT_DIRECTORY;
|
|
||||||
}
|
|
||||||
*sep = '/'; /* restore separator */
|
|
||||||
|
|
||||||
sep = dname;
|
|
||||||
while (*sep == '/') {
|
|
||||||
sep++;
|
|
||||||
}
|
|
||||||
while ((sep = strchr(sep, '/')) != NULL) {
|
|
||||||
*sep = 0;
|
|
||||||
if (stat(dname, &sb) != 0) {
|
|
||||||
if (nsmkdir(dname, S_IRWXU) != 0) {
|
|
||||||
/* could not create path element */
|
|
||||||
free(dname);
|
|
||||||
return NSERROR_NOT_FOUND;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (! S_ISDIR(sb.st_mode)) {
|
|
||||||
/* path element not a directory */
|
|
||||||
free(dname);
|
|
||||||
return NSERROR_NOT_DIRECTORY;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*sep = '/'; /* restore separator */
|
|
||||||
/* skip directory separators */
|
|
||||||
while (*sep == '/') {
|
|
||||||
sep++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
free(dname);
|
|
||||||
return NSERROR_OK;
|
|
||||||
}
|
|
||||||
|
@ -127,13 +127,5 @@ char **filepath_path_to_strvec(const char *path);
|
|||||||
void filepath_free_strvec(char **pathv);
|
void filepath_free_strvec(char **pathv);
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Ensure that all directory elements needed to store a filename exist.
|
|
||||||
*
|
|
||||||
* @param fname The filename to ensure the path to exists.
|
|
||||||
* @return NSERROR_OK on success or error code on failure.
|
|
||||||
*/
|
|
||||||
nserror filepath_mkdir_all(const char *fname);
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* _NETSURF_UTILS_FILEPATH_H_ */
|
#endif /* _NETSURF_UTILS_FILEPATH_H_ */
|
||||||
|
@ -2009,12 +2009,76 @@ static nserror windows_path_to_nsurl(const char *path, struct nsurl **url_out)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ensure that all directory elements needed to store a filename exist.
|
||||||
|
*
|
||||||
|
* @param fname The filename to ensure the path to exists.
|
||||||
|
* @return NSERROR_OK on success or error code on failure.
|
||||||
|
*/
|
||||||
|
static nserror windows_mkdir_all(const char *fname)
|
||||||
|
{
|
||||||
|
char *dname;
|
||||||
|
char *sep;
|
||||||
|
struct stat sb;
|
||||||
|
|
||||||
|
dname = strdup(fname);
|
||||||
|
|
||||||
|
sep = strrchr(dname, '\\');
|
||||||
|
if (sep == NULL) {
|
||||||
|
/* no directory separator path is just filename so its ok */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
*sep = 0; /* null terminate directory path */
|
||||||
|
|
||||||
|
if (stat(dname, &sb) == 0) {
|
||||||
|
free(dname);
|
||||||
|
if (S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path to file exists and is a directory */
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
*sep = '\\'; /* restore separator */
|
||||||
|
|
||||||
|
sep = dname;
|
||||||
|
while (*sep == '\\') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
while ((sep = strchr(sep, '\\')) != NULL) {
|
||||||
|
*sep = 0;
|
||||||
|
if (stat(dname, &sb) != 0) {
|
||||||
|
if (nsmkdir(dname, S_IRWXU) != 0) {
|
||||||
|
/* could not create path element */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_FOUND;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (! S_ISDIR(sb.st_mode)) {
|
||||||
|
/* path element not a directory */
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_NOT_DIRECTORY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*sep = '\\'; /* restore separator */
|
||||||
|
/* skip directory separators */
|
||||||
|
while (*sep == '\\') {
|
||||||
|
sep++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
free(dname);
|
||||||
|
return NSERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/* windows file handling */
|
/* windows file handling */
|
||||||
static struct gui_file_table file_table = {
|
static struct gui_file_table file_table = {
|
||||||
.mkpath = windows_mkpath,
|
.mkpath = windows_mkpath,
|
||||||
.basename = windows_basename,
|
.basename = windows_basename,
|
||||||
.nsurl_to_path = windows_nsurl_to_path,
|
.nsurl_to_path = windows_nsurl_to_path,
|
||||||
.path_to_nsurl = windows_path_to_nsurl,
|
.path_to_nsurl = windows_path_to_nsurl,
|
||||||
|
.mkdir_all = windows_mkdir_all,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct gui_file_table *win32_file_table = &file_table;
|
struct gui_file_table *win32_file_table = &file_table;
|
||||||
|
Loading…
Reference in New Issue
Block a user