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 :

Quelle arborescence de fichiers utiliser pour nos dépôts ? [Débat]


Sujet :

C++

  1. #21
    Membre expert
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    1 415
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 1 415
    Points : 3 156
    Points
    3 156
    Par défaut
    Salut à tous

    Je ne commite pas mes binaires non plus, ni tout ce qui peut être régénéré. Si un non développeur à un niveau suffisamment élevé pour utiliser un repo git ou svn, alors il doit aussi être capable de lancer la compile et générer le projet. Dans le cas contraire, on met un dépôt de binaires prêt à sa disposition via un autre canal.

    Je me permet de compléter un peu le débat avec un point qui n'a pas été vraiment soulevé : le code multi-plateforme. Je n'utilise pas la technique des macros pour sélectionner le code qui va sur une plateforme ou sur l'autre. Je préfère les mettre dans des .cc (ou .cpp selon votre convention) séparés totalement et laisser l'outil de compilation construire la liste des fichiers à utiliser.

    Un .cc mutliplateforme ira dans:
    src/[chemin]/fichier.cc

    Un .cc qui doit être implémenté différemment ira dans:
    src/[platform1]/[chemin]/fichier.cc
    src/[platform2]/[chemin]/fichier.cc
    Find me on github

  2. #22
    r0d
    r0d est déconnecté
    Expert éminent

    Homme Profil pro
    tech lead c++ linux
    Inscrit en
    Août 2004
    Messages
    4 262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : tech lead c++ linux

    Informations forums :
    Inscription : Août 2004
    Messages : 4 262
    Points : 6 680
    Points
    6 680
    Billets dans le blog
    2
    Par défaut
    J'ai une question à propos de ces arborescences de projets: lorsque vous utilisez des libs externes, comment gérez-vous les versions de ces libs externes (dépendances)?

    Prenons pour exemple boost, que tout le monde connait et qui fonctionne bien en tant qu'exemple car elle évolue beaucoup.
    La première approche consiste à se fixer une version: je fais mon appli avec la version 1.5.2 de boost, et je reste, jusqu'à la fin, sur cette version. L'avantage est que c'est beaucoup plus simple à gérer. Les désavantages sont multiples, et on les connait.

    La meilleure solution, surtout lorsqu'on travaille sur des projets voués à être maintenus et à évoluer pendant des années, est de mettre régulièrement à jour les dépendances. Mais alors, est-ce que vous faites apparaitre la version de la lib ou non? Par exemple, le dossier qui contient les en-têtes de boost s'appelera-t-il "boost-1.5.2" ou "boost"?
    « L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
    Spinoza — Éthique III, Proposition VII

  3. #23
    Membre émérite
    Avatar de white_tentacle
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    1 505
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 1 505
    Points : 2 799
    Points
    2 799
    Par défaut
    En général, les libs externes ne sont pas intégrées au repository. Il y aura exception si la lib est petite, que ça a du sens de la recompiler (par exemple : elle est modifiée par rapport à la version upstream).

    Du coup, la question ne se pose pas trop en terme d’organisation projet.

  4. #24
    Membre expert

    Avatar de germinolegrand
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Octobre 2010
    Messages
    738
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Octobre 2010
    Messages : 738
    Points : 3 892
    Points
    3 892
    Par défaut
    Pour ma part j'ai choisi d'intégrer les lib externes dans un dépôt exprès. J'ai des dépendances entre mes différents dépôts. Je pense que je vais rencontrer des problèmes quand il s'agira de revenir sur un vieux commit (encore que, non, suffit de regarder la date et de revert les différents dépôts à la même date), mais en tout cas c'est plus pratique pour travailler.

  5. #25
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Citation Envoyé par white_tentacle Voir le message
    En général, les libs externes ne sont pas intégrées au repository. Il y aura exception si la lib est petite, que ça a du sens de la recompiler (par exemple : elle est modifiée par rapport à la version upstream).

    Du coup, la question ne se pose pas trop en terme d’organisation projet.
    Tout à fait d'accord
    Citation Envoyé par r0d Voir le message
    J'ai une question à propos de ces arborescences de projets: lorsque vous utilisez des libs externes, comment gérez-vous les versions de ces libs externes (dépendances)?

    Prenons pour exemple boost, que tout le monde connait et qui fonctionne bien en tant qu'exemple car elle évolue beaucoup.
    La première approche consiste à se fixer une version: je fais mon appli avec la version 1.5.2 de boost, et je reste, jusqu'à la fin, sur cette version. L'avantage est que c'est beaucoup plus simple à gérer. Les désavantages sont multiples, et on les connait.

    La meilleure solution, surtout lorsqu'on travaille sur des projets voués à être maintenus et à évoluer pendant des années, est de mettre régulièrement à jour les dépendances. Mais alors, est-ce que vous faites apparaitre la version de la lib ou non? Par exemple, le dossier qui contient les en-têtes de boost s'appelera-t-il "boost-1.5.2" ou "boost"?
    Personnellement, je passerais plutôt une (des) variable(s) d'environnement / globales à l'EDI utilisé, #define dans un config.h (par exemple) ou tests dans l'outil de configuration que tu utilises (en fonction des cas ) avec les valeurs adéquates:

    Par exemple, des variables comme BOOST_VER_STRING qui prendraient une valeur 1_xy pour tout ce qui a trait au fait de déterminer les noms des bibliothèques et dossiers ou BOOST_VERSION pour tout ce qui permet de déterminer une version minimale à utiliser (outils de configuration automatique, essentiellement)
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  6. #26
    r0d
    r0d est déconnecté
    Expert éminent

    Homme Profil pro
    tech lead c++ linux
    Inscrit en
    Août 2004
    Messages
    4 262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : tech lead c++ linux

    Informations forums :
    Inscription : Août 2004
    Messages : 4 262
    Points : 6 680
    Points
    6 680
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par white_tentacle Voir le message
    En général, les libs externes ne sont pas intégrées au repository. Il y aura exception si la lib est petite, que ça a du sens de la recompiler (par exemple : elle est modifiée par rapport à la version upstream).
    Ha oui j'avais oublié que beaucoup de gens n'intègrent pas les dépendances externes au dépôt. C'est peut-être même une bonne pratique?

    Moi maintenant j'ajoute presque toutes mes dépendances externes à presque tous mes dépôts. Pour deux raisons:
    - J'aime bien lorsque, quelque soit l'environnement de dev (un pc vierge par exemple), tu checkout le dépôt, tu compiles, ça marche. Pas besoin d'aller chercher les dépendances à droite et à gauche.
    - Si tu récupères un projet vieux de 5 ans (et ça m'arrive assez régulièrement), c'est pas toujours évident (parfois impossible même) de trouver les bonnes versions de certaines libs.

    Les inconvénients sont nombreux, mais après 10 ans de pratique, je trouve que ces deux avantages, à eux seuls, pèsent plus que les inconvénients.
    « L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
    Spinoza — Éthique III, Proposition VII

  7. #27
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Bonjour,

    Personnellement, dès que la lib est petite, je l'intègre au dépôt, c'est plus simple, un seul cmake . && make à faire.

    Dès que la lib est assez "importante", je met ses sources et quelques binaires en téléchargement et je donne les URL dans mon fichier INSTALL.

Discussions similaires

  1. Réponses: 1
    Dernier message: 23/02/2015, 11h16
  2. Réponses: 18
    Dernier message: 11/05/2007, 19h35
  3. Réponses: 3
    Dernier message: 05/12/2006, 01h08
  4. Quel format de fichier utiliser pour les maps ?
    Par fb57 dans le forum OpenGL
    Réponses: 3
    Dernier message: 23/09/2004, 20h22

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