Я использую декларацию forward enum в моей программе cpp, из-за которой gdb дает мне несовместимый тип.Вот минимальный рабочий пример:
definitions.h:
/*definitions.h*/
#ifndef DEFINITIONS_H_
#define DEFINITIONS_H_
enum ForwardEnum : int;
typedef ForwardEnum ForwardEnum;
typedef struct {
const ForwardEnum EnumValue;
} ElemConfig;
#endif //DEFINITIONS_H_
config.h:
/*config.h*/
#ifndef CONFIG_H_
#define CONFIG_H_
#include "definitions.h"
enum ForwardEnum : int {
EnumValue1 = -1,
EnumValue2,
};
#endif //CONFIG_H_
classA.h:
/*classA.h*/
#ifndef CLASSA_H_
#define CLASSA_H_
#include <array>
#include "definitions.h"
#define N_ELEMS 8
class A{
private:
const std::array<ElemConfig, N_ELEMS> Config;
public:
A(const std::array<ElemConfig, N_ELEMS>);
};
#endif //CLASSA_H_
main.cpp:
/*main.cpp*/
#include <iostream>
#include <array>
#include "definitions.h"
#include "config.h"
#include "classA.h"
const std::array<ElemConfig, N_ELEMS> AConfig {{{EnumValue1}}};
A::A(const std::array<ElemConfig, N_ELEMS> Config) : Config(Config)
{
ForwardEnum a = Config[0].EnumValue;
std::cout << a << std::endl;
};
int main(void)
{
A objectA(AConfig);
}
Когда я пытаюсь отладить конструктор класса A в gdb, я получаю неполный тип для переменной enum.В соответствии с этим вопросом я пытался привести его к тому типу, который, на мой взгляд, является совместимым:
print (ForwardEnum) a
Когда это не удалось, я экспериментировал, чтобы увидеть, была ли проблема в typedef:
print (const enum ForwardEnum) a
А также разобрать конструктор, но все это не удалось.
Какое тогда будет правильное преобразование типов для печати содержимого EnumValue?
(Или, альтернативно, как я могу получить gdb для разрешения несовместимого типа, сохраняя предварительное объявление?)
Я использую gdb 7.7.1 и gcc 4.8.4