mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Factor the ProtocolConformance class into a small hierarchy of protocol conformances: - "normal" conformance, which provides a complete mapping for the explicit conformance of a nominal type (which may be generic) to a protocol; - "specialized" conformance, which specializes a generic conformance by applying a set of substitutions; and - "inherited" conformance, which projects the conformance from a superclass to a conformance for a subclass. In this scheme "normal" conformances are fairly heavyweight, because they provide a complete mapping. Normal conformances are unique, because they're associated with explicit conformance declarations (which cannot be repeated within a module; checking is TBD). Thus, IR generation will eventually emit them as strong symbols. "Specialized" and "inherited" conformances occur when we're dealing with generic specializations or subclasses. They project most of their members through to some underlying conformance, eventually landing at a "normal" conformance. ASTContext is responsible for uniquing these conformances when it sees them. The IR generation model for specialized conformances will involve runtime specialization of the underlying witness table; inherited conformances are probably no-ops from the IR generation perspective. Aside from being the right thing to do, having small, uniqued conformances for the specialization and inheritance cases is good for compile-time performance and memory usage. We're not really taking advantage of this everywhere we could, yet. This change uncovered a few existing issues (one known, one not known), particularly because we're projecting inherited conformances rather than building new conformances: - <rdar://problem/14620454>: protocol witnesses to methods of classes need to perform dynamic dispatch. See the test/Interpreter/typeof.swift test for an example. - <rdar://problem/14637688>: comparing NSString and String with == fails, because they are inter-convertible. I suspect we were missing some protocol conformances previously, and therefore accepting this obviously-invalid code. Swift SVN r6865
744 lines
20 KiB
C++
744 lines
20 KiB
C++
//===--- ModuleFormat.h - The internals of serialized modules ---*- C++ -*-===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2015 Apple Inc. and the Swift project authors
|
|
// Licensed under Apache License v2.0 with Runtime Library Exception
|
|
//
|
|
// See http://swift.org/LICENSE.txt for license information
|
|
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
///
|
|
/// \file Contains various constants and helper types to deal with serialized
|
|
/// modules.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SWIFT_SERIALIZATION_MODULEFORMAT_H
|
|
#define SWIFT_SERIALIZATION_MODULEFORMAT_H
|
|
|
|
#include "swift/Serialization/BCRecordLayout.h"
|
|
#include "llvm/Bitcode/BitCodes.h"
|
|
|
|
namespace swift {
|
|
namespace serialization {
|
|
|
|
/// Magic number for serialized module files.
|
|
const unsigned char SIGNATURE[] = { 0xE2, 0x9C, 0xA8, 0x0E };
|
|
|
|
/// Serialized module format major version number.
|
|
///
|
|
/// When the format changes in such a way that older compilers will not be
|
|
/// able to read the file at all, this number should be incremented.
|
|
const unsigned VERSION_MAJOR = 1;
|
|
|
|
/// Serialized module format minor version number.
|
|
///
|
|
/// When the format changes in a backwards-compatible way, this number should
|
|
/// be incremented.
|
|
const unsigned VERSION_MINOR = 0;
|
|
|
|
using DeclID = Fixnum<31>;
|
|
using DeclIDField = BCFixed<31>;
|
|
|
|
// TypeID must be the same as DeclID because it is stored in the same way.
|
|
using TypeID = DeclID;
|
|
using TypeIDField = DeclIDField;
|
|
|
|
using IdentifierID = Fixnum<31>;
|
|
using IdentifierIDField = BCFixed<31>;
|
|
|
|
using BitOffset = Fixnum<31>;
|
|
using BitOffsetField = BCFixed<31>;
|
|
|
|
// CharOffset must be the same as BitOffset because it is stored in the
|
|
// same way.
|
|
using CharOffset = BitOffset;
|
|
using CharOffsetField = BitOffsetField;
|
|
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum AbstractCC : uint8_t {
|
|
C = 0,
|
|
ObjCMethod,
|
|
Freestanding,
|
|
Method
|
|
};
|
|
using AbstractCCField = BCFixed<2>;
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum XRefKind : uint8_t {
|
|
SwiftValue = 0,
|
|
SwiftOperator,
|
|
SwiftGenericParameter
|
|
};
|
|
using XRefKindField = BCFixed<2>;
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum OperatorKind : uint8_t {
|
|
Infix = 0,
|
|
Prefix,
|
|
Postfix
|
|
};
|
|
static_assert(sizeof(OperatorKind) <= sizeof(TypeID),
|
|
"too many operator kinds");
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum GenericRequirementKind : uint8_t {
|
|
Conformance = 0,
|
|
SameType
|
|
};
|
|
using GenericRequirementKindField = BCFixed<1>;
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum Associativity : uint8_t {
|
|
NonAssociative = 0,
|
|
LeftAssociative,
|
|
RightAssociative
|
|
};
|
|
using AssociativityField = BCFixed<2>;
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum Ownership : uint8_t {
|
|
Strong = 0,
|
|
Weak,
|
|
Unowned
|
|
};
|
|
using OwnershipField = BCFixed<2>;
|
|
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum DefaultArgumentKind : uint8_t {
|
|
None = 0,
|
|
Normal,
|
|
File,
|
|
Line,
|
|
Column
|
|
};
|
|
using DefaultArgumentField = BCFixed<3>;
|
|
|
|
/// The various types of blocks that can occur within a serialized Swift
|
|
/// module.
|
|
///
|
|
/// These IDs must \em not be renumbered or reordered without incrementing
|
|
/// VERSION_MAJOR.
|
|
enum BlockID {
|
|
/// The control block, which contains all of the information that needs to
|
|
/// be validated prior to committing to loading the serialized module.
|
|
///
|
|
/// \sa control_block
|
|
CONTROL_BLOCK_ID = llvm::bitc::FIRST_APPLICATION_BLOCKID,
|
|
|
|
/// The input block, which contains all the files this module depends on.
|
|
///
|
|
/// \sa input_block
|
|
INPUT_BLOCK_ID,
|
|
|
|
/// The "decls-and-types" block, which contains all of the declarations that
|
|
/// come from this module.
|
|
///
|
|
/// Types are also stored here, so that types that just wrap a Decl don't need
|
|
/// a separate entry in the file.
|
|
///
|
|
/// \sa decls_block
|
|
DECLS_AND_TYPES_BLOCK_ID,
|
|
|
|
/// The identifier block, which contains all of the strings used in
|
|
/// identifiers in the module.
|
|
///
|
|
/// Unlike other blocks in the file, all data within this block is completely
|
|
/// opaque. Offsets into this block should point directly into the blob at a
|
|
/// null-terminated UTF-8 string.
|
|
IDENTIFIER_DATA_BLOCK_ID,
|
|
|
|
/// The index block, which contains cross-referencing information for the
|
|
/// module.
|
|
///
|
|
/// \sa index_block
|
|
INDEX_BLOCK_ID,
|
|
|
|
/// An empty block that signals to the reader to throw away the module and
|
|
/// reparse the source files in the input block.
|
|
///
|
|
/// This is a bring-up hack and will eventually go away.
|
|
FALL_BACK_TO_TRANSLATION_UNIT_ID = 100
|
|
};
|
|
|
|
/// The record types within the control block.
|
|
///
|
|
/// \sa CONTROL_BLOCK_ID
|
|
namespace control_block {
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum {
|
|
METADATA = 1
|
|
};
|
|
|
|
using MetadataLayout = BCRecordLayout<
|
|
METADATA, // ID
|
|
BCFixed<16>, // Module format major version
|
|
BCFixed<16>, // Module format minor version
|
|
BCBlob // misc. version information
|
|
>;
|
|
}
|
|
|
|
/// The record types within the input block.
|
|
///
|
|
/// \sa INPUT_BLOCK_ID
|
|
namespace input_block {
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum {
|
|
SOURCE_FILE = 1,
|
|
IMPORTED_MODULE
|
|
};
|
|
|
|
using SourceFileLayout = BCRecordLayout<
|
|
SOURCE_FILE, // ID
|
|
BCBlob // path
|
|
>;
|
|
|
|
using ImportedModuleLayout = BCRecordLayout<
|
|
IMPORTED_MODULE,
|
|
BCBlob // module name
|
|
>;
|
|
}
|
|
|
|
/// The record types within the "decls-and-types" block.
|
|
///
|
|
/// \sa DECLS_AND_TYPES_BLOCK_ID
|
|
namespace decls_block {
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum : uint8_t {
|
|
NAME_ALIAS_TYPE = 1,
|
|
NOMINAL_TYPE,
|
|
PAREN_TYPE,
|
|
TUPLE_TYPE,
|
|
TUPLE_TYPE_ELT,
|
|
FUNCTION_TYPE,
|
|
METATYPE_TYPE,
|
|
LVALUE_TYPE,
|
|
ARCHETYPE_TYPE,
|
|
ARCHETYPE_NESTED_TYPE_NAMES,
|
|
ARCHETYPE_NESTED_TYPES,
|
|
PROTOCOL_COMPOSITION_TYPE,
|
|
SUBSTITUTED_TYPE,
|
|
BOUND_GENERIC_TYPE,
|
|
BOUND_GENERIC_SUBSTITUTION,
|
|
POLYMORPHIC_FUNCTION_TYPE,
|
|
ARRAY_SLICE_TYPE,
|
|
ARRAY_TYPE,
|
|
REFERENCE_STORAGE_TYPE,
|
|
UNBOUND_GENERIC_TYPE,
|
|
|
|
TYPE_ALIAS_DECL = 100,
|
|
STRUCT_DECL,
|
|
CONSTRUCTOR_DECL,
|
|
VAR_DECL,
|
|
FUNC_DECL,
|
|
PATTERN_BINDING_DECL,
|
|
PROTOCOL_DECL,
|
|
PREFIX_OPERATOR_DECL,
|
|
POSTFIX_OPERATOR_DECL,
|
|
INFIX_OPERATOR_DECL,
|
|
CLASS_DECL,
|
|
UNION_DECL,
|
|
UNION_ELEMENT_DECL,
|
|
SUBSCRIPT_DECL,
|
|
EXTENSION_DECL,
|
|
DESTRUCTOR_DECL,
|
|
|
|
PAREN_PATTERN = 200,
|
|
TUPLE_PATTERN,
|
|
TUPLE_PATTERN_ELT,
|
|
NAMED_PATTERN,
|
|
ANY_PATTERN,
|
|
TYPED_PATTERN,
|
|
ISA_PATTERN,
|
|
NOMINAL_TYPE_PATTERN,
|
|
VAR_PATTERN,
|
|
|
|
GENERIC_PARAM_LIST = 240,
|
|
GENERIC_PARAM,
|
|
GENERIC_REQUIREMENT,
|
|
|
|
NO_CONFORMANCE = 250,
|
|
NORMAL_PROTOCOL_CONFORMANCE = 251,
|
|
SPECIALIZED_PROTOCOL_CONFORMANCE = 252,
|
|
INHERITED_PROTOCOL_CONFORMANCE = 253,
|
|
DECL_CONTEXT = 254,
|
|
XREF = 255
|
|
};
|
|
|
|
using NameAliasTypeLayout = BCRecordLayout<
|
|
NAME_ALIAS_TYPE,
|
|
DeclIDField // typealias decl
|
|
>;
|
|
|
|
using NominalTypeLayout = BCRecordLayout<
|
|
NOMINAL_TYPE,
|
|
DeclIDField, // decl
|
|
TypeIDField // parent
|
|
>;
|
|
|
|
using ParenTypeLayout = BCRecordLayout<
|
|
PAREN_TYPE,
|
|
TypeIDField // inner type
|
|
>;
|
|
|
|
using TupleTypeLayout = BCRecordLayout<
|
|
TUPLE_TYPE
|
|
>;
|
|
|
|
using TupleTypeEltLayout = BCRecordLayout<
|
|
TUPLE_TYPE_ELT,
|
|
IdentifierIDField, // name
|
|
TypeIDField, // type
|
|
DefaultArgumentField, // default argument
|
|
BCFixed<1> // vararg?
|
|
>;
|
|
|
|
using FunctionTypeLayout = BCRecordLayout<
|
|
FUNCTION_TYPE,
|
|
TypeIDField, // input
|
|
TypeIDField, // output
|
|
AbstractCCField, // calling convention
|
|
BCFixed<1>, // auto-closure?
|
|
BCFixed<1>, // thin?
|
|
BCFixed<1>, // noreturn?
|
|
BCFixed<1> // block-compatible?
|
|
>;
|
|
|
|
using MetaTypeTypeLayout = BCRecordLayout<
|
|
METATYPE_TYPE,
|
|
TypeIDField // instance type
|
|
>;
|
|
|
|
using LValueTypeLayout = BCRecordLayout<
|
|
LVALUE_TYPE,
|
|
TypeIDField, // object type
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1> // non-settable?
|
|
>;
|
|
|
|
using ArchetypeTypeLayout = BCRecordLayout<
|
|
ARCHETYPE_TYPE,
|
|
IdentifierIDField, // name
|
|
BCFixed<1>, // primary?
|
|
TypeIDField, // index if primary, parent if non-primary
|
|
TypeIDField, // superclass
|
|
BCArray<DeclIDField> // conformances
|
|
// Trailed by the nested types record.
|
|
>;
|
|
|
|
using ArchetypeNestedTypeNamesLayout = BCRecordLayout<
|
|
ARCHETYPE_NESTED_TYPE_NAMES,
|
|
BCArray<IdentifierIDField>
|
|
>;
|
|
|
|
using ArchetypeNestedTypesLayout = BCRecordLayout<
|
|
ARCHETYPE_NESTED_TYPES,
|
|
BCArray<TypeIDField>
|
|
>;
|
|
|
|
using ProtocolCompositionTypeLayout = BCRecordLayout<
|
|
PROTOCOL_COMPOSITION_TYPE,
|
|
BCArray<TypeIDField> // protocols
|
|
>;
|
|
|
|
using SubstitutedTypeLayout = BCRecordLayout<
|
|
SUBSTITUTED_TYPE,
|
|
TypeIDField, // original
|
|
TypeIDField // substitution
|
|
>;
|
|
|
|
using BoundGenericTypeLayout = BCRecordLayout<
|
|
BOUND_GENERIC_TYPE,
|
|
DeclIDField, // generic decl
|
|
TypeIDField, // parent
|
|
BCVBR<6>, // # of substitutions
|
|
BCArray<TypeIDField> // generic arguments
|
|
// The substitutions trail this record.
|
|
>;
|
|
|
|
using BoundGenericSubstitutionLayout = BCRecordLayout<
|
|
BOUND_GENERIC_SUBSTITUTION,
|
|
TypeIDField, // archetype
|
|
TypeIDField, // replacement
|
|
BCVBR<6> // # of conformances
|
|
// Trailed by the protocol conformance info (if any)
|
|
>;
|
|
|
|
using PolymorphicFunctionTypeLayout = BCRecordLayout<
|
|
POLYMORPHIC_FUNCTION_TYPE,
|
|
TypeIDField, // input
|
|
TypeIDField, // output
|
|
DeclIDField, // decl that owns the generic params
|
|
AbstractCCField, // calling convention
|
|
BCFixed<1>, // thin?
|
|
BCFixed<1> // noreturn?
|
|
>;
|
|
|
|
using ArraySliceTypeLayout = BCRecordLayout<
|
|
ARRAY_SLICE_TYPE,
|
|
TypeIDField, // element type
|
|
TypeIDField // implementation type
|
|
>;
|
|
|
|
using ArrayTypeLayout = BCRecordLayout<
|
|
ARRAY_TYPE,
|
|
TypeIDField, // element type
|
|
BCVBR<8> // size
|
|
>;
|
|
|
|
using ReferenceStorageTypeLayout = BCRecordLayout<
|
|
REFERENCE_STORAGE_TYPE,
|
|
OwnershipField, // ownership
|
|
TypeIDField // implementation type
|
|
>;
|
|
|
|
using UnboundGenericTypeLayout = BCRecordLayout<
|
|
UNBOUND_GENERIC_TYPE,
|
|
DeclIDField, // generic decl
|
|
TypeIDField // parent
|
|
>;
|
|
|
|
|
|
using TypeAliasLayout = BCRecordLayout<
|
|
TYPE_ALIAS_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
TypeIDField, // underlying type
|
|
BCFixed<1>, // generic flag
|
|
BCFixed<1>, // implicit flag
|
|
TypeIDField // superclass type
|
|
// Trailed by the conformance info (if any).
|
|
>;
|
|
|
|
template <unsigned Code>
|
|
using NominalLayout = BCRecordLayout<
|
|
Code,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
BCFixed<1> // implicit flag
|
|
// Trailed by the generic parameters (if any), conformance info (if any),
|
|
// and finally the decl context record.
|
|
>;
|
|
|
|
using StructLayout = NominalLayout<STRUCT_DECL>;
|
|
using UnionLayout = NominalLayout<UNION_DECL>;
|
|
|
|
using ClassLayout = BCRecordLayout<
|
|
CLASS_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // explicitly objc?
|
|
TypeIDField // superclass
|
|
// Trailed by the generic parameters (if any), conformance info (if any),
|
|
// and finally the decl context record.
|
|
>;
|
|
|
|
using ProtocolLayout = BCRecordLayout<
|
|
PROTOCOL_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit flag
|
|
BCFixed<1>, // class protocol?
|
|
BCFixed<1>, // objc?
|
|
BCArray<DeclIDField> // protocols
|
|
>;
|
|
|
|
using ConstructorLayout = BCRecordLayout<
|
|
CONSTRUCTOR_DECL,
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // objc?
|
|
TypeIDField, // type (signature)
|
|
DeclIDField // implicit this decl
|
|
// Trailed by its generic parameters, if any, followed by the parameter
|
|
// pattern.
|
|
>;
|
|
|
|
using VarLayout = BCRecordLayout<
|
|
VAR_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // explicitly objc?
|
|
BCFixed<1>, // iboutlet?
|
|
TypeIDField, // type
|
|
DeclIDField, // getter
|
|
DeclIDField, // setter
|
|
DeclIDField // overridden decl
|
|
>;
|
|
|
|
using FuncLayout = BCRecordLayout<
|
|
FUNC_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // class method?
|
|
BCFixed<1>, // assignment? / conversion?
|
|
BCFixed<1>, // explicitly objc?
|
|
BCFixed<1>, // iboutlet?
|
|
TypeIDField, // type (signature)
|
|
DeclIDField, // operator decl
|
|
DeclIDField, // overridden function
|
|
BCBlob // asmname, if any
|
|
// The record is trailed by its generic parameters, if any, followed by its
|
|
// argument and body parameter patterns.
|
|
>;
|
|
|
|
using PatternBindingLayout = BCRecordLayout<
|
|
PATTERN_BINDING_DECL,
|
|
DeclIDField, // context decl
|
|
BCFixed<1> // implicit flag
|
|
// The pattern trails the record.
|
|
>;
|
|
|
|
template <unsigned Code>
|
|
using UnaryOperatorLayout = BCRecordLayout<
|
|
Code, // ID field
|
|
IdentifierIDField, // name
|
|
DeclIDField // context decl
|
|
>;
|
|
|
|
using PrefixOperatorLayout = UnaryOperatorLayout<PREFIX_OPERATOR_DECL>;
|
|
using PostfixOperatorLayout = UnaryOperatorLayout<POSTFIX_OPERATOR_DECL>;
|
|
|
|
using InfixOperatorLayout = BCRecordLayout<
|
|
INFIX_OPERATOR_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
AssociativityField,
|
|
BCFixed<8> // precedence
|
|
>;
|
|
|
|
using UnionElementLayout = BCRecordLayout<
|
|
UNION_ELEMENT_DECL,
|
|
IdentifierIDField, // name
|
|
DeclIDField, // context decl
|
|
TypeIDField, // argument type
|
|
TypeIDField, // result type
|
|
TypeIDField, // constructor type
|
|
BCFixed<1> // implicit?
|
|
>;
|
|
|
|
using SubscriptLayout = BCRecordLayout<
|
|
SUBSCRIPT_DECL,
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // objc?
|
|
TypeIDField, // subscript dummy type
|
|
TypeIDField, // element type
|
|
DeclIDField, // getter
|
|
DeclIDField, // setter
|
|
DeclIDField // overridden decl
|
|
// The indices pattern trails the record.
|
|
>;
|
|
|
|
using ExtensionLayout = BCRecordLayout<
|
|
EXTENSION_DECL,
|
|
TypeIDField, // base type
|
|
DeclIDField, // context decl
|
|
BCFixed<1> // implicit flag
|
|
// Trailed by conformance info (if any), then the decl context record.
|
|
>;
|
|
|
|
using DestructorLayout = BCRecordLayout<
|
|
DESTRUCTOR_DECL,
|
|
DeclIDField, // context decl
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1>, // objc?
|
|
TypeIDField, // type (signature)
|
|
DeclIDField // implicit this decl
|
|
>;
|
|
|
|
|
|
using ParenPatternLayout = BCRecordLayout<
|
|
PAREN_PATTERN,
|
|
BCFixed<1> // implicit?
|
|
// The sub-pattern trails the record.
|
|
>;
|
|
|
|
using TuplePatternLayout = BCRecordLayout<
|
|
TUPLE_PATTERN,
|
|
TypeIDField, // type
|
|
BCVBR<5>, // arity
|
|
BCFixed<1>, // implicit?
|
|
BCFixed<1> // has vararg?
|
|
// The elements trail the record.
|
|
>;
|
|
|
|
using TuplePatternEltLayout = BCRecordLayout<
|
|
TUPLE_PATTERN_ELT,
|
|
DefaultArgumentField // default argument
|
|
// The element pattern trails the record.
|
|
>;
|
|
|
|
using NamedPatternLayout = BCRecordLayout<
|
|
NAMED_PATTERN,
|
|
DeclIDField, // associated VarDecl
|
|
BCFixed<1> // implicit?
|
|
>;
|
|
|
|
using AnyPatternLayout = BCRecordLayout<
|
|
ANY_PATTERN,
|
|
TypeIDField, // type
|
|
BCFixed<1> // implicit?
|
|
// FIXME: is the type necessary?
|
|
>;
|
|
|
|
using TypedPatternLayout = BCRecordLayout<
|
|
TYPED_PATTERN,
|
|
TypeIDField, // associated type
|
|
BCFixed<1> // implicit?
|
|
// The sub-pattern trails the record.
|
|
>;
|
|
|
|
using IsaPatternLayout = BCRecordLayout<
|
|
ISA_PATTERN,
|
|
TypeIDField, // type
|
|
BCFixed<1> // implicit?
|
|
>;
|
|
|
|
using NominalTypePatternLayout = BCRecordLayout<
|
|
NOMINAL_TYPE_PATTERN,
|
|
TypeIDField,
|
|
BCFixed<1> // implicit?
|
|
// The sub-pattern trails the record.
|
|
>;
|
|
|
|
using VarPatternLayout = BCRecordLayout<
|
|
VAR_PATTERN,
|
|
BCFixed<1> // implicit?
|
|
// The sub-pattern trails the record.
|
|
>;
|
|
|
|
|
|
using GenericParamListLayout = BCRecordLayout<
|
|
GENERIC_PARAM_LIST,
|
|
BCArray<TypeIDField> // Archetypes
|
|
// The actual parameters and requirements trail the record.
|
|
>;
|
|
|
|
using GenericParamLayout = BCRecordLayout<
|
|
GENERIC_PARAM,
|
|
DeclIDField // Typealias
|
|
>;
|
|
|
|
using GenericRequirementLayout = BCRecordLayout<
|
|
GENERIC_REQUIREMENT,
|
|
GenericRequirementKindField, // requirement kind
|
|
BCArray<TypeIDField> // types involved (currently always two)
|
|
>;
|
|
|
|
/// A placeholder for lack of conformance information. Conformances are
|
|
/// indexed, so simply omitting one would be incorrect.
|
|
using NoConformanceLayout = BCRecordLayout<
|
|
NO_CONFORMANCE,
|
|
DeclIDField // the protocol
|
|
>;
|
|
|
|
using NormalProtocolConformanceLayout = BCRecordLayout<
|
|
NORMAL_PROTOCOL_CONFORMANCE,
|
|
DeclIDField, // the protocol
|
|
BCVBR<5>, // value mapping count
|
|
BCVBR<5>, // type mapping count
|
|
BCVBR<5>, // inherited conformances count
|
|
BCVBR<5>, // defaulted definitions count
|
|
BCArray<DeclIDField>
|
|
// The array contains value-value-substitutionCount triplets,
|
|
// then type declarations, then defaulted definitions.
|
|
// The inherited conformances trail the record, followed by substitution
|
|
// records for the values and then types.
|
|
>;
|
|
|
|
using SpecializedProtocolConformanceLayout = BCRecordLayout<
|
|
SPECIALIZED_PROTOCOL_CONFORMANCE,
|
|
DeclIDField, // the protocol
|
|
DeclIDField, // the nominal type decl for the normal conformance,
|
|
// or zero to indicate that the generic conformance
|
|
// is in the following record
|
|
IdentifierIDField, // the module in which the normal conformance occurs,
|
|
// or the conforming type for the generic conformance
|
|
// record that follows
|
|
BCVBR<5>, // type mapping count
|
|
BCVBR<5>, // # of substitutions for the conformance
|
|
BCArray<DeclIDField> // the type witnesses
|
|
// followed by substitution records for the conformance, then the
|
|
// substitution records for the type witnesses
|
|
>;
|
|
|
|
using InheritedProtocolConformanceLayout = BCRecordLayout<
|
|
INHERITED_PROTOCOL_CONFORMANCE,
|
|
DeclIDField // the protocol
|
|
>;
|
|
|
|
using DeclContextLayout = BCRecordLayout<
|
|
DECL_CONTEXT,
|
|
BCArray<DeclIDField>
|
|
>;
|
|
|
|
using XRefLayout = BCRecordLayout<
|
|
XREF,
|
|
XRefKindField, // reference kind
|
|
TypeIDField, // type if value, operator kind if operator,
|
|
// index if generic parameter
|
|
BCFixed<1>, // within extension?
|
|
BCArray<IdentifierIDField> // extension module name (if extension value)
|
|
// base module name
|
|
// access path
|
|
>;
|
|
}
|
|
|
|
/// The record types within the identifier block.
|
|
///
|
|
/// \sa IDENTIFIER_BLOCK_ID
|
|
namespace identifier_block {
|
|
enum {
|
|
IDENTIFIER_DATA = 1
|
|
};
|
|
|
|
using IdentifierDataLayout = BCRecordLayout<IDENTIFIER_DATA, BCBlob>;
|
|
};
|
|
|
|
/// The record types within the index block.
|
|
///
|
|
/// \sa INDEX_BLOCK_ID
|
|
namespace index_block {
|
|
// These IDs must \em not be renumbered or reordered without incrementing
|
|
// VERSION_MAJOR.
|
|
enum {
|
|
TYPE_OFFSETS = 1,
|
|
DECL_OFFSETS,
|
|
IDENTIFIER_OFFSETS,
|
|
TOP_LEVEL_DECLS,
|
|
OPERATORS
|
|
};
|
|
|
|
using OffsetsLayout = BCGenericRecordLayout<
|
|
BCFixed<3>, // record ID
|
|
BCArray<BitOffsetField>
|
|
>;
|
|
|
|
using DeclListLayout = BCGenericRecordLayout<
|
|
BCFixed<3>, // record ID
|
|
BCArray<DeclIDField>
|
|
>;
|
|
}
|
|
|
|
} // end namespace serialization
|
|
} // end namespace swift
|
|
|
|
#endif
|