From: Dale Weiler Date: Sun, 21 Apr 2013 06:20:17 +0000 (+0000) Subject: Initial preprocessor procedure option for testsuite implemented. X-Git-Tag: before-library~40 X-Git-Url: https://git.xonotic.org/?p=xonotic%2Fgmqcc.git;a=commitdiff_plain;h=79282bfee009ecbf32dd77e56e470d872c222421 Initial preprocessor procedure option for testsuite implemented. --- diff --git a/test.c b/test.c index 7202efb..d4af984 100644 --- a/test.c +++ b/test.c @@ -894,32 +894,41 @@ bool task_execute(task_template_t *tmpl, char ***line) { char buffer[4096]; memset (buffer,0,sizeof(buffer)); - /* - * Drop the execution flags for the QCVM if none where - * actually specified. - */ - if (!strcmp(tmpl->executeflags, "$null")) { - snprintf(buffer, sizeof(buffer), "%s %s", - task_bins[TASK_EXECUTE], - tmpl->tempfilename + if (strcmp(tmpl->proceduretype, "-pp")) { + /* + * Drop the execution flags for the QCVM if none where + * actually specified. + */ + if (!strcmp(tmpl->executeflags, "$null")) { + snprintf(buffer, sizeof(buffer), "%s %s", + task_bins[TASK_EXECUTE], + tmpl->tempfilename + ); + } else { + snprintf(buffer, sizeof(buffer), "%s %s %s", + task_bins[TASK_EXECUTE], + tmpl->executeflags, + tmpl->tempfilename + ); + } + + util_debug("TEST", "executing qcvm: `%s` [%s]\n", + tmpl->description, + buffer ); + + execute = popen(buffer, "r"); + if (!execute) + return false; } else { - snprintf(buffer, sizeof(buffer), "%s %s %s", - task_bins[TASK_EXECUTE], - tmpl->executeflags, - tmpl->tempfilename - ); + /* + * we're preprocessing, which means we need to read int + * the produced file and do some really weird shit. + */ + if (!(execute = fs_file_open(tmpl->tempfilename, "r"))) + return false; } - util_debug("TEST", "executing qcvm: `%s` [%s]\n", - tmpl->description, - buffer - ); - - execute = popen(buffer, "r"); - if (!execute) - return false; - /* * Now lets read the lines and compare them to the matches we expect * and handle accordingly. @@ -965,7 +974,12 @@ bool task_execute(task_template_t *tmpl, char ***line) { mem_d(data); data = NULL; } - pclose(execute); + + if (strcmp(tmpl->proceduretype, "-pp")) + pclose(execute); + else + fs_file_close(execute); + return success; } @@ -1055,6 +1069,10 @@ void task_schedualize(size_t *pad) { continue; } + if (!strcmp(task_tasks[i].tmpl->proceduretype, "-pp")) { + /* this is a pain */ + } + if (!execute) { con_out("succeeded: `%s` %*s %*s\n", task_tasks[i].tmpl->description,