есть метод с регистрацией типа (генерируется автоматически)
GType
color_indicator_get_type (void)
просто вызов этого метода и последующий вывод
std::cout << g_type_from_name("ColorIndicator") << std::endl;
показывают что тип не зарегистрирован. но если перенести вызов color_indicator_get_type в std::cout
std::cout << "{DEBUG}"
<< " " << g_type_from_name("ColorIndicator") << " "
<< (g_type_from_name("ColorIndicator") == color_indicator_get_type()) << std::endl;
все работает
noinline
Вообще, если там есть сайдэффекты, то компилятор в принципе не может выкинуть вызов просто так…
это сам GType color_indicator_get_type (void) он генерируется автоматически из vala в С. его я менять не могу
сделал в vala отдельную void() ф-ю с регистрацией типов, которую вызываю из С++, и все норм. вопрос снимается
Вообще, недостаточно контекста. Может, функция помечена как pure? Компилятор не имеет права выкидывать сайд-эффекты в описанной ситуации, кто-то что-то недоговаривает
ну вот пример генерируемого С кода. https://godbolt.org/z/4zc8Y9oKf . среди прочих генерируется метод GType myclass_get_type (void)
Обсуждают сегодня