//===--- LayoutConstraint.cpp - Layout constraints types and APIs ---------===// // // This source file is part of the Swift.org open source project // // Copyright (c) 2014 - 2017 Apple Inc. and the Swift project authors // Licensed under Apache License v2.0 with Runtime Library Exception // // See https://swift.org/LICENSE.txt for license information // See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors // //===----------------------------------------------------------------------===// // // This file implements APIs for layout constraints. // //===----------------------------------------------------------------------===// #include "swift/AST/ASTContext.h" #include "swift/AST/Decl.h" #include "swift/AST/Types.h" namespace swift { /// This helper function is typically used by the parser to /// map a type name to a corresponding layout constraint if possible. LayoutConstraint getLayoutConstraint(Identifier ID, ASTContext &Ctx) { if (ID == Ctx.Id_TrivialLayout) return LayoutConstraint::getLayoutConstraint( LayoutConstraintKind::TrivialOfExactSize, 0, 0, Ctx); if (ID == Ctx.Id_TrivialAtMostLayout) return LayoutConstraint::getLayoutConstraint( LayoutConstraintKind::TrivialOfAtMostSize, 0, 0, Ctx); if (ID == Ctx.Id_RefCountedObjectLayout) return LayoutConstraint::getLayoutConstraint( LayoutConstraintKind::RefCountedObject, Ctx); if (ID == Ctx.Id_NativeRefCountedObjectLayout) return LayoutConstraint::getLayoutConstraint( LayoutConstraintKind::NativeRefCountedObject, Ctx); return LayoutConstraint::getLayoutConstraint( LayoutConstraintKind::UnknownLayout, Ctx); } StringRef LayoutConstraintInfo::getName() const { return getName(getKind()); } StringRef LayoutConstraintInfo::getName(LayoutConstraintKind Kind) { switch (Kind) { case LayoutConstraintKind::UnknownLayout: return "_UnknownLayout"; case LayoutConstraintKind::RefCountedObject: return "_RefCountedObject"; case LayoutConstraintKind::NativeRefCountedObject: return "_NativeRefCountedObject"; case LayoutConstraintKind::Trivial: return "_Trivial"; case LayoutConstraintKind::TrivialOfAtMostSize: return "_TrivialAtMost"; case LayoutConstraintKind::TrivialOfExactSize: return "_Trivial"; } llvm_unreachable("Unhandled LayoutConstraintKind in switch."); } /// Uniquing for the LayoutConstraintInfo. void LayoutConstraintInfo::Profile(llvm::FoldingSetNodeID &ID, LayoutConstraintKind Kind, unsigned SizeInBits, unsigned Alignment) { ID.AddInteger((unsigned)Kind); ID.AddInteger(SizeInBits); ID.AddInteger(Alignment); } bool LayoutConstraintInfo::isKnownLayout(LayoutConstraintKind Kind) { return Kind != LayoutConstraintKind::UnknownLayout; } bool LayoutConstraintInfo::isFixedSizeTrivial(LayoutConstraintKind Kind) { return Kind == LayoutConstraintKind::TrivialOfExactSize; } bool LayoutConstraintInfo::isKnownSizeTrivial(LayoutConstraintKind Kind) { return Kind > LayoutConstraintKind::UnknownLayout && Kind < LayoutConstraintKind::Trivial; } bool LayoutConstraintInfo::isAddressOnlyTrivial(LayoutConstraintKind Kind) { return Kind == LayoutConstraintKind::Trivial; } bool LayoutConstraintInfo::isTrivial(LayoutConstraintKind Kind) { return Kind > LayoutConstraintKind::UnknownLayout && Kind <= LayoutConstraintKind::Trivial; } bool LayoutConstraintInfo::isRefCountedObject(LayoutConstraintKind Kind) { return Kind == LayoutConstraintKind::RefCountedObject; } bool LayoutConstraintInfo::isNativeRefCountedObject(LayoutConstraintKind Kind) { return Kind == LayoutConstraintKind::NativeRefCountedObject; } void *LayoutConstraintInfo::operator new(size_t bytes, const ASTContext &ctx, AllocationArena arena, unsigned alignment) { return ctx.Allocate(bytes, alignment, arena); } SourceRange LayoutConstraintLoc::getSourceRange() const { return getLoc(); } } // end namespace swift