blob: 71a61f5f51311497a3ef92bef3228081330aa49e [file] [log] [blame]
//===--- 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
};
/// Constants used to customize name lookup.
enum NLOptions : unsigned {
/// Consider declarations within protocols to which the context type conforms.
NL_ProtocolMembers = 0x02,
/// Remove non-visible declarations from the set of results.
NL_RemoveNonVisible = 0x04,
/// Remove overridden declarations from the set of results.
NL_RemoveOverridden = 0x08,
/// Don't check access when doing lookup into a type.
///
/// This option is not valid when performing lookup into a module.
NL_IgnoreAccessControl = 0x10,
/// This lookup is known to be a non-cascading dependency, i.e. one that does
/// not affect downstream files.
///
/// \see NL_KnownDependencyMask
NL_KnownNonCascadingDependency = 0x20,
/// This lookup is known to be a cascading dependency, i.e. one that can
/// affect downstream files.
///
/// \see NL_KnownDependencyMask
NL_KnownCascadingDependency = 0x40,
/// This lookup should only return type declarations.
NL_OnlyTypes = 0x80,
/// Include synonyms declared with @_implements()
NL_IncludeAttributeImplements = 0x100,
/// This lookup is known to not add any additional dependencies to the
/// primary source file.
///
/// \see NL_KnownDependencyMask
NL_KnownNoDependency =
NL_KnownNonCascadingDependency|NL_KnownCascadingDependency,
/// A mask of all options controlling how a lookup should be recorded as a
/// dependency.
///
/// This offers three possible options: NL_KnownNonCascadingDependency,
/// NL_KnownCascadingDependency, NL_KnownNoDependency, as well as a default
/// "unspecified" value (0). If the dependency kind is unspecified, the
/// lookup function will attempt to infer whether it is a cascading or
/// non-cascading dependency from the decl context.
NL_KnownDependencyMask = NL_KnownNoDependency,
/// 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);
}
} // end namespace swift
#endif