aboutsummaryrefslogtreecommitdiff
path: root/tools/lldb-mi/MICmdData.h
blob: d54a21663581fff9766ec7f39c3fba35c495764e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
//===-- MICmdData.h ---------------------------------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

//++
// File:		MICmdData.h
//
// Overview:	SMICmdData interface.
//
// 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 "MICmnResources.h"

//++ ============================================================================
// Details:	MI command metadata. Holds the command's name, MI number and options
//			as found on stdin. Holds the command's MI output (written to stdout).
// Gotchas:	None.
// Authors:	Illya Rudkin 18/02/2014.
// Changes:	None.
//--
struct SMICmdData
{
	SMICmdData( void )
	:	id( 0 )
	,	bCmdValid( false )
	,	bCmdExecutedSuccessfully( false )
	,	bMIOldStyle( false )
	,	bHasResultRecordExtra( false )
	{
	};

	MIuint			id;								// A command's unique ID i.e. GUID
	CMIUtilString	strMiCmdToken;					// The command's MI token (a number)	
	CMIUtilString	strMiCmd;						// The command's name 
	CMIUtilString	strMiCmdOption;					// The command's arguments or options
	CMIUtilString	strMiCmdAll;					// The text as received from the client
	CMIUtilString	strMiCmdResultRecord;			// Each command forms 1 response to its input
	CMIUtilString	strMiCmdResultRecordExtra;		// Hack command produce more response text to help the client because of using LLDB 
	bool			bCmdValid;						// True = Valid MI format command, false = invalid
	bool			bCmdExecutedSuccessfully;		// True = Command finished successfully, false = Did not start/did not complete
	CMIUtilString	strErrorDescription;			// Command failed this is why
	bool			bMIOldStyle;					// True = format "3thread", false = format "3-thread"
	bool			bHasResultRecordExtra;			// True = Yes command produced additional MI output to its 1 line response, false = no extra MI output formed

	void Clear( void )
	{
		id = 0;
		strMiCmdToken.clear();		
		strMiCmd = MIRSRC( IDS_CMD_ERR_CMD_RUN_BUT_NO_ACTION );			
		strMiCmdOption.clear();	
		strMiCmdAll.clear();		
		strMiCmdResultRecord.clear();
		strMiCmdResultRecordExtra.clear();
		bCmdValid = false;
		bCmdExecutedSuccessfully = false;
		strErrorDescription.clear();
		bMIOldStyle = false;
		bHasResultRecordExtra = false;
	}
};