Files
swift-mirror/include/swift/AST/AttrKind.h
Becca Royal-Gordon 7703d115db Filter bad attrs out of module interface @abis
When printing an `@abi` attribute’s decl, we now filter out any attrs that are not valid in that position. Fixes a broken test.
2025-03-26 10:47:58 -07:00

170 lines
5.2 KiB
C++

//===--- AttrKind.h - Enumerate attribute kinds ----------------*- 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
//
//===----------------------------------------------------------------------===//
//
// This file defines enumerations related to declaration attributes.
//
//===----------------------------------------------------------------------===//
#ifndef SWIFT_ATTRKIND_H
#define SWIFT_ATTRKIND_H
#include "swift/Basic/InlineBitfield.h"
#include "swift/Basic/LLVM.h"
#include "swift/Config.h"
#include "llvm/Support/DataTypes.h"
namespace swift {
/// The associativity of a binary operator.
enum class Associativity : uint8_t {
/// Non-associative operators cannot be written next to other
/// operators with the same precedence. Relational operators are
/// typically non-associative.
None,
/// Left-associative operators associate to the left if written next
/// to other left-associative operators of the same precedence.
Left,
/// Right-associative operators associate to the right if written
/// next to other right-associative operators of the same precedence.
Right
};
/// Returns the in-source spelling of the given associativity.
StringRef getAssociativitySpelling(Associativity value);
/// The kind of unary operator, if any.
enum class UnaryOperatorKind : uint8_t {
None,
Prefix,
Postfix
};
/// Access control levels.
// These are used in diagnostics and with < and similar operations,
// so please do not reorder existing values.
enum class AccessLevel : uint8_t {
/// Private access is limited to the current scope.
Private = 0,
/// File-private access is limited to the current file.
FilePrivate,
/// Internal access is limited to the current module.
Internal,
/// Package access is not limited, but some capabilities may be
/// restricted outside of the current package containing modules.
/// It's similar to Public in that it's accessible from other modules
/// and subclassable only within the defining module as long as
/// the modules are in the same package.
Package,
/// Public access is not limited, but some capabilities may be
/// restricted outside of the current module.
Public,
/// Open access is not limited, and all capabilities are unrestricted.
Open,
};
/// Returns the in-source spelling of the given access level.
StringRef getAccessLevelSpelling(AccessLevel value);
enum class InlineKind : uint8_t {
Never = 0,
Always = 1,
Last_InlineKind = Always
};
enum : unsigned { NumInlineKindBits =
countBitsUsed(static_cast<unsigned>(InlineKind::Last_InlineKind)) };
/// This enum represents the possible values of the @_effects attribute.
/// These values are ordered from the strongest guarantee to the weakest,
/// so please do not reorder existing values.
enum class EffectsKind : uint8_t {
ReadNone,
ReadOnly,
ReleaseNone,
ReadWrite,
Unspecified,
Custom,
Last_EffectsKind = Unspecified
};
enum : unsigned { NumEffectsKindBits =
countBitsUsed(static_cast<unsigned>(EffectsKind::Last_EffectsKind)) };
/// This enum represents the possible values of the @_expose attribute.
enum class ExposureKind: uint8_t {
Cxx,
Wasm,
Last_ExposureKind = Wasm
};
enum : unsigned { NumExposureKindBits =
countBitsUsed(static_cast<unsigned>(ExposureKind::Last_ExposureKind)) };
/// This enum represents the possible values of the @_extern attribute.
enum class ExternKind: uint8_t {
/// Reference an externally defined C function.
/// The imported function has C function pointer representation,
/// and is called using the C calling convention.
C,
/// Reference an externally defined function through WebAssembly's
/// import mechanism.
/// This does not specify the calling convention and can be used
/// with other extern kinds together.
/// Effectively, this is no-op on non-WebAssembly targets.
Wasm,
Last_ExternKind = Wasm
};
enum : unsigned { NumExternKindBits =
countBitsUsed(static_cast<unsigned>(ExternKind::Last_ExternKind)) };
enum class ExecutionKind : uint8_t {
Concurrent = 0,
Caller,
Last_ExecutionKind = Caller
};
enum : unsigned { NumExecutionKindBits =
countBitsUsed(static_cast<unsigned>(ExecutionKind::Last_ExecutionKind)) };
enum class DeclAttrKind : unsigned {
#define DECL_ATTR(_, CLASS, ...) CLASS,
#define LAST_DECL_ATTR(CLASS) Last_DeclAttr = CLASS,
#include "swift/AST/DeclAttr.def"
};
StringRef getDeclAttrKindID(DeclAttrKind kind);
enum : unsigned {
NumDeclAttrKinds = static_cast<unsigned>(DeclAttrKind::Last_DeclAttr) + 1,
NumDeclAttrKindBits = countBitsUsed(NumDeclAttrKinds - 1),
};
// Define enumerators for each type attribute, e.g. TypeAttrKind::Weak.
enum class TypeAttrKind {
#define TYPE_ATTR(_, CLASS) CLASS,
#define LAST_TYPE_ATTR(CLASS) Last_TypeAttr = CLASS,
#include "swift/AST/TypeAttr.def"
};
enum : unsigned {
NumTypeAttrKinds = static_cast<unsigned>(TypeAttrKind::Last_TypeAttr) + 1,
NumTypeAttrKindBits = countBitsUsed(NumTypeAttrKinds - 1),
};
} // end namespace swift
#endif