Commit c4090b67 authored by Max Kellermann's avatar Max Kellermann

Permission: use std::map instead of GHashTable

parent ddf11237
......@@ -538,7 +538,6 @@ int mpd_main(int argc, char *argv[])
volume_finish();
mapper_finish();
path_global_finish();
finishPermissions();
pc_free(global_player_control);
command_finish();
update_global_finish();
......
......@@ -25,6 +25,9 @@ extern "C" {
#include "conf.h"
}
#include <map>
#include <string>
#include <glib.h>
#include <stdbool.h>
......@@ -38,7 +41,7 @@ extern "C" {
#define PERMISSION_CONTROL_STRING "control"
#define PERMISSION_ADMIN_STRING "admin"
static GHashTable *permission_passwords;
static std::map<std::string, unsigned> permission_passwords;
static unsigned permission_default;
......@@ -78,9 +81,6 @@ void initPermissions(void)
unsigned permission;
const struct config_param *param;
permission_passwords = g_hash_table_new_full(g_str_hash, g_str_equal,
g_free, NULL);
permission_default = PERMISSION_READ | PERMISSION_ADD |
PERMISSION_CONTROL | PERMISSION_ADMIN;
......@@ -104,9 +104,8 @@ void initPermissions(void)
permission = parsePermissions(separator + 1);
g_hash_table_replace(permission_passwords,
password,
GINT_TO_POINTER(permission));
permission_passwords.insert(std::make_pair(password,
permission));
} while ((param = config_get_next_param(CONF_PASSWORD, param)));
}
......@@ -118,23 +117,14 @@ void initPermissions(void)
int getPermissionFromPassword(char const* password, unsigned* permission)
{
bool found;
gpointer key, value;
found = g_hash_table_lookup_extended(permission_passwords,
password, &key, &value);
if (!found)
auto i = permission_passwords.find(password);
if (i == permission_passwords.end())
return -1;
*permission = GPOINTER_TO_INT(value);
*permission = i->second;
return 0;
}
void finishPermissions(void)
{
g_hash_table_destroy(permission_passwords);
}
unsigned getDefaultPermissions(void)
{
return permission_default;
......
......@@ -29,8 +29,6 @@
int getPermissionFromPassword(char const* password, unsigned* permission);
void finishPermissions(void);
unsigned getDefaultPermissions(void);
void initPermissions(void);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment