diff options
Diffstat (limited to 'tools/lldb-mi/MICmdCmdGdbSet.h')
-rw-r--r-- | tools/lldb-mi/MICmdCmdGdbSet.h | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/tools/lldb-mi/MICmdCmdGdbSet.h b/tools/lldb-mi/MICmdCmdGdbSet.h new file mode 100644 index 000000000000..24b54557bf37 --- /dev/null +++ b/tools/lldb-mi/MICmdCmdGdbSet.h @@ -0,0 +1,96 @@ +//===-- MICmdCmdGdbSet.h ------------- ---------------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +//++ +// File: MICmdCmdGdbSet.h +// +// Overview: CMICmdCmdGdbSet interface. +// +// To implement new MI commands derive a new command class from the command base +// class. To enable the new command for interpretation add the new command class +// to the command factory. The files of relevance are: +// MICmdCommands.cpp +// MICmdBase.h / .cpp +// MICmdCmd.h / .cpp +// For an introduction to adding a new command see CMICmdCmdSupportInfoMiCmdQuery +// command class as an example. +// +// Environment: Compilers: Visual C++ 12. +// gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1 +// Libraries: See MIReadmetxt. +// +// Copyright: None. +//-- + +#pragma once + +// In-house headers: +#include "MICmdBase.h" + +//++ ============================================================================ +// Details: MI command class. MI commands derived from the command base class. +// *this class implements MI command "gdb-set". +// This command does not follow the MI documentation exactly. While *this +// command is implemented it does not do anything with the gdb-set +// variable past in. +// The design of matching the info request to a request action (or +// command) is very simple. The request function which carries out +// the task of information gathering and printing to stdout is part of +// *this class. Should the request function become more complicated then +// that request should really reside in a command type class. Then this +// class instantiates a request info command for a matching request. The +// design/code of *this class then does not then become bloated. Use a +// lightweight version of the current MI command system. +// Gotchas: None. +// Authors: Illya Rudkin 03/03/2014. +// Changes: None. +//-- +class CMICmdCmdGdbSet : public CMICmdBase +{ +// Statics: +public: + // Required by the CMICmdFactory when registering *this command + static CMICmdBase * CreateSelf( void ); + +// Methods: +public: + /* ctor */ CMICmdCmdGdbSet( void ); + +// Overridden: +public: + // From CMICmdInvoker::ICmd + virtual bool Execute( void ); + virtual bool Acknowledge( void ); + virtual bool ParseArgs( void ); + // From CMICmnBase + /* dtor */ virtual ~CMICmdCmdGdbSet( void ); + +// Typedefs: +private: + typedef bool (CMICmdCmdGdbSet::*FnGdbOptionPtr)( const CMIUtilString::VecString_t & vrWords ); + typedef std::map< CMIUtilString, FnGdbOptionPtr > MapGdbOptionNameToFnGdbOptionPtr_t; + +// Methods: +private: + bool GetOptionFn( const CMIUtilString & vrGdbOptionName, FnGdbOptionPtr & vrwpFn ) const; + bool OptionFnSolibSearchPath( const CMIUtilString::VecString_t & vrWords ); + bool OptionFnFallback( const CMIUtilString::VecString_t & vrWords ); + +// Attributes: +private: + const static MapGdbOptionNameToFnGdbOptionPtr_t ms_mapGdbOptionNameToFnGdbOptionPtr; + // + const CMIUtilString m_constStrArgNamedThreadGrp; + const CMIUtilString m_constStrArgNamedGdbOption; + bool m_bGdbOptionRecognised; // True = This command has a function with a name that matches the Print argument, false = not found + bool m_bGdbOptionFnSuccessful; // True = The print function completed its task ok, false = function failed for some reason + bool m_bGbbOptionFnHasError; // True = The option function has an error condition (not the command!), false = option function ok. + CMIUtilString m_strGdbOptionName; + CMIUtilString m_strGdbOptionFnError; +};
\ No newline at end of file |