Why doesn\'t the commented out line in the following program compile?
#include
#include
using namespace std;
#define F1(a) 1
in
The preprocessor does not know about {} initialisation. It sees the comma and thinks that's the start of a new macro argument. And then the next one. Only brackets () are things that it knows about.
[C++11: 16.3/11]:The sequence of preprocessing tokens bounded by the outside-most matching parentheses forms the list of arguments for the function-like macro. The individual arguments within the list are separated by comma preprocessing tokens, but comma preprocessing tokens between matching inner parentheses do not separate arguments. [..]
A macro is not a function. It interprets your input vector<int>{1,2,3} as 3 inputs, which are vector<int>{1,2 and 3}. You can change this by making it an expression (vector<int>{1,2,3}) (as you already did).
Everything in parantheses is an expression and .vector<int>(...) is a (*special member-)function so the preprocessor sees it as one expression
Another workaround is to transform your macro into a variadic macro
#define F1(...) 1
Or, in a more general case:
#define M(a) a
into
#define M(...) __VA_ARGS__