Generated by Cython 3.1.2

Yellow lines hint at Python interaction.
Click on a line that starts with a "+" to see the C code that Cython generated for it.

Raw output: hbn_cy.c

+001: # cython: language_level=3, boundscheck=False, wraparound=False, cdivision=True
  __pyx_t_3 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_3) < 0) __PYX_ERR(0, 1, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 002: # hbn_cy.pyx - Cython helpers for reading HBN binary files
 003: from cpython.bytes cimport PyBytes_AsStringAndSize
 004: cimport cython
+005: import numpy as np
  __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_numpy, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_np, __pyx_t_2) < 0) __PYX_ERR(0, 5, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 006: cimport numpy as cnp
+007: from datetime import datetime, timedelta
  __pyx_t_2 = __Pyx_PyList_Pack(2, __pyx_mstate_global->__pyx_n_u_datetime, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_datetime, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_datetime); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_datetime, __pyx_t_2) < 0) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_timedelta, __pyx_t_2) < 0) __PYX_ERR(0, 7, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 008: 
+009: @cython.inline
static unsigned int __pyx_f_4hspf_6hbn_cy__read_uint32_le(unsigned char const *__pyx_v_buf, Py_ssize_t __pyx_v_offset) {
  unsigned int __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}
 010: cdef unsigned int _read_uint32_le(const unsigned char* buf, Py_ssize_t offset) nogil:
 011:     """Reads a little-endian unsigned 32-bit integer."""
+012:     return buf[offset] | (buf[offset+1] << 8) | (buf[offset+2] << 16) | (buf[offset+3] << 24)
  __pyx_r = ((((__pyx_v_buf[__pyx_v_offset]) | ((__pyx_v_buf[(__pyx_v_offset + 1)]) << 8)) | ((__pyx_v_buf[(__pyx_v_offset + 2)]) << 16)) | ((__pyx_v_buf[(__pyx_v_offset + 3)]) << 24));
  goto __pyx_L0;
 013: 
+014: @cython.boundscheck(False)
/* Python wrapper */
static PyObject *__pyx_pw_4hspf_6hbn_cy_1map_hbn_file(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_4hspf_6hbn_cy_map_hbn_file, "\n    Parses an HBN file from a file path to produce mapn and mapd dictionaries.\n    Returns (mapn, mapd, data_bytes).\n    ");
static PyMethodDef __pyx_mdef_4hspf_6hbn_cy_1map_hbn_file = {"map_hbn_file", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_4hspf_6hbn_cy_1map_hbn_file, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_4hspf_6hbn_cy_map_hbn_file};
static PyObject *__pyx_pw_4hspf_6hbn_cy_1map_hbn_file(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_file_path = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("map_hbn_file (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_file_path,0};
  PyObject* values[1] = {0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 14, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 14, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "map_hbn_file", 0) < 0) __PYX_ERR(0, 14, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("map_hbn_file", 1, 1, 1, i); __PYX_ERR(0, 14, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 14, __pyx_L3_error)
    }
    __pyx_v_file_path = ((PyObject*)values[0]);
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("map_hbn_file", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 14, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("hspf.hbn_cy.map_hbn_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_file_path), (&PyUnicode_Type), 1, "file_path", 1))) __PYX_ERR(0, 16, __pyx_L1_error)
  __pyx_r = __pyx_pf_4hspf_6hbn_cy_map_hbn_file(__pyx_self, __pyx_v_file_path);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __pyx_r = NULL;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  goto __pyx_L7_cleaned_up;
  __pyx_L0:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __pyx_L7_cleaned_up:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_4hspf_6hbn_cy_map_hbn_file(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_file_path) {
  PyObject *__pyx_v_data_bytes = 0;
  unsigned char const *__pyx_v_cbuf;
  Py_ssize_t __pyx_v_buf_len;
  Py_ssize_t __pyx_v_index;
  Py_ssize_t __pyx_v_i;
  Py_ssize_t __pyx_v_slen;
  Py_ssize_t __pyx_v_ln;
  unsigned int __pyx_v_rectype;
  unsigned int __pyx_v_tcode;
  unsigned int __pyx_v_idval;
  unsigned int __pyx_v_reclen;
  unsigned char __pyx_v_rc1;
  unsigned char __pyx_v_rc2;
  unsigned char __pyx_v_rc3;
  unsigned char __pyx_v_rc;
  PyObject *__pyx_v_mapn = 0;
  PyObject *__pyx_v_mapd = 0;
  PyObject *__pyx_v_f = NULL;
  PyObject *__pyx_v_operation = NULL;
  PyObject *__pyx_v_activity = NULL;
  PyObject *__pyx_v_key = NULL;
  PyObject *__pyx_v_name = NULL;
  PyObject *__pyx_r = NULL;
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_AddTraceback("hspf.hbn_cy.map_hbn_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_data_bytes);
  __Pyx_XDECREF(__pyx_v_mapn);
  __Pyx_XDECREF(__pyx_v_mapd);
  __Pyx_XDECREF(__pyx_v_f);
  __Pyx_XDECREF(__pyx_v_operation);
  __Pyx_XDECREF(__pyx_v_activity);
  __Pyx_XDECREF(__pyx_v_key);
  __Pyx_XDECREF(__pyx_v_name);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
  __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_4hspf_6hbn_cy_1map_hbn_file, 0, __pyx_mstate_global->__pyx_n_u_map_hbn_file, NULL, __pyx_mstate_global->__pyx_n_u_hspf_hbn_cy, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[0])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 14, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_map_hbn_file, __pyx_t_3) < 0) __PYX_ERR(0, 14, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 015: @cython.wraparound(False)
 016: def map_hbn_file(str file_path):
 017:     """
 018:     Parses an HBN file from a file path to produce mapn and mapd dictionaries.
 019:     Returns (mapn, mapd, data_bytes).
 020:     """
 021:     cdef:
 022:         bytes data_bytes
 023:         const unsigned char* cbuf
+024:         Py_ssize_t buf_len, index = 1, i, slen, ln
  __pyx_v_index = 1;
 025:         unsigned int rectype, tcode, idval, reclen
 026:         unsigned char rc1, rc2, rc3, rc
+027:         dict mapn = {}
  __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 27, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_mapn = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;
+028:         dict mapd = {}
  __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_mapd = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;
 029: 
+030:     with open(file_path, 'rb') as f:
  /*with:*/ {
    __pyx_t_2 = NULL;
    __Pyx_INCREF(__pyx_builtin_open);
    __pyx_t_3 = __pyx_builtin_open; 
    __pyx_t_4 = 1;
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_file_path, __pyx_mstate_global->__pyx_n_u_rb};
      __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 30, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_5 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_exit); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 30, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_2 = NULL;
    __pyx_t_6 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_enter); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 30, __pyx_L3_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (likely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
      __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 30, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = __pyx_t_3;
    __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    /*try:*/ {
      {
        /*try:*/ {
          __pyx_v_f = __pyx_t_6;
          __pyx_t_6 = 0;
/* … */
        }
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        goto __pyx_L12_try_end;
        __pyx_L7_error:;
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        /*except:*/ {
          __Pyx_AddTraceback("hspf.hbn_cy.map_hbn_file", __pyx_clineno, __pyx_lineno, __pyx_filename);
          if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_1, &__pyx_t_3) < 0) __PYX_ERR(0, 30, __pyx_L9_except_error)
          __Pyx_XGOTREF(__pyx_t_6);
          __Pyx_XGOTREF(__pyx_t_1);
          __Pyx_XGOTREF(__pyx_t_3);
          __pyx_t_2 = PyTuple_Pack(3, __pyx_t_6, __pyx_t_1, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 30, __pyx_L9_except_error)
          __Pyx_GOTREF(__pyx_t_2);
          __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_2, NULL);
          __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 30, __pyx_L9_except_error)
          __Pyx_GOTREF(__pyx_t_10);
          __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_10);
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          if (__pyx_t_11 < 0) __PYX_ERR(0, 30, __pyx_L9_except_error)
          __pyx_t_12 = (!__pyx_t_11);
          if (unlikely(__pyx_t_12)) {
            __Pyx_GIVEREF(__pyx_t_6);
            __Pyx_GIVEREF(__pyx_t_1);
            __Pyx_XGIVEREF(__pyx_t_3);
            __Pyx_ErrRestoreWithState(__pyx_t_6, __pyx_t_1, __pyx_t_3);
            __pyx_t_6 = 0;  __pyx_t_1 = 0;  __pyx_t_3 = 0; 
            __PYX_ERR(0, 30, __pyx_L9_except_error)
          }
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          goto __pyx_L8_exception_handled;
        }
        __pyx_L9_except_error:;
        __Pyx_XGIVEREF(__pyx_t_7);
        __Pyx_XGIVEREF(__pyx_t_8);
        __Pyx_XGIVEREF(__pyx_t_9);
        __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9);
        goto __pyx_L1_error;
        __pyx_L8_exception_handled:;
        __Pyx_XGIVEREF(__pyx_t_7);
        __Pyx_XGIVEREF(__pyx_t_8);
        __Pyx_XGIVEREF(__pyx_t_9);
        __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9);
        __pyx_L12_try_end:;
      }
    }
    /*finally:*/ {
      /*normal exit:*/{
        if (__pyx_t_5) {
          __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_mstate_global->__pyx_tuple[0], NULL);
          __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
          if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 30, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_9);
          __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
        }
        goto __pyx_L6;
      }
      __pyx_L6:;
    }
    goto __pyx_L16;
    __pyx_L3_error:;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L1_error;
    __pyx_L16:;
  }
/* … */
  __pyx_mstate_global->__pyx_tuple[0] = PyTuple_Pack(3, Py_None, Py_None, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[0])) __PYX_ERR(0, 30, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[0]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[0]);
+031:         data_bytes = f.read()
          __pyx_t_1 = __pyx_v_f;
          __Pyx_INCREF(__pyx_t_1);
          __pyx_t_4 = 0;
          {
            PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL};
            __pyx_t_6 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_read, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
            __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
            if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 31, __pyx_L7_error)
            __Pyx_GOTREF(__pyx_t_6);
          }
          if (!(likely(PyBytes_CheckExact(__pyx_t_6))||((__pyx_t_6) == Py_None) || __Pyx_RaiseUnexpectedTypeError("bytes", __pyx_t_6))) __PYX_ERR(0, 31, __pyx_L7_error)
          __pyx_v_data_bytes = ((PyObject*)__pyx_t_6);
          __pyx_t_6 = 0;
+032:     if not data_bytes:
  if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 32, __pyx_L1_error) }
  __pyx_t_12 = (__pyx_v_data_bytes != Py_None)&&(__Pyx_PyBytes_GET_SIZE(__pyx_v_data_bytes) != 0);
  if (unlikely(((!CYTHON_ASSUME_SAFE_MACROS) && __pyx_t_12 < 0))) __PYX_ERR(0, 32, __pyx_L1_error)
  __pyx_t_11 = (!__pyx_t_12);
  if (unlikely(__pyx_t_11)) {
/* … */
  }
+033:         raise ValueError(f"File is empty: {file_path}")
    __pyx_t_1 = NULL;
    __Pyx_INCREF(__pyx_builtin_ValueError);
    __pyx_t_6 = __pyx_builtin_ValueError; 
    __pyx_t_2 = __Pyx_PyUnicode_Unicode(__pyx_v_file_path); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 33, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_13 = __Pyx_PyUnicode_Concat(__pyx_mstate_global->__pyx_kp_u_File_is_empty, __pyx_t_2); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 33, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_4 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_13};
      __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 33, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_Raise(__pyx_t_3, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __PYX_ERR(0, 33, __pyx_L1_error)
 034: 
+035:     PyBytes_AsStringAndSize(data_bytes, <char **>&cbuf, &buf_len)
  if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 35, __pyx_L1_error) }
  __pyx_t_14 = PyBytes_AsStringAndSize(__pyx_v_data_bytes, ((char **)(&__pyx_v_cbuf)), (&__pyx_v_buf_len)); if (unlikely(__pyx_t_14 == ((int)-1))) __PYX_ERR(0, 35, __pyx_L1_error)
+036:     if cbuf[0] != 0xFD:
  __pyx_t_11 = ((__pyx_v_cbuf[0]) != 0xFD);
  if (unlikely(__pyx_t_11)) {
/* … */
  }
+037:         raise ValueError("BAD HBN FILE - must start with magic number 0xFD")
    __pyx_t_6 = NULL;
    __Pyx_INCREF(__pyx_builtin_ValueError);
    __pyx_t_13 = __pyx_builtin_ValueError; 
    __pyx_t_4 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_BAD_HBN_FILE_must_start_with_mag};
      __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_13, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 37, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_Raise(__pyx_t_3, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __PYX_ERR(0, 37, __pyx_L1_error)
 038: 
+039:     while index < buf_len:
  while (1) {
    __pyx_t_11 = (__pyx_v_index < __pyx_v_buf_len);
    if (!__pyx_t_11) break;
+040:         if index + 28 > buf_len: break
    __pyx_t_11 = ((__pyx_v_index + 28) > __pyx_v_buf_len);
    if (__pyx_t_11) {
      goto __pyx_L20_break;
    }
+041:         rc1 = cbuf[index]; rc2 = cbuf[index+1]; rc3 = cbuf[index+2]; rc = cbuf[index+3]
    __pyx_v_rc1 = (__pyx_v_cbuf[__pyx_v_index]);
    __pyx_v_rc2 = (__pyx_v_cbuf[(__pyx_v_index + 1)]);
    __pyx_v_rc3 = (__pyx_v_cbuf[(__pyx_v_index + 2)]);
    __pyx_v_rc = (__pyx_v_cbuf[(__pyx_v_index + 3)]);
+042:         rectype = _read_uint32_le(cbuf, index + 4)
    __pyx_t_15 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_index + 4)); if (unlikely(__pyx_t_15 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 42, __pyx_L1_error)
    __pyx_v_rectype = __pyx_t_15;
+043:         idval = _read_uint32_le(cbuf, index + 16)
    __pyx_t_15 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_index + 16)); if (unlikely(__pyx_t_15 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 43, __pyx_L1_error)
    __pyx_v_idval = __pyx_t_15;
+044:         reclen = (<unsigned int>(rc) * 4194304) + (<unsigned int>(rc3) * 16384) + (<unsigned int>(rc2) * 64) + (<unsigned int>(rc1) >> 2) - 24
    __pyx_v_reclen = (((((((unsigned int)__pyx_v_rc) * 0x400000) + (((unsigned int)__pyx_v_rc3) * 0x4000)) + (((unsigned int)__pyx_v_rc2) * 64)) + (((unsigned int)__pyx_v_rc1) >> 2)) - 24);
 045: 
+046:         operation = data_bytes[index+8:index+16].decode('ascii', 'ignore').strip()
    if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 46, __pyx_L1_error) }
    if (unlikely(__pyx_v_data_bytes == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(0, 46, __pyx_L1_error)
    }
    __pyx_t_6 = __Pyx_decode_bytes(__pyx_v_data_bytes, (__pyx_v_index + 8), (__pyx_v_index + 16), NULL, ((char const *)"ignore"), PyUnicode_DecodeASCII); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 46, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_13 = __pyx_t_6;
    __Pyx_INCREF(__pyx_t_13);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_13, NULL};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_strip, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 46, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_XDECREF_SET(__pyx_v_operation, ((PyObject*)__pyx_t_3));
    __pyx_t_3 = 0;
+047:         activity = data_bytes[index+20:index+28].decode('ascii', 'ignore').strip()
    if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 47, __pyx_L1_error) }
    if (unlikely(__pyx_v_data_bytes == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(0, 47, __pyx_L1_error)
    }
    __pyx_t_13 = __Pyx_decode_bytes(__pyx_v_data_bytes, (__pyx_v_index + 20), (__pyx_v_index + 28), NULL, ((char const *)"ignore"), PyUnicode_DecodeASCII); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 47, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __pyx_t_6 = __pyx_t_13;
    __Pyx_INCREF(__pyx_t_6);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_strip, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 47, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_XDECREF_SET(__pyx_v_activity, ((PyObject*)__pyx_t_3));
    __pyx_t_3 = 0;
 048: 
+049:         if rectype == 1:  # data record
    switch (__pyx_v_rectype) {
      case 1:
/* … */
      break;
      case 0:
+050:             if index + 36 > buf_len: break
      __pyx_t_11 = ((__pyx_v_index + 36) > __pyx_v_buf_len);
      if (__pyx_t_11) {
        goto __pyx_L20_break;
      }
+051:             tcode = _read_uint32_le(cbuf, index + 32)
      __pyx_t_15 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_index + 32)); if (unlikely(__pyx_t_15 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 51, __pyx_L1_error)
      __pyx_v_tcode = __pyx_t_15;
+052:             key = (operation, idval, activity, int(tcode))
      __pyx_t_3 = __Pyx_PyLong_From_unsigned_int(__pyx_v_idval); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 52, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_6 = NULL;
      __Pyx_INCREF((PyObject *)(&PyLong_Type));
      __pyx_t_1 = ((PyObject *)(&PyLong_Type)); 
      __pyx_t_2 = __Pyx_PyLong_From_unsigned_int(__pyx_v_tcode); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 52, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_4 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_2};
        __pyx_t_13 = __Pyx_PyObject_FastCall(__pyx_t_1, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 52, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
      }
      __pyx_t_1 = PyTuple_New(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 52, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_v_operation);
      __Pyx_GIVEREF(__pyx_v_operation);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_operation) != (0)) __PYX_ERR(0, 52, __pyx_L1_error);
      __Pyx_GIVEREF(__pyx_t_3);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3) != (0)) __PYX_ERR(0, 52, __pyx_L1_error);
      __Pyx_INCREF(__pyx_v_activity);
      __Pyx_GIVEREF(__pyx_v_activity);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 2, __pyx_v_activity) != (0)) __PYX_ERR(0, 52, __pyx_L1_error);
      __Pyx_GIVEREF(__pyx_t_13);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 3, __pyx_t_13) != (0)) __PYX_ERR(0, 52, __pyx_L1_error);
      __pyx_t_3 = 0;
      __pyx_t_13 = 0;
      __Pyx_XDECREF_SET(__pyx_v_key, ((PyObject*)__pyx_t_1));
      __pyx_t_1 = 0;
+053:             if key not in mapd: mapd[key] = []
      __pyx_t_11 = (__Pyx_PyDict_ContainsTF(__pyx_v_key, __pyx_v_mapd, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 53, __pyx_L1_error)
      if (__pyx_t_11) {
        __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 53, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
        if (unlikely((PyDict_SetItem(__pyx_v_mapd, __pyx_v_key, __pyx_t_1) < 0))) __PYX_ERR(0, 53, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      }
+054:             mapd[key].append((index, reclen))
      __pyx_t_1 = __Pyx_PyDict_GetItem(__pyx_v_mapd, __pyx_v_key); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 54, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_13 = PyLong_FromSsize_t(__pyx_v_index); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 54, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      __pyx_t_3 = __Pyx_PyLong_From_unsigned_int(__pyx_v_reclen); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 54, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 54, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_GIVEREF(__pyx_t_13);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_13) != (0)) __PYX_ERR(0, 54, __pyx_L1_error);
      __Pyx_GIVEREF(__pyx_t_3);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_3) != (0)) __PYX_ERR(0, 54, __pyx_L1_error);
      __pyx_t_13 = 0;
      __pyx_t_3 = 0;
      __pyx_t_16 = __Pyx_PyObject_Append(__pyx_t_1, __pyx_t_2); if (unlikely(__pyx_t_16 == ((int)-1))) __PYX_ERR(0, 54, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+055:         elif rectype == 0:  # data names record
      break;
      default: break;
    }
+056:             key = (operation, idval, activity)
      __pyx_t_2 = __Pyx_PyLong_From_unsigned_int(__pyx_v_idval); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 56, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = PyTuple_New(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 56, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_v_operation);
      __Pyx_GIVEREF(__pyx_v_operation);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_operation) != (0)) __PYX_ERR(0, 56, __pyx_L1_error);
      __Pyx_GIVEREF(__pyx_t_2);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_2) != (0)) __PYX_ERR(0, 56, __pyx_L1_error);
      __Pyx_INCREF(__pyx_v_activity);
      __Pyx_GIVEREF(__pyx_v_activity);
      if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 2, __pyx_v_activity) != (0)) __PYX_ERR(0, 56, __pyx_L1_error);
      __pyx_t_2 = 0;
      __Pyx_XDECREF_SET(__pyx_v_key, ((PyObject*)__pyx_t_1));
      __pyx_t_1 = 0;
+057:             if key not in mapn: mapn[key] = []
      __pyx_t_11 = (__Pyx_PyDict_ContainsTF(__pyx_v_key, __pyx_v_mapn, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 57, __pyx_L1_error)
      if (__pyx_t_11) {
        __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 57, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
        if (unlikely((PyDict_SetItem(__pyx_v_mapn, __pyx_v_key, __pyx_t_1) < 0))) __PYX_ERR(0, 57, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      }
+058:             i = index + 28
      __pyx_v_i = (__pyx_v_index + 28);
+059:             slen = 0
      __pyx_v_slen = 0;
+060:             while slen < reclen:
      while (1) {
        __pyx_t_11 = (__pyx_v_slen < __pyx_v_reclen);
        if (!__pyx_t_11) break;
+061:                 if i + slen + 4 > buf_len: break
        __pyx_t_11 = (((__pyx_v_i + __pyx_v_slen) + 4) > __pyx_v_buf_len);
        if (__pyx_t_11) {
          goto __pyx_L26_break;
        }
+062:                 ln = _read_uint32_le(cbuf, i + slen)
        __pyx_t_15 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_i + __pyx_v_slen)); if (unlikely(__pyx_t_15 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 62, __pyx_L1_error)
        __pyx_v_ln = __pyx_t_15;
+063:                 if i + slen + 4 + ln > buf_len: break
        __pyx_t_11 = ((((__pyx_v_i + __pyx_v_slen) + 4) + __pyx_v_ln) > __pyx_v_buf_len);
        if (__pyx_t_11) {
          goto __pyx_L26_break;
        }
+064:                 name = data_bytes[i + slen + 4 : i + slen + 4 + ln].decode('ascii', 'ignore').strip().replace('-', '')
        if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 64, __pyx_L1_error) }
        if (unlikely(__pyx_v_data_bytes == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
          __PYX_ERR(0, 64, __pyx_L1_error)
        }
        __pyx_t_3 = __Pyx_decode_bytes(__pyx_v_data_bytes, ((__pyx_v_i + __pyx_v_slen) + 4), (((__pyx_v_i + __pyx_v_slen) + 4) + __pyx_v_ln), NULL, ((char const *)"ignore"), PyUnicode_DecodeASCII); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 64, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __pyx_t_2 = __pyx_t_3;
        __Pyx_INCREF(__pyx_t_2);
        __pyx_t_4 = 0;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
          __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_strip, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
          __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 64, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __pyx_t_3 = PyUnicode_Replace(((PyObject*)__pyx_t_1), __pyx_mstate_global->__pyx_kp_u_, __pyx_mstate_global->__pyx_kp_u__2, -1L); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 64, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_XDECREF_SET(__pyx_v_name, ((PyObject*)__pyx_t_3));
        __pyx_t_3 = 0;
+065:                 mapn[key].append(name)
        __pyx_t_3 = __Pyx_PyDict_GetItem(__pyx_v_mapn, __pyx_v_key); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 65, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __pyx_t_16 = __Pyx_PyObject_Append(__pyx_t_3, __pyx_v_name); if (unlikely(__pyx_t_16 == ((int)-1))) __PYX_ERR(0, 65, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+066:                 slen += 4 + ln
        __pyx_v_slen = (__pyx_v_slen + (4 + __pyx_v_ln));
      }
      __pyx_L26_break:;
 067: 
+068:         if reclen < 36: index += reclen + 29
    __pyx_t_11 = (__pyx_v_reclen < 36);
    if (__pyx_t_11) {
      __pyx_v_index = (__pyx_v_index + (__pyx_v_reclen + 29));
      goto __pyx_L29;
    }
+069:         else: index += reclen + 30
    /*else*/ {
      __pyx_v_index = (__pyx_v_index + (__pyx_v_reclen + 30));
    }
    __pyx_L29:;
  }
  __pyx_L20_break:;
 070: 
+071:     return mapn, mapd, data_bytes
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_data_bytes)) { __Pyx_RaiseUnboundLocalError("data_bytes"); __PYX_ERR(0, 71, __pyx_L1_error) }
  __pyx_t_3 = PyTuple_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 71, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_v_mapn);
  __Pyx_GIVEREF(__pyx_v_mapn);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_mapn) != (0)) __PYX_ERR(0, 71, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_mapd);
  __Pyx_GIVEREF(__pyx_v_mapd);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_v_mapd) != (0)) __PYX_ERR(0, 71, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_data_bytes);
  __Pyx_GIVEREF(__pyx_v_data_bytes);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_v_data_bytes) != (0)) __PYX_ERR(0, 71, __pyx_L1_error);
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 072: 
+073: @cython.boundscheck(False)
/* Python wrapper */
static PyObject *__pyx_pw_4hspf_6hbn_cy_3read_data_entries(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_4hspf_6hbn_cy_2read_data_entries, "\n    Reads data entries from the file's bytes. Returns (times, rows_array).\n    ");
static PyMethodDef __pyx_mdef_4hspf_6hbn_cy_3read_data_entries = {"read_data_entries", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_4hspf_6hbn_cy_3read_data_entries, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_4hspf_6hbn_cy_2read_data_entries};
static PyObject *__pyx_pw_4hspf_6hbn_cy_3read_data_entries(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_data_bytes = 0;
  PyObject *__pyx_v_entries = 0;
  int __pyx_v_nvals;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("read_data_entries (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_data_bytes,&__pyx_mstate_global->__pyx_n_u_entries,&__pyx_mstate_global->__pyx_n_u_nvals,0};
  PyObject* values[3] = {0,0,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 73, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 73, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 73, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 73, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "read_data_entries", 0) < 0) __PYX_ERR(0, 73, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 3; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("read_data_entries", 1, 3, 3, i); __PYX_ERR(0, 73, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 3)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 73, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 73, __pyx_L3_error)
      values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 73, __pyx_L3_error)
    }
    __pyx_v_data_bytes = ((PyObject*)values[0]);
    __pyx_v_entries = ((PyObject*)values[1]);
    __pyx_v_nvals = __Pyx_PyLong_As_int(values[2]); if (unlikely((__pyx_v_nvals == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 75, __pyx_L3_error)
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("read_data_entries", 1, 3, 3, __pyx_nargs); __PYX_ERR(0, 73, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("hspf.hbn_cy.read_data_entries", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_data_bytes), (&PyBytes_Type), 1, "data_bytes", 1))) __PYX_ERR(0, 75, __pyx_L1_error)
  if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_entries), (&PyList_Type), 1, "entries", 1))) __PYX_ERR(0, 75, __pyx_L1_error)
  __pyx_r = __pyx_pf_4hspf_6hbn_cy_2read_data_entries(__pyx_self, __pyx_v_data_bytes, __pyx_v_entries, __pyx_v_nvals);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __pyx_r = NULL;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  goto __pyx_L7_cleaned_up;
  __pyx_L0:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __pyx_L7_cleaned_up:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_4hspf_6hbn_cy_2read_data_entries(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_data_bytes, PyObject *__pyx_v_entries, int __pyx_v_nvals) {
  unsigned char const *__pyx_v_cbuf;
  Py_ssize_t __pyx_v_buf_len;
  Py_ssize_t __pyx_v_num_entries;
  Py_ssize_t __pyx_v_k;
  Py_ssize_t __pyx_v_idx;
  unsigned int __pyx_v_yr;
  unsigned int __pyx_v_mo;
  unsigned int __pyx_v_dy;
  unsigned int __pyx_v_hr;
  unsigned int __pyx_v_mn;
  PyArrayObject *__pyx_v_rows2d = 0;
  PyObject *__pyx_v_times = 0;
  __Pyx_LocalBuf_ND __pyx_pybuffernd_rows2d;
  __Pyx_Buffer __pyx_pybuffer_rows2d;
  PyObject *__pyx_r = NULL;
  __pyx_pybuffer_rows2d.pybuffer.buf = NULL;
  __pyx_pybuffer_rows2d.refcount = 0;
  __pyx_pybuffernd_rows2d.data = NULL;
  __pyx_pybuffernd_rows2d.rcbuffer = &__pyx_pybuffer_rows2d;
/* … */
  __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_4hspf_6hbn_cy_3read_data_entries, 0, __pyx_mstate_global->__pyx_n_u_read_data_entries, NULL, __pyx_mstate_global->__pyx_n_u_hspf_hbn_cy, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[1])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 73, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_read_data_entries, __pyx_t_3) < 0) __PYX_ERR(0, 73, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 074: @cython.wraparound(False)
 075: def read_data_entries(bytes data_bytes, list entries, int nvals):
 076:     """
 077:     Reads data entries from the file's bytes. Returns (times, rows_array).
 078:     """
 079:     cdef:
 080:         const unsigned char* cbuf
+081:         Py_ssize_t buf_len, num_entries = len(entries), k, idx
  if (unlikely(__pyx_v_entries == Py_None)) {
    PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()");
    __PYX_ERR(0, 81, __pyx_L1_error)
  }
  __pyx_t_1 = __Pyx_PyList_GET_SIZE(__pyx_v_entries); if (unlikely(__pyx_t_1 == ((Py_ssize_t)-1))) __PYX_ERR(0, 81, __pyx_L1_error)
  __pyx_v_num_entries = __pyx_t_1;
 082:         unsigned int yr, mo, dy, hr, mn
+083:         cnp.ndarray[cnp.float32_t, ndim=2] rows2d = np.empty((num_entries, nvals), dtype=np.float32)
  __pyx_t_3 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_empty); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyLong_FromSsize_t(__pyx_v_num_entries); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_nvals); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GIVEREF(__pyx_t_4);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_4) != (0)) __PYX_ERR(0, 83, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_6) != (0)) __PYX_ERR(0, 83, __pyx_L1_error);
  __pyx_t_4 = 0;
  __pyx_t_6 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_float32); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 83, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_8 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_3);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_8 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_3, __pyx_t_7};
    __pyx_t_6 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 83, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_4, __pyx_t_6, __pyx_callargs+2, 0) < 0) __PYX_ERR(0, 83, __pyx_L1_error)
    __pyx_t_2 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_5, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_6);
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 83, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (!(likely(((__pyx_t_2) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_2, __pyx_mstate_global->__pyx_ptype_5numpy_ndarray))))) __PYX_ERR(0, 83, __pyx_L1_error)
  {
    __Pyx_BufFmt_StackElem __pyx_stack[1];
    if (unlikely(__Pyx_GetBufferAndValidate(&__pyx_pybuffernd_rows2d.rcbuffer->pybuffer, (PyObject*)((PyArrayObject *)__pyx_t_2), &__Pyx_TypeInfo_nn___pyx_t_5numpy_float32_t, PyBUF_FORMAT| PyBUF_STRIDES, 2, 0, __pyx_stack) == -1)) {
      __pyx_v_rows2d = ((PyArrayObject *)Py_None); __Pyx_INCREF(Py_None); __pyx_pybuffernd_rows2d.rcbuffer->pybuffer.buf = NULL;
      __PYX_ERR(0, 83, __pyx_L1_error)
    } else {__pyx_pybuffernd_rows2d.diminfo[0].strides = __pyx_pybuffernd_rows2d.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_rows2d.diminfo[0].shape = __pyx_pybuffernd_rows2d.rcbuffer->pybuffer.shape[0]; __pyx_pybuffernd_rows2d.diminfo[1].strides = __pyx_pybuffernd_rows2d.rcbuffer->pybuffer.strides[1]; __pyx_pybuffernd_rows2d.diminfo[1].shape = __pyx_pybuffernd_rows2d.rcbuffer->pybuffer.shape[1];
    }
  }
  __pyx_v_rows2d = ((PyArrayObject *)__pyx_t_2);
  __pyx_t_2 = 0;
+084:         list times = [None] * num_entries
  __pyx_t_2 = PyList_New(1 * ((__pyx_v_num_entries<0) ? 0:__pyx_v_num_entries)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 84, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  { Py_ssize_t __pyx_temp;
    for (__pyx_temp=0; __pyx_temp < __pyx_v_num_entries; __pyx_temp++) {
      __Pyx_INCREF(Py_None);
      __Pyx_GIVEREF(Py_None);
      if (__Pyx_PyList_SET_ITEM(__pyx_t_2, __pyx_temp, Py_None) != (0)) __PYX_ERR(0, 84, __pyx_L1_error);
    }
  }
  __pyx_v_times = ((PyObject*)__pyx_t_2);
  __pyx_t_2 = 0;
 085: 
+086:     PyBytes_AsStringAndSize(data_bytes, <char **>&cbuf, &buf_len)
  __pyx_t_9 = PyBytes_AsStringAndSize(__pyx_v_data_bytes, ((char **)(&__pyx_v_cbuf)), (&__pyx_v_buf_len)); if (unlikely(__pyx_t_9 == ((int)-1))) __PYX_ERR(0, 86, __pyx_L1_error)
 087: 
+088:     for k in range(num_entries):
  __pyx_t_1 = __pyx_v_num_entries;
  __pyx_t_10 = __pyx_t_1;
  for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_10; __pyx_t_11+=1) {
    __pyx_v_k = __pyx_t_11;
+089:         idx = entries[k][0] # Get just the index from the (index, reclen) tuple
    if (unlikely(__pyx_v_entries == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(0, 89, __pyx_L1_error)
    }
    __pyx_t_2 = __Pyx_GetItemInt(__Pyx_PyList_GET_ITEM(__pyx_v_entries, __pyx_v_k), 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 0, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 89, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_12 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_12 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(0, 89, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_idx = __pyx_t_12;
 090: 
 091:         # Boundary check for safety
+092:         if idx + 56 + (nvals * 4) > buf_len: continue
    __pyx_t_13 = (((__pyx_v_idx + 56) + (__pyx_v_nvals * 4)) > __pyx_v_buf_len);
    if (__pyx_t_13) {
      goto __pyx_L3_continue;
    }
 093: 
+094:         yr = _read_uint32_le(cbuf, idx + 36)
    __pyx_t_14 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_idx + 36)); if (unlikely(__pyx_t_14 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 94, __pyx_L1_error)
    __pyx_v_yr = __pyx_t_14;
+095:         mo = _read_uint32_le(cbuf, idx + 40)
    __pyx_t_14 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_idx + 40)); if (unlikely(__pyx_t_14 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 95, __pyx_L1_error)
    __pyx_v_mo = __pyx_t_14;
+096:         dy = _read_uint32_le(cbuf, idx + 44)
    __pyx_t_14 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_idx + 44)); if (unlikely(__pyx_t_14 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 96, __pyx_L1_error)
    __pyx_v_dy = __pyx_t_14;
+097:         hr = _read_uint32_le(cbuf, idx + 48)
    __pyx_t_14 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_idx + 48)); if (unlikely(__pyx_t_14 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 97, __pyx_L1_error)
    __pyx_v_hr = __pyx_t_14;
+098:         mn = _read_uint32_le(cbuf, idx + 52)
    __pyx_t_14 = __pyx_f_4hspf_6hbn_cy__read_uint32_le(__pyx_v_cbuf, (__pyx_v_idx + 52)); if (unlikely(__pyx_t_14 == ((unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 98, __pyx_L1_error)
    __pyx_v_mn = __pyx_t_14;
 099: 
+100:         try:
    {
      /*try:*/ {
/* … */
      }
      __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0;
      __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
      __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0;
      goto __pyx_L13_try_end;
      __pyx_L6_error:;
      __Pyx_XDECREF(__pyx_t_18); __pyx_t_18 = 0;
      __Pyx_XDECREF(__pyx_t_19); __pyx_t_19 = 0;
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
      __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
      __Pyx_XDECREF(__pyx_t_22); __pyx_t_22 = 0;
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
/* … */
      __pyx_L8_except_error:;
      __Pyx_XGIVEREF(__pyx_t_15);
      __Pyx_XGIVEREF(__pyx_t_16);
      __Pyx_XGIVEREF(__pyx_t_17);
      __Pyx_ExceptionReset(__pyx_t_15, __pyx_t_16, __pyx_t_17);
      goto __pyx_L1_error;
      __pyx_L7_exception_handled:;
      __Pyx_XGIVEREF(__pyx_t_15);
      __Pyx_XGIVEREF(__pyx_t_16);
      __Pyx_XGIVEREF(__pyx_t_17);
      __Pyx_ExceptionReset(__pyx_t_15, __pyx_t_16, __pyx_t_17);
      __pyx_L13_try_end:;
    }
+101:             times[k] = datetime(int(yr), int(mo), int(dy), int(hr) - 1, int(mn))
        __pyx_t_5 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_datetime); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_7 = NULL;
        __Pyx_INCREF((PyObject *)(&PyLong_Type));
        __pyx_t_3 = ((PyObject *)(&PyLong_Type)); 
        __pyx_t_18 = __Pyx_PyLong_From_unsigned_int(__pyx_v_yr); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_18);
        __pyx_t_8 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_18};
          __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
          __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_4);
        }
        __pyx_t_18 = NULL;
        __Pyx_INCREF((PyObject *)(&PyLong_Type));
        __pyx_t_7 = ((PyObject *)(&PyLong_Type)); 
        __pyx_t_19 = __Pyx_PyLong_From_unsigned_int(__pyx_v_mo); if (unlikely(!__pyx_t_19)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_19);
        __pyx_t_8 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_18, __pyx_t_19};
          __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_18); __pyx_t_18 = 0;
          __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
          __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
          if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_3);
        }
        __pyx_t_19 = NULL;
        __Pyx_INCREF((PyObject *)(&PyLong_Type));
        __pyx_t_18 = ((PyObject *)(&PyLong_Type)); 
        __pyx_t_20 = __Pyx_PyLong_From_unsigned_int(__pyx_v_dy); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_20);
        __pyx_t_8 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_19, __pyx_t_20};
          __pyx_t_7 = __Pyx_PyObject_FastCall(__pyx_t_18, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_19); __pyx_t_19 = 0;
          __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
          __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
          if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_7);
        }
        __pyx_t_20 = NULL;
        __Pyx_INCREF((PyObject *)(&PyLong_Type));
        __pyx_t_19 = ((PyObject *)(&PyLong_Type)); 
        __pyx_t_21 = __Pyx_PyLong_From_unsigned_int(__pyx_v_hr); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_21);
        __pyx_t_8 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_20, __pyx_t_21};
          __pyx_t_18 = __Pyx_PyObject_FastCall(__pyx_t_19, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
          __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
          __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
          if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_18);
        }
        __pyx_t_19 = __Pyx_PyLong_SubtractObjC(__pyx_t_18, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_19)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_19);
        __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
        __pyx_t_21 = NULL;
        __Pyx_INCREF((PyObject *)(&PyLong_Type));
        __pyx_t_20 = ((PyObject *)(&PyLong_Type)); 
        __pyx_t_22 = __Pyx_PyLong_From_unsigned_int(__pyx_v_mn); if (unlikely(!__pyx_t_22)) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_GOTREF(__pyx_t_22);
        __pyx_t_8 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_21, __pyx_t_22};
          __pyx_t_18 = __Pyx_PyObject_FastCall(__pyx_t_20, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
          __Pyx_DECREF(__pyx_t_22); __pyx_t_22 = 0;
          __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
          if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_18);
        }
        __pyx_t_8 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_6))) {
          __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_6);
          assert(__pyx_t_5);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
          __Pyx_INCREF(__pyx_t_5);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
          __pyx_t_8 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[6] = {__pyx_t_5, __pyx_t_4, __pyx_t_3, __pyx_t_7, __pyx_t_19, __pyx_t_18};
          __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_8, (6-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
          __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
          __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
          __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 101, __pyx_L6_error)
          __Pyx_GOTREF(__pyx_t_2);
        }
        if (unlikely((__Pyx_SetItemInt(__pyx_v_times, __pyx_v_k, __pyx_t_2, Py_ssize_t, 1, PyLong_FromSsize_t, 1, 0, 0, 1) < 0))) __PYX_ERR(0, 101, __pyx_L6_error)
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+102:         except ValueError:
      __pyx_t_9 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_ValueError);
      if (__pyx_t_9) {
        __Pyx_AddTraceback("hspf.hbn_cy.read_data_entries", __pyx_clineno, __pyx_lineno, __pyx_filename);
        if (__Pyx_GetException(&__pyx_t_2, &__pyx_t_6, &__pyx_t_18) < 0) __PYX_ERR(0, 102, __pyx_L8_except_error)
        __Pyx_XGOTREF(__pyx_t_2);
        __Pyx_XGOTREF(__pyx_t_6);
        __Pyx_XGOTREF(__pyx_t_18);
+103:             times[k] = datetime(1900, 1, 1) # Fallback for bad date data
        __Pyx_GetModuleGlobalName(__pyx_t_19, __pyx_mstate_global->__pyx_n_u_datetime); if (unlikely(!__pyx_t_19)) __PYX_ERR(0, 103, __pyx_L8_except_error)
        __Pyx_GOTREF(__pyx_t_19);
        __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_19, __pyx_mstate_global->__pyx_tuple[1], NULL); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 103, __pyx_L8_except_error)
        __Pyx_GOTREF(__pyx_t_7);
        __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
        if (unlikely((__Pyx_SetItemInt(__pyx_v_times, __pyx_v_k, __pyx_t_7, Py_ssize_t, 1, PyLong_FromSsize_t, 1, 0, 0, 1) < 0))) __PYX_ERR(0, 103, __pyx_L8_except_error)
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_XDECREF(__pyx_t_18); __pyx_t_18 = 0;
        goto __pyx_L7_exception_handled;
      }
      goto __pyx_L8_except_error;
 104: 
+105:         rows2d[k] = np.frombuffer(data_bytes, dtype=np.float32, count=nvals, offset=idx + 56)
    __pyx_t_6 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_frombuffer); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_19 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_float32); if (unlikely(!__pyx_t_19)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_19);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_nvals); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyLong_FromSsize_t((__pyx_v_idx + 56)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_8 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_6);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_8 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 3 : 0)] = {__pyx_t_6, __pyx_v_data_bytes};
      __pyx_t_4 = __Pyx_MakeVectorcallBuilderKwds(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 105, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_19, __pyx_t_4, __pyx_callargs+2, 0) < 0) __PYX_ERR(0, 105, __pyx_L1_error)
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_count, __pyx_t_2, __pyx_t_4, __pyx_callargs+2, 1) < 0) __PYX_ERR(0, 105, __pyx_L1_error)
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_offset, __pyx_t_3, __pyx_t_4, __pyx_callargs+2, 2) < 0) __PYX_ERR(0, 105, __pyx_L1_error)
      __pyx_t_18 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_4);
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 105, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_18);
    }
    if (unlikely((__Pyx_SetItemInt(((PyObject *)__pyx_v_rows2d), __pyx_v_k, __pyx_t_18, Py_ssize_t, 1, PyLong_FromSsize_t, 0, 0, 0, 1) < 0))) __PYX_ERR(0, 105, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
    __pyx_L3_continue:;
  }
 106: 
+107:     return times, rows2d
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_18 = PyTuple_New(2); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 107, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_18);
  __Pyx_INCREF(__pyx_v_times);
  __Pyx_GIVEREF(__pyx_v_times);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_18, 0, __pyx_v_times) != (0)) __PYX_ERR(0, 107, __pyx_L1_error);
  __Pyx_INCREF((PyObject *)__pyx_v_rows2d);
  __Pyx_GIVEREF((PyObject *)__pyx_v_rows2d);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_18, 1, ((PyObject *)__pyx_v_rows2d)) != (0)) __PYX_ERR(0, 107, __pyx_L1_error);
  __pyx_r = __pyx_t_18;
  __pyx_t_18 = 0;
  goto __pyx_L0;