003 File Manager
Current Path:
/usr/src/contrib/llvm-project/clang/include/clang/Tooling/Refactoring
usr
/
src
/
contrib
/
llvm-project
/
clang
/
include
/
clang
/
Tooling
/
Refactoring
/
📁
..
📄
ASTSelection.h
(5.39 KB)
📄
AtomicChange.h
(7.51 KB)
📁
Extract
📄
RecursiveSymbolVisitor.h
(4.69 KB)
📄
RefactoringAction.h
(2.52 KB)
📄
RefactoringActionRule.h
(2.69 KB)
📄
RefactoringActionRuleRequirements.h
(4.87 KB)
📄
RefactoringActionRules.h
(3.85 KB)
📄
RefactoringActionRulesInternal.h
(5.97 KB)
📄
RefactoringDiagnostic.h
(610 B)
📄
RefactoringOption.h
(2.12 KB)
📄
RefactoringOptionVisitor.h
(1.82 KB)
📄
RefactoringOptions.h
(1.81 KB)
📄
RefactoringResultConsumer.h
(1.82 KB)
📄
RefactoringRuleContext.h
(2.96 KB)
📁
Rename
Editing: RefactoringOption.h
//===--- RefactoringOption.h - Clang refactoring library ------------------===// // // 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 LLVM_CLANG_TOOLING_REFACTOR_REFACTORING_OPTION_H #define LLVM_CLANG_TOOLING_REFACTOR_REFACTORING_OPTION_H #include "clang/Basic/LLVM.h" #include <memory> #include <type_traits> namespace clang { namespace tooling { class RefactoringOptionVisitor; /// A refactoring option is an interface that describes a value that /// has an impact on the outcome of a refactoring. /// /// Refactoring options can be specified using command-line arguments when /// the clang-refactor tool is used. class RefactoringOption { public: virtual ~RefactoringOption() {} /// Returns the name of the refactoring option. /// /// Each refactoring option must have a unique name. virtual StringRef getName() const = 0; virtual StringRef getDescription() const = 0; /// True when this option must be specified before invoking the refactoring /// action. virtual bool isRequired() const = 0; /// Invokes the \c visit method in the option consumer that's appropriate /// for the option's value type. /// /// For example, if the option stores a string value, this method will /// invoke the \c visit method with a reference to an std::string value. virtual void passToVisitor(RefactoringOptionVisitor &Visitor) = 0; }; /// Constructs a refactoring option of the given type. /// /// The ownership of options is shared among requirements that use it because /// one option can be used by multiple rules in a refactoring action. template <typename OptionType> std::shared_ptr<OptionType> createRefactoringOption() { static_assert(std::is_base_of<RefactoringOption, OptionType>::value, "invalid option type"); return std::make_shared<OptionType>(); } } // end namespace tooling } // end namespace clang #endif // LLVM_CLANG_TOOLING_REFACTOR_REFACTORING_OPTION_H
Upload File
Create Folder