IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Visual C++ Discussion :

LNK2019 due a une décoration abusive :)


Sujet :

Visual C++

  1. #1
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut LNK2019 due a une décoration abusive :)
    Bonjour à toutes et à tous.

    Lors de la compilation de mon projet, je ne rencontre aucune erreur, mais lors du linkage ...

    Ma solution se décompose en deux projets :
    • FreeImage : Directement téléchargé de freeimage.sourceforge.net et compilé en library statique (lib)
    • Isys : créé par mes soins et utilisant une dizaines de fonctions de FreeImage (10 sur plus de mille, d'où l'utilisation de bilio statique).


    Dans le main d'Isys je fais figurer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #pragma comment(lib, "../common/debug/FreeImage.lib")
    Et dans son en-tête principale
    Je prends bien entendu le soin de préciser à FreeImage.h qu'elle est utilisée dans le cadre d'une biblio statique (pas d'imports/exports).


    Résultat :
    Lors du linkage, pour chaque fonction de FreeImage que j'utilise j'obtiens l'erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    IsysSnapShot error LNK2019: symbole externe non résolu _FreeImage_Allocate référencé dans la fonction _SaveSnapshot
    [...]

    J'ai donc fait une recherche dans le .lib : il apparait bien ces fonctions, mais elles sont décorées : _FreeImage_Allocate@24
    Je me suis dit : et bien s'il ne s'agit que de ça, ne précisons pas à FreeImage.h que nous l'utilisons pour une lib statique, et déclarons les "__declspec(dllimport)". Résultat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    IsysSnapShot error LNK2019: symbole externe non résolu __imp__FreeImage_Allocate@24 référencé dans la fonction _SaveSnapshot
    [...]

    J'aimerais votre aide pour couper la poire en deux
    Merci.

  2. #2
    Rédacteur
    Avatar de nico-pyright(c)
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    6 414
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 6 414
    Par défaut
    pour éviter la décoration, il faut utiliser extern "C"

  3. #3
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut
    Mais où ?
    (il est déjà déclaré autour de la définitions des fonctions de FreeImage (Le FreeImage.h qui sert à la compilation du .lib & le FreeImage.h qui sert à déclarer les fonctions dans le projet Isys - en fait c'est le même fichier )

  4. #4
    Rédacteur
    Avatar de farscape
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2003
    Messages
    9 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2003
    Messages : 9 055
    Par défaut
    sur la declaration du prototype de la fonction, idealement dans le .h de declaration des fonctions qui devrait etre utilisé pour la lib et pour l'application..
    comme dans ce post de la faq:http://c.developpez.com/faq/vc/?page=DLL#MakeDynDll

  5. #5
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut
    C'est ce qui est fait. Pourtant les fonctions dans FreeImage.lib sont décorées.

  6. #6
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut
    Pitit up : personne a une idée pour empécher la déco ?
    Merci.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    391
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 391
    Par défaut
    bonjour

    moi pour enlever la deco je cree un fichier .def quand je cree ma librairie.
    A la compile les fonction ne sont plus decorées.

    je les declare comme çà:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    int	__stdcall GetListTag(int SrPortNo,BOOL axe1,BOOL axe2,BOOL axe3,BOOL axe4,BOOL axe5,BOOL axe6);
    int	__stdcall GetSerialPortNumber(void);
    int	__stdcall ResetduDSP(int SrPortNo);
    et si je veux cree une dll nomme nomdemadll.dll je cree un fichier nomdemadll.def dans mon projet qui a la forme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    ; GetList.def : Declares the module parameters for the DLL.
     
    LIBRARY      "GetList"
    DESCRIPTION  'GetList Windows Dynamic Link Library'
     
    EXPORTS
        ; Explicit exports can go here
     
    	GetListTag			@1
    	GetSerialPortNumber @2
    	ResetduDSP			@3
    cordialement

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    ricky78: pas la bonne méthode.


    prgasp77, farscape, nico-pyright(c) : Les fonctions sont déjà en extern "C", mais elles sont en __stdcall dans la bibliothèque, et considérées comme en __cdecl dans le header.

    Solutions:
    Soit changer la convention d'appel par défaut de ton projet utilisateur (ce que je qualifierais de mauvais), soit modifier le header pour préciser que les fonctions sont en __stdcall.

    PS: Apprenez à distinguer une décoration C d'une décoration C++:
    Format of a C Decorated Name
    Format of a C++ Decorated Name
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  9. #9
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut
    Bonjour Médinoc.
    J'ai un peu tout essayé, quand je parviens à linker les fonctions problématiques, j'ai tout le reste qui foire (environ 250 erreur de link).
    Je ne sais plus trop quoi faire, est-ce ma bibliothèque qui est mal écrite ?


    Edit :
    Mea Culpa
    http://freeimage.sourceforge.net/faq.html (il faut compiler spécialement la bibliothèque comme expliqué à la question How to use FreeImage as a static library instead of as a DLL (Visual C++ 6) ?).
    En revanche je ne sais pas pourquoi mon linker (qui me joue encore des tours) cherche le fichier C:\Program.obj

    Je travaille là dessus.

  10. #10
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Tout ce qui s'appelle C:\Program est généralement un truc dans Program Files pour lequel on aurait oublié les guillemets.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  11. #11
    Membre Expert
    Avatar de prgasp77
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Juin 2004
    Messages
    1 306
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 306
    Par défaut
    Oui en effet.
    Un grand merci mais ma lutte contre mon éditeur de lien n'est pas finie.

    Apparemment, il ne rencontre plus de problème pour lier les fonctions de ma lib utilisée dans mon projet ... en revanche j'ai des erreurs bien étranges :
    • Des symboles externes non résolus qui existent bel et bien dans le lib
    • Des objets déjà défini dans FreeImage.lib (et où ailleurs ???)


    Si quelqu'un a une hypothèse ... je commence à avoir des sueurs froides
    Merci.


    Edit :
    J'ai tenté avec un programme trivial (console Win32)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #include "stdafx.h"
    #include "FreeImage.h"
    #pragma comment(lib, "C:/Program Files/Microsoft Visual Studio/MyProjects/Isys/common/Release/FreeImage.lib")
     
    int _tmain(int argc, _TCHAR* argv[])
    {
    	// fonctions du lib
    	FreeImage_Initialise();
    	FreeImage_DeInitialise();
    	return 0;
    }
    Et ces mêmes erreurs apparaissent, je me doute que le soucis vient justement de ma biblio, je tente une recompilation ... mais je n'espère plus

    Edit 2 : Lib recompilée à l'identique ... Ouiiiiiiiiiiiinnnnnnnnnnnnnnnn
    Edit 3 : J'arrive à compiler et linker en n'utilisant que des fonctions simples (FreeImage_GetVersion par exemple) ... et ça fonctionne ; mais pour la plupart des fonctions il y a plein d'erreurs commes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    test_FreeImage_dot_lib error LNK2005: "class std::basic_ostream<char,struct std::char_traits<char> > & __cdecl std::operator<<<struct std::char_traits<char> >(class std::basic_ostream<char,struct std::char_traits<char> > &,char const *)" (??$?6U?$char_traits@D@std@@@std@@YAAAV?$basic_ostream@DU?$char_traits@D@std@@@0@AAV10@PBD@Z) déjà défini(e) dans msvcprt.lib(MSVCP71.dll)
    test_FreeImage_dot_lib error LNK2019: symbole externe non résolu _TIFFWriteDirectory référencé dans la fonction "long __cdecl Save(struct FreeImageIO *,struct FIBITMAP *,void *,int,int,void *)" (?Save@@YAJPAUFreeImageIO@@PAUFIBITMAP@@PAXHH2@Z)

  12. #12
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    La première erreur semble indiquer que quelque chose tente de redéfinir l'opérateur d'insertion d'un const char * dans un ostream.

    L'autre indique qu'il ne trouve pas une fonction extern "C" __cdecl, dont une fonction C++ a besoin.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. [Macro]Action echoué due a une macro
    Par Bass_Room dans le forum VBA Access
    Réponses: 1
    Dernier message: 12/04/2007, 21h40
  2. une autre erreur LNK2019
    Par crossbowman dans le forum C++
    Réponses: 5
    Dernier message: 25/02/2006, 22h29

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo