2014-05-16 18:51:01 +08:00
|
|
|
//===-- MICmnMIResultRecord.h -----------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2014-05-16 18:51:01 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// In-house headers:
|
|
|
|
#include "MICmnBase.h"
|
|
|
|
#include "MICmnMIValueResult.h"
|
2016-09-07 04:57:50 +08:00
|
|
|
#include "MIUtilString.h"
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
//++
|
|
|
|
//============================================================================
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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
|
2016-09-07 04:57:50 +08:00
|
|
|
// const ==> c-string (7 bit iso c string content) i.e. "all" inc
|
|
|
|
// quotes
|
2014-11-18 02:06:21 +08:00
|
|
|
// tuple ==> "{}" | "{" result ( "," result )* "}"
|
2016-09-07 04:57:50 +08:00
|
|
|
// list ==> "[]" | "[" value ( "," value )* "]" | "[" result ( ","
|
|
|
|
// result )* "]"
|
2014-05-16 18:51:01 +08:00
|
|
|
//
|
2014-11-18 02:06:21 +08:00
|
|
|
// The result record can be retrieve at any time *this object is
|
2016-09-07 04:57:50 +08:00
|
|
|
// 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
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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
|
2014-05-16 18:51:01 +08:00
|
|
|
//--
|
2016-09-07 04:57:50 +08:00
|
|
|
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
|
|
|
|
};
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
// Methods:
|
|
|
|
public:
|
|
|
|
/* ctor */ CMICmnMIResultRecord();
|
|
|
|
/* ctor */ CMICmnMIResultRecord(const CMIUtilString &vrToken,
|
|
|
|
ResultClass_e veType);
|
|
|
|
/* ctor */ CMICmnMIResultRecord(const CMIUtilString &vrToken,
|
|
|
|
ResultClass_e veType,
|
|
|
|
const CMICmnMIValueResult &vValue);
|
|
|
|
//
|
|
|
|
const CMIUtilString &GetString() const;
|
|
|
|
void Add(const CMICmnMIValue &vMIValue);
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
// Overridden:
|
|
|
|
public:
|
|
|
|
// From CMICmnBase
|
|
|
|
/* dtor */ ~CMICmnMIResultRecord() override;
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
// Attributes:
|
|
|
|
private:
|
|
|
|
CMIUtilString
|
|
|
|
m_strResultRecord; // Holds the text version of the result record to date
|
2014-05-16 18:51:01 +08:00
|
|
|
};
|