Объявить функцию C другом класса и вернуть C перечислитель

Это очень похоже на этот вопрос, однако функция, которую я пытаюсь сделать другом, возвращает C перечислитель. Я не могу понять правильный синтаксис:

#include <iostream>

extern "C" {
  enum X {ONE};
  int foo();
  X bar();
}

namespace a {
class A {
public:
  A(int a): a(a) {}
private:
  friend int ::foo();
  friend X ::bar();  // Doesn't work
  int a;
};
}

extern "C" {
 int foo() {
  a::A a(1);
  std::cout << a.a << std::endl;
  return ONE;
}
 X bar() {
  a::A a(2);
  std::cout << a.a << std::endl;
  return ONE;
}
}

int main()
{
  foo();  // outputs: 1
  bar();  // doesn't compile
}

friend X ::bar(); не работает Какой правильный синтаксис для этого.

Онлайн демо

main.cpp:20:18: error: 'enum X' is not a class or a namespace
   friend X ::bar();
                  ^
main.cpp:20:18: error: ISO C++ forbids declaration of 'bar' with no type     [-fpermissive]
main.cpp: In function 'X bar()':
main.cpp:22:7: error: 'int a::A::a' is private
   int a;
       ^
main.cpp:35:18: error: within this context
   std::cout << a.a << std::endl;

1 ответ

Решение

Попробуйте добавить скобки для устранения неоднозначности синтаксического анализа

friend X (::bar)();
Другие вопросы по тегам