Add another scripts search path for Windows builds
Add single "scripts" folder to search path for Windows OpenOCD builds that don't use cygwin bin/openocd.exe scripts/interface/dummy.cfg scripts/target/at91eb40a.cfg Do some refactoring of current code (thx to Andreas). Change-Id: Idbb08d1368b06f25da44f4f9ab1511db992b1724 Signed-off-by: Freddie Chopin <freddie.chopin@gmail.com> Signed-off-by: Andreas Fritiofson <andreas.fritiofson@gmail.com> Reviewed-on: http://openocd.zylin.com/785 Tested-by: jenkins
This commit is contained in:
parent
73d87c6210
commit
07158a7f8a
|
@ -55,43 +55,52 @@ int configuration_output_handler(struct command_context *context, const char *li
|
||||||
static void add_default_dirs(void)
|
static void add_default_dirs(void)
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
char strExePath[MAX_PATH];
|
||||||
|
char *path;
|
||||||
|
GetModuleFileName(NULL, strExePath, MAX_PATH);
|
||||||
|
|
||||||
|
/* Strip executable file name, leaving path */
|
||||||
|
*strrchr(strExePath, '\\') = '\0';
|
||||||
|
|
||||||
|
/* Convert path separators to UNIX style, should work on Windows also. */
|
||||||
|
for (char *p = strExePath; *p; p++) {
|
||||||
|
if (*p == '\\')
|
||||||
|
*p = '/';
|
||||||
|
}
|
||||||
|
|
||||||
/* Add the parent of the directory where openocd.exe resides to the
|
/* Add the parent of the directory where openocd.exe resides to the
|
||||||
* config script search path.
|
* config script search path.
|
||||||
* Directory layout:
|
*
|
||||||
* bin\openocd.exe
|
* bin/openocd.exe
|
||||||
* lib\openocd
|
* interface/dummy.cfg
|
||||||
|
* target/at91eb40a.cfg
|
||||||
*/
|
*/
|
||||||
{
|
path = alloc_printf("%s%s", strExePath, "/..");
|
||||||
char strExePath[MAX_PATH];
|
if (path) {
|
||||||
GetModuleFileName(NULL, strExePath, MAX_PATH);
|
add_script_search_dir(path);
|
||||||
/* Either this code will *always* work or it will SEGFAULT giving
|
free(path);
|
||||||
* excellent information on the culprit.
|
|
||||||
*/
|
|
||||||
*strrchr(strExePath, '\\') = 0;
|
|
||||||
strcat(strExePath, "\\..");
|
|
||||||
add_script_search_dir(strExePath);
|
|
||||||
}
|
}
|
||||||
/*
|
/* Add support for the directory layout resulting from a 'make install'.
|
||||||
* Add support for the default (as of 20091118) layout when
|
|
||||||
* using autotools and cygwin/MinGW to build native binary.
|
|
||||||
* Path separator is converted to UNIX style so that MinGW is
|
|
||||||
* pleased.
|
|
||||||
*
|
*
|
||||||
* bin/openocd.exe
|
* bin/openocd.exe
|
||||||
* share/openocd/scripts/interface/dummy.cfg
|
* share/openocd/scripts/interface/dummy.cfg
|
||||||
* share/openocd/scripts/target/at91eb40a.cfg
|
* share/openocd/scripts/target/at91eb40a.cfg
|
||||||
*/
|
*/
|
||||||
{
|
path = alloc_printf("%s%s", strExePath, "/../share/" PACKAGE "/scripts");
|
||||||
char strExePath[MAX_PATH];
|
if (path) {
|
||||||
char *p;
|
add_script_search_dir(path);
|
||||||
GetModuleFileName(NULL, strExePath, MAX_PATH);
|
free(path);
|
||||||
*strrchr(strExePath, '\\') = 0;
|
}
|
||||||
strcat(strExePath, "/../share/"PACKAGE "/scripts");
|
/* Add single "scripts" folder to search path for Windows OpenOCD builds that don't use cygwin
|
||||||
for (p = strExePath; *p; p++) {
|
*
|
||||||
if (*p == '\\')
|
* bin/openocd.exe
|
||||||
*p = '/';
|
* scripts/interface/dummy.cfg
|
||||||
}
|
* scripts/target/at91eb40a.cfg
|
||||||
add_script_search_dir(strExePath);
|
*/
|
||||||
|
path = alloc_printf("%s%s", strExePath, "/../scripts");
|
||||||
|
if (path) {
|
||||||
|
add_script_search_dir(path);
|
||||||
|
free(path);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue