Files
swift-mirror/include/swift/AST/LookupKinds.h
Becca Royal-Gordon ffaa35810c Handle lookup into Builtin with module selector
Lookups like Builtin::Int64 were failing because BuiltinUnit rejected all unqualified lookups. Make it allow unqualified lookups with a module selector.
2025-10-24 16:23:48 -07:00

115 lines
3.7 KiB
C++

//===--- LookupKinds.h - Swift name-lookup enums ----------------*- 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 enums relating to name lookup.
//
//===----------------------------------------------------------------------===//
#ifndef SWIFT_LOOKUPKINDS_H
#define SWIFT_LOOKUPKINDS_H
namespace swift {
/// NLKind - This is a specifier for the kind of name lookup being performed
/// by various query methods.
enum class NLKind {
UnqualifiedLookup,
QualifiedLookup
};
void simple_display(llvm::raw_ostream &out, NLKind kind);
/// Constants used to customize name lookup.
enum NLOptions : unsigned {
/// Consider declarations within protocols to which the context type conforms.
NL_ProtocolMembers = 1 << 0,
/// Remove non-visible declarations from the set of results.
NL_RemoveNonVisible = 1 << 1,
/// Remove overridden declarations from the set of results.
NL_RemoveOverridden = 1 << 2,
/// Don't check access when doing lookup into a type.
///
/// When performing lookup into a module, this option only applies to
/// declarations in the same module the lookup is coming from.
NL_IgnoreAccessControl = 1 << 3,
/// This lookup should only return type declarations.
NL_OnlyTypes = 1 << 4,
/// Include synonyms declared with @_implements()
NL_IncludeAttributeImplements = 1 << 5,
// Include @usableFromInline and @inlinable
NL_IncludeUsableFromInline = 1 << 6,
/// Exclude names introduced by macro expansions in the top-level module.
NL_ExcludeMacroExpansions = 1 << 7,
/// This lookup should only return macro declarations.
NL_OnlyMacros = 1 << 8,
/// Include members that would otherwise be filtered out because they come
/// from a module that has not been imported.
NL_IgnoreMissingImports = 1 << 9,
/// If @abi attributes are present, return the decls representing the ABI,
/// not the API.
NL_ABIProviding = 1 << 10,
/// The default set of options used for qualified name lookup.
///
/// FIXME: Eventually, add NL_ProtocolMembers to this, once all of the
/// callers can handle it.
NL_QualifiedDefault = NL_RemoveNonVisible | NL_RemoveOverridden,
/// The default set of options used for unqualified name lookup.
NL_UnqualifiedDefault = NL_RemoveNonVisible | NL_RemoveOverridden
};
static inline NLOptions operator|(NLOptions lhs, NLOptions rhs) {
return NLOptions(unsigned(lhs) | unsigned(rhs));
}
static inline NLOptions &operator|=(NLOptions &lhs, NLOptions rhs) {
return (lhs = lhs | rhs);
}
static inline NLOptions operator&(NLOptions lhs, NLOptions rhs) {
return NLOptions(unsigned(lhs) & unsigned(rhs));
}
static inline NLOptions &operator&=(NLOptions &lhs, NLOptions rhs) {
return (lhs = lhs & rhs);
}
static inline NLOptions operator~(NLOptions value) {
return NLOptions(~(unsigned)value);
}
void simple_display(llvm::raw_ostream &out, NLOptions options);
/// Flags affecting module-level lookup.
enum class ModuleLookupFlags : unsigned {
/// Exclude names introduced by macro expansions in the top-level module.
ExcludeMacroExpansions = 1 << 0,
/// If @abi attributes are present, return the decls representing the ABI,
/// not the API.
ABIProviding = 1 << 1,
/// The lookup is qualified by a module selector which has specified this
/// module explicitly.
HasModuleSelector = 1 << 2,
};
} // end namespace swift
#endif