From 5ed2ba26680f06846e7602ce65432b0a723b1273 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 10 Jul 2008 01:09:33 +0000 Subject: [PATCH] The source and dest of an alias are *not* required to have the same type, though that would be nice and make sense :). Patch by Nathan Keynes! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53387 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Linker/LinkModules.cpp | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/lib/Linker/LinkModules.cpp b/lib/Linker/LinkModules.cpp index cd18bf4aa16..ea7769a1159 100644 --- a/lib/Linker/LinkModules.cpp +++ b/lib/Linker/LinkModules.cpp @@ -714,9 +714,7 @@ static bool LinkAlias(Module *Dest, const Module *Src, // If types don't agree due to opaque types, try to resolve them. if (DGV && DGV->getType() != SGA->getType()) - if (RecursiveResolveTypes(SGA->getType(), DGV->getType())) - return Error(Err, "Alias Collision on '" + SGA->getName()+ - "': aliases have different types"); + RecursiveResolveTypes(SGA->getType(), DGV->getType()); } if (!DGV && !SGA->hasInternalLinkage()) { @@ -724,9 +722,7 @@ static bool LinkAlias(Module *Dest, const Module *Src, // If types don't agree due to opaque types, try to resolve them. if (DGV && DGV->getType() != SGA->getType()) - if (RecursiveResolveTypes(SGA->getType(), DGV->getType())) - return Error(Err, "Alias Collision on '" + SGA->getName()+ - "': aliases have different types"); + RecursiveResolveTypes(SGA->getType(), DGV->getType()); } if (!DGV && !SGA->hasInternalLinkage()) { @@ -734,9 +730,7 @@ static bool LinkAlias(Module *Dest, const Module *Src, // If types don't agree due to opaque types, try to resolve them. if (DGV && DGV->getType() != SGA->getType()) - if (RecursiveResolveTypes(SGA->getType(), DGV->getType())) - return Error(Err, "Alias Collision on '" + SGA->getName()+ - "': aliases have different types"); + RecursiveResolveTypes(SGA->getType(), DGV->getType()); } // No linking to be performed on internal stuff.