From aabf4423482c2b9f7893eea217c0bbba3c845fa7 Mon Sep 17 00:00:00 2001 From: Khairul Azhar Kasmiran Date: Sat, 13 Jan 2024 18:39:13 +0800 Subject: [PATCH] Use `RzPVector` for `rz_bin_object_get_sections`/`segments` (#3281) * Use `RzPVector` for `rz_bin_object_get_sections`/`segments` * Bump rizin submodule to latest --- rizin | 2 +- src/core/Cutter.cpp | 23 +++++++++-------------- 2 files changed, 10 insertions(+), 15 deletions(-) diff --git a/rizin b/rizin index f5ca4b96..ce88bbed 160000 --- a/rizin +++ b/rizin @@ -1 +1 @@ -Subproject commit f5ca4b96310efb7e38100076580d854b5aaf3248 +Subproject commit ce88bbed49d1142fa33a57afee2ccfa62694f23b diff --git a/src/core/Cutter.cpp b/src/core/Cutter.cpp index cab4f2e5..baaa8410 100644 --- a/src/core/Cutter.cpp +++ b/src/core/Cutter.cpp @@ -3422,7 +3422,7 @@ QList CutterCore::getAllSections() return sections; } - RzList *sects = rz_bin_object_get_sections(o); + RzPVector *sects = rz_bin_object_get_sections(o); if (!sects) { return sections; } @@ -3431,9 +3431,7 @@ QList CutterCore::getAllSections() return sections; } rz_list_push(hashnames, rz_str_new("entropy")); - RzListIter *it; - RzBinSection *sect; - CutterRzListForeach (sects, it, RzBinSection, sect) { + for (const auto § : CutterPVector(sects)) { if (RZ_STR_ISEMPTY(sect->name)) continue; @@ -3456,7 +3454,7 @@ QList CutterCore::getAllSections() sections << section; } - rz_list_free(sects); + rz_pvector_free(sects); return sections; } @@ -3470,15 +3468,14 @@ QStringList CutterCore::getSectionList() return ret; } - RzList *sects = rz_bin_object_get_sections(o); + RzPVector *sects = rz_bin_object_get_sections(o); if (!sects) { return ret; } - RzListIter *it; - RzBinSection *sect; - CutterRzListForeach (sects, it, RzBinSection, sect) { + for (const auto § : CutterPVector(sects)) { ret << sect->name; } + rz_pvector_free(sects); return ret; } @@ -3494,15 +3491,13 @@ QList CutterCore::getAllSegments() if (!bf) { return {}; } - RzList *segments = rz_bin_object_get_segments(bf->o); + RzPVector *segments = rz_bin_object_get_segments(bf->o); if (!segments) { return {}; } - RzBinSection *segment; - RzListIter *iter; QList ret; - CutterRzListForeach (segments, iter, RzBinSection, segment) { + for (const auto &segment : CutterPVector(segments)) { SegmentDescription segDesc; segDesc.name = segment->name; segDesc.vaddr = segment->vaddr; @@ -3512,7 +3507,7 @@ QList CutterCore::getAllSegments() segDesc.perm = perms_str(segment->perm); ret << segDesc; } - rz_list_free(segments); + rz_pvector_free(segments); return ret; }