From: Dale Weiler Date: Wed, 24 Apr 2013 14:04:00 +0000 (+0000) Subject: Shitty testsuite support for windows the hacky way because there exists no sane simpl... X-Git-Tag: before-library~12 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=a0f6b00a15852c6f13034c9cd3974b62e442696d;p=xonotic%2Fgmqcc.git Shitty testsuite support for windows the hacky way because there exists no sane simple way of redirecting pipes without a heafty chunk of code. --- diff --git a/test.c b/test.c index 6987bb3..40bf798 100755 --- a/test.c +++ b/test.c @@ -157,22 +157,39 @@ int task_pclose(FILE **handles) { * other hacks. */ typedef struct { - int __dummy; - /* TODO: implement */ + char name_err[L_tmpnam]; + char name_out[L_tmpnam]; } popen_t; FILE **task_popen(const char *command, const char *mode) { - (void)command; - (void)mode; + FILE **handles = NULL; + char *cmd = NULL; + popen_t *open = (popen_t*)mem_a(sizeof(popen_t) * 3); - /* TODO: implement */ - return NULL; + tmpnam(open->name_err); + tmpnam(open->name_out); + + (void)mode; /* excluded */ + + util_asprintf(&cmd, "%s -redirout=%s -redirerr=%s", command, open->name_out, open->name_err); + + system(cmd); /* HACK */ + handles = (FILE**)(open + 1); + handles[0] = NULL; + handles[1] = fs_file_open(open->name_out, "r"); + handles[2] = fs_file_open(open->name_err, "r"); + + return handles; } void task_pclose(FILE **files) { - /* TODO: implement */ - (void)files; - return; + popen_t *open = ((popen_t*)files) - 1; + fs_file_close(files[1]); + fs_file_close(files[2]); + remove(open->name_err); + remove(open->name_out); + + mem_d(open); } #endif /*! _WIN32 */ diff --git a/tests/vec_ops.tmpl b/tests/vec_ops.tmpl index 39e2750..7d8a501 100644 --- a/tests/vec_ops.tmpl +++ b/tests/vec_ops.tmpl @@ -2,7 +2,7 @@ I: vec_ops.qc D: some additional vector operations T: -execute C: -std=fteqcc -E: -vector '8 16 32' +E: -vector "8 16 32" M: '8 16 32' M: '4 8 16' M: '2 4 8'