Rizin
unix-like reverse engineering framework and cli tools
sdbht.h File Reference
#include "ht_pp.h"

Go to the source code of this file.

Classes

struct  sdb_kv
 

Typedefs

typedef struct sdb_kv SdbKv
 

Functions

static char * sdbkv_key (const SdbKv *kv)
 
static char * sdbkv_value (const SdbKv *kv)
 
static ut32 sdbkv_key_len (const SdbKv *kv)
 
static ut32 sdbkv_value_len (const SdbKv *kv)
 
RZ_API SdbKvsdbkv_new2 (const char *k, int kl, const char *v, int vl)
 
RZ_API SdbKvsdbkv_new (const char *k, const char *v)
 
RZ_API void sdbkv_free (SdbKv *kv)
 
RZ_API ut32 sdb_hash (const char *key)
 
RZ_API HtPP * sdb_ht_new (void)
 
RZ_API void sdb_ht_free (HtPP *ht)
 
RZ_API bool sdb_ht_insert (HtPP *ht, const char *key, const char *value)
 
RZ_API bool sdb_ht_insert_kvp (HtPP *ht, SdbKv *kvp, bool update)
 
RZ_API bool sdb_ht_update (HtPP *ht, const char *key, const char *value)
 
RZ_API bool sdb_ht_delete (HtPP *ht, const char *key)
 
RZ_API char * sdb_ht_find (HtPP *ht, const char *key, bool *found)
 
RZ_API SdbKvsdb_ht_find_kvp (HtPP *ht, const char *key, bool *found)
 

Typedef Documentation

◆ SdbKv

typedef struct sdb_kv SdbKv

keyvalue pair

Function Documentation

◆ sdb_hash()

RZ_API ut32 sdb_hash ( const char *  key)

Definition at line 22 of file util.c.

22  {
23  return sdb_hash_len(s, NULL);
24 }
#define NULL
Definition: cris-opc.c:27
RZ_API ut32 sdb_hash_len(const char *s, ut32 *len)
Definition: util.c:7
static RzSocket * s
Definition: rtr.c:28

◆ sdb_ht_delete()

RZ_API bool sdb_ht_delete ( HtPP *  ht,
const char *  key 
)

Definition at line 67 of file sdbht.c.

67  {
68  return ht_pp_delete(ht, key);
69 }
static static sync static getppid static getegid const char static filename char static len const char char static bufsiz static mask static vfork const void static prot static getpgrp const char static swapflags static arg static fd static protocol static who struct sockaddr static addrlen static backlog struct timeval struct timezone static tz const struct iovec static count static mode const void const struct sockaddr static tolen const char static pathname void static offset struct stat static buf void long static basep static whence static length const void static len key
Definition: sflib.h:118

References key.

Referenced by _remove_afer_insert(), sdb_remove(), and sdb_set_internal().

◆ sdb_ht_find()

RZ_API char* sdb_ht_find ( HtPP *  ht,
const char *  key,
bool found 
)

Definition at line 59 of file sdbht.c.

59  {
60  return (char *)ht_pp_find(ht, key, found);
61 }
RZ_API const KEY_TYPE bool * found
Definition: ht_inc.h:130

References found, and key.

Referenced by resolve_mig_subsystem(), rz_bin_pe_get_libs(), and symbols_from_stubs().

◆ sdb_ht_find_kvp()

RZ_API SdbKv* sdb_ht_find_kvp ( HtPP *  ht,
const char *  key,
bool found 
)

Definition at line 55 of file sdbht.c.

55  {
56  return (SdbKv *)ht_pp_find_kv(ht, key, found);
57 }
Definition: sdbht.h:14

References found, and key.

Referenced by sdb_const_get_len(), sdb_exists(), sdb_expire_get(), sdb_expire_set(), sdb_foreach_cdb(), and sdb_set_internal().

◆ sdb_ht_free()

RZ_API void sdb_ht_free ( HtPP *  ht)

Definition at line 63 of file sdbht.c.

63  {
64  ht_pp_free(ht);
65 }

Referenced by resolve_mig_subsystem(), rz_bin_pe_get_libs(), sdb_fini(), sdb_reset(), and symbols().

◆ sdb_ht_insert()

RZ_API bool sdb_ht_insert ( HtPP *  ht,
const char *  key,
const char *  value 
)

Definition at line 43 of file sdbht.c.

43  {
44  return sdb_ht_internal_insert(ht, key, value, false);
45 }
static int value
Definition: cmd_api.c:93
static bool sdb_ht_internal_insert(HtPP *ht, const char *key, const char *value, bool update)
Definition: sdbht.c:19

References key, sdb_ht_internal_insert(), and value.

Referenced by mig_hash_new(), rz_bin_pe_get_libs(), and symbols().

◆ sdb_ht_insert_kvp()

RZ_API bool sdb_ht_insert_kvp ( HtPP *  ht,
SdbKv kvp,
bool  update 
)

Definition at line 47 of file sdbht.c.

47  {
48  return ht_pp_insert_kv(ht, (HtPPKv *)kvp, update);
49 }
static bool update(RzCrypto *cry, const ut8 *buf, int len)
Definition: crypto_aes.c:92

References update().

Referenced by sdb_set_internal().

◆ sdb_ht_new()

RZ_API HtPP* sdb_ht_new ( void  )

Definition at line 11 of file sdbht.c.

11  {
12  HtPP *ht = ht_pp_new((HtPPDupValue)strdup, (HtPPKvFreeFunc)sdbkv_fini, (HtPPCalcSizeV)strlen);
13  if (ht) {
14  ht->opt.elem_size = sizeof(SdbKv);
15  }
16  return ht;
17 }
return strdup("=SP r13\n" "=LR r14\n" "=PC r15\n" "=A0 r0\n" "=A1 r1\n" "=A2 r2\n" "=A3 r3\n" "=ZF zf\n" "=SF nf\n" "=OF vf\n" "=CF cf\n" "=SN or0\n" "gpr lr .32 56 0\n" "gpr pc .32 60 0\n" "gpr cpsr .32 64 0 ____tfiae_________________qvczn\n" "gpr or0 .32 68 0\n" "gpr tf .1 64.5 0 thumb\n" "gpr ef .1 64.9 0 endian\n" "gpr jf .1 64.24 0 java\n" "gpr qf .1 64.27 0 sticky_overflow\n" "gpr vf .1 64.28 0 overflow\n" "gpr cf .1 64.29 0 carry\n" "gpr zf .1 64.30 0 zero\n" "gpr nf .1 64.31 0 negative\n" "gpr itc .4 64.10 0 if_then_count\n" "gpr gef .4 64.16 0 great_or_equal\n" "gpr r0 .32 0 0\n" "gpr r1 .32 4 0\n" "gpr r2 .32 8 0\n" "gpr r3 .32 12 0\n" "gpr r4 .32 16 0\n" "gpr r5 .32 20 0\n" "gpr r6 .32 24 0\n" "gpr r7 .32 28 0\n" "gpr r8 .32 32 0\n" "gpr r9 .32 36 0\n" "gpr r10 .32 40 0\n" "gpr r11 .32 44 0\n" "gpr r12 .32 48 0\n" "gpr r13 .32 52 0\n" "gpr r14 .32 56 0\n" "gpr r15 .32 60 0\n" "gpr r16 .32 64 0\n" "gpr r17 .32 68 0\n")
void sdbkv_fini(SdbKv *kv)
Definition: sdbht.c:6
struct sdb_kv SdbKv

References sdbkv_fini(), and strdup().

Referenced by mig_hash_new(), rz_bin_pe_get_libs(), sdb_new(), sdb_reset(), and symbols().

◆ sdb_ht_update()

RZ_API bool sdb_ht_update ( HtPP *  ht,
const char *  key,
const char *  value 
)

Definition at line 51 of file sdbht.c.

51  {
52  return sdb_ht_internal_insert(ht, key, value, true);
53 }

References key, sdb_ht_internal_insert(), and value.

◆ sdbkv_free()

RZ_API void sdbkv_free ( SdbKv kv)

Definition at line 524 of file sdb.c.

524  {
525  if (kv) {
526  free(sdbkv_key(kv));
527  free(sdbkv_value(kv));
528  RZ_FREE(kv);
529  }
530 }
RZ_API void Ht_() free(HtName_(Ht) *ht)
Definition: ht_inc.c:130
#define RZ_FREE(x)
Definition: rz_types.h:369
static char * sdbkv_key(const SdbKv *kv)
Definition: sdbht.h:21
static char * sdbkv_value(const SdbKv *kv)
Definition: sdbht.h:25

References free(), RZ_FREE, sdbkv_key(), and sdbkv_value().

Referenced by sdb_foreach_list(), sdb_foreach_list_filter_cb(), sdb_foreach_list_filter_user(), and sdb_foreach_match().

◆ sdbkv_key()

◆ sdbkv_key_len()

static ut32 sdbkv_key_len ( const SdbKv kv)
inlinestatic

Definition at line 29 of file sdbht.h.

29  {
30  return kv->base.key_len;
31 }

References sdb_kv::base.

◆ sdbkv_new()

RZ_API SdbKv* sdbkv_new ( const char *  k,
const char *  v 
)

Definition at line 489 of file sdb.c.

489  {
490  return sdbkv_new2(k, strlen(k), v, strlen(v));
491 }
const char * k
Definition: dsignal.c:11
const char * v
Definition: dsignal.c:12
RZ_API SdbKv * sdbkv_new2(const char *k, int kl, const char *v, int vl)
Definition: sdb.c:493

References k, sdbkv_new2(), and v.

◆ sdbkv_new2()

RZ_API SdbKv* sdbkv_new2 ( const char *  k,
int  kl,
const char *  v,
int  vl 
)

Definition at line 493 of file sdb.c.

493  {
494  SdbKv *kv;
495  if (!v) {
496  vl = 0;
497  }
498  kv = RZ_NEW0(SdbKv);
499  kv->base.key_len = kl;
500  kv->base.key = malloc(kv->base.key_len + 1);
501  if (!kv->base.key) {
502  free(kv);
503  return NULL;
504  }
505  memcpy(kv->base.key, k, kv->base.key_len + 1);
506  kv->base.value_len = vl;
507  if (vl) {
508  kv->base.value = malloc(vl + 1);
509  if (!kv->base.value) {
510  free(kv->base.key);
511  free(kv);
512  return NULL;
513  }
514  memcpy(kv->base.value, v, vl + 1);
515  } else {
516  kv->base.value = NULL;
517  kv->base.value_len = 0;
518  }
519  kv->cas = nextcas();
520  kv->expire = 0LL;
521  return kv;
522 }
memcpy(mem, inblock.get(), min(CONTAINING_RECORD(inblock.get(), MEMBLOCK, data) ->size, size))
void * malloc(size_t size)
Definition: malloc.c:123
#define RZ_NEW0(x)
Definition: rz_types.h:284
static int nextcas(void)
Definition: sdb.c:26
ut64 expire
Definition: sdbht.h:18
ut32 cas
Definition: sdbht.h:17

References sdb_kv::base, sdb_kv::cas, sdb_kv::expire, free(), k, malloc(), memcpy(), nextcas(), NULL, RZ_NEW0, and v.

Referenced by sdb_set_internal(), and sdbkv_new().

◆ sdbkv_value()

◆ sdbkv_value_len()

static ut32 sdbkv_value_len ( const SdbKv kv)
inlinestatic

Definition at line 33 of file sdbht.h.

33  {
34  return kv->base.value_len;
35 }

References sdb_kv::base.

Referenced by sdb_const_get_len(), and sdb_set_internal().