llvm/clang-tools-extra/test/clang-tidy/checkers/modernize/use-override-allow-override-and-final.cpp

// RUN: %check_clang_tidy %s modernize-use-override %t -- \
// RUN:   -config="{CheckOptions: {modernize-use-override.AllowOverrideAndFinal: true}}"

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;
};