From: Kazu Hirata Date: Mon, 25 Jul 2022 05:28:11 +0000 (-0700) Subject: Remove redundaunt override specifiers (NFC) X-Git-Tag: upstream/15.0.7~618 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=95a932fb15960e66fdc43dc9821685addd5ee44d;p=platform%2Fupstream%2Fllvm.git Remove redundaunt override specifiers (NFC) Identified with modernize-use-override. --- diff --git a/clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.h b/clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.h index def04c9..d00afec 100644 --- a/clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.h +++ b/clang-tools-extra/clang-tidy/utils/RenamerClangTidyCheck.h @@ -34,12 +34,11 @@ public: /// class will do the matching and call the derived class' /// getDeclFailureInfo() and getMacroFailureInfo() for determining whether a /// given identifier passes or fails the check. - void registerMatchers(ast_matchers::MatchFinder *Finder) override final; - void - check(const ast_matchers::MatchFinder::MatchResult &Result) override final; + void registerMatchers(ast_matchers::MatchFinder *Finder) final; + void check(const ast_matchers::MatchFinder::MatchResult &Result) final; void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP, - Preprocessor *ModuleExpanderPP) override final; - void onEndOfTranslationUnit() override final; + Preprocessor *ModuleExpanderPP) final; + void onEndOfTranslationUnit() final; /// Derived classes that override this function should call this method from /// the overridden method. diff --git a/clang-tools-extra/clangd/CodeComplete.cpp b/clang-tools-extra/clangd/CodeComplete.cpp index b999871..edbb172 100644 --- a/clang-tools-extra/clangd/CodeComplete.cpp +++ b/clang-tools-extra/clangd/CodeComplete.cpp @@ -788,7 +788,7 @@ struct CompletionRecorder : public CodeCompleteConsumer { void ProcessCodeCompleteResults(class Sema &S, CodeCompletionContext Context, CodeCompletionResult *InResults, - unsigned NumResults) override final { + unsigned NumResults) final { // Results from recovery mode are generally useless, and the callback after // recovery (if any) is usually more interesting. To make sure we handle the // future callback from sema, we just ignore all callbacks in recovery mode, diff --git a/clang-tools-extra/clangd/refactor/tweaks/AnnotateHighlightings.cpp b/clang-tools-extra/clangd/refactor/tweaks/AnnotateHighlightings.cpp index 1383560..2a34e43 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/AnnotateHighlightings.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/AnnotateHighlightings.cpp @@ -23,7 +23,7 @@ namespace { /// void /* entity.name.function.cpp */ f() { int /* variable.cpp */ abc; } class AnnotateHighlightings : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override { return true; } Expected apply(const Selection &Inputs) override; diff --git a/clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp b/clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp index 9812cfc..96d0a19 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/DefineInline.cpp @@ -385,7 +385,7 @@ addInlineIfInHeader(const FunctionDecl *FD) { /// class DefineInline : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; diff --git a/clang-tools-extra/clangd/refactor/tweaks/DumpAST.cpp b/clang-tools-extra/clangd/refactor/tweaks/DumpAST.cpp index d0c06f8..f2ae97c 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/DumpAST.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/DumpAST.cpp @@ -31,7 +31,7 @@ namespace { /// `-StringLiteral "foo" class DumpAST : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override { for (auto *N = Inputs.ASTSelection.commonAncestor(); N && !Node; @@ -84,7 +84,7 @@ llvm::Expected DumpAST::apply(const Selection &Inputs) { /// *IntegerLiteral 2 class ShowSelectionTree : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override { return true; } Expected apply(const Selection &Inputs) override { @@ -104,7 +104,7 @@ REGISTER_TWEAK(ShowSelectionTree) /// foo - /// {"containerName":null,"id":"CA2EBE44A1D76D2A","name":"foo","usr":"c:@F@foo#"} class DumpSymbol : public Tweak { - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override { return true; } Expected apply(const Selection &Inputs) override { std::string Storage; @@ -133,7 +133,7 @@ REGISTER_TWEAK(DumpSymbol) /// | nvsize=4, nvalign=4] class DumpRecordLayout : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override { if (auto *Node = Inputs.ASTSelection.commonAncestor()) diff --git a/clang-tools-extra/clangd/refactor/tweaks/ExpandMacro.cpp b/clang-tools-extra/clangd/refactor/tweaks/ExpandMacro.cpp index fad3a3c..29e681c 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/ExpandMacro.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/ExpandMacro.cpp @@ -30,7 +30,7 @@ namespace { /// 10*a+10*a class ExpandMacro : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp b/clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp index adfc42a..66fe4fd 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/ExtractFunction.cpp @@ -796,7 +796,7 @@ llvm::Expected getExtractedFunction(ExtractionZone &ExtZone, class ExtractFunction : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override; Expected apply(const Selection &Inputs) override; std::string title() const override { return "Extract to function"; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/ExtractVariable.cpp b/clang-tools-extra/clangd/refactor/tweaks/ExtractVariable.cpp index 5efe09f..aac017c 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/ExtractVariable.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/ExtractVariable.cpp @@ -485,7 +485,7 @@ const SelectionTree::Node *computeExtractedExpr(const SelectionTree::Node *N) { /// int x = placeholder * 3; class ExtractVariable : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override; Expected apply(const Selection &Inputs) override; std::string title() const override { diff --git a/clang-tools-extra/clangd/refactor/tweaks/MemberwiseConstructor.cpp b/clang-tools-extra/clangd/refactor/tweaks/MemberwiseConstructor.cpp index bc0f4e1..9bb8ca9 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/MemberwiseConstructor.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/MemberwiseConstructor.cpp @@ -32,7 +32,7 @@ namespace { // We place the constructor inline, other tweaks are available to outline it. class MemberwiseConstructor : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/ObjCLocalizeStringLiteral.cpp b/clang-tools-extra/clangd/refactor/tweaks/ObjCLocalizeStringLiteral.cpp index 1e2d6c3..6299584 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/ObjCLocalizeStringLiteral.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/ObjCLocalizeStringLiteral.cpp @@ -30,7 +30,7 @@ namespace { /// NSLocalizedString(@"description", @"") class ObjCLocalizeStringLiteral : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp b/clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp index 30ff058..c129428 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/ObjCMemberwiseInitializer.cpp @@ -172,7 +172,7 @@ initializerForParams(const SmallVector &Params, /// properties and instance variables. class ObjCMemberwiseInitializer : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/RawStringLiteral.cpp b/clang-tools-extra/clangd/refactor/tweaks/RawStringLiteral.cpp index 4185127..f5021b8 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/RawStringLiteral.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/RawStringLiteral.cpp @@ -28,7 +28,7 @@ namespace { /// b)"); class RawStringLiteral : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override; Expected apply(const Selection &Inputs) override; diff --git a/clang-tools-extra/clangd/refactor/tweaks/SpecialMembers.cpp b/clang-tools-extra/clangd/refactor/tweaks/SpecialMembers.cpp index 7d5b41a..e156051 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/SpecialMembers.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/SpecialMembers.cpp @@ -86,7 +86,7 @@ std::string buildSpecialMemberDeclarations(const CXXRecordDecl &Class) { // - as a baseline for explicit modification class DeclareCopyMove : public Tweak { public: - const char *id() const override final; + const char *id() const final; llvm::StringLiteral kind() const override { return CodeAction::REFACTOR_KIND; } diff --git a/clang-tools-extra/clangd/refactor/tweaks/SwapIfBranches.cpp b/clang-tools-extra/clangd/refactor/tweaks/SwapIfBranches.cpp index 5c829cb..b59f1d6 100644 --- a/clang-tools-extra/clangd/refactor/tweaks/SwapIfBranches.cpp +++ b/clang-tools-extra/clangd/refactor/tweaks/SwapIfBranches.cpp @@ -31,7 +31,7 @@ namespace { /// if (foo) { continue; } else { return 10; } class SwapIfBranches : public Tweak { public: - const char *id() const override final; + const char *id() const final; bool prepare(const Selection &Inputs) override; Expected apply(const Selection &Inputs) override; diff --git a/clang/include/clang/Frontend/Utils.h b/clang/include/clang/Frontend/Utils.h index 240624d..143cf43 100644 --- a/clang/include/clang/Frontend/Utils.h +++ b/clang/include/clang/Frontend/Utils.h @@ -107,10 +107,10 @@ public: void finishedMainFile(DiagnosticsEngine &Diags) override; - bool needSystemDependencies() final override { return IncludeSystemHeaders; } + bool needSystemDependencies() final { return IncludeSystemHeaders; } bool sawDependency(StringRef Filename, bool FromModule, bool IsSystem, - bool IsModuleFile, bool IsMissing) final override; + bool IsModuleFile, bool IsMissing) final; protected: void outputDependencyFile(llvm::raw_ostream &OS); diff --git a/clang/include/clang/StaticAnalyzer/Core/BugReporter/BugReporterVisitors.h b/clang/include/clang/StaticAnalyzer/Core/BugReporter/BugReporterVisitors.h index 685dc66..48da56c 100644 --- a/clang/include/clang/StaticAnalyzer/Core/BugReporter/BugReporterVisitors.h +++ b/clang/include/clang/StaticAnalyzer/Core/BugReporter/BugReporterVisitors.h @@ -731,7 +731,7 @@ public: PathDiagnosticPieceRef VisitNode(const ExplodedNode *N, BugReporterContext &BR, - PathSensitiveBugReport &R) override final; + PathSensitiveBugReport &R) final; }; } // namespace ento diff --git a/clang/include/clang/Tooling/Refactoring/RefactoringActionRuleRequirements.h b/clang/include/clang/Tooling/Refactoring/RefactoringActionRuleRequirements.h index 49e4a0c..1a318da 100644 --- a/clang/include/clang/Tooling/Refactoring/RefactoringActionRuleRequirements.h +++ b/clang/include/clang/Tooling/Refactoring/RefactoringActionRuleRequirements.h @@ -98,7 +98,7 @@ public: OptionRequirement() : Opt(createRefactoringOption()) {} ArrayRef> - getRefactoringOptions() const final override { + getRefactoringOptions() const final { return Opt; } diff --git a/clang/include/clang/Tooling/Refactoring/RefactoringActionRules.h b/clang/include/clang/Tooling/Refactoring/RefactoringActionRules.h index 86fcc6a..5cb051d 100644 --- a/clang/include/clang/Tooling/Refactoring/RefactoringActionRules.h +++ b/clang/include/clang/Tooling/Refactoring/RefactoringActionRules.h @@ -52,7 +52,7 @@ using RefactoringActionRules = class SourceChangeRefactoringRule : public RefactoringActionRuleBase { public: void invoke(RefactoringResultConsumer &Consumer, - RefactoringRuleContext &Context) final override { + RefactoringRuleContext &Context) final { Expected Changes = createSourceReplacements(Context); if (!Changes) Consumer.handleError(Changes.takeError()); @@ -74,7 +74,7 @@ private: class FindSymbolOccurrencesRefactoringRule : public RefactoringActionRuleBase { public: void invoke(RefactoringResultConsumer &Consumer, - RefactoringRuleContext &Context) final override { + RefactoringRuleContext &Context) final { Expected Occurrences = findSymbolOccurrences(Context); if (!Occurrences) Consumer.handleError(Occurrences.takeError()); diff --git a/clang/include/clang/Tooling/Refactoring/RefactoringOptions.h b/clang/include/clang/Tooling/Refactoring/RefactoringOptions.h index 1575a13..75bd91d 100644 --- a/clang/include/clang/Tooling/Refactoring/RefactoringOptions.h +++ b/clang/include/clang/Tooling/Refactoring/RefactoringOptions.h @@ -24,7 +24,7 @@ template ::value>> class OptionalRefactoringOption : public RefactoringOption { public: - void passToVisitor(RefactoringOptionVisitor &Visitor) final override { + void passToVisitor(RefactoringOptionVisitor &Visitor) final { Visitor.visit(*this, Value); } @@ -48,7 +48,7 @@ public: const ValueType &getValue() const { return *OptionalRefactoringOption::Value; } - bool isRequired() const final override { return true; } + bool isRequired() const final { return true; } }; } // end namespace tooling diff --git a/clang/lib/CodeGen/ABIInfo.h b/clang/lib/CodeGen/ABIInfo.h index fe6cc7a..c1eb8a9 100644 --- a/clang/lib/CodeGen/ABIInfo.h +++ b/clang/lib/CodeGen/ABIInfo.h @@ -127,7 +127,7 @@ namespace CodeGen { public: SwiftABIInfo(CodeGen::CodeGenTypes &cgt) : ABIInfo(cgt) {} - bool supportsSwift() const final override { return true; } + bool supportsSwift() const final { return true; } virtual bool shouldPassIndirectlyForSwift(ArrayRef types, bool asReturnValue) const = 0; diff --git a/clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp b/clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp index 2caa5bbc..b99c219 100644 --- a/clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp +++ b/clang/lib/StaticAnalyzer/Core/BugReporterVisitors.cpp @@ -547,19 +547,17 @@ private: // Region of interest corresponds to an IVar, exiting a method // which could have written into that IVar, but did not. - virtual PathDiagnosticPieceRef - maybeEmitNoteForObjCSelf(PathSensitiveBugReport &R, - const ObjCMethodCall &Call, - const ExplodedNode *N) override final; + PathDiagnosticPieceRef maybeEmitNoteForObjCSelf(PathSensitiveBugReport &R, + const ObjCMethodCall &Call, + const ExplodedNode *N) final; - virtual PathDiagnosticPieceRef - maybeEmitNoteForCXXThis(PathSensitiveBugReport &R, - const CXXConstructorCall &Call, - const ExplodedNode *N) override final; + PathDiagnosticPieceRef maybeEmitNoteForCXXThis(PathSensitiveBugReport &R, + const CXXConstructorCall &Call, + const ExplodedNode *N) final; - virtual PathDiagnosticPieceRef + PathDiagnosticPieceRef maybeEmitNoteForParameters(PathSensitiveBugReport &R, const CallEvent &Call, - const ExplodedNode *N) override final; + const ExplodedNode *N) final; /// Consume the information on the no-store stack frame in order to /// either emit a note or suppress the report enirely. diff --git a/lld/MachO/SyntheticSections.h b/lld/MachO/SyntheticSections.h index afdd46d..29c2d98 100644 --- a/lld/MachO/SyntheticSections.h +++ b/lld/MachO/SyntheticSections.h @@ -70,7 +70,7 @@ public: // Sections in __LINKEDIT are special: their offsets are recorded in the // load commands like LC_DYLD_INFO_ONLY and LC_SYMTAB, instead of in section // headers. - bool isHidden() const override final { return true; } + bool isHidden() const final { return true; } virtual uint64_t getRawSize() const = 0; @@ -80,9 +80,7 @@ public: // // NOTE: This assumes that the extra bytes required for alignment can be // zero-valued bytes. - uint64_t getSize() const override final { - return llvm::alignTo(getRawSize(), align); - } + uint64_t getSize() const final { return llvm::alignTo(getRawSize(), align); } }; // The header of the Mach-O file, which must have a file offset of zero. diff --git a/llvm/include/llvm/Analysis/DDG.h b/llvm/include/llvm/Analysis/DDG.h index 7649e63..bc599cb 100644 --- a/llvm/include/llvm/Analysis/DDG.h +++ b/llvm/include/llvm/Analysis/DDG.h @@ -348,37 +348,37 @@ public: DDGBuilder(DataDependenceGraph &G, DependenceInfo &D, const BasicBlockListType &BBs) : AbstractDependenceGraphBuilder(G, D, BBs) {} - DDGNode &createRootNode() final override { + DDGNode &createRootNode() final { auto *RN = new RootDDGNode(); assert(RN && "Failed to allocate memory for DDG root node."); Graph.addNode(*RN); return *RN; } - DDGNode &createFineGrainedNode(Instruction &I) final override { + DDGNode &createFineGrainedNode(Instruction &I) final { auto *SN = new SimpleDDGNode(I); assert(SN && "Failed to allocate memory for simple DDG node."); Graph.addNode(*SN); return *SN; } - DDGNode &createPiBlock(const NodeListType &L) final override { + DDGNode &createPiBlock(const NodeListType &L) final { auto *Pi = new PiBlockDDGNode(L); assert(Pi && "Failed to allocate memory for pi-block node."); Graph.addNode(*Pi); return *Pi; } - DDGEdge &createDefUseEdge(DDGNode &Src, DDGNode &Tgt) final override { + DDGEdge &createDefUseEdge(DDGNode &Src, DDGNode &Tgt) final { auto *E = new DDGEdge(Tgt, DDGEdge::EdgeKind::RegisterDefUse); assert(E && "Failed to allocate memory for edge"); Graph.connect(Src, Tgt, *E); return *E; } - DDGEdge &createMemoryEdge(DDGNode &Src, DDGNode &Tgt) final override { + DDGEdge &createMemoryEdge(DDGNode &Src, DDGNode &Tgt) final { auto *E = new DDGEdge(Tgt, DDGEdge::EdgeKind::MemoryDependence); assert(E && "Failed to allocate memory for edge"); Graph.connect(Src, Tgt, *E); return *E; } - DDGEdge &createRootedEdge(DDGNode &Src, DDGNode &Tgt) final override { + DDGEdge &createRootedEdge(DDGNode &Src, DDGNode &Tgt) final { auto *E = new DDGEdge(Tgt, DDGEdge::EdgeKind::Rooted); assert(E && "Failed to allocate memory for edge"); assert(isa(Src) && "Expected root node"); @@ -386,7 +386,7 @@ public: return *E; } - const NodeListType &getNodesInPiBlock(const DDGNode &N) final override { + const NodeListType &getNodesInPiBlock(const DDGNode &N) final { auto *PiNode = dyn_cast(&N); assert(PiNode && "Expected a pi-block node."); return PiNode->getNodes(); @@ -394,11 +394,10 @@ public: /// Return true if the two nodes \pSrc and \pTgt are both simple nodes and /// the consecutive instructions after merging belong to the same basic block. - bool areNodesMergeable(const DDGNode &Src, - const DDGNode &Tgt) const final override; - void mergeNodes(DDGNode &Src, DDGNode &Tgt) final override; - bool shouldSimplify() const final override; - bool shouldCreatePiBlocks() const final override; + bool areNodesMergeable(const DDGNode &Src, const DDGNode &Tgt) const final; + void mergeNodes(DDGNode &Src, DDGNode &Tgt) final; + bool shouldSimplify() const final; + bool shouldCreatePiBlocks() const final; }; raw_ostream &operator<<(raw_ostream &OS, const DDGNode &N); diff --git a/llvm/lib/Target/SystemZ/SystemZRegisterInfo.h b/llvm/lib/Target/SystemZ/SystemZRegisterInfo.h index 93ffa98..db0936f 100644 --- a/llvm/lib/Target/SystemZ/SystemZRegisterInfo.h +++ b/llvm/lib/Target/SystemZ/SystemZRegisterInfo.h @@ -81,25 +81,22 @@ public: /// Particular to z/OS when in 64 bit mode class SystemZXPLINK64Registers : public SystemZCallingConventionRegisters { public: - int getReturnFunctionAddressRegister() override final { - return SystemZ::R7D; - }; + int getReturnFunctionAddressRegister() final { return SystemZ::R7D; }; - int getStackPointerRegister() override final { return SystemZ::R4D; }; + int getStackPointerRegister() final { return SystemZ::R4D; }; - int getFramePointerRegister() override final { return SystemZ::R8D; }; + int getFramePointerRegister() final { return SystemZ::R8D; }; int getAddressOfCalleeRegister() { return SystemZ::R6D; }; - const MCPhysReg * - getCalleeSavedRegs(const MachineFunction *MF) const override final; + const MCPhysReg *getCalleeSavedRegs(const MachineFunction *MF) const final; const uint32_t *getCallPreservedMask(const MachineFunction &MF, - CallingConv::ID CC) const override final; + CallingConv::ID CC) const final; - int getCallFrameSize() override final { return 128; } + int getCallFrameSize() final { return 128; } - int getStackPointerBias() override final { return 2048; } + int getStackPointerBias() final { return 2048; } /// Destroys the object. Bogus destructor overriding base class destructor ~SystemZXPLINK64Registers() = default; @@ -109,23 +106,20 @@ public: /// Particular when on zLinux in 64 bit mode class SystemZELFRegisters : public SystemZCallingConventionRegisters { public: - int getReturnFunctionAddressRegister() override final { - return SystemZ::R14D; - }; + int getReturnFunctionAddressRegister() final { return SystemZ::R14D; }; - int getStackPointerRegister() override final { return SystemZ::R15D; }; + int getStackPointerRegister() final { return SystemZ::R15D; }; - int getFramePointerRegister() override final { return SystemZ::R11D; }; + int getFramePointerRegister() final { return SystemZ::R11D; }; - const MCPhysReg * - getCalleeSavedRegs(const MachineFunction *MF) const override final; + const MCPhysReg *getCalleeSavedRegs(const MachineFunction *MF) const final; const uint32_t *getCallPreservedMask(const MachineFunction &MF, - CallingConv::ID CC) const override final; + CallingConv::ID CC) const final; - int getCallFrameSize() override final { return SystemZMC::ELFCallFrameSize; } + int getCallFrameSize() final { return SystemZMC::ELFCallFrameSize; } - int getStackPointerBias() override final { return 0; } + int getStackPointerBias() final { return 0; } /// Destroys the object. Bogus destructor overriding base class destructor ~SystemZELFRegisters() = default; diff --git a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp index b887ea4..238b074 100644 --- a/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp +++ b/llvm/lib/Transforms/Vectorize/LoopVectorize.cpp @@ -798,8 +798,7 @@ public: // Override this function to handle the more complex control flow around the // three loops. - std::pair - createVectorizedLoopSkeleton() final override { + std::pair createVectorizedLoopSkeleton() final { return createEpilogueVectorizedLoopSkeleton(); } @@ -835,8 +834,7 @@ public: EPI, LVL, CM, BFI, PSI, Check) {} /// Implements the interface for creating a vectorized skeleton using the /// *main loop* strategy (ie the first pass of vplan execution). - std::pair - createEpilogueVectorizedLoopSkeleton() final override; + std::pair createEpilogueVectorizedLoopSkeleton() final; protected: /// Emits an iteration count bypass check once for the main loop (when \p @@ -866,8 +864,7 @@ public: } /// Implements the interface for creating a vectorized skeleton using the /// *epilogue loop* strategy (ie the second pass of vplan execution). - std::pair - createEpilogueVectorizedLoopSkeleton() final override; + std::pair createEpilogueVectorizedLoopSkeleton() final; protected: /// Emits an iteration count bypass check after the main vector loop has