diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-02-25 01:57:42 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-02-25 01:57:42 +0000 |
commit | 63787f0343ab3546a5346a833e2f7485779f17e2 (patch) | |
tree | f67dc23d5a8a831ef2757b043146c5414f66cc45 /lib | |
parent | a66eccbf1f26a2a48c59b6e733dde9c79c19f0df (diff) |
[arcmt] GC migrator: don't try to remove redundant __strong, it does
more harm than good.
Fixes rdar://10522805&10521433
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151424 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ARCMigrate/TransGCAttrs.cpp | 25 |
1 files changed, 0 insertions, 25 deletions
diff --git a/lib/ARCMigrate/TransGCAttrs.cpp b/lib/ARCMigrate/TransGCAttrs.cpp index fa62b36208..de710abb5d 100644 --- a/lib/ARCMigrate/TransGCAttrs.cpp +++ b/lib/ARCMigrate/TransGCAttrs.cpp @@ -183,30 +183,6 @@ public: } // anonymous namespace -static void clearRedundantStrongs(MigrationContext &MigrateCtx) { - TransformActions &TA = MigrateCtx.Pass.TA; - - for (unsigned i = 0, e = MigrateCtx.GCAttrs.size(); i != e; ++i) { - MigrationContext::GCAttrOccurrence &Attr = MigrateCtx.GCAttrs[i]; - if (Attr.Kind == MigrationContext::GCAttrOccurrence::Strong && - Attr.FullyMigratable && Attr.Dcl) { - TypeSourceInfo *TInfo = 0; - if (DeclaratorDecl *DD = dyn_cast<DeclaratorDecl>(Attr.Dcl)) - TInfo = DD->getTypeSourceInfo(); - else if (ObjCPropertyDecl *PD = dyn_cast<ObjCPropertyDecl>(Attr.Dcl)) - TInfo = PD->getTypeSourceInfo(); - if (!TInfo) - continue; - - if (TInfo->getType().getObjCLifetime() == Qualifiers::OCL_Strong) { - Transaction Trans(TA); - TA.remove(Attr.Loc); - MigrateCtx.RemovedAttrSet.insert(Attr.Loc.getRawEncoding()); - } - } - } -} - static void errorForGCAttrsOnNonObjC(MigrationContext &MigrateCtx) { TransformActions &TA = MigrateCtx.Pass.TA; @@ -354,7 +330,6 @@ void GCAttrsTraverser::traverseTU(MigrationContext &MigrateCtx) { GCAttrsCollector(MigrateCtx, AllProps).TraverseDecl( MigrateCtx.Pass.Ctx.getTranslationUnitDecl()); - clearRedundantStrongs(MigrateCtx); errorForGCAttrsOnNonObjC(MigrateCtx); checkAllProps(MigrateCtx, AllProps); checkWeakGCAttrs(MigrateCtx); |