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

 C++ Discussion :

Windows 10 et LoadResource()


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 60
    Par défaut Windows 10 et LoadResource()
    Bonjour

    J'ai un petit programme exe, développé sous BCB6, nécessitant l'utilisation d'une dll. Pour ne pas avoir à distribuer cette dll en plus de l'exe, je l'ai mise dans les ressources de l'exe. A l'execution, lors de la création de la fenêtre principale, j'extraie cette dll [avec FindResource(), LoadResource() et LockResource()], et je re-crée ce fichier dll [avec CreateFile()] dans le même répertoire que celui où se trouve l'exe. L'execution peut se poursuivre en utilisant cette dll qui vient d'être créée.
    Cette méthode fonctionne parfaitement sous Vista, W7 et W8, mais elle ne fonctionne pas sous W10 : La dll n'est pas créée.

    Quelqu'un voit-il une piste pour résoudre ce problème ?
    Merci.

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Quelle est la fonction qui échoue et quelle est la valeur retournée par GetLastError() à ce moment-là?


    Sinon, en dézoomant un peu, il y a quelques problèmes avec ton approche: Notamment que ce la nécessite que celui qui exécute le programme ait les droits d'écriture sur le répertoire le contenant (donc, pas question de le mettre dans Program Files, etc.)
    Pourquoi ne pas passer plutôt par un vrai installeur ou, au pire, pourquoi ne pas utiliser le répertoire temporaire (obtenu avec SHGetKnownFolderPath() si possible, ou le vieux SHGetSpecialFolderPath() si nécessaire) pour y stocker ta DLL (avec le flag FILE_FLAG_DELETE_ON_CLOSE si possible)?
    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.

  3. #3
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 60
    Par défaut
    Merci pour la réponse.

    L'utilisateur de cet exe sait qu'il doit le placer dans un de ses répertoires (Users/login/...), donc il n'y a pas de problème de droits d'écriture manquants.
    Le but est de fournir quelque chose d'ultra simple et immédiat à lancer pour l'utilisateur : Pas de programme d'installation, pas de dll à copier en plus de l'exe : Il copie cet exe dans un de ses répertoires, double-clique sur le nom de ce fichier, et c'est parti... sauf sous Windows 10 !!!

    Il n'y a pas de fonction qui échoue : Je peux le vérifier en mettant au préalable manuellement cette dll dans le répertoire de l'exe : Aucune des fonctions FindResource(), LoadResource() et LockResource() ne renvoie un pointeur NULL.
    Si je mets un message qui doit s'afficher tout au début du Form Create, ce message ne s'affiche pas si je ne mets pas manuellement cette dll dans le répertoire de l'exe.
    Tout se passe en fait comme si Windows 10 vérifiait les dépendances de l'exe avant de commencer la moindre exécution, alors que sous les OS précédents, au moins le Form Create se faisait, ce qui permettait de créer cette dll nécessaire à la suite de l'exécution.

  4. #4
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Tout se passe en fait comme si Windows 10 vérifiait les dépendances de l'exe avant de commencer la moindre exécution
    1. Quand cela se fait, il y a un message d'erreur tout-à-fait explicite avant le lancement du programme.
    2. Je ne vois pas pourquoi Windows 10 cesserait subitement de supporter les delay-loaded DLLs (et encore plus impossible si c'est LoadLibrary() qui est utilisé)

    Aucune des fonctions FindResource(), LoadResource() et LockResource() ne renvoie un pointeur NULL.
    Et CreateFile() (ou ce que tu utilises pour écrire la DLL)?
    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.

  5. #5
    Responsable 2D/3D/Jeux


    Avatar de LittleWhite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2008
    Messages
    27 141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 27 141
    Billets dans le blog
    150
    Par défaut
    Bonjour,

    Sinon, peut être en désactivant l'anti virus ?
    Vous souhaitez participer à la rubrique 2D/3D/Jeux ? Contactez-moi

    Ma page sur DVP
    Mon Portfolio

    Qui connaît l'erreur, connaît la solution.

  6. #6
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 60
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Quand cela se fait, il y a un message d'erreur tout-à-fait explicite avant le lancement du programme.
    Il y a bien un message d'erreur sous W10 (voir ci-dessous).

    Nom : erreur W10.jpg
Affichages : 161
Taille : 13,8 Ko

    Ce message n'apparaît bien sur pas sous les autres OS < W10.

    Citation Envoyé par Médinoc Voir le message
    Et CreateFile() (ou ce que tu utilises pour écrire la DLL)?
    Quand il n'y a pas de dll pré-existante dans le répertoire de l'exe, CreateFile() n'est pas exécuté, car il se trouve dans FormCreate, qui ne se fait pas (on a le message d'erreur ci-dessus à la place).
    Si je mets cette dll manuellement avant de lancer l'exe, FormCreate se fait bien, et CreateFile() retourne bien un pointeur non NULL.

    Citation Envoyé par LittleWhite Voir le message
    Sinon, peut être en désactivant l'anti virus ?
    J'ai essayé, mais malheureusement, toujours le même comportement sous W10.

  7. #7
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Vérifie alors dans les options de compilation du projet, que ton programme est bien configuré pour charger la DLL en "delay-loaded DLL". Particulièrement si tu as des variations 32/64 bits, etc.
    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. [Windows]accès base de registre windows
    Par Greg01 dans le forum API standards et tierces
    Réponses: 27
    Dernier message: 05/06/2007, 15h14
  2. Documentation gratuite sur l'API Windows, COM, DCOM, OLE, etc.
    Par Community Management dans le forum Windows
    Réponses: 1
    Dernier message: 16/11/2006, 15h28
  3. Programme de boot qui passe la main à Windows
    Par Bob dans le forum Assembleur
    Réponses: 7
    Dernier message: 25/11/2002, 03h08
  4. OmniORB : code sous Windows et Linux
    Par debug dans le forum CORBA
    Réponses: 2
    Dernier message: 30/04/2002, 17h45
  5. Quel désassembleur/assembleur pour un exe Windows ?
    Par Anonymous dans le forum x86 32-bits / 64-bits
    Réponses: 6
    Dernier message: 17/04/2002, 10h59

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