1 //===- FileLineColLocBreakpointManager.cpp - MLIR Optimizer Driver --------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #include "mlir/Debug/BreakpointManagers/FileLineColLocBreakpointManager.h"
10 #include "mlir/IR/Diagnostics.h"
11 #include "llvm/Support/raw_ostream.h"
14 using namespace mlir::tracing
;
16 FailureOr
<std::tuple
<StringRef
, int64_t, int64_t>>
17 FileLineColLocBreakpoint::parseFromString(StringRef str
,
18 function_ref
<void(Twine
)> diag
) {
19 // Watch at debug locations arguments are expected to be in the form:
20 // `fileName:line:col`, `fileName:line`, or `fileName`.
24 diag("error: initializing FileLineColLocBreakpoint with empty file name");
28 // This logic is complex because on Windows `:` is a comment valid path
29 // character: `C:\...`.
30 auto [fileLine
, colStr
] = str
.rsplit(':');
31 auto [file
, lineStr
] = fileLine
.rsplit(':');
32 // Extract the line and column value
33 int64_t line
= -1, col
= -1;
34 if (lineStr
.empty()) {
35 // No candidate for line number, try to use the column string as line
38 if (!colStr
.empty() && colStr
.getAsInteger(0, line
))
41 if (lineStr
.getAsInteger(0, line
)) {
42 // Failed to parse a line number, try to use the column string as line
43 // instead. If this failed as well, the entire string is the file name.
45 if (colStr
.getAsInteger(0, line
))
48 // We successfully parsed a line number, try to parse the column number.
49 // This shouldn't fail, or the entire string is the file name.
50 if (colStr
.getAsInteger(0, col
)) {
56 return std::tuple
<StringRef
, int64_t, int64_t>{file
, line
, col
};