diff options
Diffstat (limited to 'lldb/source/Interpreter/ScriptInterpreter.cpp')
| -rw-r--r-- | lldb/source/Interpreter/ScriptInterpreter.cpp | 96 | 
1 files changed, 96 insertions, 0 deletions
diff --git a/lldb/source/Interpreter/ScriptInterpreter.cpp b/lldb/source/Interpreter/ScriptInterpreter.cpp new file mode 100644 index 000000000000..d04baec76e60 --- /dev/null +++ b/lldb/source/Interpreter/ScriptInterpreter.cpp @@ -0,0 +1,96 @@ +//===-- ScriptInterpreter.cpp -----------------------------------*- C++ -*-===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "lldb/Interpreter/ScriptInterpreter.h" + +#include <stdio.h> +#include <stdlib.h> +#include <string> + +#include "lldb/Host/PseudoTerminal.h" +#include "lldb/Interpreter/CommandReturnObject.h" +#include "lldb/Utility/Status.h" +#include "lldb/Utility/Stream.h" +#include "lldb/Utility/StringList.h" + +using namespace lldb; +using namespace lldb_private; + +ScriptInterpreter::ScriptInterpreter(Debugger &debugger, +                                     lldb::ScriptLanguage script_lang) +    : m_debugger(debugger), m_script_lang(script_lang) {} + +ScriptInterpreter::~ScriptInterpreter() {} + +void ScriptInterpreter::CollectDataForBreakpointCommandCallback( +    std::vector<BreakpointOptions *> &bp_options_vec, +    CommandReturnObject &result) { +  result.SetStatus(eReturnStatusFailed); +  result.AppendError( +      "ScriptInterpreter::GetScriptCommands(StringList &) is not implemented."); +} + +void ScriptInterpreter::CollectDataForWatchpointCommandCallback( +    WatchpointOptions *bp_options, CommandReturnObject &result) { +  result.SetStatus(eReturnStatusFailed); +  result.AppendError( +      "ScriptInterpreter::GetScriptCommands(StringList &) is not implemented."); +} + +std::string ScriptInterpreter::LanguageToString(lldb::ScriptLanguage language) { +  std::string return_value; + +  switch (language) { +  case eScriptLanguageNone: +    return_value = "None"; +    break; +  case eScriptLanguagePython: +    return_value = "Python"; +    break; +  case eScriptLanguageUnknown: +    return_value = "Unknown"; +    break; +  } + +  return return_value; +} + +lldb::ScriptLanguage +ScriptInterpreter::StringToLanguage(const llvm::StringRef &language) { +  if (language.equals_lower(LanguageToString(eScriptLanguageNone))) +    return eScriptLanguageNone; +  if (language.equals_lower(LanguageToString(eScriptLanguagePython))) +    return eScriptLanguagePython; +  return eScriptLanguageUnknown; +} + +Status ScriptInterpreter::SetBreakpointCommandCallback( +    std::vector<BreakpointOptions *> &bp_options_vec, +    const char *callback_text) { +  Status return_error; +  for (BreakpointOptions *bp_options : bp_options_vec) { +    return_error = SetBreakpointCommandCallback(bp_options, callback_text); +    if (return_error.Success()) +      break; +  } +  return return_error; +} + +void ScriptInterpreter::SetBreakpointCommandCallbackFunction( +    std::vector<BreakpointOptions *> &bp_options_vec, +    const char *function_name) { +  for (BreakpointOptions *bp_options : bp_options_vec) { +    SetBreakpointCommandCallbackFunction(bp_options, function_name); +  } +} + +std::unique_ptr<ScriptInterpreterLocker> +ScriptInterpreter::AcquireInterpreterLock() { +  return std::unique_ptr<ScriptInterpreterLocker>( +      new ScriptInterpreterLocker()); +}  | 
