[clang-tools-extra] r343848 - [clang-tidy] Replace deprecated std::ios_base aliases

Mikael Holmén via cfe-commits cfe-commits at lists.llvm.org
Tue Oct 9 02:10:55 PDT 2018


Hi Jonas, Bence,

On 10/08/2018 08:22 AM, Mikael Holmén via cfe-commits wrote:
> Hi Jonas,
> 
> I get the follwing warning/error when compiling this commit with clang 3.6:
> 
> ../tools/clang/tools/extra/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp:21:5:
> error: suggest braces around initialization of subobject
> [-Werror,-Wmissing-braces]
>       "::std::ios_base::io_state",  "::std::ios_base::open_mode",
>       ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> 1 error generated.
> 
> 
> It looks like r343916 tried to fix it (but failed? and was reverted) so
> I suppose I'm not alone seeing it.

This is still giving the warning with clang 3.6.

Thanks,
Mikael

> 
> Regards,
> Mikael
> 
> On 10/05/2018 03:36 PM, Jonas Toth via cfe-commits wrote:
>> Author: jonastoth
>> Date: Fri Oct  5 06:36:00 2018
>> New Revision: 343848
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=343848&view=rev
>> Log:
>> [clang-tidy] Replace deprecated std::ios_base aliases
>>
>> This check warns the uses of the deprecated member types of std::ios_base
>> and replaces those that have a non-deprecated equivalent.
>>
>> Patch by andobence!
>>
>> Reviewd by: alexfh
>>
>> Revision ID: https://reviews.llvm.org/D51332
>>
>> Added:
>>       clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp
>>       clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.h
>>       clang-tools-extra/trunk/docs/clang-tidy/checks/modernize-deprecated-ios-base-aliases.rst
>>       clang-tools-extra/trunk/test/clang-tidy/modernize-deprecated-ios-base-aliases.cpp
>> Modified:
>>       clang-tools-extra/trunk/clang-tidy/modernize/CMakeLists.txt
>>       clang-tools-extra/trunk/clang-tidy/modernize/ModernizeTidyModule.cpp
>>       clang-tools-extra/trunk/docs/ReleaseNotes.rst
>>       clang-tools-extra/trunk/docs/clang-tidy/checks/list.rst
>>
>> Modified: clang-tools-extra/trunk/clang-tidy/modernize/CMakeLists.txt
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/clang-tidy/modernize/CMakeLists.txt?rev=343848&r1=343847&r2=343848&view=diff
>> ==============================================================================
>> --- clang-tools-extra/trunk/clang-tidy/modernize/CMakeLists.txt (original)
>> +++ clang-tools-extra/trunk/clang-tidy/modernize/CMakeLists.txt Fri Oct  5 06:36:00 2018
>> @@ -4,6 +4,7 @@ add_clang_library(clangTidyModernizeModu
>>      AvoidBindCheck.cpp
>>      ConcatNestedNamespacesCheck.cpp
>>      DeprecatedHeadersCheck.cpp
>> +  DeprecatedIosBaseAliasesCheck.cpp
>>      LoopConvertCheck.cpp
>>      LoopConvertUtils.cpp
>>      MakeSharedCheck.cpp
>>
>> Added: clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp?rev=343848&view=auto
>> ==============================================================================
>> --- clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp (added)
>> +++ clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.cpp Fri Oct  5 06:36:00 2018
>> @@ -0,0 +1,80 @@
>> +//===--- DeprecatedIosBaseAliasesCheck.cpp - clang-tidy--------------------===//
>> +//
>> +//                     The LLVM Compiler Infrastructure
>> +//
>> +// This file is distributed under the University of Illinois Open Source
>> +// License. See LICENSE.TXT for details.
>> +//
>> +//===----------------------------------------------------------------------===//
>> +
>> +#include "DeprecatedIosBaseAliasesCheck.h"
>> +#include "clang/AST/ASTContext.h"
>> +#include "clang/ASTMatchers/ASTMatchFinder.h"
>> +
>> +using namespace clang::ast_matchers;
>> +
>> +namespace clang {
>> +namespace tidy {
>> +namespace modernize {
>> +
>> +static const std::array<StringRef, 5> DeprecatedTypes = {
>> +    "::std::ios_base::io_state",  "::std::ios_base::open_mode",
>> +    "::std::ios_base::seek_dir",  "::std::ios_base::streamoff",
>> +    "::std::ios_base::streampos",
>> +};
>> +
>> +static const llvm::StringMap<StringRef> ReplacementTypes = {
>> +    {"io_state", "iostate"},
>> +    {"open_mode", "openmode"},
>> +    {"seek_dir", "seekdir"}};
>> +
>> +void DeprecatedIosBaseAliasesCheck::registerMatchers(MatchFinder *Finder) {
>> +  // Only register the matchers for C++; the functionality currently does not
>> +  // provide any benefit to other languages, despite being benign.
>> +  if (!getLangOpts().CPlusPlus)
>> +    return;
>> +
>> +  auto IoStateDecl = typedefDecl(hasAnyName(DeprecatedTypes)).bind("TypeDecl");
>> +  auto IoStateType =
>> +      qualType(hasDeclaration(IoStateDecl), unless(elaboratedType()));
>> +
>> +  Finder->addMatcher(typeLoc(loc(IoStateType)).bind("TypeLoc"), this);
>> +}
>> +
>> +void DeprecatedIosBaseAliasesCheck::check(
>> +    const MatchFinder::MatchResult &Result) {
>> +  SourceManager &SM = *Result.SourceManager;
>> +
>> +  const auto *Typedef = Result.Nodes.getNodeAs<TypedefDecl>("TypeDecl");
>> +  StringRef TypeName = Typedef->getName();
>> +  bool HasReplacement = ReplacementTypes.count(TypeName);
>> +
>> +  const auto *TL = Result.Nodes.getNodeAs<TypeLoc>("TypeLoc");
>> +  SourceLocation IoStateLoc = TL->getBeginLoc();
>> +
>> +  // Do not generate fixits for matches depending on template arguments and
>> +  // macro expansions.
>> +  bool Fix = HasReplacement && !TL->getType()->isDependentType();
>> +  if (IoStateLoc.isMacroID()) {
>> +    IoStateLoc = SM.getSpellingLoc(IoStateLoc);
>> +    Fix = false;
>> +  }
>> +
>> +  SourceLocation EndLoc = IoStateLoc.getLocWithOffset(TypeName.size() - 1);
>> +
>> +  if (HasReplacement) {
>> +    auto FixName = ReplacementTypes.lookup(TypeName);
>> +    auto Builder = diag(IoStateLoc, "'std::ios_base::%0' is deprecated; use "
>> +                                    "'std::ios_base::%1' instead")
>> +                   << TypeName << FixName;
>> +
>> +    if (Fix)
>> +      Builder << FixItHint::CreateReplacement(SourceRange(IoStateLoc, EndLoc),
>> +                                              FixName);
>> +  } else
>> +    diag(IoStateLoc, "'std::ios_base::%0' is deprecated") << TypeName;
>> +}
>> +
>> +} // namespace modernize
>> +} // namespace tidy
>> +} // namespace clang
>>
>> Added: clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.h
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.h?rev=343848&view=auto
>> ==============================================================================
>> --- clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.h (added)
>> +++ clang-tools-extra/trunk/clang-tidy/modernize/DeprecatedIosBaseAliasesCheck.h Fri Oct  5 06:36:00 2018
>> @@ -0,0 +1,36 @@
>> +//===--- DeprecatedIosBaseAliasesCheck.h - clang-tidy------------*- C++ -*-===//
>> +//
>> +//                     The LLVM Compiler Infrastructure
>> +//
>> +// This file is distributed under the University of Illinois Open Source
>> +// License. See LICENSE.TXT for details.
>> +//
>> +//===----------------------------------------------------------------------===//
>> +
>> +#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_DEPRECATEDIOSBASEALIASESCHECK_H
>> +#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_DEPRECATEDIOSBASEALIASESCHECK_H
>> +
>> +#include "../ClangTidy.h"
>> +
>> +namespace clang {
>> +namespace tidy {
>> +namespace modernize {
>> +
>> +/// This check warns the uses of the deprecated member types of ``std::ios_base``
>> +/// and replaces those that have a non-deprecated equivalent.
>> +///
>> +/// For the user-facing documentation see:
>> +/// http://clang.llvm.org/extra/clang-tidy/checks/modernize-deprecated-ios-base-aliases.html
>> +class DeprecatedIosBaseAliasesCheck : public ClangTidyCheck {
>> +public:
>> +  DeprecatedIosBaseAliasesCheck(StringRef Name, ClangTidyContext *Context)
>> +      : ClangTidyCheck(Name, Context) {}
>> +  void registerMatchers(ast_matchers::MatchFinder *Finder) override;
>> +  void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
>> +};
>> +
>> +} // namespace modernize
>> +} // namespace tidy
>> +} // namespace clang
>> +
>> +#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_MODERNIZE_DEPRECATEDIOSBASEALIASESCHECK_H
>>
>> Modified: clang-tools-extra/trunk/clang-tidy/modernize/ModernizeTidyModule.cpp
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/clang-tidy/modernize/ModernizeTidyModule.cpp?rev=343848&r1=343847&r2=343848&view=diff
>> ==============================================================================
>> --- clang-tools-extra/trunk/clang-tidy/modernize/ModernizeTidyModule.cpp (original)
>> +++ clang-tools-extra/trunk/clang-tidy/modernize/ModernizeTidyModule.cpp Fri Oct  5 06:36:00 2018
>> @@ -13,6 +13,7 @@
>>    #include "AvoidBindCheck.h"
>>    #include "ConcatNestedNamespacesCheck.h"
>>    #include "DeprecatedHeadersCheck.h"
>> +#include "DeprecatedIosBaseAliasesCheck.h"
>>    #include "LoopConvertCheck.h"
>>    #include "MakeSharedCheck.h"
>>    #include "MakeUniqueCheck.h"
>> @@ -51,6 +52,8 @@ public:
>>            "modernize-concat-nested-namespaces");
>>        CheckFactories.registerCheck<DeprecatedHeadersCheck>(
>>            "modernize-deprecated-headers");
>> +    CheckFactories.registerCheck<DeprecatedIosBaseAliasesCheck>(
>> +        "modernize-deprecated-ios-base-aliases");
>>        CheckFactories.registerCheck<LoopConvertCheck>("modernize-loop-convert");
>>        CheckFactories.registerCheck<MakeSharedCheck>("modernize-make-shared");
>>        CheckFactories.registerCheck<MakeUniqueCheck>("modernize-make-unique");
>>
>> Modified: clang-tools-extra/trunk/docs/ReleaseNotes.rst
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/docs/ReleaseNotes.rst?rev=343848&r1=343847&r2=343848&view=diff
>> ==============================================================================
>> --- clang-tools-extra/trunk/docs/ReleaseNotes.rst (original)
>> +++ clang-tools-extra/trunk/docs/ReleaseNotes.rst Fri Oct  5 06:36:00 2018
>> @@ -99,6 +99,12 @@ Improvements to clang-tidy
>>      Checks for uses of nested namespaces in the form of
>>      ``namespace a { namespace b { ... }}`` and offers change to
>>      syntax introduced in C++17 standard: ``namespace a::b { ... }``.
>> +
>> +- New :doc:`modernize-deprecated-ios-base-aliases
>> +  <clang-tidy/checks/modernize-deprecated-ios-base-aliases>` check.
>> +
>> +  This check warns the uses of the deprecated member types of ``std::ios_base``
>> +  and replaces those that have a non-deprecated equivalent.
>>    
>>    - New :doc:`readability-magic-numbers
>>      <clang-tidy/checks/readability-magic-numbers>` check.
>>
>> Modified: clang-tools-extra/trunk/docs/clang-tidy/checks/list.rst
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/docs/clang-tidy/checks/list.rst?rev=343848&r1=343847&r2=343848&view=diff
>> ==============================================================================
>> --- clang-tools-extra/trunk/docs/clang-tidy/checks/list.rst (original)
>> +++ clang-tools-extra/trunk/docs/clang-tidy/checks/list.rst Fri Oct  5 06:36:00 2018
>> @@ -174,6 +174,7 @@ Clang-Tidy Checks
>>       modernize-avoid-bind
>>       modernize-concat-nested-namespaces
>>       modernize-deprecated-headers
>> +   modernize-deprecated-ios-base-aliases
>>       modernize-loop-convert
>>       modernize-make-shared
>>       modernize-make-unique
>>
>> Added: clang-tools-extra/trunk/docs/clang-tidy/checks/modernize-deprecated-ios-base-aliases.rst
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/docs/clang-tidy/checks/modernize-deprecated-ios-base-aliases.rst?rev=343848&view=auto
>> ==============================================================================
>> --- clang-tools-extra/trunk/docs/clang-tidy/checks/modernize-deprecated-ios-base-aliases.rst (added)
>> +++ clang-tools-extra/trunk/docs/clang-tidy/checks/modernize-deprecated-ios-base-aliases.rst Fri Oct  5 06:36:00 2018
>> @@ -0,0 +1,17 @@
>> +.. title:: clang-tidy - modernize-deprecated-ios-base-aliases
>> +
>> +modernize-deprecated-ios-base-aliases
>> +=====================================
>> +
>> +This check warns the uses of the deprecated member types of ``std::ios_base``
>> +and replaces those that have a non-deprecated equivalent.
>> +
>> +===================================  ===========================
>> +Deprecated member type               Replacement
>> +===================================  ===========================
>> +``std::ios_base::io_state``          ``std::ios_base::iostate``
>> +``std::ios_base::open_mode``         ``std::ios_base::openmode``
>> +``std::ios_base::seek_dir``          ``std::ios_base::seekdir``
>> +``std::ios_base::streamoff``
>> +``std::ios_base::streampos``
>> +===================================  ===========================
>>
>> Added: clang-tools-extra/trunk/test/clang-tidy/modernize-deprecated-ios-base-aliases.cpp
>> URL: http://llvm.org/viewvc/llvm-project/clang-tools-extra/trunk/test/clang-tidy/modernize-deprecated-ios-base-aliases.cpp?rev=343848&view=auto
>> ==============================================================================
>> --- clang-tools-extra/trunk/test/clang-tidy/modernize-deprecated-ios-base-aliases.cpp (added)
>> +++ clang-tools-extra/trunk/test/clang-tidy/modernize-deprecated-ios-base-aliases.cpp Fri Oct  5 06:36:00 2018
>> @@ -0,0 +1,239 @@
>> +// RUN: %check_clang_tidy %s modernize-deprecated-ios-base-aliases %t
>> +
>> +namespace std {
>> +class ios_base {
>> +public:
>> +  typedef int io_state;
>> +  typedef int open_mode;
>> +  typedef int seek_dir;
>> +
>> +  typedef int streampos;
>> +  typedef int streamoff;
>> +};
>> +
>> +template <class CharT>
>> +class basic_ios : public ios_base {
>> +};
>> +} // namespace std
>> +
>> +// Test function return values (declaration)
>> +std::ios_base::io_state f_5();
>> +// CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'std::ios_base::io_state' is deprecated; use 'std::ios_base::iostate' instead [modernize-deprecated-ios-base-aliases]
>> +// CHECK-FIXES: std::ios_base::iostate f_5();
>> +
>> +// Test function parameters.
>> +void f_6(std::ios_base::open_mode);
>> +// CHECK-MESSAGES: :[[@LINE-1]]:25: warning: 'std::ios_base::open_mode' is deprecated
>> +// CHECK-FIXES: void f_6(std::ios_base::openmode);
>> +void f_7(const std::ios_base::seek_dir &);
>> +// CHECK-MESSAGES: :[[@LINE-1]]:31: warning: 'std::ios_base::seek_dir' is deprecated
>> +// CHECK-FIXES: void f_7(const std::ios_base::seekdir &);
>> +
>> +// Test on record type fields.
>> +struct A {
>> +  std::ios_base::io_state field;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate field;
>> +
>> +  typedef std::ios_base::io_state int_ptr_type;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:26: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: typedef std::ios_base::iostate int_ptr_type;
>> +};
>> +
>> +struct B : public std::ios_base {
>> +  io_state a;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: iostate a;
>> +};
>> +
>> +struct C : public std::basic_ios<char> {
>> +  io_state a;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: iostate a;
>> +};
>> +
>> +void f_1() {
>> +  std::ios_base::io_state a;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate a;
>> +
>> +  // Check that spaces aren't modified unnecessarily.
>> +  std :: ios_base :: io_state b;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:22: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std :: ios_base :: iostate b;
>> +
>> +  // Test construction from a temporary.
>> +  std::ios_base::io_state c = std::ios_base::io_state{};
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-MESSAGES: :[[@LINE-2]]:46: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate c = std::ios_base::iostate{};
>> +
>> +  typedef std::ios_base::io_state alias1;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:26: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: typedef std::ios_base::iostate alias1;
>> +  alias1 d(a);
>> +
>> +  using alias2 = std::ios_base::io_state;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:33: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: using alias2 = std::ios_base::iostate;
>> +  alias2 e;
>> +
>> +  // Test pointers.
>> +  std::ios_base::io_state *f;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate *f;
>> +
>> +  // Test 'static' declarations.
>> +  static std::ios_base::io_state g;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:25: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: static std::ios_base::iostate g;
>> +
>> +  // Test with cv-qualifiers.
>> +  const std::ios_base::io_state h(0);
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:24: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: const std::ios_base::iostate h(0);
>> +  volatile std::ios_base::io_state i;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:27: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: volatile std::ios_base::iostate i;
>> +  const volatile std::ios_base::io_state j(0);
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:33: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: const volatile std::ios_base::iostate j(0);
>> +
>> +  // Test auto and initializer-list.
>> +  auto k = std::ios_base::io_state{};
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:27: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: auto k = std::ios_base::iostate{};
>> +
>> +  std::ios_base::io_state l{std::ios_base::io_state()};
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-MESSAGES: :[[@LINE-2]]:44: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate l{std::ios_base::iostate()};
>> +
>> +  // Test temporaries.
>> +  std::ios_base::io_state();
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::ios_base::iostate();
>> +
>> +  // Test inherited type usage
>> +  std::basic_ios<char>::io_state m;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:25: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: std::basic_ios<char>::iostate m;
>> +
>> +  std::ios_base::streampos n;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::streampos' is deprecated [modernize-deprecated-ios-base-aliases]
>> +
>> +  std::ios_base::streamoff o;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:18: warning: 'std::ios_base::streamoff' is deprecated [modernize-deprecated-ios-base-aliases]
>> +}
>> +
>> +// Test without the nested name specifiers.
>> +void f_2() {
>> +  using namespace std;
>> +
>> +  ios_base::io_state a;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:13: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: ios_base::iostate a;
>> +}
>> +
>> +// Test messing-up with macros.
>> +void f_4() {
>> +#define MACRO_1 std::ios_base::io_state
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:32: warning: 'std::ios_base::io_state' is deprecated
>> +  MACRO_1 a;
>> +
>> +#define MACRO_2 io_state
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:17: warning: 'std::ios_base::io_state' is deprecated
>> +  std::ios_base::MACRO_2 b;
>> +
>> +#define MACRO_3 std::ios_base
>> +  MACRO_3::io_state c;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: 'std::ios_base::io_state' is deprecated
>> +
>> +#define MACRO_4(type) type::io_state
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:29: warning: 'std::ios_base::io_state' is deprecated
>> +  MACRO_4(std::ios_base) d;
>> +
>> +#undef MACRO_1
>> +#undef MACRO_2
>> +#undef MACRO_3
>> +#undef MACRO_4
>> +}
>> +
>> +// Test function return values (definition).
>> +std::ios_base::io_state f_5()
>> +// CHECK-MESSAGES: :[[@LINE-1]]:16: warning: 'std::ios_base::io_state' is deprecated
>> +// CHECK-FIXES: std::ios_base::iostate f_5()
>> +{
>> +  // Test constructor.
>> +  return std::ios_base::io_state(0);
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:25: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: return std::ios_base::iostate(0);
>> +}
>> +
>> +// Test that other aliases with same name aren't replaced
>> +struct my_ios_base {
>> +  typedef int io_state;
>> +};
>> +
>> +namespace ns_1 {
>> +struct my_ios_base2 {
>> +  typedef int io_state;
>> +};
>> +} // namespace ns_1
>> +
>> +void f_8() {
>> +  my_ios_base::io_state a;
>> +
>> +  ns_1::my_ios_base2::io_state b;
>> +}
>> +
>> +// Test templates
>> +template <typename X>
>> +void f_9() {
>> +  typename std::basic_ios<X>::io_state p;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:31: warning: 'std::ios_base::io_state' is deprecated
>> +  typename std::ios_base::io_state q;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:27: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: typename std::ios_base::iostate q;
>> +}
>> +
>> +template <typename T>
>> +void f_10(T arg) {
>> +  T x(arg);
>> +}
>> +
>> +template <typename T>
>> +void f_11() {
>> +  typename T::io_state x{};
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:15: warning: 'std::ios_base::io_state' is deprecated
>> +}
>> +
>> +template <typename T>
>> +struct D : std::ios_base {
>> +  io_state a;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: iostate a;
>> +
>> +  typename std::basic_ios<T>::io_state b;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:31: warning: 'std::ios_base::io_state' is deprecated
>> +};
>> +
>> +template <typename T>
>> +struct E {
>> +  T t;
>> +};
>> +
>> +void f_12() {
>> +  f_9<char>();
>> +
>> +  f_10<std::ios_base::io_state>(0);
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:23: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: f_10<std::ios_base::iostate>(0);
>> +
>> +  f_11<std::ios_base>();
>> +  D<char> d;
>> +
>> +  E<std::ios_base::io_state> e;
>> +  // CHECK-MESSAGES: :[[@LINE-1]]:20: warning: 'std::ios_base::io_state' is deprecated
>> +  // CHECK-FIXES: E<std::ios_base::iostate> e;
>> +}
>>
>>
>> _______________________________________________
>> cfe-commits mailing list
>> cfe-commits at lists.llvm.org
>> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
> 



More information about the cfe-commits mailing list