blob: ddd1b9662ca3726bce00b23de9e50cb6ab27338f [file] [log] [blame]
Greg Clayton67cc0632012-08-22 17:17:09 +00001//===-- OptionValueSInt64.cpp -----------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "lldb/Interpreter/OptionValueSInt64.h"
11
12// C Includes
13// C++ Includes
14// Other libraries and framework includes
15// Project includes
Vince Harron5275aaa2015-01-15 20:08:35 +000016#include "lldb/Host/StringConvert.h"
Zachary Turnerbf9a7732017-02-02 21:39:50 +000017#include "lldb/Utility/Stream.h"
Greg Clayton67cc0632012-08-22 17:17:09 +000018
19using namespace lldb;
20using namespace lldb_private;
21
Kate Stoneb9c1b512016-09-06 20:57:50 +000022void OptionValueSInt64::DumpValue(const ExecutionContext *exe_ctx, Stream &strm,
23 uint32_t dump_mask) {
Adrian Prantl05097242018-04-30 16:49:04 +000024 // printf ("%p: DumpValue (exe_ctx=%p, strm, mask) m_current_value = %"
25 // PRIi64
Kate Stoneb9c1b512016-09-06 20:57:50 +000026 // "\n", this, exe_ctx, m_current_value);
27 if (dump_mask & eDumpOptionType)
28 strm.Printf("(%s)", GetTypeAsCString());
29 // if (dump_mask & eDumpOptionName)
30 // DumpQualifiedName (strm);
31 if (dump_mask & eDumpOptionValue) {
Greg Clayton67cc0632012-08-22 17:17:09 +000032 if (dump_mask & eDumpOptionType)
Kate Stoneb9c1b512016-09-06 20:57:50 +000033 strm.PutCString(" = ");
34 strm.Printf("%" PRIi64, m_current_value);
35 }
Greg Clayton67cc0632012-08-22 17:17:09 +000036}
37
Zachary Turner97206d52017-05-12 04:51:55 +000038Status OptionValueSInt64::SetValueFromString(llvm::StringRef value_ref,
39 VarSetOperationType op) {
40 Status error;
Kate Stoneb9c1b512016-09-06 20:57:50 +000041 switch (op) {
42 case eVarSetOperationClear:
43 Clear();
44 NotifyValueChanged();
45 break;
46
47 case eVarSetOperationReplace:
48 case eVarSetOperationAssign: {
49 bool success = false;
50 std::string value_str = value_ref.trim().str();
51 int64_t value = StringConvert::ToSInt64(value_str.c_str(), 0, 0, &success);
52 if (success) {
53 if (value >= m_min_value && value <= m_max_value) {
54 m_value_was_set = true;
55 m_current_value = value;
56 NotifyValueChanged();
57 } else
58 error.SetErrorStringWithFormat(
59 "%" PRIi64 " is out of range, valid values must be between %" PRIi64
60 " and %" PRIi64 ".",
61 value, m_min_value, m_max_value);
62 } else {
63 error.SetErrorStringWithFormat("invalid int64_t string value: '%s'",
64 value_ref.str().c_str());
Greg Clayton67cc0632012-08-22 17:17:09 +000065 }
Kate Stoneb9c1b512016-09-06 20:57:50 +000066 } break;
67
68 case eVarSetOperationInsertBefore:
69 case eVarSetOperationInsertAfter:
70 case eVarSetOperationRemove:
71 case eVarSetOperationAppend:
72 case eVarSetOperationInvalid:
73 error = OptionValue::SetValueFromString(value_ref, op);
74 break;
75 }
76 return error;
Greg Clayton67cc0632012-08-22 17:17:09 +000077}
78
Kate Stoneb9c1b512016-09-06 20:57:50 +000079lldb::OptionValueSP OptionValueSInt64::DeepCopy() const {
80 return OptionValueSP(new OptionValueSInt64(*this));
Greg Clayton67cc0632012-08-22 17:17:09 +000081}