From 988b3ead05deadcd18111418a3d4c7307153282c Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Mon, 11 Dec 2023 21:04:33 +0100 Subject: [PATCH] src: avoid shadowed string in fs_permission --- src/permission/fs_permission.h | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/permission/fs_permission.h b/src/permission/fs_permission.h index 1c818567934f7d..642d2dbc6ea502 100644 --- a/src/permission/fs_permission.h +++ b/src/permission/fs_permission.h @@ -32,24 +32,26 @@ class FSPermission final : public PermissionBase { Node() : wildcard_child(nullptr), is_leaf(false) {} - Node* CreateChild(const std::string& prefix) { - if (prefix.empty() && !is_leaf) { + Node* CreateChild(const std::string& path_prefix) { + if (path_prefix.empty() && !is_leaf) { is_leaf = true; return this; } - char label = prefix[0]; + + CHECK(!path_prefix.empty()); + char label = path_prefix[0]; Node* child = children[label]; if (child == nullptr) { - children[label] = new Node(prefix); + children[label] = new Node(path_prefix); return children[label]; } // swap prefix size_t i = 0; - size_t prefix_len = prefix.length(); + size_t prefix_len = path_prefix.length(); for (; i < child->prefix.length(); ++i) { - if (i > prefix_len || prefix[i] != child->prefix[i]) { + if (i > prefix_len || path_prefix[i] != child->prefix[i]) { std::string parent_prefix = child->prefix.substr(0, i); std::string child_prefix = child->prefix.substr(i); @@ -58,11 +60,11 @@ class FSPermission final : public PermissionBase { split_child->children[child_prefix[0]] = child; children[parent_prefix[0]] = split_child; - return split_child->CreateChild(prefix.substr(i)); + return split_child->CreateChild(path_prefix.substr(i)); } } child->is_leaf = true; - return child->CreateChild(prefix.substr(i)); + return child->CreateChild(path_prefix.substr(i)); } Node* CreateWildcardChild() {