File: MICmnMIResultRecord.h

package info (click to toggle)
llvm-toolchain-3.5 1%3A3.5-10
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 282,028 kB
  • ctags: 310,872
  • sloc: cpp: 1,883,926; ansic: 310,731; objc: 86,612; python: 79,565; asm: 65,844; sh: 9,829; makefile: 6,057; perl: 5,589; ml: 5,254; pascal: 3,285; lisp: 1,640; xml: 686; cs: 239; csh: 117
file content (106 lines) | stat: -rw-r--r-- 3,389 bytes parent folder | download | duplicates (2)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//===-- MICmnMIResultRecord.h -----------------------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

//++
// File:		MICmnMIResultRecord.h
//
// Overview:	CMICmnMIResultRecord interface.
//
// Environment:	Compilers:	Visual C++ 12.
//							gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
//				Libraries:	See MIReadmetxt. 
//
// Copyright:	None.
//--

#pragma once

// Third party headers:
#include <map>

// In-house headers:
#include "MICmnBase.h"
#include "MIUtilString.h"
#include "MICmnMIValueResult.h"

//++ ============================================================================
// Details:	MI common code MI Result Record class. A class that encapsulates 
//			MI result record data and the forming/format of data added to it.
//			The syntax is as follows:
//			result-record ==>  [ token ] "^" result-class ( "," result )* nl 
//			token = any sequence of digits
//			* = 0 to many
//			nl = CR | CR_LF
//			result-class ==> "done" | "running" | "connected" | "error" | "exit" 
//			result ==> variable "=" value
//			value ==> const | tuple | list  
//			const ==> c-string (7 bit iso c string content) i.e. "all" inc quotes
//			tuple ==>  "{}" | "{" result ( "," result )* "}"  
//			list ==>  "[]" | "[" value ( "," value )* "]" | "[" result ( "," result )* "]" 
//
//			The result record can be retrieve at any time *this object is
//			instantiated so unless work is done on *this result record then it is
//			possible to return a malformed result record. If nothing has been set 
//			or added to *this MI result record object then text "<Invalid>" will 
//			be returned.
//			More information see: 
//			http://ftp.gnu.org/old-gnu/Manuals/gdb-5.1.1/html_chapter/gdb_22.html
// Gotchas:	None.
// Authors:	Illya Rudkin 24/02/2014.
// Changes:	None.
//--
class CMICmnMIResultRecord : public CMICmnBase
{
// Enumerations:
public:
	//++
	// Details:	Enumeration of the result class for *this result record
	//--
	enum ResultClass_e
	{
		eResultClass_Done	= 0,
		eResultClass_Running,
		eResultClass_Connected,
		eResultClass_Error,
		eResultClass_Exit,
		eResultClass_count	// Always the last one
	};

// Typedefs:
public:
	typedef	std::map< ResultClass_e, CMIUtilString >	MapResultClassToResultClassText_t;

// Methods:
public:
	/* ctor */	CMICmnMIResultRecord( void );
	/* ctor */	CMICmnMIResultRecord( const CMIUtilString & vrToken, const ResultClass_e veType );
	/* ctor */	CMICmnMIResultRecord( const CMIUtilString & vrToken, const ResultClass_e veType, const CMICmnMIValueResult & vValue );
	//
	const CMIUtilString &	GetString( void ) const;
	bool					Add( const CMICmnMIValue & vMIValue );

// Overridden:
public:
	// From CMICmnBase
	/* dtor */ virtual ~CMICmnMIResultRecord( void );

// Methods:
private:
	bool	BuildResultRecord( void );

// Attributes:
private:
	static const CMIUtilString					ms_constStrResultRecordHat;
	static MapResultClassToResultClassText_t	ms_constMapResultClassToResultClassText;
	//
	CMIUtilString		m_strResultRecordToken;
	ResultClass_e		m_eResultRecordResultClass;
	CMIUtilString		m_strResultRecord;			// Holds the text version of the result record to date
	CMICmnMIValueResult	m_partResult;
};