Summary: This is how I applied my clang-tidy check (see https://reviews.llvm.org/D80531) in order to remove `DISALLOW_COPY_AND_ASSIGN` and have deleted copy ctors and deleted assignment operators instead. ``` lang=bash grep DISALLOW_COPY_AND_ASSIGN /opt/notnfs/kkleine/llvm/lldb -r -l | sort | uniq > files for i in $(cat files); do clang-tidy \ --checks="-*,modernize-replace-disallow-copy-and-assign-macro" \ --format-style=LLVM \ --header-filter=.* \ --fix \ -fix-errors \ $i; done ``` Reviewers: espindola, labath, aprantl, teemperor Reviewed By: labath, aprantl, teemperor Subscribers: teemperor, aprantl, labath, emaste, sbc100, aheejin, MaskRay, arphaman, usaxena95, lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D80543
90 lines
2.9 KiB
C++
90 lines
2.9 KiB
C++
//===-- VariableList.h ------------------------------------------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLDB_SYMBOL_VARIABLELIST_H
|
|
#define LLDB_SYMBOL_VARIABLELIST_H
|
|
|
|
#include "lldb/Symbol/SymbolContext.h"
|
|
#include "lldb/Symbol/Variable.h"
|
|
#include "lldb/lldb-private.h"
|
|
|
|
namespace lldb_private {
|
|
|
|
class VariableList {
|
|
typedef std::vector<lldb::VariableSP> collection;
|
|
|
|
public:
|
|
// Constructors and Destructors
|
|
// VariableList(const SymbolContext &symbol_context);
|
|
VariableList();
|
|
virtual ~VariableList();
|
|
|
|
void AddVariable(const lldb::VariableSP &var_sp);
|
|
|
|
bool AddVariableIfUnique(const lldb::VariableSP &var_sp);
|
|
|
|
void AddVariables(VariableList *variable_list);
|
|
|
|
void Clear();
|
|
|
|
void Dump(Stream *s, bool show_context) const;
|
|
|
|
lldb::VariableSP GetVariableAtIndex(size_t idx) const;
|
|
|
|
lldb::VariableSP RemoveVariableAtIndex(size_t idx);
|
|
|
|
lldb::VariableSP FindVariable(ConstString name,
|
|
bool include_static_members = true);
|
|
|
|
lldb::VariableSP FindVariable(ConstString name,
|
|
lldb::ValueType value_type,
|
|
bool include_static_members = true);
|
|
|
|
uint32_t FindVariableIndex(const lldb::VariableSP &var_sp);
|
|
|
|
size_t AppendVariablesIfUnique(VariableList &var_list);
|
|
|
|
// Returns the actual number of unique variables that were added to the list.
|
|
// "total_matches" will get updated with the actually number of matches that
|
|
// were found regardless of whether they were unique or not to allow for
|
|
// error conditions when nothing is found, versus conditions where any
|
|
// variables that match "regex" were already in "var_list".
|
|
size_t AppendVariablesIfUnique(const RegularExpression ®ex,
|
|
VariableList &var_list, size_t &total_matches);
|
|
|
|
size_t AppendVariablesWithScope(lldb::ValueType type, VariableList &var_list,
|
|
bool if_unique = true);
|
|
|
|
uint32_t FindIndexForVariable(Variable *variable);
|
|
|
|
size_t MemorySize() const;
|
|
|
|
size_t GetSize() const;
|
|
bool Empty() const { return m_variables.empty(); }
|
|
|
|
typedef collection::iterator iterator;
|
|
typedef collection::const_iterator const_iterator;
|
|
|
|
iterator begin() { return m_variables.begin(); }
|
|
iterator end() { return m_variables.end(); }
|
|
const_iterator begin() const { return m_variables.begin(); }
|
|
const_iterator end() const { return m_variables.end(); }
|
|
|
|
protected:
|
|
collection m_variables;
|
|
|
|
private:
|
|
// For VariableList only
|
|
VariableList(const VariableList &) = delete;
|
|
const VariableList &operator=(const VariableList &) = delete;
|
|
};
|
|
|
|
} // namespace lldb_private
|
|
|
|
#endif // LLDB_SYMBOL_VARIABLELIST_H
|