Hi, sorry for the late response. I will look at it, currently multiple things to do though.
Am 09.10.2018 um 11:10 schrieb Mikael Holmén via cfe-commits: > 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@lists.llvm.org >>> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits >>> >> _______________________________________________ >> cfe-commits mailing list >> cfe-commits@lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits >> > _______________________________________________ > cfe-commits mailing list > cfe-commits@lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits