mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
Introduce two modes of bridging: * inline mode: this is basically how it worked so far. Using full C++ interop which allows bridging functions to be inlined. * pure mode: bridging functions are not inlined but compiled in a cpp file. This allows to reduce the C++ interop requirements to a minimum. No std/llvm/swift headers are imported. This change requires a major refactoring of bridging sources. The implementation of bridging functions go to two separate files: SILBridgingImpl.h and OptimizerBridgingImpl.h. Depending on the mode, those files are either included in the corresponding header files (inline mode), or included in the c++ file (pure mode). The mode can be selected with the BRIDGING_MODE cmake variable. By default it is set to the inline mode (= existing behavior). The pure mode is only selected in certain configurations to work around C++ interop issues: * In debug builds, to workaround a problem with LLDB's `po` command (rdar://115770255). * On windows to workaround a build problem.
59 lines
2.1 KiB
C++
59 lines
2.1 KiB
C++
//===--- ParseRegex.cpp - Regular expression literal parsing --------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2021 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Regular expression literal parsing
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "swift/AST/BridgingUtils.h"
|
|
#include "swift/AST/DiagnosticsParse.h"
|
|
#include "swift/Basic/BridgingUtils.h"
|
|
#include "swift/Parse/Parser.h"
|
|
|
|
// Regex parser delivered via Swift modules.
|
|
#include "swift/Parse/RegexParserBridging.h"
|
|
static RegexLiteralParsingFn regexLiteralParsingFn = nullptr;
|
|
void Parser_registerRegexLiteralParsingFn(RegexLiteralParsingFn fn) {
|
|
regexLiteralParsingFn = fn;
|
|
}
|
|
|
|
using namespace swift;
|
|
|
|
ParserResult<Expr> Parser::parseExprRegexLiteral() {
|
|
assert(Tok.is(tok::regex_literal));
|
|
assert(regexLiteralParsingFn);
|
|
|
|
auto regexText = Tok.getText();
|
|
|
|
// Let the Swift library parse the contents, returning an error, or null if
|
|
// successful.
|
|
unsigned version = 0;
|
|
auto capturesBuf = Context.AllocateUninitialized<uint8_t>(
|
|
RegexLiteralExpr::getCaptureStructureSerializationAllocationSize(
|
|
regexText.size()));
|
|
bool hadError =
|
|
regexLiteralParsingFn(regexText.str().c_str(), &version,
|
|
/*captureStructureOut*/ capturesBuf.data(),
|
|
/*captureStructureSize*/ capturesBuf.size(),
|
|
/*diagBaseLoc*/ {(const uint8_t *)(Tok.getLoc().getOpaquePointerValue())},
|
|
getBridgedDiagnosticEngine(&Diags));
|
|
auto loc = consumeToken();
|
|
SourceMgr.recordRegexLiteralStartLoc(loc);
|
|
|
|
if (hadError) {
|
|
return makeParserResult(new (Context) ErrorExpr(loc));
|
|
}
|
|
assert(version >= 1);
|
|
return makeParserResult(RegexLiteralExpr::createParsed(
|
|
Context, loc, regexText, version, capturesBuf));
|
|
}
|