J'ai une macro où je passe un argument et l'utilisation qui définissent une nouvelle variable en fonction du nom de l'entrée:Remplacer une chaîne dans une variable macro?
#define DO_X(x) char _do_x_var_ ## x; /* other things */
Le problème est que si je passe dans une variable struct, il se casse:
DO_X(some_struct->thing)
devient:
char _do_x_var_some_struct->thing; /* other things */
EDIT: ce que je veux évaluer à est:
char _do_x_var_some_struct__thing; /* other things */
(ou tout autre nom de variable valide contenant quelque chose de similaire à l'entrée)
Ce que je veux vraiment est pour ces au travail:
#define DO_X(x) for(char _do_x_var_ ## x; /*things*/)
DO_X(x){
DO_X(y) {
/*things*/
}
}
DO_X(object->x){
DO_X(object->y) {
/*things*/
}
}
mais pour ceux-ci à l'échec:
#define DO_X(x) for(char _do_x_var_ ## x; /*things*/)
DO_X(x){
DO_X(x) { // <-- multiple definition of _do_x_var_x
/*things*/
}
}
DO_X(object->x){
DO_X(object->x) { // <-- multiple definition of _do_x_var_object__x (or whatever)
/*things*/
}
}
Existe-t-il un moyen de faire en sorte que cela fonctionne? Peut-être remplacer ->
avec __
ou quelque chose? J'ai trouvé des façons de concaténer, mais pas de remplacer les chaînes.
Pouvez-vous clarifier ce que vous voulez que la macro vous donne? –
1. Essayez-vous de déclarer une variable de classe en dehors de celle-ci? 2. Ceci est la mort par les macros. –
@Oli Charlesworth: J'ai ajouté plus de clarification de ce que je veux –