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

Langage PHP Discussion :

Développement d'une librairie, Autoloader ou require/include?


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Avatar de _skip
    Homme Profil pro
    Développeur d'applications
    Inscrit en
    Novembre 2005
    Messages
    2 898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur d'applications
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 898
    Par défaut Développement d'une librairie, Autoloader ou require/include?
    Bonjour,

    Je n'arrive pas à trouver une vraie réponse à ce problème. Je mets actuellement à disposition une librairie permettant de faciliter l'utilisation de services distants (payants) développés par mon entreprise. La version actuelle comprend une quarantaine de classes, pour faciliter au maximum la mise en oeuvre, il y a un seul répertoire et l'inclusion est gérée par des require_once().
    Ca fonctionne, personne ne s'est jamais plaint, mais niveau maintenance ça commence à devenir pas terrible de gérer tous les cas d'utilisation de la lib sans tout à coup oublier un require_once() quelque part, et ce d'autant plus que ce n'est pas facilement détectable.

    Donc j'hésite à utiliser un autoloader, mais je sais pas si c'est une pratique acceptable dans le cas d'une librairie tierce. Est-ce que je peux raisonnablement demander à mes utilisateurs d'enregistrer mon propre autoloader dans leur stack? Il me semble que que ça pourrait être vu comme une exigence assez intrusive.

    Je n'arrive pas à trouver vraiment un état de l'art en la matière. J'ai regardé pas mal de librairies sur le net, la moitié du temps soit elles sont super simples et utilisent include/require, soit elles sont conçues spécifiquement pour des frameworks et elles utilisent les conventions de ces derniers.
    Un petit conseil ou une piste pour moi? Est-ce que vous jugez raisonnable qu'un code tiers exige d'enregistrer son autoloader ou au contraire vous trouvez que c'est pas concevable à cause... par exemple de conflits ou de soucis d'indépendance du projet par rapport à la lib en question?

  2. #2
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    L'idéal est à mon avis un autoloader qui respecte le standard PSR-0
    Si en plus tu veux simplifier la vie de tes utilisateurs tu peux carrément en faire un package composer (voir cette doc en particulier) ce qui permettra des installations ultra rapide.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre Expert

    Profil pro
    Inscrit en
    Mai 2008
    Messages
    1 576
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 1 576
    Par défaut
    Autoloader sans hésiter.
    S'ils utilisent composer, il n'y aura aucun problème. Sinon, tu peux mettre ton autoloader dans un fichier bootstrap et leur demander d'inclure ce fichier.

  4. #4
    Membre éprouvé
    Avatar de _skip
    Homme Profil pro
    Développeur d'applications
    Inscrit en
    Novembre 2005
    Messages
    2 898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur d'applications
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 898
    Par défaut
    Merci pour vos réponses.
    Donc pour vous c'est pas un problème d'amener son propre autoloader pour une librairie tierce. Effectivement j'aurai certainement fait ça en demandant d'inclure un fichier qui aurait fait le "register".
    Je suis déjà tombé sur PSR-0 lors de mes recherches, par contre j'ai aussi cru comprendre que c'était basé sur les namespaces qui sont devenus accessibles en 5.3. J'hésite à dropper le support pour 5.2 dans ma prochaine version mais je ne sais pas encore si je vais le faire car je trouve peu d'infos sur les parts de marché de 5.2.

  5. #5
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    5.2 est sortie en 2006 autant dire qu'un serveur encore sous cette version c'est une faute professionnel.

    Pour des stats de version tu peux regardé sur le blog de pascal martin :
    http://blog.pascal-martin.fr/post/st...ns-php-2013-11
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  6. #6
    Membre éprouvé
    Avatar de _skip
    Homme Profil pro
    Développeur d'applications
    Inscrit en
    Novembre 2005
    Messages
    2 898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur d'applications
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 898
    Par défaut
    Je suis d'accord avec toi pour 5.2, mais si tu voyais les trucs sur lesquels je tombe parfois, enfin je pense que tu imagines sans peine... Faut que je réfléchisse à tout ça.
    En tout cas merci pour les conseils et tous les pointeurs, ça m'a été très utile.

    Si vous voulez ajouté quelque chose, hésitez pas.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 7
    Dernier message: 30/05/2008, 16h50
  2. Réponses: 5
    Dernier message: 02/01/2008, 16h58
  3. inclure une librairie *.lib
    Par darkbm dans le forum C
    Réponses: 2
    Dernier message: 16/12/2002, 22h48

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