Rizin
unix-like reverse engineering framework and cli tools
tags.c File Reference
#include <rz_flag.h>

Go to the source code of this file.

Classes

struct  iter_glob_flag_t
 

Functions

RZ_API void rz_flag_tags_set (RzFlag *f, const char *name, const char *words)
 
RZ_API RZ_OWN RzListrz_flag_tags_list (RzFlag *f)
 
RZ_API void rz_flag_tags_reset (RzFlag *f, const char *name)
 
static bool iter_glob_flag (RzFlagItem *fi, void *user)
 
RZ_API RzListrz_flag_tags_get (RzFlag *f, const char *name)
 

Function Documentation

◆ iter_glob_flag()

static bool iter_glob_flag ( RzFlagItem fi,
void *  user 
)
static

Definition at line 40 of file tags.c.

40  {
41  struct iter_glob_flag_t *u = (struct iter_glob_flag_t *)user;
43  const char *word;
44 
45  rz_list_foreach (u->words, iter, word) {
46  if (rz_str_glob(fi->name, word)) {
47  rz_list_append(u->res, fi);
48  }
49  }
50  return true;
51 }
RZ_API RZ_BORROW RzListIter * rz_list_append(RZ_NONNULL RzList *list, void *data)
Appends at the end of the list a new element.
Definition: list.c:288
RZ_API bool rz_str_glob(const char *str, const char *glob)
Definition: str.c:2368
RzList * res
Definition: tags.c:36
RzList * words
Definition: tags.c:37
char * name
Definition: rz_flag.h:35

References rz_flag_item_t::name, iter_glob_flag_t::res, rz_list_append(), rz_str_glob(), and iter_glob_flag_t::words.

Referenced by rz_flag_tags_get().

◆ rz_flag_tags_get()

RZ_API RzList* rz_flag_tags_get ( RzFlag f,
const char *  name 
)

Definition at line 53 of file tags.c.

53  {
55  const char *k = sdb_fmt("tag.%s", name);
56  RzList *res = rz_list_newf(NULL);
57  char *words = sdb_get(f->tags, k, NULL);
58  if (words) {
59  RzList *list = rz_str_split_list(words, " ", 0);
60  struct iter_glob_flag_t u = { .res = res, .words = list };
63  free(words);
64  }
65  return res;
66 }
#define NULL
Definition: cris-opc.c:27
const char * k
Definition: dsignal.c:11
RZ_API void rz_flag_foreach(RzFlag *f, RzFlagItemCb cb, void *user)
Definition: flag.c:800
RZ_API char * sdb_fmt(const char *fmt,...)
Definition: fmt.c:26
RZ_API void Ht_() free(HtName_(Ht) *ht)
Definition: ht_inc.c:130
static void list(RzEgg *egg)
Definition: rz-gg.c:52
RZ_API RZ_OWN RzList * rz_list_newf(RzListFree f)
Returns a new initialized RzList pointer and sets the free method.
Definition: list.c:248
RZ_API void rz_list_free(RZ_NONNULL RzList *list)
Empties the list and frees the list pointer.
Definition: list.c:137
#define rz_return_val_if_fail(expr, val)
Definition: rz_assert.h:108
RZ_API RzList * rz_str_split_list(char *str, const char *c, int n)
Split the string str according to the substring c and returns a RzList with the result.
Definition: str.c:3429
RZ_API char * sdb_get(Sdb *s, const char *key, ut32 *cas)
Definition: sdb.c:290
#define f(i)
Definition: sha256.c:46
Definition: z80asm.h:102
static bool iter_glob_flag(RzFlagItem *fi, void *user)
Definition: tags.c:40

References f, free(), iter_glob_flag(), k, list(), NULL, iter_glob_flag_t::res, rz_flag_foreach(), rz_list_free(), rz_list_newf(), rz_return_val_if_fail, rz_str_split_list(), sdb_fmt(), sdb_get(), and iter_glob_flag_t::words.

Referenced by flag_tag_print(), and rz_flag_tag_search_handler().

◆ rz_flag_tags_list()

RZ_API RZ_OWN RzList* rz_flag_tags_list ( RzFlag f)

Definition at line 12 of file tags.c.

12  {
14  RzList *res = rz_list_newf(free);
15  SdbList *o = sdb_foreach_list(f->tags, false);
17  SdbKv *kv;
18  ls_foreach (o, iter, kv) {
19  const char *tag = sdbkv_key(kv);
20  if (strlen(tag) < 5) {
21  continue;
22  }
23  rz_list_append(res, (void *)strdup(tag + 4));
24  }
25  ls_free(o);
26  return res;
27 }
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")
RZ_API void ls_free(SdbList *list)
Definition: ls.c:191
#define ls_foreach(list, it, pos)
Definition: ls.h:31
RZ_API SdbList * sdb_foreach_list(Sdb *s, bool sorted)
Definition: sdb.c:630
static char * sdbkv_key(const SdbKv *kv)
Definition: sdbht.h:21
Definition: ls.h:17
Definition: ls.h:22
Definition: sdbht.h:14

References f, free(), ls_foreach, ls_free(), NULL, rz_list_append(), rz_list_newf(), rz_return_val_if_fail, sdb_foreach_list(), sdbkv_key(), strdup(), and test-lz4-versions::tag.

Referenced by rz_flag_tag_list_handler().

◆ rz_flag_tags_reset()

RZ_API void rz_flag_tags_reset ( RzFlag f,
const char *  name 
)

Definition at line 29 of file tags.c.

29  {
30  // TODO: use name
32  sdb_reset(f->tags);
33 }
#define rz_return_if_fail(expr)
Definition: rz_assert.h:100
RZ_API void sdb_reset(Sdb *s)
Definition: sdb.c:433

References f, rz_return_if_fail, and sdb_reset().

◆ rz_flag_tags_set()

RZ_API void rz_flag_tags_set ( RzFlag f,
const char *  name,
const char *  words 
)

Definition at line 6 of file tags.c.

6  {
7  rz_return_if_fail(f && name && words);
8  const char *k = sdb_fmt("tag.%s", name);
9  sdb_set(f->tags, k, words, -1);
10 }
RZ_API int sdb_set(Sdb *s, const char *key, const char *val, ut32 cas)
Definition: sdb.c:611

References f, k, rz_return_if_fail, sdb_fmt(), and sdb_set().

Referenced by rz_flag_tag_add_handler().