aboutsummaryrefslogtreecommitdiff
path: root/tools/lldb-mi/MIDriverMgr.h
diff options
context:
space:
mode:
Diffstat (limited to 'tools/lldb-mi/MIDriverMgr.h')
-rw-r--r--tools/lldb-mi/MIDriverMgr.h138
1 files changed, 138 insertions, 0 deletions
diff --git a/tools/lldb-mi/MIDriverMgr.h b/tools/lldb-mi/MIDriverMgr.h
new file mode 100644
index 000000000000..438d184895b1
--- /dev/null
+++ b/tools/lldb-mi/MIDriverMgr.h
@@ -0,0 +1,138 @@
+//===-- MIDriverMgr.h -------------------------------------------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+//++
+// File: MIDriverMgr.h
+//
+// Overview: CMIImplCmn interface.
+//
+// Environment: Compilers: Visual C++ 12.
+// gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
+// Libraries: See MIReadme.txt.
+//
+// Copyright: None.
+//--
+
+#pragma once
+
+// Third party headers:
+#include <map>
+#include <lldb/API/SBDebugger.h>
+
+// In-house headers:
+#include "MICmnBase.h"
+#include "MIUtilString.h"
+#include "MICmnLog.h"
+#include "MIUtilSingletonBase.h"
+
+//++ ============================================================================
+// Details: MI Driver Manager. Register lldb::SBBroadcaster derived Driver type
+// objects with *this manager. The manager does not own driver objects
+// registered with it and so will not delete when this manager is
+// shutdown. The Driver flagged as "use this one" will be set as current
+// driver and will be the one that is used. Other drivers are not
+// operated. A Driver can call another Driver should it not handle a
+// command.
+// It also initializes other resources as part it's setup such as the
+// Logger and Resources objects (explicit indicate *this object requires
+// those objects (modules/components) to support it's own functionality).
+// The Driver manager is the first object instantiated as part of the
+// MI code base. It is also the first thing to interpret the command
+// line arguments passed to the executeable. Bases on options it
+// understands the manage will set up the appropriate driver or give
+// help information. Other options are passed on to the driver chosen
+// to do work.
+// Each driver instance (the CMIDriver, LLDB::Driver) has its own
+// LLDB::SBDebugger.
+// Singleton class.
+// Gotchas: None.
+// Authors: Illya Rudkin 28/02/2014.
+// Changes: None.
+//--
+class CMIDriverMgr
+: public CMICmnBase
+, public MI::ISingleton< CMIDriverMgr >
+{
+ friend MI::ISingleton< CMIDriverMgr >;
+
+// Class:
+public:
+ //++
+ // Description: Driver deriver objects need this interface to work with
+ // *this manager.
+ //--
+ class IDriver
+ {
+ public:
+ virtual bool DoInitialize( void ) = 0;
+ virtual bool DoShutdown( void ) = 0;
+ virtual bool DoMainLoop( void ) = 0;
+ virtual void DoResizeWindow( const uint32_t vWindowSizeWsCol ) = 0;
+ virtual lldb::SBError DoParseArgs( const int argc, const char * argv[], FILE * vpStdOut, bool & vwbExiting ) = 0;
+ virtual CMIUtilString GetError( void ) const = 0;
+ virtual const CMIUtilString & GetName( void ) const = 0;
+ virtual lldb::SBDebugger & GetTheDebugger( void ) = 0;
+ virtual bool GetDriverIsGDBMICompatibleDriver( void ) const = 0;
+ virtual bool SetId( const CMIUtilString & vId ) = 0;
+ virtual const CMIUtilString & GetId( void ) const = 0;
+
+ // Not part of the interface, ignore
+ /* dtor */ virtual ~IDriver( void ) {}
+ };
+
+// Methods:
+public:
+ // MI system
+ bool Initialize( void );
+ bool Shutdown( void );
+ //
+ CMIUtilString GetAppVersion( void ) const;
+ bool RegisterDriver( const IDriver & vrADriver, const CMIUtilString & vrDriverID );
+ bool UnregisterDriver( const IDriver & vrADriver );
+ bool SetUseThisDriverToDoWork( const IDriver & vrADriver ); // Specify working main driver
+ IDriver * GetUseThisDriverToDoWork( void ) const;
+ bool ParseArgs( const int argc, const char * argv[], bool & vwbExiting );
+ IDriver * GetDriver( const CMIUtilString & vrDriverId ) const;
+ //
+ // MI Proxy fn to current specified working driver
+ bool DriverMainLoop( void );
+ void DriverResizeWindow( const uint32_t vWindowSizeWsCol );
+ bool DriverParseArgs( const int argc, const char * argv[], FILE * vpStdOut, bool & vwbExiting );
+ CMIUtilString DriverGetError( void ) const;
+ CMIUtilString DriverGetName( void ) const;
+ lldb::SBDebugger * DriverGetTheDebugger( void );
+
+// Typedef:
+private:
+ typedef std::map< CMIUtilString, IDriver * > MapDriverIdToDriver_t;
+ typedef std::pair< CMIUtilString, IDriver * > MapPairDriverIdToDriver_t;
+
+// Methods:
+private:
+ /* ctor */ CMIDriverMgr( void );
+ /* ctor */ CMIDriverMgr( const CMIDriverMgr & );
+ void operator=( const CMIDriverMgr & );
+ //
+ bool HaveDriverAlready( const IDriver & vrMedium ) const;
+ bool UnregisterDriverAll( void );
+ IDriver * GetFirstMIDriver( void ) const;
+ IDriver * GetFirstNonMIDriver( void ) const;
+ CMIUtilString GetHelpOnCmdLineArgOptions( void ) const;
+
+// Overridden:
+private:
+ // From CMICmnBase
+ /* dtor */ virtual ~CMIDriverMgr( void );
+
+// Attributes:
+private:
+ MapDriverIdToDriver_t m_mapDriverIdToDriver;
+ IDriver * m_pDriverCurrent; // This driver is used by this manager to do work. It is the main driver.
+ bool m_bInMi2Mode; // True = --interpreter entered on the cmd line, false = operate LLDB driver (non GDB)
+};