Konrad Kleine eaebcbc679 [lldb] NFC remove DISALLOW_COPY_AND_ASSIGN
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
2020-06-02 13:23:53 -04:00

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 &regex,
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