mono_binary_search (const void * key, const void * array, size_t array_length, size_t member_size, int (*BinarySearchComparer) (const void *, const void *) comparer)
{
  unsigned int D.2211;
  unsigned int D.2212;
  void * D.2215;
  const char * base;
  size_t lim;
  int cmp;
  const void * p;

  base = array;
  lim = array_length;
  goto <D.2208>;
  <D.2207>:
  D.2211 = lim >> 1;
  D.2212 = D.2211 * member_size;
  p = base + D.2212;
  cmp = comparer (key, p);
  if (cmp == 0) goto <D.2213>; else goto <D.2214>;
  <D.2213>:
  D.2215 = p;
  return D.2215;
  <D.2214>:
  if (cmp > 0) goto <D.2216>; else goto <D.2217>;
  <D.2216>:
  base = p + member_size;
  lim = lim + 4294967295;
  <D.2217>:
  lim = lim >> 1;
  <D.2208>:
  if (lim != 0) goto <D.2207>; else goto <D.2209>;
  <D.2209>:
  D.2215 = 0B;
  return D.2215;
}


