blob: 367ce43130aeafad65b4172ffc74fa0190ba40d3 [file] [log] [blame]
//===--- RCStateTransition.def ----------------------------------*- C++ -*-===//
//
// 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
//
//===----------------------------------------------------------------------===//
//
// Declarations for metaprogramming with RCStateTransitionKind.
//
//===----------------------------------------------------------------------===//
/// KIND(X)
/// This represents a specific kind of RCStateTransitionKind equivalence class
/// that attempts to describe the effect of an operation on a ref count. Some
/// ways that this can happen are:
///
/// 1. The introduction of a new strong ref count. (StrongEntrance)
/// 2. The incrementing of a strong ref count. (StrongIncrement)
/// 3. The decrementing of a strong ref count. (StrongDecrement)
#ifndef KIND
#define KIND(K)
#endif
/// ABSTRACT_VALUE(Name, Start, End)
///
/// This enables one to form a grouping of Kinds that represent an abstract
/// operation. Some examples of this include:
///
/// 1. End Points
/// 2. Mutators.
///
/// It is specified by the range of instructions in between Start and End.
#ifndef ABSTRACT_VALUE
#define ABSTRACT_VALUE(Name, Start, End)
#endif
///-------
/// Misc |
///-------
///
/// An invalid transition kind. This must always be first so that it is zero.
KIND(Invalid)
/// An unknown kind.
KIND(Unknown)
/// An autorelease pool call.
KIND(AutoreleasePoolCall)
///-------------
/// End Points |
///-------------
/// The introduction of a strong reference count. This can go on SILArguments
/// and non-terminator instructions.
KIND(StrongEntrance)
/// Introduces a ref count identity or consumes a ref count identity.
ABSTRACT_VALUE(EndPoint, StrongEntrance, StrongEntrance)
///-----------
/// Mutators |
///-----------
/// The increment of a strong reference count. This can only represent
/// non-terminator instructions.
KIND(StrongIncrement)
/// The decrement of a strong reference count. This can only represent
/// non-terminator instructions.
KIND(StrongDecrement)
ABSTRACT_VALUE(Mutator, StrongIncrement, StrongDecrement)
#undef ABSTRACT_VALUE
#undef KIND