aboutsummaryrefslogtreecommitdiff
path: root/lldb/source/Commands/CommandObjectFrame.cpp
diff options
context:
space:
mode:
authorRaphael Isemann <teemperor@gmail.com>2019-09-30 09:00:23 +0000
committerRaphael Isemann <teemperor@gmail.com>2019-09-30 09:00:23 +0000
commit5a039d55710f72a474572f08f390e17d8cd37e57 (patch)
treee8472d4241c83269cf99aab0885214e53b58c7ff /lldb/source/Commands/CommandObjectFrame.cpp
parente7714fe7bff811785eeac2b7627ca4293565aa65 (diff)
downloadllvm-5a039d55710f72a474572f08f390e17d8cd37e57.zip
llvm-5a039d55710f72a474572f08f390e17d8cd37e57.tar.gz
llvm-5a039d55710f72a474572f08f390e17d8cd37e57.tar.bz2
[lldb] Partly revert 370734: Test 'frame select -r' and fix that INT32_MIN breaks the option parser
This somehow caused that 'frame select X' ends up being interpreted as 'frame select -r 1' when 'up' or 'down' were run before 'frame select X'. See rdar://55791276. Partly reverting to unbreak master. The changes that aren't reverted are the generic 'frame select -r' tests that are obviously NFC and test existing behavior. llvm-svn: 373194
Diffstat (limited to 'lldb/source/Commands/CommandObjectFrame.cpp')
-rw-r--r--lldb/source/Commands/CommandObjectFrame.cpp32
1 files changed, 16 insertions, 16 deletions
diff --git a/lldb/source/Commands/CommandObjectFrame.cpp b/lldb/source/Commands/CommandObjectFrame.cpp
index 89efdab..0a10231 100644
--- a/lldb/source/Commands/CommandObjectFrame.cpp
+++ b/lldb/source/Commands/CommandObjectFrame.cpp
@@ -246,15 +246,13 @@ public:
Status error;
const int short_option = m_getopt_table[option_idx].val;
switch (short_option) {
- case 'r': {
- int32_t offset = 0;
- if (option_arg.getAsInteger(0, offset) || offset == INT32_MIN) {
+ case 'r':
+ if (option_arg.getAsInteger(0, relative_frame_offset)) {
+ relative_frame_offset = INT32_MIN;
error.SetErrorStringWithFormat("invalid frame offset argument '%s'",
option_arg.str().c_str());
- } else
- relative_frame_offset = offset;
+ }
break;
- }
default:
llvm_unreachable("Unimplemented option");
@@ -263,13 +261,15 @@ public:
return error;
}
- void OptionParsingStarting(ExecutionContext *execution_context) override {}
-
+ void OptionParsingStarting(ExecutionContext *execution_context) override {
+ relative_frame_offset = INT32_MIN;
+ }
+
llvm::ArrayRef<OptionDefinition> GetDefinitions() override {
return llvm::makeArrayRef(g_frame_select_options);
}
- llvm::Optional<int32_t> relative_frame_offset;
+ int32_t relative_frame_offset;
};
CommandObjectFrameSelect(CommandInterpreter &interpreter)
@@ -307,15 +307,15 @@ protected:
Thread *thread = m_exe_ctx.GetThreadPtr();
uint32_t frame_idx = UINT32_MAX;
- if (m_options.relative_frame_offset.hasValue()) {
+ if (m_options.relative_frame_offset != INT32_MIN) {
// The one and only argument is a signed relative frame index
frame_idx = thread->GetSelectedFrameIndex();
if (frame_idx == UINT32_MAX)
frame_idx = 0;
- if (*m_options.relative_frame_offset < 0) {
- if (static_cast<int32_t>(frame_idx) >= -*m_options.relative_frame_offset)
- frame_idx += *m_options.relative_frame_offset;
+ if (m_options.relative_frame_offset < 0) {
+ if (static_cast<int32_t>(frame_idx) >= -m_options.relative_frame_offset)
+ frame_idx += m_options.relative_frame_offset;
else {
if (frame_idx == 0) {
// If you are already at the bottom of the stack, then just warn
@@ -326,15 +326,15 @@ protected:
} else
frame_idx = 0;
}
- } else if (*m_options.relative_frame_offset > 0) {
+ } else if (m_options.relative_frame_offset > 0) {
// I don't want "up 20" where "20" takes you past the top of the stack
// to produce
// an error, but rather to just go to the top. So I have to count the
// stack here...
const uint32_t num_frames = thread->GetStackFrameCount();
if (static_cast<int32_t>(num_frames - frame_idx) >
- *m_options.relative_frame_offset)
- frame_idx += *m_options.relative_frame_offset;
+ m_options.relative_frame_offset)
+ frame_idx += m_options.relative_frame_offset;
else {
if (frame_idx == num_frames - 1) {
// If we are already at the top of the stack, just warn and don't