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 :

[XP vers W7] Portage d'une application en C++


Sujet :

C++

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2014
    Messages : 28
    Points : 20
    Points
    20
    Par défaut [XP vers W7] Portage d'une application en C++
    Bonjour,
    je suis développeur débutant, en stage pour apprendre le métier, et dans la perspective d'une très prochaine migration de XP (32) vers W7 (64), il m'est demandé de procéder au portage d'une application. Cependant, je n'ai encore jamais fait ça et ne sais pas comment m'y prendre :

    • quels éléments dois-je exactement prendre en compte AVANT, PENDANT et APRES ?

    • Quels sont les changement impliqués dans le code même de l'application (codée en C++) ?

    • des conseils, des indications particulières ?

    Je suis là pour apprendre et suis preneur de toute remarque que vous m'apporterez.

    Merci beaucoup par avance !!

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 115
    Points : 32 967
    Points
    32 967
    Billets dans le blog
    4
    Par défaut
    Salut,

    porter une application c'est souvent pas compliqué.
    Tu prends ton projet, tu compiles, et tu résouds les erreurs jusqu'à ce que ça compile.
    De Windows à Windows, à moins d'utiliser des trucs très bas niveau ou bien spécifiques, c'est fort simple.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  3. #3
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Tout va dépendre de la qualité du code initial. Là, tu as deux portages en 1 :
    - 32 bits vers 64 bits
    - XP vers 7

    Je te suggère éventuellement d'en faire un troisième dans la foulé : Passer à une version plus récente du compilateur. En effet, quitte à devoir tout retester, autant ne le faire qu'une fois Et pour peu que ça te permette des nouveautés du langage comme auto, la partie portage 32/64 bits devrait être plus simple.


    Pour le premier, si ça compile, ça devrait déjà être pas trop mal. Généralement, les soucis vont être avec les tailles de conteneurs stockées dans des entiers là où il aurait fallu des size_t (en 32 bits, les deux types sont équivalents, pas en 64 bits.

    Pour le second, les plus gros problèmes que j'ai pu avoir son liés à l'UAC : Sous xp, il était autorisé qu'une application enregistre des choses dans son propre répertoire. Sous 7, le répertoire program files est protégé, tu ne peux pas écrire dedans. En fait, il te laisse croire que l'écriture au eu lieu, mais il met les données ailleurs, quand il ne lance pas tout simplement une erreur. Donc première chose à faire, c'est regarder si le programme essaye d'écrire là dedans (fichier de configuration, répertoire temporaire...).
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par JolyLoic Voir le message
    Pour le second, les plus gros problèmes que j'ai pu avoir son liés à l'UAC : Sous xp, il était autorisé qu'une application enregistre des choses dans son propre répertoire. Sous 7, le répertoire program files est protégé, tu ne peux pas écrire dedans. En fait, il te laisse croire que l'écriture au eu lieu, mais il met les données ailleurs, quand il ne lance pas tout simplement une erreur. Donc première chose à faire, c'est regarder si le programme essaye d'écrire là dedans (fichier de configuration, répertoire temporaire...).
    Inexact. C'est juste que sous XP, pratiquement tout le monde tournait en Admin, ce qui laissait les applications écrire dans leur propre répertoire même quand celui-ci était dans Program Files.
    Sous Vista et supérieur, même les Admins tournent en non-Admin par défaut.

    Les façons "horrible paresseux" de corriger ça casser le thermomètre, sont:
    • Ne pas installer l'application dans Program Files (certaines comme Google Chrome s'installent individuellement pour chaque utilisateur, dans un répertoire lui appartenant).
    • Indiquer dans le manifeste de l'application qu'elle doit toujours être exécutée en Admin, et que le commun des mortels n'a pas le droit de la lancer. Il existe certaines applications spécifiques pour lesquelles c'est justifié, mais elles sont rares.
    • Donner au commun des mortels le droit d'écrire dans le sous-répertoire en question (comme le fait Steam). Attention, ne jamais donner de tels droits sur Program Files lui-même!


    La vraie façon de corriger ça est:


    À noter que le même problème se présente pour le Registre (HKEY_LOCAL_MACHINE contre HKEY_CURRENT_USER).
    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 Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    17 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 17 452
    Points : 43 101
    Points
    43 101
    Par défaut
    Attention aux chemins si ils sont en durs
    Windows XP : Mes documents Vista/7 : Documents
    All Users devenant quelque chose comme ProgramData
    etc...
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Ou plus exactement,
    • Mes Documents devient FOLDERID_Documents
    • All Users devient FOLDERID_Public
    • All Users\Application data devient FOLDERID_ProgramData

    Etc.

    À noter aussi que SHGetKnownFolderPath() ne retourne que des paths en UTF-16: En 2014, on n'est plus vraiment censé utiliser des chemins de fichier en ASCII étendu. La classe CA2W (ou si tu n'as pas ATL/MFC, MultiByteToWideChar() dans un wrapper C++ de ton cru retournant une std::wstring) est ton amie.
    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.

  7. #7
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2014
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2014
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Très bien, merci beaucoup à tous pour vos réponses, j'en prends note.
    J'en suis encore à ma phase d'analyse pendant un petit moment je pense, le temps d'étudier correctement l'existant/ce qui a été fait, les versions utilisés etc, mais je reviendrai vers vous pendant l'écriture/la ré-écriture du code si j'ai loupé un truc...

    Mais si vous avez d'autres suggestions/conseils, n'importe quoi, n'hésitez pas à m'en faire part !!

    Merci à tous.

Discussions similaires

  1. [iOS] Portage d'une application Android vers iOS
    Par Kreepz dans le forum Applications mobiles
    Réponses: 4
    Dernier message: 26/02/2015, 15h18
  2. Réponses: 5
    Dernier message: 27/02/2013, 14h00
  3. Portages d'une application en console vers des fenêtres
    Par mess-mate dans le forum wxWidgets
    Réponses: 8
    Dernier message: 08/10/2008, 20h27
  4. portage d'une application à un téléphone portable?
    Par ryosnake dans le forum Développement Mobile en Java
    Réponses: 1
    Dernier message: 13/03/2006, 09h38
  5. Portage d'une application MFC sous Linux/Unix
    Par farscape dans le forum MFC
    Réponses: 29
    Dernier message: 20/02/2006, 17h47

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