netsurf/windows/findfile.c
Vincent Sanders ad12c46af5 remove extraneous logging
fix windows path_to_url coping with NULL input and allocation errors.
remove forced verbose logging

svn path=/trunk/netsurf/; revision=12147
2011-03-29 20:50:31 +00:00

209 lines
4.7 KiB
C

/*
* Copyright 2008 Daniel Silverstone <dsilvers@netsurf-browser.org>
* Copyright 2009 Mark Benjamin <netsurf-browser.org.MarkBenjamin@dfgh.net>
*
* This file is part of NetSurf, http://www.netsurf-browser.org/
*
* NetSurf is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* NetSurf is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <windows.h>
#include <limits.h>
#include <unistd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <curl/curl.h>
#include "utils/url.h"
#include "utils/log.h"
#include "utils/utils.h"
#include "utils/filepath.h"
#include "windows/findfile.h"
/** Create an array of valid paths to search for resources.
*
* The idea is that all the complex path computation to find resources
* is performed here, once, rather than every time a resource is
* searched for.
*/
char **
nsws_init_resource(const char *resource_path)
{
char **pathv; /* resource path string vector */
char **respath; /* resource paths vector */
const char *lang = NULL;
char *winpath;
int pathi;
char *slsh;
pathv = filepath_path_to_strvec(resource_path);
if (pathv == NULL)
return NULL;
winpath = malloc(MAX_PATH);
GetModuleFileName(NULL, winpath, MAX_PATH);
slsh = strrchr(winpath, '\\');
if (slsh != NULL)
*slsh=0;
strncat(winpath, "\\windows\\res", MAX_PATH);
pathi = 0;
while (pathv[pathi] != NULL)
pathi++;
pathv[pathi] = winpath;
respath = filepath_generate(pathv, &lang);
filepath_free_strvec(pathv);
return respath;
}
static char *realpath(const char *path, char *resolved_path)
{
/* useless, but there we go */
return strncpy(resolved_path, path, PATH_MAX);
}
char *path_to_url(const char *path)
{
char *url;
char *sidx;
if (path == NULL)
return NULL;
url = malloc(strlen(path) + FILE_SCHEME_PREFIX_LEN + 3);
if (url == NULL)
return NULL;
strcpy(url, FILE_SCHEME_PREFIX);
if (*path == '/') {
/* unix style path start, so try wine Z: */
strcat(url, "Z:");
}
strcat(url, path);
sidx = strrchr(url, '\\');
while (sidx != NULL) {
*sidx = '/';
sidx = strrchr(url, '\\');
}
return url;
}
char *url_to_path(const char *url)
{
char *url_path = curl_unescape(url, 0);
char *path;
char *sidx;
if ((url_path[FILE_SCHEME_PREFIX_LEN + 1] == ':') ||
(url_path[FILE_SCHEME_PREFIX_LEN + 1] == '|')) {
/* url_path contains a drive: prefix */
path = strdup(url_path + FILE_SCHEME_PREFIX_LEN);
/* swap / for \ */
sidx = strrchr(path, '/');
while (sidx != NULL) {
*sidx = '\\';
sidx = strrchr(path, '/');
}
} else {
/* return the absolute path including leading / */
path = strdup(url_path + (FILE_SCHEME_PREFIX_LEN - 1));
}
curl_free(url_path);
return path;
}
/**
* Locate a shared resource file by searching known places in order.
*
* \param buf buffer to write to. must be at least PATH_MAX chars
* \param filename file to look for
* \param def default to return if file not found
* \return buf
*
* Search order is: ~/.netsurf/, $NETSURFRES/ (where NETSURFRES is an
* environment variable), then the path specified in
NETSURF_WINDOWS_RESPATH in the Makefile then .\res\ [windows paths]
*/
char *nsws_find_resource(char *buf, const char *filename, const char *def)
{
char *cdir = getenv("HOME");
char t[PATH_MAX];
if (cdir != NULL) {
LOG(("Found Home %s", cdir));
strcpy(t, cdir);
strcat(t, "/.netsurf/");
strcat(t, filename);
if ((realpath(t, buf) != NULL) && (access(buf, R_OK) == 0))
return buf;
}
cdir = getenv("NETSURFRES");
if (cdir != NULL) {
if (realpath(cdir , buf) != NULL) {
strcat(buf, "/");
strcat(buf, filename);
if (access(buf, R_OK) == 0)
return buf;
}
}
strcpy(t, NETSURF_WINDOWS_RESPATH);
strcat(t, filename);
if ((realpath(t, buf) != NULL) && (access(buf, R_OK) == 0))
return buf;
getcwd(t, PATH_MAX - SLEN("\\res\\") - strlen(filename));
strcat(t, "\\res\\");
strcat(t, filename);
LOG(("looking in %s", t));
if ((realpath(t, buf) != NULL) && (access(buf, R_OK) == 0))
return buf;
if (def[0] == '~') {
snprintf(t, PATH_MAX, "%s%s", getenv("HOME"), def + 1);
if (realpath(t, buf) == NULL) {
strcpy(buf, t);
}
} else {
if (realpath(def, buf) == NULL) {
strcpy(buf, def);
}
}
return buf;
}
/*
* Local Variables:
* c-basic-offset: 8
* End:
*/