#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
static inline int parse_hex_len(const char *p, int *used) {
  int v = 0;
  int i = 0;
  for (;; i++) {
    char c = p[i];
    if (c == '\r')
      break;
    int d;
    if (c >= '0' && c <= '9')
      d = c - '0';
    else if (c >= 'a' && c <= 'f')
      d = c - 'a' + 10;
    else if (c >= 'A' && c <= 'F')
      d = c - 'A' + 10;
    else
      d = 0;
    v = (v << 4) | d;
  }
  *used = i;
  return v;
}
static double chunk_run(const char *buf, int buflen) {
  uint64_t h = 1469598103934665603ULL;
  int pos = 0;
  for (;;) {
    int used = 0;
    int len = parse_hex_len(buf + pos, &used);
    pos += used;
    pos += 2;
    if (len == 0)
      break;
    for (int i = 0; i < len; i++) {
      unsigned char b = (unsigned char)buf[pos + i];
      h ^= (uint64_t)b;
      h *= 1099511628211ULL;
    }
    pos += len;
    pos += 2;
  }
  pos += 2;
  double ans_once = (double)h;
  double ans = 0.0;

  ans = ans_once;
  return ans;
}
BENCH_MAIN_SCALAR3(
    T004_Module_058, CHUNKED, 4096, 16384, 65536,
    char *buf = (char *)malloc((size_t)n * 4 + 1024);
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      int chunks = n / 32;
      if (chunks < 1)
        chunks = 1;
      int pos = 0;
      for (int c = 0; c < chunks; c++) {
        int len = (int)(bench_rng_next(&rng) % 15ULL) + 1;
        char hexstr[16];
        int hexlen = snprintf(hexstr, sizeof(hexstr), "%X", len);
        memcpy(buf + pos, hexstr, (size_t)hexlen);
        pos += hexlen;
        buf[pos++] = '\r';
        buf[pos++] = '\n';
        for (int i = 0; i < len; i++) {
          char ch = (char)('A' + (bench_rng_next(&rng) % 26ULL));
          buf[pos++] = ch;
        }
        buf[pos++] = '\r';
        buf[pos++] = '\n';
      }
      buf[pos++] = '0';
      buf[pos++] = '\r';
      buf[pos++] = '\n';
      buf[pos++] = '\r';
      buf[pos++] = '\n';
      buf[pos] = '\0';
      n = pos;
    },
    ans_scalar = chunk_run(buf, n), ans_scalar, free(buf);)
