// RUN: %check_clang_tidy %s modernize-use-override %t -- \ // RUN: -config="{CheckOptions: [{key: modernize-use-override.AllowOverrideAndFinal, value: 1}]}" struct Base { virtual ~Base(); virtual void a(); virtual void b(); virtual void c(); virtual void d(); virtual void e(); virtual void f(); virtual void g(); virtual void h(); virtual void i(); }; struct Simple : public Base { virtual ~Simple(); // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: prefer using 'override' or (rarely) 'final' instead of 'virtual' [modernize-use-override] // CHECK-FIXES: {{^}} ~Simple() override; virtual void a() override; // CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'virtual' is redundant since the function is already declared 'override' [modernize-use-override] // CHECK-FIXES: {{^}} void a() override; virtual void b() final; // CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'virtual' is redundant since the function is already declared 'final' [modernize-use-override] // CHECK-FIXES: {{^}} void b() final; virtual void c() final override; // CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'virtual' is redundant since the function is already declared 'final' [modernize-use-override] // CHECK-FIXES: {{^}} void c() final override; virtual void d() override final; // CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'virtual' is redundant since the function is already declared 'final' [modernize-use-override] // CHECK-FIXES: {{^}} void d() override final; void e() final override; void f() override final; void g() final; void h() override; void i(); // CHECK-MESSAGES: :[[@LINE-1]]:8: warning: annotate this function with 'override' or (rarely) 'final' [modernize-use-override] // CHECK-FIXES: {{^}} void i() override; };