Get rid of windres wrapper and temporarily disable pipeline for this branch
This commit is contained in:
parent
460d5820da
commit
79cca854bc
@ -519,7 +519,7 @@ xtchain_build()
|
|||||||
for EXEC in dlltool ld objdump; do
|
for EXEC in dlltool ld objdump; do
|
||||||
ln -sf ../${GENERIC}/bin/${EXEC}-wrapper ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
ln -sf ../${GENERIC}/bin/${EXEC}-wrapper ${BINDIR}/bin/${ARCH}-w64-mingw32-${EXEC}
|
||||||
done
|
done
|
||||||
for EXEC in bin2c exetool windres xtcspecc; do
|
for EXEC in bin2c exetool xtcspecc; do
|
||||||
if [ ! -e ${BINDIR}/bin/${EXEC} ]; then
|
if [ ! -e ${BINDIR}/bin/${EXEC} ]; then
|
||||||
gcc ${WRKDIR}/tools/${EXEC}.c -o ${BINDIR}/bin/${EXEC}
|
gcc ${WRKDIR}/tools/${EXEC}.c -o ${BINDIR}/bin/${EXEC}
|
||||||
fi
|
fi
|
||||||
|
558
tools/windres.c
558
tools/windres.c
@ -1,558 +0,0 @@
|
|||||||
/**
|
|
||||||
* PROJECT: XTchain
|
|
||||||
* LICENSE: See COPYING.md in the top level directory
|
|
||||||
* FILE: tools/windres.c
|
|
||||||
* DESCRIPTION: WINDRES compatible interface to LLVM
|
|
||||||
* DEVELOPERS: Josh de Kock <josh@itanimul.li>
|
|
||||||
* Martin Storsjo <martin@martin.st>
|
|
||||||
* Rafal Kupiec <belliash@codingworkshop.eu.org>
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "xtchain.h"
|
|
||||||
|
|
||||||
#define WINDRES_VERSION "1.0"
|
|
||||||
|
|
||||||
#ifndef DEFAULT_TARGET
|
|
||||||
#define DEFAULT_TARGET "x86_64-w64-mingw32"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdarg.h>
|
|
||||||
|
|
||||||
#define _tspawnvp_escape _spawnvp
|
|
||||||
|
|
||||||
#include <sys/wait.h>
|
|
||||||
#include <errno.h>
|
|
||||||
|
|
||||||
#define _P_WAIT 0
|
|
||||||
|
|
||||||
static
|
|
||||||
int
|
|
||||||
_spawnvp(int mode,
|
|
||||||
const char *filename,
|
|
||||||
const char * const *argv)
|
|
||||||
{
|
|
||||||
pid_t pid;
|
|
||||||
|
|
||||||
if(!(pid = fork()))
|
|
||||||
{
|
|
||||||
execvp(filename, (char **) argv);
|
|
||||||
perror(filename);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
int stat = 0;
|
|
||||||
|
|
||||||
if(waitpid(pid, &stat, 0) == -1)
|
|
||||||
{
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(WIFEXITED(stat))
|
|
||||||
{
|
|
||||||
return WEXITSTATUS(stat);
|
|
||||||
}
|
|
||||||
errno = EIO;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
const
|
|
||||||
char *unescape_cpp(const char *str)
|
|
||||||
{
|
|
||||||
char *out = strdup(str);
|
|
||||||
int len = strlen(str);
|
|
||||||
int i, outpos = 0;
|
|
||||||
|
|
||||||
for(i = 0; i < len - 1; i++)
|
|
||||||
{
|
|
||||||
if(str[i] == '\\' && str[i + 1] == '"')
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
out[outpos++] = str[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
while(i < len)
|
|
||||||
{
|
|
||||||
out[outpos++] = str[i++];
|
|
||||||
}
|
|
||||||
|
|
||||||
out[outpos++] = '\0';
|
|
||||||
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
void print_version(void)
|
|
||||||
{
|
|
||||||
printf("XTchain windres (GNU windres compatible) %s\n", WINDRES_VERSION);
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
void print_help(void)
|
|
||||||
{
|
|
||||||
printf(
|
|
||||||
"usage: llvm-windres <OPTION> [INPUT-FILE] [OUTPUT-FILE]\n"
|
|
||||||
"\n"
|
|
||||||
"LLVM Tool to manipulate Windows resources with a GNU windres interface.\n"
|
|
||||||
"\n"
|
|
||||||
"Options:\n"
|
|
||||||
" -i, --input <arg> Name of the input file.\n"
|
|
||||||
" -o, --output <arg> Name of the output file.\n"
|
|
||||||
" -J, --input-format <arg> Input format to read.\n"
|
|
||||||
" -O, --output-format <arg> Output format to generate.\n"
|
|
||||||
" --preprocessor <arg> Custom preprocessor command.\n"
|
|
||||||
" --preprocessor-arg <arg> Preprocessor command arguments.\n"
|
|
||||||
" -F, --target <arg> Target for COFF objects to be compiled for.\n"
|
|
||||||
" -I, --include-dir <arg> Include directory to pass to preprocessor and resource compiler.\n"
|
|
||||||
" -D, --define <arg[=val]> Define to pass to preprocessor.\n"
|
|
||||||
" -U, --undefine <arg[=val]> Undefine to pass to preprocessor.\n"
|
|
||||||
" -c, --codepage <arg> Default codepage to use when reading an rc file (0x0-0xffff).\n"
|
|
||||||
" -l, --language <arg> Specify default language (0x0-0xffff).\n"
|
|
||||||
" --use-temp-file Use a temporary file for the preprocessing output.\n"
|
|
||||||
" -v, --verbose Enable verbose output.\n"
|
|
||||||
" -V, --version Display version.\n"
|
|
||||||
" -h, --help Display this message and exit.\n"
|
|
||||||
"Input Formats:\n"
|
|
||||||
" rc Text Windows Resource\n"
|
|
||||||
" res Binary Windows Resource\n"
|
|
||||||
"Output Formats:\n"
|
|
||||||
" res Binary Windows Resource\n"
|
|
||||||
" coff COFF object\n"
|
|
||||||
"Targets:\n"
|
|
||||||
" pe-x86-64\n"
|
|
||||||
" pei-x86-64\n"
|
|
||||||
" pe-i386\n"
|
|
||||||
" pei-i386\n");
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
void error(const char *basename,
|
|
||||||
const char *fmt,
|
|
||||||
...)
|
|
||||||
{
|
|
||||||
fprintf(stderr, _T(TS": error: "), basename);
|
|
||||||
va_list ap;
|
|
||||||
va_start(ap, fmt);
|
|
||||||
vfprintf(stderr, fmt, ap);
|
|
||||||
fprintf(stderr, _T("\n"));
|
|
||||||
va_end(ap);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
void print_argv(const char **exec_argv)
|
|
||||||
{
|
|
||||||
while(*exec_argv)
|
|
||||||
{
|
|
||||||
fprintf(stderr, _T(TS" "), *exec_argv);
|
|
||||||
exec_argv++;
|
|
||||||
}
|
|
||||||
|
|
||||||
fprintf(stderr, _T("\n"));
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
void check_num_args(int arg,
|
|
||||||
int max_arg)
|
|
||||||
{
|
|
||||||
if(arg > max_arg)
|
|
||||||
{
|
|
||||||
fprintf(stderr, "Too many options added\n");
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc,
|
|
||||||
char* argv[])
|
|
||||||
{
|
|
||||||
const char *dir;
|
|
||||||
const char *basename;
|
|
||||||
const char *target;
|
|
||||||
|
|
||||||
split_argv(argv[0], &dir, &basename, &target, NULL);
|
|
||||||
|
|
||||||
if (!target)
|
|
||||||
target = _T(DEFAULT_TARGET);
|
|
||||||
|
|
||||||
const char *bfd_target = NULL;
|
|
||||||
const char *input = _T("-");
|
|
||||||
const char *output = _T("/dev/stdout");
|
|
||||||
const char *input_format = _T("rc");
|
|
||||||
const char *output_format = _T("coff");
|
|
||||||
const char **includes = malloc(argc * sizeof(*includes));
|
|
||||||
int nb_includes = 0;
|
|
||||||
const char *codepage = _T("1252");
|
|
||||||
const char *language = NULL;
|
|
||||||
const char **cpp_options = malloc(argc * sizeof(*cpp_options));
|
|
||||||
int nb_cpp_options = 0;
|
|
||||||
int verbose = 0;
|
|
||||||
|
|
||||||
#define _tcslen_const(a) (sizeof(a)/sizeof(char) - 1)
|
|
||||||
|
|
||||||
#define _tcsstart(a, b) !strncmp(a, b, _tcslen_const(b))
|
|
||||||
|
|
||||||
#define IF_MATCH_EITHER(short, long) \
|
|
||||||
if(!strcmp(argv[i], _T(short)) || !strcmp(argv[i], _T(long)))
|
|
||||||
|
|
||||||
#define IF_MATCH_THREE(first, second, third) \
|
|
||||||
if(!strcmp(argv[i], _T(first)) || !strcmp(argv[i], _T(second)) || !strcmp(argv[i], _T(third)))
|
|
||||||
|
|
||||||
#define OPTION(short, long, var) \
|
|
||||||
if(_tcsstart(argv[i], _T(short)) && argv[i][_tcslen_const(_T(short))]) { \
|
|
||||||
var = argv[i] + _tcslen_const(_T(short)); \
|
|
||||||
} else if(_tcsstart(argv[i], _T(long "="))) { \
|
|
||||||
var = strchr(argv[i], '=') + 1; \
|
|
||||||
} else IF_MATCH_EITHER(short, long) { \
|
|
||||||
if(i + 1 < argc) \
|
|
||||||
var = argv[++i]; \
|
|
||||||
else \
|
|
||||||
error(basename, _T(TS" missing argument"), argv[i]); \
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SEPARATE_ARG(var) do { \
|
|
||||||
if(i + 1 < argc) \
|
|
||||||
var = argv[++i]; \
|
|
||||||
else \
|
|
||||||
error(basename, _T(TS" missing argument"), argv[i]); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define SEPARATE_ARG_PREFIX(var, prefix) do { \
|
|
||||||
if(i + 1 < argc) \
|
|
||||||
var = concat(_T(prefix), argv[++i]); \
|
|
||||||
else \
|
|
||||||
error(basename, _T(TS" missing argument"), argv[i]); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
for(int i = 1; i < argc; i++)
|
|
||||||
{
|
|
||||||
OPTION("-i", "--input", input)
|
|
||||||
else OPTION("-o", "--output", output)
|
|
||||||
else OPTION("-J", "--input-format", input_format)
|
|
||||||
else OPTION("-O", "--output-format", output_format)
|
|
||||||
else OPTION("-F", "--target", bfd_target)
|
|
||||||
else IF_MATCH_THREE("-I", "--include-dir", "--include") {
|
|
||||||
SEPARATE_ARG(includes[nb_includes++]);
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("--include-dir=")) ||
|
|
||||||
_tcsstart(argv[i], _T("--include=")))
|
|
||||||
{
|
|
||||||
includes[nb_includes++] = strchr(argv[i], '=') + 1;
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("-I")))
|
|
||||||
{
|
|
||||||
includes[nb_includes++] = argv[i] + 2;
|
|
||||||
}
|
|
||||||
else OPTION("-c", "--codepage", codepage)
|
|
||||||
else OPTION("-l", "--language", language)
|
|
||||||
else if(!strcmp(argv[i], _T("--preprocessor")))
|
|
||||||
{
|
|
||||||
error(basename, _T("ENOSYS"));
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("--preprocessor-arg=")))
|
|
||||||
{
|
|
||||||
cpp_options[nb_cpp_options++] = strchr(argv[i], '=') + 1;
|
|
||||||
}
|
|
||||||
else if(!strcmp(argv[i], _T("--preprocessor-arg")))
|
|
||||||
{
|
|
||||||
SEPARATE_ARG(cpp_options[nb_cpp_options++]);
|
|
||||||
}
|
|
||||||
else IF_MATCH_EITHER("-D", "--define")
|
|
||||||
{
|
|
||||||
SEPARATE_ARG_PREFIX(cpp_options[nb_cpp_options++], "-D");
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("-D")))
|
|
||||||
{
|
|
||||||
cpp_options[nb_cpp_options++] = argv[i];
|
|
||||||
}
|
|
||||||
else IF_MATCH_EITHER("-U", "--undefine")
|
|
||||||
{
|
|
||||||
SEPARATE_ARG_PREFIX(cpp_options[nb_cpp_options++], "-U");
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("-U")))
|
|
||||||
{
|
|
||||||
cpp_options[nb_cpp_options++] = argv[i];
|
|
||||||
}
|
|
||||||
else IF_MATCH_EITHER("-v", "--verbose")
|
|
||||||
{
|
|
||||||
verbose = 1;
|
|
||||||
}
|
|
||||||
else IF_MATCH_EITHER("-V", "--version")
|
|
||||||
{
|
|
||||||
print_version();
|
|
||||||
}
|
|
||||||
else IF_MATCH_EITHER("-h", "--help")
|
|
||||||
{
|
|
||||||
print_help();
|
|
||||||
}
|
|
||||||
else if(!strcmp(argv[i], _T("--use-temp-file")))
|
|
||||||
{
|
|
||||||
// No-op, we use a temp file by default.
|
|
||||||
}
|
|
||||||
else if(_tcsstart(argv[i], _T("-")))
|
|
||||||
{
|
|
||||||
error(basename, _T("unrecognized option: `"TS"'"), argv[i]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if(!strcmp(input, _T("-")))
|
|
||||||
{
|
|
||||||
input = argv[i];
|
|
||||||
}
|
|
||||||
else if(!strcmp(output, _T("/dev/stdout")))
|
|
||||||
{
|
|
||||||
output = argv[i];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
error(basename, _T("rip: `"TS"'"), argv[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(bfd_target)
|
|
||||||
{
|
|
||||||
if(!strcmp(bfd_target, _T("pe-x86-64")) ||
|
|
||||||
!strcmp(bfd_target, _T("pei-x86-64")))
|
|
||||||
{
|
|
||||||
target = _T("x86_64-w64-mingw32");
|
|
||||||
}
|
|
||||||
else if(!strcmp(bfd_target, _T("pe-i386")) ||
|
|
||||||
!strcmp(bfd_target, _T("pei-i386")))
|
|
||||||
{
|
|
||||||
target = _T("i686-w64-mingw32");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
error(basename, _T("unsupported target: `"TS"'"), bfd_target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
char *arch = strdup(target);
|
|
||||||
char *dash = strchr(arch, '-');
|
|
||||||
if(dash)
|
|
||||||
{
|
|
||||||
*dash = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *machine = _T("unknown");
|
|
||||||
|
|
||||||
if(!strcmp(arch, _T("i686")))
|
|
||||||
{
|
|
||||||
machine = _T("X86");
|
|
||||||
}
|
|
||||||
else if(!strcmp(arch, _T("x86_64")))
|
|
||||||
{
|
|
||||||
machine = _T("X64");
|
|
||||||
}
|
|
||||||
else if(!strcmp(arch, _T("armv7")))
|
|
||||||
{
|
|
||||||
machine = _T("ARM");
|
|
||||||
}
|
|
||||||
else if(!strcmp(arch, _T("aarch64")))
|
|
||||||
{
|
|
||||||
machine = _T("ARM64");
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *CC = concat(target, _T("-clang"));
|
|
||||||
const char **rc_options = malloc(2 * argc * sizeof(*cpp_options));
|
|
||||||
int nb_rc_options = 0;
|
|
||||||
|
|
||||||
for(int i = 0; i < nb_includes; i++)
|
|
||||||
{
|
|
||||||
cpp_options[nb_cpp_options++] = concat(_T("-I"), includes[i]);
|
|
||||||
rc_options[nb_rc_options++] = _T("-I");
|
|
||||||
rc_options[nb_rc_options++] = includes[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
for(int i = 0; i < nb_cpp_options; i++)
|
|
||||||
{
|
|
||||||
cpp_options[i] = unescape_cpp(cpp_options[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *preproc_rc = concat(output, _T(".preproc.rc"));
|
|
||||||
const char *res = concat(output, _T(".out.res"));
|
|
||||||
|
|
||||||
char *inputdir = strdup(input);
|
|
||||||
{
|
|
||||||
char *sep = _tcsrchrs(inputdir, '/', '\\');
|
|
||||||
if(sep)
|
|
||||||
{
|
|
||||||
*sep = '\0';
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
inputdir = strdup(_T("."));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int max_arg = 2 * argc + 20;
|
|
||||||
const char **exec_argv = malloc((max_arg + 1) * sizeof(*exec_argv));
|
|
||||||
int arg = 0;
|
|
||||||
|
|
||||||
if(!_tcsicmp(input_format, _T("rc")))
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = concat(dir, CC);
|
|
||||||
exec_argv[arg++] = _T("-E");
|
|
||||||
|
|
||||||
for(int i = 0; i < nb_cpp_options; i++)
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = cpp_options[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
exec_argv[arg++] = _T("-xc");
|
|
||||||
exec_argv[arg++] = _T("-DRC_INVOKED=1");
|
|
||||||
exec_argv[arg++] = input;
|
|
||||||
exec_argv[arg++] = _T("-o");
|
|
||||||
exec_argv[arg++] = preproc_rc;
|
|
||||||
exec_argv[arg] = NULL;
|
|
||||||
|
|
||||||
check_num_args(arg, max_arg);
|
|
||||||
|
|
||||||
if(verbose)
|
|
||||||
{
|
|
||||||
print_argv(exec_argv);
|
|
||||||
}
|
|
||||||
|
|
||||||
int ret = _tspawnvp_escape(_P_WAIT, exec_argv[0], exec_argv);
|
|
||||||
|
|
||||||
if(ret == -1)
|
|
||||||
{
|
|
||||||
perror(exec_argv[0]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(ret != 0)
|
|
||||||
{
|
|
||||||
error(basename, _T("preprocessor failed"));
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
arg = 0;
|
|
||||||
exec_argv[arg++] = concat(dir, _T("llvm-rc"));
|
|
||||||
|
|
||||||
for(int i = 0; i < nb_rc_options; i++)
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = rc_options[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
exec_argv[arg++] = _T("-I");
|
|
||||||
exec_argv[arg++] = inputdir;
|
|
||||||
exec_argv[arg++] = preproc_rc;
|
|
||||||
exec_argv[arg++] = _T("-c");
|
|
||||||
exec_argv[arg++] = codepage;
|
|
||||||
|
|
||||||
if(language)
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = _T("-l");
|
|
||||||
exec_argv[arg++] = language;
|
|
||||||
}
|
|
||||||
|
|
||||||
exec_argv[arg++] = _T("-fo");
|
|
||||||
|
|
||||||
if(!_tcsicmp(output_format, _T("res")))
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = output;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = res;
|
|
||||||
}
|
|
||||||
|
|
||||||
exec_argv[arg] = NULL;
|
|
||||||
check_num_args(arg, max_arg);
|
|
||||||
|
|
||||||
if(verbose)
|
|
||||||
{
|
|
||||||
print_argv(exec_argv);
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = _tspawnvp_escape(_P_WAIT, exec_argv[0], exec_argv);
|
|
||||||
|
|
||||||
if(ret == -1)
|
|
||||||
{
|
|
||||||
perror(exec_argv[0]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(ret != 0)
|
|
||||||
{
|
|
||||||
error(basename, _T("llvm-rc failed"));
|
|
||||||
if(!verbose)
|
|
||||||
{
|
|
||||||
unlink(preproc_rc);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!_tcsicmp(output_format, _T("res")))
|
|
||||||
{
|
|
||||||
// All done
|
|
||||||
}
|
|
||||||
else if(!_tcsicmp(output_format, _T("coff")))
|
|
||||||
{
|
|
||||||
arg = 0;
|
|
||||||
exec_argv[arg++] = concat(dir, _T("llvm-cvtres"));
|
|
||||||
exec_argv[arg++] = res;
|
|
||||||
exec_argv[arg++] = concat(_T("-machine:"), machine);
|
|
||||||
exec_argv[arg++] = concat(_T("-out:"), output);
|
|
||||||
exec_argv[arg] = NULL;
|
|
||||||
|
|
||||||
check_num_args(arg, max_arg);
|
|
||||||
if(verbose)
|
|
||||||
{
|
|
||||||
print_argv(exec_argv);
|
|
||||||
}
|
|
||||||
|
|
||||||
int ret = _tspawnvp_escape(_P_WAIT, exec_argv[0], exec_argv);
|
|
||||||
if(ret == -1)
|
|
||||||
{
|
|
||||||
perror(exec_argv[0]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!verbose)
|
|
||||||
{
|
|
||||||
unlink(preproc_rc);
|
|
||||||
unlink(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
} else {
|
|
||||||
error(basename, _T("invalid output format: `"TS"'"), output_format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if(!_tcsicmp(input_format, _T("res")))
|
|
||||||
{
|
|
||||||
exec_argv[arg++] = concat(dir, _T("llvm-cvtres"));
|
|
||||||
exec_argv[arg++] = input;
|
|
||||||
exec_argv[arg++] = concat(_T("-machine:"), machine);
|
|
||||||
exec_argv[arg++] = concat(_T("-out:"), output);
|
|
||||||
exec_argv[arg] = NULL;
|
|
||||||
|
|
||||||
check_num_args(arg, max_arg);
|
|
||||||
|
|
||||||
if(verbose)
|
|
||||||
{
|
|
||||||
print_argv(exec_argv);
|
|
||||||
}
|
|
||||||
|
|
||||||
int ret = _tspawnvp_escape(_P_WAIT, exec_argv[0], exec_argv);
|
|
||||||
if(ret == -1)
|
|
||||||
{
|
|
||||||
perror(exec_argv[0]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
error(basename, _T("invalid input format: `"TS"'"), input_format);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user