Re: XCode C99 : duplicate symbol

Liste des GroupesRevenir à fcl c 
Sujet : Re: XCode C99 : duplicate symbol
De : om+news (at) *nospam* miakinen.net (Olivier Miakinen)
Groupes : fr.comp.lang.c
Date : 23. Apr 2022, 17:20:58
Autres entêtes
Organisation : There's no cabale
Message-ID : <t415gq$2l91$1@cabale.usenet-fr.net>
References : 1 2 3
User-Agent : Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0 SeaMonkey/2.49.4
Le 22/04/2022 20:13, kurtz le pirate a écrit :
>
Si de vieux dinosaures passent par la...
 
Plutôt que de chercher des dinosaures sur un groupe Mac, pourquoi
ne pas poser la question sur le groupe où c'est en charte ? Je fais
suivre.
 
parceque XCode = Mac ;)

Désolé, je ne connaissais pas.

Quoi qu'il en soit, ça ressemble beaucoup à du langage C, et à moins qu'il
y ait une spécificité Mac j'ai l'impression que les compétences en C
devraient pouvoir t'aider.

Dans mon projet, j'ai ces fichiers :
 a_structures.h
 a_toolbox.h
 a_toolbox.c
 a_m.h
 a_m.c
 main.c
>
Le fichier a_structures.h ne contient que des définitions de structures.

Ok.

>
Dans main.c j'ai :
 #include "a_structures.h"
 #include "a_toolbox.h"
 #include "a_m.h"

[...]

 
Parce qu'en le mettant dans un .h inclus dans différents .c, tu le
redéfinis dans chacun des .c .
 
oui... mais non. dans mes .c, je n'ai pas de #include "a_structures.h"

Tu l'as au moins dans le main.c, d'après ce que tu écrivais plus haut.

les #include ne sont que dans les .h

Eh bien si tu n'inclus pas directement a_structures.h dans a_m.c et
a_toolbox.c, c'est forcément qu'il est inclus de façon indirecte,
que ce soit par un autre #include, soit parce que XCode fait ça de
manière implicite.

Pour t'en convaincre, écris dans a_structures.h quelque chose provoquant
une erreur de compilation plutôt qu'une erreur détectée à l'édition de
liens, par exemple :

 #error Le fichier .h est inclus dans ce .c !

Plusieurs solutions possibles : soit tu le définis en 'static', auquel
cas chaque .c aura sa propre copie du tableau, soit tu le déclares
uniquement dans le .h et tu le définis dans un seul .c .
 
je vais regarder du coté de 'static'.


Le plus propre à mon avis serait de ne mettre que la déclaration dans le .h :

 extern const char * DayNames[];

et la définition dans l'un des .c, par exemple main.c


Sinon, oui, une définition statique est possible puisque ça ne prend que
quelques octets dans chacun des .c, et que le tableau n'a pas besoin d'être
partagé puisqu'il ne devrait pas être modifié.


j'ai vu aussi un pragma 'once'.

Ça, outre que ce n'est pas standard (quoique assez largement supporté), il
me semble que ça peut éviter d'inclure plusieurs fois la même définition
dans un même .c, mais que ça n'empêchera pas que cette définition soit
incluse une fois dans chaque .c : ça ne devrait donc strictement rien
changer à ton problème.


--
Olivier Miakinen


Date Sujet#  Auteur
22 Apr 22 * Re: XCode C99 : duplicate symbol3Olivier Miakinen
22 Apr 22 `* Re: XCode C99 : duplicate symbol2kurtz le pirate
23 Apr 22  `- Re: XCode C99 : duplicate symbol1Olivier Miakinen

Haut de la page

Les messages affichés proviennent d'usenet.

NewsPortal