
This is intended as a clean up after the big clang-format commit (r280751), which unfortunately resulted in many of the comment paragraphs in LLDB being very hard to read. FYI, the script I used was: import textwrap import commands import os import sys import re tmp = "%s.tmp"%sys.argv[1] out = open(tmp, "w+") with open(sys.argv[1], "r") as f: header = "" text = "" comment = re.compile(r'^( *//) ([^ ].*)$') special = re.compile(r'^((([A-Z]+[: ])|([0-9]+ )).*)|(.*;)$') for line in f: match = comment.match(line) if match and not special.match(match.group(2)): # skip intentionally short comments. if not text and len(match.group(2)) < 40: out.write(line) continue if text: text += " " + match.group(2) else: header = match.group(1) text = match.group(2) continue if text: filled = textwrap.wrap(text, width=(78-len(header)), break_long_words=False) for l in filled: out.write(header+" "+l+'\n') text = "" out.write(line) os.rename(tmp, sys.argv[1]) Differential Revision: https://reviews.llvm.org/D46144 llvm-svn: 331197
82 lines
2.5 KiB
C++
82 lines
2.5 KiB
C++
//===-- OptionValueSInt64.cpp -----------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Interpreter/OptionValueSInt64.h"
|
|
|
|
// C Includes
|
|
// C++ Includes
|
|
// Other libraries and framework includes
|
|
// Project includes
|
|
#include "lldb/Host/StringConvert.h"
|
|
#include "lldb/Utility/Stream.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
void OptionValueSInt64::DumpValue(const ExecutionContext *exe_ctx, Stream &strm,
|
|
uint32_t dump_mask) {
|
|
// printf ("%p: DumpValue (exe_ctx=%p, strm, mask) m_current_value = %"
|
|
// PRIi64
|
|
// "\n", this, exe_ctx, m_current_value);
|
|
if (dump_mask & eDumpOptionType)
|
|
strm.Printf("(%s)", GetTypeAsCString());
|
|
// if (dump_mask & eDumpOptionName)
|
|
// DumpQualifiedName (strm);
|
|
if (dump_mask & eDumpOptionValue) {
|
|
if (dump_mask & eDumpOptionType)
|
|
strm.PutCString(" = ");
|
|
strm.Printf("%" PRIi64, m_current_value);
|
|
}
|
|
}
|
|
|
|
Status OptionValueSInt64::SetValueFromString(llvm::StringRef value_ref,
|
|
VarSetOperationType op) {
|
|
Status error;
|
|
switch (op) {
|
|
case eVarSetOperationClear:
|
|
Clear();
|
|
NotifyValueChanged();
|
|
break;
|
|
|
|
case eVarSetOperationReplace:
|
|
case eVarSetOperationAssign: {
|
|
bool success = false;
|
|
std::string value_str = value_ref.trim().str();
|
|
int64_t value = StringConvert::ToSInt64(value_str.c_str(), 0, 0, &success);
|
|
if (success) {
|
|
if (value >= m_min_value && value <= m_max_value) {
|
|
m_value_was_set = true;
|
|
m_current_value = value;
|
|
NotifyValueChanged();
|
|
} else
|
|
error.SetErrorStringWithFormat(
|
|
"%" PRIi64 " is out of range, valid values must be between %" PRIi64
|
|
" and %" PRIi64 ".",
|
|
value, m_min_value, m_max_value);
|
|
} else {
|
|
error.SetErrorStringWithFormat("invalid int64_t string value: '%s'",
|
|
value_ref.str().c_str());
|
|
}
|
|
} break;
|
|
|
|
case eVarSetOperationInsertBefore:
|
|
case eVarSetOperationInsertAfter:
|
|
case eVarSetOperationRemove:
|
|
case eVarSetOperationAppend:
|
|
case eVarSetOperationInvalid:
|
|
error = OptionValue::SetValueFromString(value_ref, op);
|
|
break;
|
|
}
|
|
return error;
|
|
}
|
|
|
|
lldb::OptionValueSP OptionValueSInt64::DeepCopy() const {
|
|
return OptionValueSP(new OptionValueSInt64(*this));
|
|
}
|