Refactor what has effectively become copy-and-pasted code

llvm-svn: 8357
This commit is contained in:
Chris Lattner 2003-09-05 02:30:47 +00:00
parent 8a75d6619b
commit 5ac07d2221
1 changed files with 17 additions and 32 deletions

View File

@ -503,6 +503,7 @@ public:
return I;
}
// containsEquivalent - Return true if the typemap contains a type that is
// structurally equivalent to the specified type.
//
@ -519,6 +520,18 @@ public:
return 0;
}
void finishRefinement(TypeClass *Ty) {
if (TypeClass *NewTy = containsEquivalent(Ty)) {
// Refined to a different type altogether?
Ty->refineAbstractTypeToInternal(NewTy, false);
} else {
// If the type is currently thought to be abstract, rescan all of our
// subtypes to see if the type has just become concrete!
if (Ty->isAbstract()) Ty->setAbstract(Ty->isTypeAbstract());
Ty->typeIsRefined(); // Same type, different contents...
}
}
// refineAbstractType - This is called when one of the contained abstract
// types gets refined... this simply removes the abstract type from our table.
// We expect that whoever refined the type will add it back to the table,
@ -1181,14 +1194,7 @@ void FunctionType::refineAbstractType(const DerivedType *OldType,
ParamTys[i] = NewType;
}
if (const FunctionType *MT = FunctionTypes.containsEquivalent(this)) {
refineAbstractTypeToInternal(MT, false); // Different type altogether...
} else {
// If the type is currently thought to be abstract, rescan all of our
// subtypes to see if the type has just become concrete!
if (isAbstract()) setAbstract(isTypeAbstract());
typeIsRefined(); // Same type, different contents...
}
FunctionTypes.finishRefinement(this);
}
@ -1215,14 +1221,7 @@ void ArrayType::refineAbstractType(const DerivedType *OldType,
ElementType.removeUserFromConcrete();
ElementType = NewType;
if (const ArrayType *AT = ArrayTypes.containsEquivalent(this)) {
refineAbstractTypeToInternal(AT, false); // Different type altogether...
} else {
// If the type is currently thought to be abstract, rescan all of our
// subtypes to see if the type has just become concrete!
if (isAbstract()) setAbstract(isTypeAbstract());
typeIsRefined(); // Same type, different contents...
}
ArrayTypes.finishRefinement(this);
}
@ -1253,14 +1252,7 @@ void StructType::refineAbstractType(const DerivedType *OldType,
ETypes[i] = NewType;
}
if (const StructType *ST = StructTypes.containsEquivalent(this)) {
refineAbstractTypeToInternal(ST, false); // Different type altogether...
} else {
// If the type is currently thought to be abstract, rescan all of our
// subtypes to see if the type has just become concrete!
if (isAbstract()) setAbstract(isTypeAbstract());
typeIsRefined(); // Same type, different contents...
}
StructTypes.finishRefinement(this);
}
// refineAbstractType - Called when a contained type is found to be more
@ -1286,13 +1278,6 @@ void PointerType::refineAbstractType(const DerivedType *OldType,
ElementType.removeUserFromConcrete();
ElementType = NewType;
if (const PointerType *PT = PointerTypes.containsEquivalent(this)) {
refineAbstractTypeToInternal(PT, false); // Different type altogether...
} else {
// If the type is currently thought to be abstract, rescan all of our
// subtypes to see if the type has just become concrete!
if (isAbstract()) setAbstract(isTypeAbstract());
typeIsRefined(); // Same type, different contents...
}
PointerTypes.finishRefinement(this);
}