[INFO] fetching crate ezcp 0.4.0...
[INFO] testing ezcp-0.4.0 against master#733b47ea4b1b86216f14ef56e49440c33933f230+rustflags=-Copt-level=3 for pr-138759
[INFO] extracting crate ezcp 0.4.0 into /workspace/builds/worker-7-tc2/source
[INFO] started tweaking crates.io crate ezcp 0.4.0
[INFO] removed 0 missing examples
[INFO] finished tweaking crates.io crate ezcp 0.4.0
[INFO] tweaked toml for crates.io crate ezcp 0.4.0 written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate ezcp 0.4.0 on toolchain 733b47ea4b1b86216f14ef56e49440c33933f230
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate ezcp 0.4.0 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6d8e4aaab99f15f591b798784ec73b06fc7bf19eeadf20d84a97c6731b893dd3
[INFO] running `Command { std: "docker" "start" "-a" "6d8e4aaab99f15f591b798784ec73b06fc7bf19eeadf20d84a97c6731b893dd3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6d8e4aaab99f15f591b798784ec73b06fc7bf19eeadf20d84a97c6731b893dd3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6d8e4aaab99f15f591b798784ec73b06fc7bf19eeadf20d84a97c6731b893dd3", kill_on_drop: false }`
[INFO] [stdout] 6d8e4aaab99f15f591b798784ec73b06fc7bf19eeadf20d84a97c6731b893dd3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7ce52b7366aa3cfec9ba69589588186601c44f85660e468e0d9e115a0fe42ee1
[INFO] running `Command { std: "docker" "start" "-a" "7ce52b7366aa3cfec9ba69589588186601c44f85660e468e0d9e115a0fe42ee1", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling bitflags v2.9.3
[INFO] [stderr]    Compiling zlib-rs v0.5.1
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling bumpalo v3.19.0
[INFO] [stderr]    Compiling unit-prefix v0.5.1
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling snap v1.1.1
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling env_home v0.1.0
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling zopfli v0.8.2
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling indexmap v2.11.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling console v0.16.0
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling indicatif v0.18.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling tempfile v3.21.0
[INFO] [stderr]    Compiling which v8.0.0
[INFO] [stderr]    Compiling libz-rs-sys v0.5.1
[INFO] [stderr]    Compiling flate2 v1.1.2
[INFO] [stderr]    Compiling indicatif-log-bridge v0.2.3
[INFO] [stderr]    Compiling zip v4.5.0
[INFO] [stderr]    Compiling bincode v2.0.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling ezcp v0.4.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 50.53s
[INFO] running `Command { std: "docker" "inspect" "7ce52b7366aa3cfec9ba69589588186601c44f85660e468e0d9e115a0fe42ee1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7ce52b7366aa3cfec9ba69589588186601c44f85660e468e0d9e115a0fe42ee1", kill_on_drop: false }`
[INFO] [stdout] 7ce52b7366aa3cfec9ba69589588186601c44f85660e468e0d9e115a0fe42ee1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7dc6f5f6b92b3174b750f95e46560f421b002f121f2864b9002c64f1d06bf49b
[INFO] running `Command { std: "docker" "start" "-a" "7dc6f5f6b92b3174b750f95e46560f421b002f121f2864b9002c64f1d06bf49b", kill_on_drop: false }`
[INFO] [stderr]    Compiling ezcp v0.4.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 9.91s
[INFO] running `Command { std: "docker" "inspect" "7dc6f5f6b92b3174b750f95e46560f421b002f121f2864b9002c64f1d06bf49b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7dc6f5f6b92b3174b750f95e46560f421b002f121f2864b9002c64f1d06bf49b", kill_on_drop: false }`
[INFO] [stdout] 7dc6f5f6b92b3174b750f95e46560f421b002f121f2864b9002c64f1d06bf49b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 9cfc9620cc3d2c934216f773934b7666aff8b72e9ca1ea33570ff371cbaa96a2
[INFO] running `Command { std: "docker" "start" "-a" "9cfc9620cc3d2c934216f773934b7666aff8b72e9ca1ea33570ff371cbaa96a2", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.12s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ezcp-e889403bbdd89002)
[INFO] [stdout] 
[INFO] [stdout] running 70 tests
[INFO] [stderr] [D] Logger initialized with level: TRACE
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmp3FjsGu/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmp1a6bNL/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmp3FjsGu/build/p14324055355525279488.cpp, Executable file: /tmp/.tmp3FjsGu/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmp3FjsGu/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpiyrzR9/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmp3FjsGu/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmp3FjsGu/build/p14324055355525279488.cpp" "-o" "/tmp/.tmp3FjsGu/build/p14324055355525279488"
[INFO] [stderr] [T] Source file: /tmp/.tmpiyrzR9/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpiyrzR9/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpiyrzR9/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpiyrzR9/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpiyrzR9/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpiyrzR9/build/p14324055355525279488"
[INFO] [stderr] [T] Source file: /tmp/.tmp1a6bNL/build/p14324055355525279488.cpp, Executable file: /tmp/.tmp1a6bNL/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmp1a6bNL/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmp1a6bNL/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmp1a6bNL/build/p14324055355525279488.cpp" "-o" "/tmp/.tmp1a6bNL/build/p14324055355525279488"
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpLBpKYG/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpLBpKYG/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpLBpKYG/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpLBpKYG/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpLBpKYG/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpLBpKYG/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpLBpKYG/build/p14324055355525279488"
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpAtzfKi/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpaCCIhx/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpaCCIhx/build/p14324055355525279488"
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpFKg1z0/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpQErJ06
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpFKg1z0/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpFKg1z0/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpFKg1z0/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpFKg1z0/build/p14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpQErJ06/p14324055355525279488.cpp, Executable file: /tmp/.tmpQErJ06/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpQErJ06/p14324055355525279488.cpp
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpr5CueU
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpAtzfKi/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpAtzfKi/build/p14324055355525279488
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Source file: /tmp/.tmpr5CueU/p14324055355525279488.cpp, Executable file: /tmp/.tmpr5CueU/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpr5CueU/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpQErJ06/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpFKg1z0/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpFKg1z0/build/p14324055355525279488"
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpQErJ06/p14324055355525279488.cpp" "-o" "/tmp/.tmpQErJ06/p14324055355525279488"
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpGHiPG2
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpAtzfKi/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpGHiPG2/p14324055355525279488.cpp, Executable file: /tmp/.tmpGHiPG2/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpGHiPG2/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpGHiPG2/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpGHiPG2/p14324055355525279488.cpp" "-o" "/tmp/.tmpGHiPG2/p14324055355525279488"
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpr5CueU/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpr5CueU/p14324055355525279488.cpp" "-o" "/tmp/.tmpr5CueU/p14324055355525279488"
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpAtzfKi/build/p14324055355525279488
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpOrF5Oh
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpAtzfKi/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpAtzfKi/build/p14324055355525279488"
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpRYTOYh/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpRYTOYh/build/p14324055355525279488"
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpOrF5Oh/p14324055355525279488.cpp, Executable file: /tmp/.tmpOrF5Oh/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpOrF5Oh/p14324055355525279488.cpp
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpOrF5Oh/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpOrF5Oh/p14324055355525279488.cpp" "-o" "/tmp/.tmpOrF5Oh/p14324055355525279488"
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpC98lHh/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpC98lHh/build/p14324055355525279488"
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpuRxRCA/p14324055355525279488.cpp
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpcwXVVe
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpuRxRCA/p14324055355525279488.cpp" "-o" "/tmp/.tmpuRxRCA/p14324055355525279488"
[INFO] [stderr] [T] Source file: /tmp/.tmpcwXVVe/p14324055355525279488.cpp, Executable file: /tmp/.tmpcwXVVe/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpcwXVVe/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpcwXVVe/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpcwXVVe/p14324055355525279488.cpp" "-o" "/tmp/.tmpcwXVVe/p14324055355525279488"
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpiQTGw7
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpiQTGw7/p14324055355525279488.cpp, Executable file: /tmp/.tmpiQTGw7/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpiQTGw7/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpiQTGw7/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpiQTGw7/p14324055355525279488.cpp" "-o" "/tmp/.tmpiQTGw7/p14324055355525279488"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpcwXVVe/p12833077150707811555.cpp, Executable file: /tmp/.tmpcwXVVe/p12833077150707811555
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpcwXVVe/p12833077150707811555.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpcwXVVe/p12833077150707811555
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpcwXVVe/p12833077150707811555.cpp" "-o" "/tmp/.tmpcwXVVe/p12833077150707811555"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              compile error here
[INFO] [stderr]  |              cout << "Hello, World!" << endl;
[INFO] [stderr]  |              return 1;
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 18162641665155307359
[INFO] [stderr] [T] Source file: /tmp/.tmpGHiPG2/p18162641665155307359.cpp, Executable file: /tmp/.tmpGHiPG2/p18162641665155307359
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpGHiPG2/p18162641665155307359.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpGHiPG2/p18162641665155307359
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpGHiPG2/p18162641665155307359.cpp" "-o" "/tmp/.tmpGHiPG2/p18162641665155307359"
[INFO] [stdout] test tests::cpp_runner_tests::cpp_runner_tests::test_runner_new ... ok
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpa2g25g
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpa2g25g/p14324055355525279488.cpp, Executable file: /tmp/.tmpa2g25g/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpa2g25g/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpa2g25g/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpa2g25g/p14324055355525279488.cpp" "-o" "/tmp/.tmpa2g25g/p14324055355525279488"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int n;
[INFO] [stderr]  |              cin>>n;
[INFO] [stderr]  |              int a[n];
[INFO] [stderr]  |              for(int i=0;i<n;i++) {
[INFO] [stderr]  |                  cin>>a[i];
[INFO] [stderr]  |              }
[INFO] [stderr]  |              cout<<"1\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 11267333155935078430
[INFO] [stderr] [T] Source file: /tmp/.tmpLBpKYG/build/p11267333155935078430.cpp, Executable file: /tmp/.tmpLBpKYG/build/p11267333155935078430
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpLBpKYG/build/p11267333155935078430.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpLBpKYG/build/p11267333155935078430
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpLBpKYG/build/p11267333155935078430.cpp" "-o" "/tmp/.tmpLBpKYG/build/p11267333155935078430"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              while (true) {
[INFO] [stderr]  |                  // Infinite loop to simulate TLE
[INFO] [stderr]  |              }
[INFO] [stderr]  |              return 0;
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 3369991095479187441
[INFO] [stderr] [T] Source file: /tmp/.tmpiQTGw7/p3369991095479187441.cpp, Executable file: /tmp/.tmpiQTGw7/p3369991095479187441
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpiQTGw7/p3369991095479187441.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpiQTGw7/p3369991095479187441
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpiQTGw7/p3369991095479187441.cpp" "-o" "/tmp/.tmpiQTGw7/p3369991095479187441"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpuRxRCA/p12833077150707811555.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpuRxRCA/p12833077150707811555.cpp" "-o" "/tmp/.tmpuRxRCA/p12833077150707811555"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpaCCIhx/build/p12681089750808797356.cpp" "-o" "/tmp/.tmpaCCIhx/build/p12681089750808797356"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpr5CueU/p12833077150707811555.cpp, Executable file: /tmp/.tmpr5CueU/p12833077150707811555
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpr5CueU/p12833077150707811555.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpr5CueU/p12833077150707811555
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpr5CueU/p12833077150707811555.cpp" "-o" "/tmp/.tmpr5CueU/p12833077150707811555"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpC98lHh/build/p12681089750808797356.cpp" "-o" "/tmp/.tmpC98lHh/build/p12681089750808797356"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpRYTOYh/build/p12681089750808797356.cpp" "-o" "/tmp/.tmpRYTOYh/build/p12681089750808797356"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpAtzfKi/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpAtzfKi/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpAtzfKi/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpAtzfKi/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpAtzfKi/build/p12681089750808797356.cpp" "-o" "/tmp/.tmpAtzfKi/build/p12681089750808797356"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpiQTGw7
[INFO] [stderr] [T] Running command: "/tmp/.tmpiQTGw7/p14324055355525279488" "/tmp/.tmpiQTGw7/p3369991095479187441" "1000"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int n;
[INFO] [stderr]  |              cin>>n;
[INFO] [stderr]  |              int a[n];
[INFO] [stderr]  |              for(int i=0;i<n;i++) {
[INFO] [stderr]  |                  cin>>a[i];
[INFO] [stderr]  |              }
[INFO] [stderr]  |              cout<<"1\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 11267333155935078430
[INFO] [stderr] [T] Source file: /tmp/.tmp3FjsGu/build/p11267333155935078430.cpp, Executable file: /tmp/.tmp3FjsGu/build/p11267333155935078430
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmp3FjsGu/build/p11267333155935078430.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmp3FjsGu/build/p11267333155935078430
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmp3FjsGu/build/p11267333155935078430.cpp" "-o" "/tmp/.tmp3FjsGu/build/p11267333155935078430"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int n;
[INFO] [stderr]  |              cin>>n;
[INFO] [stderr]  |              int a[n];
[INFO] [stderr]  |              for(int i=0;i<n;i++) {
[INFO] [stderr]  |                  cin>>a[i];
[INFO] [stderr]  |              }
[INFO] [stderr]  |              cout<<"1\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 6857213752579981138
[INFO] [stderr] [T] Source file: /tmp/.tmpiyrzR9/build/p6857213752579981138.cpp, Executable file: /tmp/.tmpiyrzR9/build/p6857213752579981138
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpiyrzR9/build/p6857213752579981138.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpiyrzR9/build/p6857213752579981138
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpiyrzR9/build/p6857213752579981138.cpp" "-o" "/tmp/.tmpiyrzR9/build/p6857213752579981138"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int*n=nullptr;
[INFO] [stderr]  |              while(true){
[INFO] [stderr]  |                  *n=1;
[INFO] [stderr]  |                  n++;
[INFO] [stderr]  |              }
[INFO] [stderr]  |              return 0;
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 6845191756198366168
[INFO] [stderr] [T] Source file: /tmp/.tmpQErJ06/p6845191756198366168.cpp, Executable file: /tmp/.tmpQErJ06/p6845191756198366168
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpQErJ06/p6845191756198366168.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpQErJ06/p6845191756198366168
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpQErJ06/p6845191756198366168.cpp" "-o" "/tmp/.tmpQErJ06/p6845191756198366168"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmp1a6bNL/build/p12681089750808797356.cpp, Executable file: /tmp/.tmp1a6bNL/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmp1a6bNL/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmp1a6bNL/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmp1a6bNL/build/p12681089750808797356.cpp" "-o" "/tmp/.tmp1a6bNL/build/p12681089750808797356"
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpC98lHh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpC98lHh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpC98lHh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpC98lHh/build/p12681089750808797356
[INFO] [stderr] [ERROR] a should be equal to b
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stdout] test tests::checker_tests::generator_tests::test_checker_fail2 ... ok
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpQErJ06
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpIiAd0s
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpIiAd0s/p14324055355525279488.cpp, Executable file: /tmp/.tmpIiAd0s/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpIiAd0s/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpIiAd0s/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpIiAd0s/p14324055355525279488.cpp" "-o" "/tmp/.tmpIiAd0s/p14324055355525279488"
[INFO] [stderr] [T] Running command: "/tmp/.tmpQErJ06/p14324055355525279488" "/tmp/.tmpQErJ06/p6845191756198366168" "1000"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpFKg1z0/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpFKg1z0/build/p12681089750808797356
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpFKg1z0/build/p12681089750808797356.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpFKg1z0/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpFKg1z0/build/p12681089750808797356.cpp" "-o" "/tmp/.tmpFKg1z0/build/p12681089750808797356"
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stdout] test tests::checker_tests::generator_tests::test_checker_fail4 ... ok
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpRYTOYh/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpRYTOYh/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpRYTOYh/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpRYTOYh/build/p12681089750808797356
[INFO] [stderr] [ERROR] Expected end of input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpbnDb0Y/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpbnDb0Y/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpbnDb0Y/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpbnDb0Y/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpbnDb0Y/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpbnDb0Y/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpbnDb0Y/build/p14324055355525279488"
[INFO] [stdout] test tests::cpp_runner_tests::cpp_runner_tests::test_runner_add_faulty_program ... ok
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpw39zDx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpw39zDx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpw39zDx/build/p14324055355525279488
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpw39zDx/build/p14324055355525279488.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpw39zDx/build/p14324055355525279488
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpw39zDx/build/p14324055355525279488.cpp" "-o" "/tmp/.tmpw39zDx/build/p14324055355525279488"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Task 1 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Task 3 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Task 5 finished with result: Ok(3, "8\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 8 finished with result: Ok(1, "2\n")
[INFO] [stderr] [T] Task 9 finished with result: Ok(2, "3\n")
[INFO] [stderr] [T] Task 10 finished with result: Ok(1, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 11 finished with result: Ok(2, "5\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 4 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Task 7 finished with result: Ok(2, "200\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 12 finished with result: Ok(2, "101\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 6 finished with result: Ok(2, "10\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 2 finished with result: Ok(1, "6\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Getting result for task id: 1
[INFO] [stderr] [T] Getting result for task id: 2
[INFO] [stderr] [T] Getting result for task id: 3
[INFO] [stderr] [T] Getting result for task id: 4
[INFO] [stderr] [T] Getting result for task id: 5
[INFO] [stderr] [T] Getting result for task id: 6
[INFO] [stderr] [T] Getting result for task id: 7
[INFO] [stderr] [T] Getting result for task id: 8
[INFO] [stderr] [T] Getting result for task id: 9
[INFO] [stderr] [T] Getting result for task id: 10
[INFO] [stderr] [T] Getting result for task id: 11
[INFO] [stderr] [T] Getting result for task id: 12
[INFO] [stderr] [*] Solution time: 3ms
[INFO] [stderr] [T] Clearing tasks
[INFO] [stderr] [*] Tests size: 0.00MB
[INFO] [stderr] [*] Elapsed time: 9.89s
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "/tmp/.tmpnvHU2E/test.cpp" "-o" "/tmp/.tmpnvHU2E/test"
[INFO] [stdout] test tests::cpp_runner_tests::cpp_runner_tests::test_runner_add_program ... ok
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 6 finished with result: Ok(2, "10\n")
[INFO] [stderr] [T] Task 9 finished with result: Ok(2, "3\n")
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Task 12 finished with result: Ok(3, "101\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 2 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 10 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 1 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 5 finished with result: Ok(2, "8\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(1, "Hello, World!\n")
[INFO] [stderr] [T] Task 3 finished with result: Ok(1, "2\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 4 finished with result: Ok(1, "6\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 8 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 7 finished with result: Ok(2, "200\n")
[INFO] [stderr] [T] Task 11 finished with result: Ok(2, "5\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Getting result for task id: 1
[INFO] [stderr] [T] Getting result for task id: 2
[INFO] [stderr] [T] Getting result for task id: 3
[INFO] [stderr] [T] Getting result for task id: 4
[INFO] [stderr] [T] Getting result for task id: 5
[INFO] [stderr] [T] Getting result for task id: 6
[INFO] [stderr] [T] Getting result for task id: 7
[INFO] [stderr] [T] Getting result for task id: 8
[INFO] [stderr] [T] Getting result for task id: 9
[INFO] [stderr] [T] Getting result for task id: 10
[INFO] [stderr] [T] Getting result for task id: 11
[INFO] [stderr] [T] Getting result for task id: 12
[INFO] [stderr] [*] Solution time: 3ms
[INFO] [stderr] [T] Clearing tasks
[INFO] [stderr] [*] Tests size: 0.00MB
[INFO] [stderr] [*] Elapsed time: 0.23s
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Solution timed out with signal 175
[INFO] [stderr] [T] Task 0 finished with result: TimedOut
[INFO] [stdout] test tests::cpp_runner_tests::cpp_runner_tests::test_runner_program_tle ... ok
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "/tmp/.tmp40qiVM/test.cpp" "-o" "/tmp/.tmp40qiVM/test"
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(1, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpcwXVVe
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpcwXVVe/p14324055355525279488" "/tmp/.tmpcwXVVe/p12833077150707811555" "1000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 9 finished with result: Ok(1, "3\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 8 finished with result: Ok(1, "2\n")
[INFO] [stderr] [T] Task 0 finished with result: Ok(3, "Hello, World!\n")
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stdout] test tests::cpp_runner_tests::cpp_runner_tests::test_runner_run_program ... ok
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "/tmp/.tmp6evGG6/test.cpp" "-o" "/tmp/.tmp6evGG6/test"
[INFO] [stderr] [T] Task 12 finished with result: Ok(2, "101\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 2 finished with result: Ok(1, "6\n")
[INFO] [stderr] [T] Task 3 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 4 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Task 10 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 5 finished with result: Ok(2, "8\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 6 finished with result: Ok(1, "10\n")
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Task 1 finished with result: Ok(3, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 7 finished with result: Ok(2, "200\n")
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(3, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 11 finished with result: Ok(2, "5\n")
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 3 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(3, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Getting result for task id: 1
[INFO] [stderr] [T] Getting result for task id: 2
[INFO] [stderr] [T] Getting result for task id: 3
[INFO] [stderr] [T] Getting result for task id: 4
[INFO] [stderr] [T] Getting result for task id: 5
[INFO] [stderr] [T] Getting result for task id: 6
[INFO] [stderr] [T] Getting result for task id: 7
[INFO] [stderr] [T] Getting result for task id: 8
[INFO] [stderr] [T] Getting result for task id: 9
[INFO] [stderr] [T] Getting result for task id: 10
[INFO] [stderr] [T] Getting result for task id: 11
[INFO] [stderr] [T] Getting result for task id: 12
[INFO] [stderr] [*] Solution time: 3ms
[INFO] [stderr] [T] Clearing tasks
[INFO] [stderr] [*] Tests size: 0.00MB
[INFO] [stderr] [*] Elapsed time: 0.31s
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |              #include <iostream>
[INFO] [stderr]  |              using namespace std;
[INFO] [stderr]  |              int main() {
[INFO] [stderr]  |                  int n;
[INFO] [stderr]  |                  cin>>n;
[INFO] [stderr]  |                  cout << 0 << " " << n << endl;
[INFO] [stderr]  |                  return 0;
[INFO] [stderr]  |              }
[INFO] [stderr]  |              
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 665691812841231303
[INFO] [stderr] [T] Source file: /tmp/.tmpa2g25g/p665691812841231303.cpp, Executable file: /tmp/.tmpa2g25g/p665691812841231303
[INFO] [stderr] [T] Source file does not exist, writing to: /tmp/.tmpa2g25g/p665691812841231303.cpp
[INFO] [stderr] [T] Executable file does not exist. Compiling: /tmp/.tmpa2g25g/p665691812841231303
[INFO] [stderr] [D] Running command: cd "/usr/bin" && "/usr/bin/g++" "-std=c++17" "-O2" "/tmp/.tmpa2g25g/p665691812841231303.cpp" "-o" "/tmp/.tmpa2g25g/p665691812841231303"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 4 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 8 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 9 finished with result: Ok(2, "3\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 6 finished with result: Ok(2, "10\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 5 finished with result: Ok(1, "8\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 3 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 7 finished with result: Ok(2, "200\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 10 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Task 11 finished with result: Ok(2, "5\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 1 finished with result: Ok(1, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 12 finished with result: Ok(2, "101\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 0 finished with result: Ok(2, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 2 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Getting result for task id: 1
[INFO] [stderr] [T] Getting result for task id: 2
[INFO] [stderr] [T] Getting result for task id: 3
[INFO] [stderr] [T] Getting result for task id: 4
[INFO] [stderr] [T] Getting result for task id: 5
[INFO] [stderr] [T] Getting result for task id: 6
[INFO] [stderr] [T] Getting result for task id: 7
[INFO] [stderr] [T] Getting result for task id: 8
[INFO] [stderr] [T] Getting result for task id: 9
[INFO] [stderr] [T] Getting result for task id: 10
[INFO] [stderr] [T] Getting result for task id: 11
[INFO] [stderr] [T] Getting result for task id: 12
[INFO] [stderr] [*] Solution time: 2ms
[INFO] [stderr] [T] Clearing tasks
[INFO] [stderr] [*] Tests size: 0.00MB
[INFO] [stderr] [*] Elapsed time: 0.31s
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p14324055355525279488.cpp, Executable file: /tmp/.tmpaCCIhx/build/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |          #include <iostream>
[INFO] [stderr]  |          using namespace std;
[INFO] [stderr]  |          
[INFO] [stderr]  |          int main() {
[INFO] [stderr]  |              int a,b;
[INFO] [stderr]  |              cin>>a>>b;
[INFO] [stderr]  |              cout<<a+b<<"\n";
[INFO] [stderr]  |              return 0; 
[INFO] [stderr]  |          }
[INFO] [stderr]  |          
[INFO] [stderr]  |          
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12681089750808797356
[INFO] [stderr] [T] Source file: /tmp/.tmpaCCIhx/build/p12681089750808797356.cpp, Executable file: /tmp/.tmpaCCIhx/build/p12681089750808797356
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 5
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpaCCIhx/build
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Task 0 finished with result: Ok(1, "Hello, World!\n")
[INFO] [stderr] [T] Getting result for task id: 0
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175; // Timeout occurred
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #else
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <unistd.h>
[INFO] [stderr]  |  #include <sys/wait.h>
[INFO] [stderr]  |  #include <signal.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <sys/resource.h>
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage() {
[INFO] [stderr]  |      rusage res;
[INFO] [stderr]  |      getrusage(RUSAGE_CHILDREN, &res);
[INFO] [stderr]  |      timeval user = res.ru_utime;
[INFO] [stderr]  |      timeval sys = res.ru_stime;
[INFO] [stderr]  |      long long user_ms = 1LL * user.tv_sec * 1000 + 1LL * user.tv_usec / 1000;
[INFO] [stderr]  |      long long sys_ms = 1LL * sys.tv_sec * 1000 + 1LL * sys.tv_usec / 1000;
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int run_command_with_timeout(const string& command, int timeout_ms) {
[INFO] [stderr]  |      pid_t pid = fork();
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid < 0) {
[INFO] [stderr]  |          // fork failed
[INFO] [stderr]  |          return -1;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      if (pid == 0) {
[INFO] [stderr]  |          exit(execl(command.c_str(), (char*) nullptr));
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      int status;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          pid_t result = waitpid(pid, &status, WNOHANG);
[INFO] [stderr]  |          if (result == pid) {
[INFO] [stderr]  |              if (WIFEXITED(status)) {
[INFO] [stderr]  |                  int exit_code = WEXITSTATUS(status);
[INFO] [stderr]  |                  return exit_code;
[INFO] [stderr]  |              } else if (WIFSIGNALED(status)) {
[INFO] [stderr]  |                  int signal = WTERMSIG(status);
[INFO] [stderr]  |                  return signal;
[INFO] [stderr]  |              }
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          this_thread::sleep_for(chrono::milliseconds(wait_time_ms));
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      kill(pid, SIGKILL);
[INFO] [stderr]  |      waitpid(pid, &status, 0);
[INFO] [stderr]  |  
[INFO] [stderr]  |      return 175;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int time_limit_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long start = get_rusage();
[INFO] [stderr]  |      int exit_status = run_command_with_timeout(command, time_limit_ms * 2);
[INFO] [stderr]  |      long long end = get_rusage();
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long elapsed = end - start;
[INFO] [stderr]  |  
[INFO] [stderr]  |      if(elapsed >= time_limit_ms)
[INFO] [stderr]  |          return 175;
[INFO] [stderr]  |  
[INFO] [stderr]  |      cerr << end - start;
[INFO] [stderr]  |      return exit_status;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  #endif
[INFO] [stderr] [T] Program handle created with id: 0 and hash: 14324055355525279488
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p14324055355525279488.cpp, Executable file: /tmp/.tmpuRxRCA/p14324055355525279488
[INFO] [stderr] [T] Adding program with source code: 
[INFO] [stderr]  |      #include <iostream>
[INFO] [stderr]  |      using namespace std;
[INFO] [stderr]  |      int main() {
[INFO] [stderr]  |          cout << "Hello, World!" << endl;
[INFO] [stderr]  |          return 0;
[INFO] [stderr]  |      }
[INFO] [stderr]  |      
[INFO] [stderr] [T] Program handle created with id: 1 and hash: 12833077150707811555
[INFO] [stderr] [T] Source file: /tmp/.tmpuRxRCA/p12833077150707811555.cpp, Executable file: /tmp/.tmpuRxRCA/p12833077150707811555
[INFO] [stderr] [T] Adding task for program id: 1, time limit: 1
[INFO] [stderr] [T] Cleaning build folder: /tmp/.tmpuRxRCA
[INFO] [stderr] [T] Running command: "/tmp/.tmpuRxRCA/p14324055355525279488" "/tmp/.tmpuRxRCA/p12833077150707811555" "1000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 6 finished with result: Ok(2, "10\n")
[INFO] [stderr] [T] Running command: "/tmp/.tmpaCCIhx/build/p14324055355525279488" "/tmp/.tmpaCCIhx/build/p12681089750808797356" "5000"
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 1 finished with result: Ok(2, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 7 finished with result: Ok(2, "200\n")
[INFO] [stderr] [T] Task 8 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 2 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Task 5 finished with result: Ok(2, "8\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 4 finished with result: Ok(2, "6\n")
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 3 finished with result: Ok(2, "2\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Task 10 finished with result: Ok(1, "4\n")
[INFO] [stderr] [T] Elapsed time from timer: 1 ms
[INFO] [stderr] [T] Elapsed time from timer: 2 ms
[INFO] [stderr] [T] Task 9 finished with result: Ok(2, "3\n")
[INFO] [stderr] [ERROR] Expected integer in input
[INFO] [stderr] [T] Creating CppRunner with build folder: /tmp/.tmpAtzfKi/build
[INFO] [stderr] [T] Building timer program
[INFO] [stderr] [T] Adding program with source code: #ifdef _WIN32
[INFO] [stderr]  |  #include <iostream>
[INFO] [stderr]  |  #include <chrono>
[INFO] [stderr]  |  #include <windows.h>
[INFO] [stderr]  |  #include <thread>
[INFO] [stderr]  |  #include <string>
[INFO] [stderr]  |  
[INFO] [stderr]  |  using namespace std;
[INFO] [stderr]  |  
[INFO] [stderr]  |  long long get_rusage(HANDLE process) {
[INFO] [stderr]  |      FILETIME creationTime, exitTime, kernelTime, userTime;
[INFO] [stderr]  |      GetProcessTimes(process, &creationTime, &exitTime, &kernelTime, &userTime);
[INFO] [stderr]  |  
[INFO] [stderr]  |      ULARGE_INTEGER userTimeInt, sysTimeInt;
[INFO] [stderr]  |      userTimeInt.LowPart = userTime.dwLowDateTime;
[INFO] [stderr]  |      userTimeInt.HighPart = userTime.dwHighDateTime;
[INFO] [stderr]  |      sysTimeInt.LowPart = kernelTime.dwLowDateTime;
[INFO] [stderr]  |      sysTimeInt.HighPart = kernelTime.dwHighDateTime;
[INFO] [stderr]  |  
[INFO] [stderr]  |      long long user_ms = userTimeInt.QuadPart / 10000;  // Convert to milliseconds
[INFO] [stderr]  |      long long sys_ms = sysTimeInt.QuadPart / 10000;    // Convert to milliseconds
[INFO] [stderr]  |  
[INFO] [stderr]  |      return user_ms + sys_ms;
[INFO] [stderr]  |  }
[INFO] [stderr]  |  
[INFO] [stderr]  |  int main(int argc, const char* argv[]) {
[INFO] [stderr]  |      string command = argv[1];
[INFO] [stderr]  |      int timeout_ms = stoi(argv[2]);
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use STARTUPINFOW for wide characters
[INFO] [stderr]  |      STARTUPINFOW si = { sizeof(si) };
[INFO] [stderr]  |      PROCESS_INFORMATION pi;
[INFO] [stderr]  |      ZeroMemory(&pi, sizeof(pi));
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Convert command to wide string for Windows (needed for CreateProcessW)
[INFO] [stderr]  |      wstring wcommand(command.begin(), command.end());
[INFO] [stderr]  |  
[INFO] [stderr]  |      // Use CreateProcessW (wide character version)
[INFO] [stderr]  |      if (!CreateProcessW(
[INFO] [stderr]  |              NULL, &wcommand[0], NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) {
[INFO] [stderr]  |          return -1;  // Error in creating process
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      DWORD waitResult;
[INFO] [stderr]  |      int elapsed = 0;
[INFO] [stderr]  |      int wait_time_ms = 10; // check every 10ms
[INFO] [stderr]  |  
[INFO] [stderr]  |      while (elapsed < timeout_ms) {
[INFO] [stderr]  |          waitResult = WaitForSingleObject(pi.hProcess, wait_time_ms);
[INFO] [stderr]  |          if (waitResult == WAIT_OBJECT_0) {
[INFO] [stderr]  |              long long elapsed_time = get_rusage(pi.hProcess);
[INFO] [stderr]  |              cerr << elapsed_time << endl; // Output the elapsed time
[INFO] [stderr]  |  
[INFO] [stderr]  |              DWORD exitCode;
[INFO] [stderr]  |              GetExitCodeProcess(pi.hProcess, &exitCode);
[INFO] [stderr]  |              CloseHandle(pi.hProcess);
[INFO] [stderr]  |              CloseHandle(pi.hThread);
[INFO] [stderr]  |              return exitCode;
[INFO] [stderr]  |          }
[INFO] [stderr]  |  
[INFO] [stderr]  |          Sleep(wait_time_ms);
[INFO] [stderr]  |          elapsed += wait_time_ms;
[INFO] [stderr]  |      }
[INFO] [stderr]  |  
[INFO] [stderr]  |      TerminateProcess(pi.hProcess, 1); // Kill the process
[INFO] [stderr]  |      WaitForSingleObject(pi.hProcess, INFINITE);  // Wait for it to terminate
[INFO] [stderr]  |  
[INFO] [stderr]  |      CloseHandle(pi.hProcess);
[INFO] [stderr]  |      CloseHandle(pi.hThread);
[WARN] too many lines in the log, truncating it
