Skip to content

Commit

Permalink
Use unordered_dense hash map
Browse files Browse the repository at this point in the history
  • Loading branch information
imwints committed Nov 29, 2023
1 parent ebc46ca commit 2fb70c8
Show file tree
Hide file tree
Showing 19 changed files with 2,062 additions and 2,655 deletions.
1,936 changes: 1,936 additions & 0 deletions include/ankerl/unordered_dense.h

Large diffs are not rendered by default.

2,544 changes: 0 additions & 2,544 deletions include/robin_hood.h

This file was deleted.

3 changes: 2 additions & 1 deletion src/btop.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ tab-size = 4
#include <semaphore>
#endif

#include "ankerl/unordered_dense.h"
#include "btop_shared.hpp"
#include "btop_tools.hpp"
#include "btop_config.hpp"
Expand Down Expand Up @@ -416,7 +417,7 @@ namespace Runner {
};

string debug_bg;
unordered_flat_map<string, array<uint64_t, 2>> debug_times;
ankerl::unordered_dense::map<string, array<uint64_t, 2>> debug_times;

class MyNumPunct : public std::numpunct<char>
{
Expand Down
13 changes: 7 additions & 6 deletions src/btop_config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ tab-size = 4

#include <fmt/core.h>

#include "ankerl/unordered_dense.h"
#include "btop_config.hpp"
#include "btop_shared.hpp"
#include "btop_tools.hpp"
Expand Down Expand Up @@ -215,7 +216,7 @@ namespace Config {
#endif
};

unordered_flat_map<std::string_view, string> strings = {
ankerl::unordered_dense::map<std::string_view, string> strings = {
{"color_theme", "Default"},
{"shown_boxes", "cpu mem net proc"},
{"graph_symbol", "braille"},
Expand Down Expand Up @@ -251,9 +252,9 @@ namespace Config {
{"show_gpu_info", "Auto"}
#endif
};
unordered_flat_map<std::string_view, string> stringsTmp;
ankerl::unordered_dense::map<std::string_view, string> stringsTmp;

unordered_flat_map<std::string_view, bool> bools = {
ankerl::unordered_dense::map<std::string_view, bool> bools = {
{"theme_background", true},
{"truecolor", true},
{"rounded_corners", true},
Expand Down Expand Up @@ -304,9 +305,9 @@ namespace Config {
{"gpu_mirror_graph", true},
#endif
};
unordered_flat_map<std::string_view, bool> boolsTmp;
ankerl::unordered_dense::map<std::string_view, bool> boolsTmp;

unordered_flat_map<std::string_view, int> ints = {
ankerl::unordered_dense::map<std::string_view, int> ints = {
{"update_ms", 2000},
{"net_download", 100},
{"net_upload", 100},
Expand All @@ -317,7 +318,7 @@ namespace Config {
{"proc_selected", 0},
{"proc_last_selected", 0},
};
unordered_flat_map<std::string_view, int> intsTmp;
ankerl::unordered_dense::map<std::string_view, int> intsTmp;

bool _locked(const std::string_view name) {
atomic_wait(writelock, true);
Expand Down
15 changes: 7 additions & 8 deletions src/btop_config.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,24 +22,23 @@ tab-size = 4
#include <vector>
#include <filesystem>

#include <robin_hood.h>
#include "ankerl/unordered_dense.h"

using std::string;
using std::vector;
using robin_hood::unordered_flat_map;

//* Functions and variables for reading and writing the btop config file
namespace Config {

extern std::filesystem::path conf_dir;
extern std::filesystem::path conf_file;

extern unordered_flat_map<std::string_view, string> strings;
extern unordered_flat_map<std::string_view, string> stringsTmp;
extern unordered_flat_map<std::string_view, bool> bools;
extern unordered_flat_map<std::string_view, bool> boolsTmp;
extern unordered_flat_map<std::string_view, int> ints;
extern unordered_flat_map<std::string_view, int> intsTmp;
extern ankerl::unordered_dense::map<std::string_view, string> strings;
extern ankerl::unordered_dense::map<std::string_view, string> stringsTmp;
extern ankerl::unordered_dense::map<std::string_view, bool> bools;
extern ankerl::unordered_dense::map<std::string_view, bool> boolsTmp;
extern ankerl::unordered_dense::map<std::string_view, int> ints;
extern ankerl::unordered_dense::map<std::string_view, int> intsTmp;

const vector<string> valid_graph_symbols = { "braille", "block", "tty" };
const vector<string> valid_graph_symbols_def = { "default", "braille", "block", "tty" };
Expand Down
34 changes: 18 additions & 16 deletions src/btop_draw.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,9 @@ tab-size = 4
#include <ranges>
#include <stdexcept>
#include <string>
#include <utility>

#include "ankerl/unordered_dense.h"
#include "btop_draw.hpp"
#include "btop_config.hpp"
#include "btop_theme.hpp"
Expand Down Expand Up @@ -54,7 +56,7 @@ namespace Symbols {

const array<string, 10> superscript = { "", "¹", "²", "³", "", "", "", "", "", "" };

const unordered_flat_map<string, vector<string>> graph_symbols = {
const ankerl::unordered_dense::map<string, vector<string>> graph_symbols = {
{ "braille_up", {
" ", "", "", "", "",
"", "", "", "", "",
Expand Down Expand Up @@ -300,7 +302,7 @@ namespace Draw {
return false;
}

static const unordered_flat_map<string, string> clock_custom_format = {
static const ankerl::unordered_dense::map<string, string> clock_custom_format = {
{"/user", Tools::username()},
{"/host", Tools::hostname()},
{"/uptime", ""}
Expand Down Expand Up @@ -707,7 +709,7 @@ namespace Cpu {
static long old_seconds{}; // defaults to = 0
static string old_status;
static Draw::Meter bat_meter {10, "cpu", true};
static const unordered_flat_map<string, string> bat_symbols = {
static const ankerl::unordered_dense::map<string, string> bat_symbols = {
{"charging", ""},
{"discharging", ""},
{"full", ""},
Expand Down Expand Up @@ -1096,11 +1098,11 @@ namespace Mem {
int disks_io_half = 0;
bool shown = true, redraw = true;
string box;
unordered_flat_map<string, Draw::Meter> mem_meters;
unordered_flat_map<string, Draw::Graph> mem_graphs;
unordered_flat_map<string, Draw::Meter> disk_meters_used;
unordered_flat_map<string, Draw::Meter> disk_meters_free;
unordered_flat_map<string, Draw::Graph> io_graphs;
ankerl::unordered_dense::map<string, Draw::Meter> mem_meters;
ankerl::unordered_dense::map<string, Draw::Graph> mem_graphs;
ankerl::unordered_dense::map<string, Draw::Meter> disk_meters_used;
ankerl::unordered_dense::map<string, Draw::Meter> disk_meters_free;
ankerl::unordered_dense::map<string, Draw::Graph> io_graphs;

string draw(const mem_info& mem, bool force_redraw, bool data_same) {
if (Runner::stopping) return "";
Expand Down Expand Up @@ -1148,7 +1150,7 @@ namespace Mem {
//? Disk meters and io graphs
if (show_disks) {
if (show_io_stat or io_mode) {
unordered_flat_map<string, int> custom_speeds;
ankerl::unordered_dense::map<string, int> custom_speeds;
int half_height = 0;
if (io_mode) {
disks_io_h = max((int)floor((double)(height - 2 - (disk_ios * 2)) / max(1, disk_ios)), (io_graph_combined ? 1 : 2));
Expand Down Expand Up @@ -1353,7 +1355,7 @@ namespace Net {
int b_x, b_y, b_width, b_height, d_graph_height, u_graph_height;
bool shown = true, redraw = true;
string old_ip;
unordered_flat_map<string, Draw::Graph> graphs;
ankerl::unordered_dense::map<string, Draw::Graph> graphs;
string box;

string draw(const net_info& net, bool force_redraw, bool data_same) {
Expand Down Expand Up @@ -1453,9 +1455,9 @@ namespace Proc {
bool shown = true, redraw = true;
int selected_pid = 0, selected_depth = 0;
string selected_name;
unordered_flat_map<size_t, Draw::Graph> p_graphs;
unordered_flat_map<size_t, bool> p_wide_cmd;
unordered_flat_map<size_t, int> p_counters;
ankerl::unordered_dense::map<size_t, Draw::Graph> p_graphs;
ankerl::unordered_dense::map<size_t, bool> p_wide_cmd;
ankerl::unordered_dense::map<size_t, int> p_counters;
int counter = 0;
Draw::TextEdit filter;
Draw::Graph detailed_cpu_graph;
Expand Down Expand Up @@ -1926,8 +1928,8 @@ namespace Proc {
else
++element;
}
p_graphs.compact();
p_counters.compact();
p_graphs.rehash(0);
p_counters.rehash(0);

for (auto element = p_wide_cmd.begin(); element != p_wide_cmd.end();) {
if (rng::find(plist, element->first, &proc_info::pid) == plist.end()) {
Expand All @@ -1936,7 +1938,7 @@ namespace Proc {
else
++element;
}
p_wide_cmd.compact();
p_wide_cmd.rehash(0);
}

if (selected == 0 and selected_pid != 0) {
Expand Down
10 changes: 5 additions & 5 deletions src/btop_draw.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,10 @@ tab-size = 4
#include <string>
#include <vector>
#include <array>
#include <robin_hood.h>
#include <deque>

using robin_hood::unordered_flat_map;
#include "ankerl/unordered_dense.h"

using std::array;
using std::deque;
using std::string;
Expand Down Expand Up @@ -108,7 +108,7 @@ namespace Draw {
long long offset;
long long last = 0, max_value = 0;
bool current = true, tty_mode = false;
unordered_flat_map<bool, vector<string>> graphs = { {true, {}}, {false, {}}};
ankerl::unordered_dense::map<bool, vector<string>> graphs = { {true, {}}, {false, {}}};

//* Create two representations of the graph to switch between to represent two values for each braille character
void _create(const deque<long long>& data, int data_offset);
Expand All @@ -135,6 +135,6 @@ namespace Draw {

namespace Proc {
extern Draw::TextEdit filter;
extern unordered_flat_map<size_t, Draw::Graph> p_graphs;
extern unordered_flat_map<size_t, int> p_counters;
extern ankerl::unordered_dense::map<size_t, Draw::Graph> p_graphs;
extern ankerl::unordered_dense::map<size_t, int> p_counters;
}
6 changes: 4 additions & 2 deletions src/btop_input.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ tab-size = 4
#include <vector>
#include <thread>
#include <mutex>
#include <utility>
#include <signal.h>
#include <utility>

Expand All @@ -32,6 +33,7 @@ tab-size = 4
#include "btop_draw.hpp"


#include "ankerl/unordered_dense.h"
#include "btop_input.hpp"
#include "btop_tools.hpp"
#include "btop_config.hpp"
Expand All @@ -49,7 +51,7 @@ namespace rng = std::ranges;
namespace Input {

//* Map for translating key codes to readable values
const unordered_flat_map<string, string> Key_escapes = {
const ankerl::unordered_dense::map<string, string> Key_escapes = {
{"\033", "escape"},
{"\n", "enter"},
{" ", "space"},
Expand Down Expand Up @@ -92,7 +94,7 @@ namespace Input {
std::atomic<bool> interrupt (false);
std::atomic<bool> polling (false);
array<int, 2> mouse_pos;
unordered_flat_map<string, Mouse_loc> mouse_mappings;
ankerl::unordered_dense::map<string, Mouse_loc> mouse_mappings;

deque<string> history(50, "");
string old_filter;
Expand Down
6 changes: 3 additions & 3 deletions src/btop_input.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,10 @@ tab-size = 4
#include <string>
#include <atomic>
#include <array>
#include <robin_hood.h>
#include <deque>

using robin_hood::unordered_flat_map;
#include "ankerl/unordered_dense.h"

using std::array;
using std::atomic;
using std::deque;
Expand All @@ -44,7 +44,7 @@ namespace Input {
};

//? line, col, height, width
extern unordered_flat_map<string, Mouse_loc> mouse_mappings;
extern ankerl::unordered_dense::map<string, Mouse_loc> mouse_mappings;

extern atomic<bool> interrupt;
extern atomic<bool> polling;
Expand Down
7 changes: 3 additions & 4 deletions src/btop_menu.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,21 +17,20 @@ tab-size = 4
*/

#include <deque>
#include <robin_hood.h>
#include <array>
#include <signal.h>
#include <errno.h>
#include <cmath>
#include <filesystem>

#include "ankerl/unordered_dense.h"
#include "btop_menu.hpp"
#include "btop_tools.hpp"
#include "btop_config.hpp"
#include "btop_theme.hpp"
#include "btop_draw.hpp"
#include "btop_shared.hpp"

using robin_hood::unordered_flat_map;
using std::array;
using std::ceil;
using std::max;
Expand Down Expand Up @@ -123,7 +122,7 @@ namespace Menu {
#endif
};

unordered_flat_map<string, Input::Mouse_loc> mouse_mappings;
ankerl::unordered_dense::map<string, Input::Mouse_loc> mouse_mappings;

const array<array<string, 3>, 3> menu_normal = {
array<string, 3>{
Expand Down Expand Up @@ -1165,7 +1164,7 @@ namespace Menu {
static Draw::TextEdit editor;
static string warnings;
static bitset<8> selPred;
static const unordered_flat_map<string, std::reference_wrapper<const vector<string>>> optionsList = {
static const ankerl::unordered_dense::map<string, std::reference_wrapper<const vector<string>>> optionsList = {
{"color_theme", std::cref(Theme::themes)},
{"log_level", std::cref(Logger::log_levels)},
{"temp_scale", std::cref(Config::temp_scales)},
Expand Down
3 changes: 2 additions & 1 deletion src/btop_menu.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ tab-size = 4
#include <vector>
#include <bitset>

#include "ankerl/unordered_dense.h"
#include "btop_input.hpp"

using std::atomic;
Expand All @@ -38,7 +39,7 @@ namespace Menu {
extern bool redraw;

//? line, col, height, width
extern unordered_flat_map<string, Input::Mouse_loc> mouse_mappings;
extern ankerl::unordered_dense::map<string, Input::Mouse_loc> mouse_mappings;

//* Creates a message box centered on screen
//? Height of box is determined by size of content vector
Expand Down
Loading

0 comments on commit 2fb70c8

Please sign in to comment.