Roman Matveev
Roman Matveev

Reputation: 577

Macro as a parameter to another macro

I'm trying to pass the parameters to macro SETBIT with another predefined macro like this:

#define SETBIT(ADDRESS,BIT,N) {(N) ? (ADDRESS &= ~(1<<BIT)) : (ADDRESS |= (1<<BIT))}
#define DAC_SYNC PORTB,3,POS
SETBIT(DAC_SYNC);

However I receiver error:

macro SETBIT requires 3 parameters only 1 given

There is an article with the following recommendations:

to prevent misnesting of arithmetic operations: #define foo (a,b) or #define bar(x) lose((x))

But even though I still have an error. BTW, reading the article I've indicated I can make the following conclusion: preprocessor expands ALL macroses appearing. But actually it looks like macro #define DAC_SYNC PORTB,3,POS is not expanding by preprocessor.

Could anyone make more clear how the GCC's preprocessor works?

Upvotes: 6

Views: 4973

Answers (2)

Mali Remorker
Mali Remorker

Reputation: 1266

Just for the sake of completeness, that same manual you are linking to also states:

The number of arguments you give must match the number of parameters in the macro definition. When the macro is expanded, each use of a parameter in its body is replaced by the tokens of the corresponding argument.

So ooga's example is a nice demonstration of how macro expansion works recursively, first the outer macro gets expanded, then the argument.

Upvotes: 4

ooga
ooga

Reputation: 15501

This works:

#define SETBIT2(ADDRESS,BIT,N) ((N) ? (ADDRESS &= ~(1<<BIT)) : (ADDRESS |= (1<<BIT)))
#define SETBIT(PARAMS) SETBIT2(PARAMS)
#define PORTB 5
#define POS 7
#define DAC_SYNC PORTB,3,POS

int main() {
  int a = SETBIT(DAC_SYNC);
  return 0;
}

Upvotes: 9

Related Questions