Branch Coverage

xs/ii.xs
Criterion Covered Total %
branch 360 600 60.0


line true false branch
7 137 1 char errbuf[SHM_ERR_BUFLEN]; const char* path = SvOK(path_sv) ? SvPV_nolen(path_sv) : NULL; ShmHandle* map = shm_ii_create(path, (uint32_t)max_entries, (uint32_t)lru_max, (uint32_t)ttl_default, (uint32_t)lru_skip, errbuf);
8 2 136 if (!map) croak("HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
2 0 if (!map) croak("HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
17 0 17 if (!map) croak("HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
27 3 0 const char* name = SvOK(name_sv) ? SvPV_nolen(name_sv) : NULL;
29 0 3 if (!map) croak("Data::HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("Data::HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
39 1 1 if (!map) croak("Data::HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
1 0 if (!map) croak("Data::HashMap::Shared::II: %s", errbuf[0] ? errbuf : "unknown error");
47 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
48 0 2 RETVAL = h->backing_fd;
56 1 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
57 0 1 if (shm_msync(h) != 0) croak("Data::HashMap::Shared::II sync: %s", strerror(errno));
62 0 157 if (!SvROK(self_sv)) return;
64 0 157 if (!h) return;
71 7210 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7210 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7210 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
72 7141 69 RETVAL = shm_ii_put(h, key, value);
79 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
80 1 5 if ((items - 1) % 2 != 0) croak("set_multi requires even number of arguments (key, value pairs)");
82 1 4 if (h->shard_handles) {
83 5 1 for (int i = 1; i < items; i += 2)
89 1008 4 for (int i = 1; i < items; i += 2)
94 0 5 RETVAL = count;
101 4 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
103 1 3 if (nkeys == 0) XSRETURN_EMPTY;
104 3 0 EXTEND(SP, nkeys);
0 3 EXTEND(SP, nkeys);
105 1 2 if (h->shard_handles) {
106 4 1 for (int i = 0; i < nkeys; i++) {
109 3 1 if (shm_ii_get(h, key, &val))
118 1 1 uint32_t now = h->expires_at ? shm_now() : 0;
125 7 2 for (int i = 0; i < nkeys; i++) {
131 7 2 for (int i = 0; i < nkeys; i++) {
138 9 0 for (uint32_t j = 0; j <= mask; j++) {
141 1 8 if (st == SHM_EMPTY) break;
142 2 6 if (st != tag) continue;
143 6 0 if (nodes[idx].key == key) {
144 3 3 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
3 0 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
1 2 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
150 5 2 if (found) mPUSHi(val);
153 5 2 if (i + 1 < nkeys) {
164 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
185 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
186 3 3 RETVAL = shm_ii_cas(h, key, expected, desired);
193 4 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
194 3 1 RETVAL = shm_ii_persist(h, key);
201 5 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
202 4 1 RETVAL = shm_ii_set_ttl(h, key, (uint32_t)ttl_sec);
209 894 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 894 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 894 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
211 86 808 if (!shm_ii_get(h, key, &value)) XSRETURN_UNDEF;
219 2785 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2785 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2785 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
220 2785 0 RETVAL = shm_ii_remove(h, key);
227 56 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 56 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 56 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
228 28 28 RETVAL = shm_ii_exists(h, key);
235 8 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
238 0 8 if (!ok) croak("HashMap::Shared::II: increment failed");
246 3 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
249 0 3 if (!ok) croak("HashMap::Shared::II: decrement failed");
257 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
260 0 6 if (!ok) croak("HashMap::Shared::II: incr_by failed");
268 70 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 70 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 70 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
269 0 70 RETVAL = (UV)shm_ii_size(h);
276 3 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
277 0 3 RETVAL = (UV)shm_ii_max_entries(h);
284 3 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 3 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
285 1 2 uint32_t ns = h->shard_handles ? h->num_shards : 1;
286 6 3 for (uint32_t si = 0; si < ns; si++) {
287 4 2 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
290 1 5 uint32_t now = sh->expires_at ? shm_now() : 0;
292 0 6 EXTEND(SP, hdr->size);
293 128 6 for (uint32_t i = 0; i < hdr->table_cap; i++) {
294 55 73 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
2 53 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
2 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
1 1 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
295 0 54 mXPUSHi(nodes[i].key);
302 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
303 1 1 uint32_t ns = h->shard_handles ? h->num_shards : 1;
304 5 2 for (uint32_t si = 0; si < ns; si++) {
305 4 1 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
308 0 5 uint32_t now = sh->expires_at ? shm_now() : 0;
310 0 5 EXTEND(SP, hdr->size);
311 112 5 for (uint32_t i = 0; i < hdr->table_cap; i++) {
312 53 59 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
0 53 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
313 0 53 mXPUSHi(nodes[i].value);
320 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
321 1 1 uint32_t ns = h->shard_handles ? h->num_shards : 1;
322 5 2 for (uint32_t si = 0; si < ns; si++) {
323 4 1 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
326 0 5 uint32_t now = sh->expires_at ? shm_now() : 0;
328 0 5 EXTEND(SP, hdr->size * 2);
329 112 5 for (uint32_t i = 0; i < hdr->table_cap; i++) {
330 53 59 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 53 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
331 0 53 mXPUSHi(nodes[i].key);
332 0 53 mXPUSHi(nodes[i].value);
341 662 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 662 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 662 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
343 649 13 if (shm_ii_each(h, &out_key, &out_value)) {
344 0 649 EXTEND(SP, 2);
345 0 649 mXPUSHi(out_key);
346 0 649 mXPUSHi(out_value);
355 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
362 7 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
368 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
370 1 1 uint32_t ns = h->shard_handles ? h->num_shards : 1;
371 5 2 for (uint32_t si = 0; si < ns; si++) {
372 4 1 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
375 0 5 uint32_t now = sh->expires_at ? shm_now() : 0;
377 112 5 for (uint32_t i = 0; i < hdr->table_cap; i++) {
378 52 60 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 52 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
0 0 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now)) {
382 0 52 if (!hv_store(hv, kbuf, klen, val, 0)) SvREFCNT_dec(val);
394 7 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
397 0 7 if (!rc) XSRETURN_UNDEF;
405 21 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 21 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 21 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
406 1 20 REQUIRE_TTL(h);
1 20 REQUIRE_TTL(h);
407 20 0 RETVAL = shm_ii_put_ttl(h, key, value, (uint32_t)ttl_sec);
414 5 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
415 0 5 RETVAL = (UV)shm_ii_max_size(h);
422 5 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
423 0 5 RETVAL = (UV)shm_ii_ttl(h);
430 5 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 5 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
432 2 3 if (!shm_ii_take(h, key, &out_value)) XSRETURN_UNDEF;
440 12 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 12 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 12 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
443 2 10 if (!shm_ii_pop(h, &out_key, &out_val)) XSRETURN_EMPTY;
444 0 10 EXTEND(SP, 2);
451 8 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
454 1 7 if (!shm_ii_shift(h, &out_key, &out_val)) XSRETURN_EMPTY;
455 0 7 EXTEND(SP, 2);
462 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
463 0 6 if (limit == 0) XSRETURN_EMPTY;
465 0 6 Newxz(entries, limit, shm_ii_drain_entry);
471 0 6 EXTEND(SP, n * 2);
472 15 6 for (uint32_t i = 0; i < n; i++) {
476 0 6 if (buf) free(buf);
482 8 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
483 0 8 RETVAL = (UV)shm_ii_flush_expired(h);
490 27 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 27 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 27 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
493 0 27 EXTEND(SP, 2);
500 4 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
508 9 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 9 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 9 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
509 6 3 RETVAL = shm_ii_touch(h, key);
516 8 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
517 5 3 RETVAL = shm_ii_reserve(h, (uint32_t)target);
524 11 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 11 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 11 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
532 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
540 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
541 0 2 RETVAL = (UV)shm_ii_stat_recoveries(h);
548 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
556 2 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
564 11 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 11 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 11 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
565 8 3 RETVAL = shm_ii_add(h, key, value);
572 6 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 6 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
573 4 2 RETVAL = shm_ii_update(h, key, value);
580 8 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
583 3 5 if (rc != 1) XSRETURN_UNDEF;
591 4 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 4 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
592 2 2 RETVAL = h->path ? newSVpv(h->path, 0) : &PL_sv_undef;
600 2 2 if (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) {
2 0 if (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) {
602 0 2 if (!h) croak("Attempted to use a destroyed Data::HashMap::Shared::II object");
605 0 2 if (items < 2) croak("Usage: Data::HashMap::Shared::II->unlink($path)");
608 2 0 RETVAL = (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) ?
3 1 RETVAL = (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) ?
609 2 2 shm_unlink_sharded(INT2PTR(ShmHandle*, SvIV(SvRV(self_or_class)))) :
617 33 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 33 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 33 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
619 2 31 if (remaining < 0) XSRETURN_UNDEF;
627 15 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 15 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 15 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
628 0 15 RETVAL = (UV)shm_ii_capacity(h);
635 7 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 7 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
636 0 7 RETVAL = (UV)shm_ii_tombstones(h);
643 18 0 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 18 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
0 18 EXTRACT_MAP("Data::HashMap::Shared::II", self_sv);
645 0 18 if (!c) croak("Failed to allocate cursor");
656 0 18 if (!SvROK(self_sv)) return;
658 0 18 if (!c) return;
661 18 0 if (h) shm_ii_flush_deferred(h);
667 745 0 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 745 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 745 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
669 731 14 if (shm_ii_cursor_next(c, &out_key, &out_value)) {
670 0 731 EXTEND(SP, 2);
671 0 731 mXPUSHi(out_key);
672 0 731 mXPUSHi(out_value);
680 2 0 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 2 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 2 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
686 5 0 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 5 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
0 5 EXTRACT_CURSOR("Data::HashMap::Shared::II::Cursor", self_sv);
687 3 2 RETVAL = shm_ii_cursor_seek(c, key);