1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
//===--- 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"
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);
}
}
|