Files
swift-mirror/lib/AST/FreestandingMacroExpansion.cpp
Tim Kientzle 1d961ba22d Add #include "swift/Basic/Assertions.h" to a lot of source files
Although I don't plan to bring over new assertions wholesale
into the current qualification branch, it's entirely possible
that various minor changes in main will use the new assertions;
having this basic support in the release branch will simplify that.
(This is why I'm adding the includes as a separate pass from
rewriting the individual assertions)
2024-06-05 19:37:30 -07:00

77 lines
2.7 KiB
C++

//===--- FreestandingMacroExpansion.cpp -----------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2023 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
//
//===----------------------------------------------------------------------===//
#include "swift/AST/FreestandingMacroExpansion.h"
#include "swift/AST/ASTContext.h"
#include "swift/AST/Decl.h"
#include "swift/AST/Expr.h"
#include "swift/AST/MacroDiscriminatorContext.h"
#include "swift/Basic/Assertions.h"
using namespace swift;
SourceRange MacroExpansionInfo::getSourceRange() const {
SourceLoc endLoc;
if (ArgList && !ArgList->isImplicit())
endLoc = ArgList->getEndLoc();
else if (RightAngleLoc.isValid())
endLoc = RightAngleLoc;
else
endLoc = MacroNameLoc.getEndLoc();
return SourceRange(SigilLoc, endLoc);
}
#define FORWARD_VARIANT(NAME) \
switch (getFreestandingMacroKind()) { \
case FreestandingMacroKind::Expr: \
return cast<MacroExpansionExpr>(this)->NAME(); \
case FreestandingMacroKind::Decl: \
return cast<MacroExpansionDecl>(this)->NAME(); \
}
DeclContext *FreestandingMacroExpansion::getDeclContext() const {
FORWARD_VARIANT(getDeclContext);
}
SourceRange FreestandingMacroExpansion::getSourceRange() const {
FORWARD_VARIANT(getSourceRange);
}
unsigned FreestandingMacroExpansion::getDiscriminator() const {
auto info = getExpansionInfo();
if (info->Discriminator != MacroExpansionInfo::InvalidDiscriminator)
return info->Discriminator;
auto mutableThis = const_cast<FreestandingMacroExpansion *>(this);
auto dc = getDeclContext();
ASTContext &ctx = dc->getASTContext();
auto discriminatorContext =
MacroDiscriminatorContext::getParentOf(mutableThis);
info->Discriminator = ctx.getNextMacroDiscriminator(
discriminatorContext, getMacroName().getBaseName());
assert(info->Discriminator != MacroExpansionInfo::InvalidDiscriminator);
return info->Discriminator;
}
unsigned FreestandingMacroExpansion::getRawDiscriminator() const {
return getExpansionInfo()->Discriminator;
}
ASTNode FreestandingMacroExpansion::getASTNode() {
switch (getFreestandingMacroKind()) {
case FreestandingMacroKind::Expr:
return cast<MacroExpansionExpr>(this);
case FreestandingMacroKind::Decl:
return cast<MacroExpansionDecl>(this);
}
}