Branch Coverage

xs/i32.xs
Criterion Covered Total %
branch 75 660 11.3


line true false branch
7 5 0 char errbuf[SHM_ERR_BUFLEN]; const char* path = SvOK(path_sv) ? SvPV_nolen(path_sv) : NULL; ShmHandle* map = shm_i32_create(path, (uint32_t)max_entries, (uint32_t)lru_max, (uint32_t)ttl_default, (uint32_t)lru_skip, errbuf);
8 0 5 if (!map) croak("HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
17 0 0 if (!map) croak("HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
27 0 0 const char* name = SvOK(name_sv) ? SvPV_nolen(name_sv) : NULL;
29 0 0 if (!map) croak("Data::HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("Data::HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
39 0 0 if (!map) croak("Data::HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
0 0 if (!map) croak("Data::HashMap::Shared::I32: %s", errbuf[0] ? errbuf : "unknown error");
47 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
48 0 0 RETVAL = h->backing_fd;
56 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
57 0 0 if (shm_msync(h) != 0) croak("Data::HashMap::Shared::I32 sync: %s", strerror(errno));
62 0 5 if (!SvROK(self_sv)) return;
64 0 5 if (!h) return;
71 1014 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1014 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1014 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
72 1014 0 RETVAL = shm_i32_put(h, key, value);
79 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
80 0 0 if ((items - 1) % 2 != 0) croak("set_multi requires even number of arguments (key, value pairs)");
82 0 0 if (h->shard_handles) {
83 0 0 for (int i = 1; i < items; i += 2)
89 0 0 for (int i = 1; i < items; i += 2)
94 0 0 RETVAL = count;
101 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
103 0 0 if (h->shard_handles) {
104 0 0 for (int i = 1; i < items; i++)
110 0 0 for (int i = 1; i < items; i++)
112 0 0 if (count) shm_i32_maybe_shrink(h);
116 0 0 RETVAL = count;
123 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
125 0 0 if (nkeys == 0) XSRETURN_EMPTY;
126 0 0 EXTEND(SP, nkeys);
0 0 EXTEND(SP, nkeys);
127 0 0 if (h->shard_handles) {
128 0 0 for (int i = 0; i < nkeys; i++) {
131 0 0 if (shm_i32_get(h, key, &val))
140 0 0 uint32_t now = h->expires_at ? shm_now() : 0;
147 0 0 for (int i = 0; i < nkeys; i++) {
153 0 0 for (int i = 0; i < nkeys; i++) {
160 0 0 for (uint32_t j = 0; j <= mask; j++) {
163 0 0 if (st == SHM_EMPTY) break;
164 0 0 if (st != tag) continue;
165 0 0 if (nodes[idx].key == key) {
166 0 0 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
0 0 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
0 0 if (h->expires_at && h->expires_at[idx] && now >= h->expires_at[idx]) break;
172 0 0 if (found) mPUSHi(val);
175 0 0 if (i + 1 < nkeys) {
186 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
189 0 0 if (!shm_i32_get_with_ttl(h, key, &out_value, &out_ttl)) XSRETURN_EMPTY;
190 0 0 EXTEND(SP, 2);
192 0 0 if (out_ttl < 0) PUSHs(&PL_sv_undef);
198 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
219 2 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
220 1 1 RETVAL = shm_i32_cas(h, key, expected, desired);
227 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
229 0 0 if (!shm_i32_cas_take(h, key, expected, &out_value)) XSRETURN_UNDEF;
237 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
238 0 0 RETVAL = shm_i32_persist(h, key);
245 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
246 0 0 RETVAL = shm_i32_set_ttl(h, key, (uint32_t)ttl_sec);
253 8 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 8 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
255 0 8 if (!shm_i32_get(h, key, &value)) XSRETURN_UNDEF;
263 500 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 500 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 500 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
264 500 0 RETVAL = shm_i32_remove(h, key);
271 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
272 0 0 RETVAL = shm_i32_exists(h, key);
279 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
282 0 1 if (!ok) croak("HashMap::Shared::I32: increment failed");
290 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
293 0 0 if (!ok) croak("HashMap::Shared::I32: decrement failed");
301 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
304 0 1 if (!ok) croak("HashMap::Shared::I32: incr_by failed");
312 2 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
313 0 2 RETVAL = (UV)shm_i32_size(h);
320 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
321 0 0 RETVAL = (UV)shm_i32_max_entries(h);
328 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
329 0 0 uint32_t ns = h->shard_handles ? h->num_shards : 1;
330 0 0 for (uint32_t si = 0; si < ns; si++) {
331 0 0 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
334 0 0 uint32_t now = sh->expires_at ? shm_now() : 0;
336 0 0 EXTEND(SP, hdr->size);
337 0 0 for (uint32_t i = 0; i < hdr->table_cap; i++) {
338 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))
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))
339 0 0 mXPUSHi(nodes[i].key);
346 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
347 0 1 uint32_t ns = h->shard_handles ? h->num_shards : 1;
348 1 1 for (uint32_t si = 0; si < ns; si++) {
349 0 1 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
352 0 1 uint32_t now = sh->expires_at ? shm_now() : 0;
354 0 1 EXTEND(SP, hdr->size);
355 16 1 for (uint32_t i = 0; i < hdr->table_cap; i++) {
356 10 6 if (SHM_IS_LIVE(sh->states[i]) && !SHM_IS_EXPIRED(sh, i, now))
0 10 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))
357 0 10 mXPUSHi(nodes[i].value);
364 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
365 0 0 uint32_t ns = h->shard_handles ? h->num_shards : 1;
366 0 0 for (uint32_t si = 0; si < ns; si++) {
367 0 0 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
370 0 0 uint32_t now = sh->expires_at ? shm_now() : 0;
372 0 0 EXTEND(SP, hdr->size * 2);
373 0 0 for (uint32_t i = 0; i < hdr->table_cap; i++) {
374 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)) {
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)) {
375 0 0 mXPUSHi(nodes[i].key);
376 0 0 mXPUSHi(nodes[i].value);
385 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
387 0 0 if (shm_i32_each(h, &out_key, &out_value)) {
388 0 0 EXTEND(SP, 2);
389 0 0 mXPUSHi(out_key);
390 0 0 mXPUSHi(out_value);
399 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
406 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
412 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
414 0 0 uint32_t ns = h->shard_handles ? h->num_shards : 1;
415 0 0 for (uint32_t si = 0; si < ns; si++) {
416 0 0 ShmHandle *sh = h->shard_handles ? h->shard_handles[si] : h;
419 0 0 uint32_t now = sh->expires_at ? shm_now() : 0;
421 0 0 for (uint32_t i = 0; i < hdr->table_cap; i++) {
422 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)) {
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)) {
426 0 0 if (!hv_store(hv, kbuf, klen, val, 0)) SvREFCNT_dec(val);
438 2 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
441 0 2 if (!rc) XSRETURN_UNDEF;
449 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
450 0 0 REQUIRE_TTL(h);
0 0 REQUIRE_TTL(h);
451 0 0 RETVAL = shm_i32_put_ttl(h, key, value, (uint32_t)ttl_sec);
458 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
459 0 0 RETVAL = (UV)shm_i32_max_size(h);
466 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
467 0 0 RETVAL = (UV)shm_i32_ttl(h);
474 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
476 0 0 if (!shm_i32_take(h, key, &out_value)) XSRETURN_UNDEF;
484 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
487 0 0 if (!shm_i32_pop(h, &out_key, &out_val)) XSRETURN_EMPTY;
488 0 0 EXTEND(SP, 2);
495 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
498 0 0 if (!shm_i32_shift(h, &out_key, &out_val)) XSRETURN_EMPTY;
499 0 0 EXTEND(SP, 2);
506 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
507 0 0 if (limit == 0) XSRETURN_EMPTY;
509 0 0 Newxz(entries, limit, shm_i32_drain_entry);
515 0 0 EXTEND(SP, n * 2);
516 0 0 for (uint32_t i = 0; i < n; i++) {
520 0 0 if (buf) free(buf);
526 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
527 0 0 RETVAL = (UV)shm_i32_flush_expired(h);
534 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
537 0 0 EXTEND(SP, 2);
544 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
552 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
553 0 0 RETVAL = shm_i32_touch(h, key);
560 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
561 0 0 RETVAL = shm_i32_reserve(h, (uint32_t)target);
568 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
576 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
584 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
585 0 0 RETVAL = (UV)shm_i32_stat_recoveries(h);
592 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
600 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
608 2 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
609 1 1 RETVAL = shm_i32_add(h, key, value);
616 2 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 2 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
617 0 2 REQUIRE_TTL(h);
0 2 REQUIRE_TTL(h);
618 1 1 RETVAL = shm_i32_add_ttl(h, key, value, (uint32_t)ttl_sec);
625 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
626 1 0 RETVAL = shm_i32_update(h, key, value);
633 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
634 0 0 REQUIRE_TTL(h);
0 0 REQUIRE_TTL(h);
635 0 0 RETVAL = shm_i32_update_ttl(h, key, value, (uint32_t)ttl_sec);
642 1 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 1 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
645 0 1 if (rc != 1) XSRETURN_UNDEF;
653 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
654 0 0 RETVAL = h->path ? newSVpv(h->path, 0) : &PL_sv_undef;
662 0 0 if (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) {
0 0 if (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) {
664 0 0 if (!h) croak("Attempted to use a destroyed Data::HashMap::Shared::I32 object");
667 0 0 if (items < 2) croak("Usage: Data::HashMap::Shared::I32->unlink($path)");
670 0 0 RETVAL = (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) ?
0 0 RETVAL = (SvROK(self_or_class) && SvOBJECT(SvRV(self_or_class))) ?
671 0 0 shm_unlink_sharded(INT2PTR(ShmHandle*, SvIV(SvRV(self_or_class)))) :
679 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
681 0 0 if (remaining < 0) XSRETURN_UNDEF;
689 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
690 0 0 RETVAL = (UV)shm_i32_capacity(h);
697 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
698 0 0 RETVAL = (UV)shm_i32_tombstones(h);
705 0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
0 0 EXTRACT_MAP("Data::HashMap::Shared::I32", self_sv);
707 0 0 if (!c) croak("Failed to allocate cursor");
718 0 0 if (!SvROK(self_sv)) return;
720 0 0 if (!c) return;
723 0 0 if (h) shm_i32_flush_deferred(h);
729 0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
731 0 0 if (shm_i32_cursor_next(c, &out_key, &out_value)) {
732 0 0 EXTEND(SP, 2);
733 0 0 mXPUSHi(out_key);
734 0 0 mXPUSHi(out_value);
742 0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
748 0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
0 0 EXTRACT_CURSOR("Data::HashMap::Shared::I32::Cursor", self_sv);
749 0 0 RETVAL = shm_i32_cursor_seek(c, key);