2022-10-04 20:57:49 +08:00
|
|
|
#include "uoj_judger_v2.h"
|
2016-07-19 00:39:37 +08:00
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
main_judger_init(argc, argv);
|
2022-10-04 20:57:49 +08:00
|
|
|
|
|
|
|
runp::config rpc(conf_str("judger"), {
|
|
|
|
main_path, work_path, result_path, data_path
|
|
|
|
});
|
|
|
|
rpc.result_file_name = result_path / "run_judger_result.txt";
|
|
|
|
rpc.input_file_name = "/dev/null";
|
|
|
|
rpc.output_file_name = "/dev/null";
|
|
|
|
rpc.error_file_name = "stderr";
|
|
|
|
rpc.limits = conf_run_limit("judger", 0, RL_JUDGER_DEFAULT);
|
|
|
|
rpc.unsafe = true;
|
|
|
|
runp::result res = runp::run(rpc);
|
2023-02-05 10:23:46 +08:00
|
|
|
|
2022-10-04 20:57:49 +08:00
|
|
|
if (res.type != runp::RS_AC) {
|
2023-02-05 10:23:46 +08:00
|
|
|
stringstream msg;
|
|
|
|
|
|
|
|
msg << "Judgment Failed" << endl;
|
|
|
|
msg << "\n------\n" << endl;
|
|
|
|
msg << "Judger result: " << runp::rstype_str(res.type) << endl;
|
|
|
|
msg << "Extra message: " << res.extra << endl;
|
|
|
|
|
|
|
|
end_judge_judgment_failed(msg.str());
|
2016-07-19 00:39:37 +08:00
|
|
|
}
|
2023-02-05 10:23:46 +08:00
|
|
|
|
2016-07-19 00:39:37 +08:00
|
|
|
return 0;
|
|
|
|
}
|