| 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); |