Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.md 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. title: Manifeste de développeur
  2. slug: manifeste-developpeur
  3. date: 2014-02-16
  4. chapo: Utilité, expérimentation, convivialité, partage, inconfort, économie et savoir-être.
  5. > Like any experienced engineer, I understand the desire to build the best, most flexible and robust system for every project. I do. But I also understand the common business constraints of every project: time and money. Most projects have a definite deadline and/or a specific budget that must be met and, often times, building something grand is just not feasible within either them. This is where the developer must make a conscious decision to limit creativity to meet the goals. There is no excuse for spending a week to setup a "proper" caching layer for database queries on a 20-row table, that is only used from the administrative panel by three publishers. Understand the use cases. As cool as it may be to build a flexible and expendable XHR framework to support variable simultaneous requests; you don't need to invest in it if the only feature that will be using it is an update to a visitors counter on one page. Understand the scope. I cannot stress it enough: a good engineer is not the one who knows how to build the most advanced system, but the one who knows when *not to* build that system.
  6. >
  7. > <cite>*[Your Code May Be Elegant](http://omniti.com/seeds/your-code-may-be-elegant)*</cite>
  8. Il s'agit d'un manifeste engagé qui fait état de mes réflexions actuelles sur le métier de développeur, il est amené à évoluer dans le temps :
  9. > **De l'utilité plus que de la qualité,**
  10. > **De l'expérimentation plus que du troll,**
  11. > **De la convivialité plus que de l'exhaustivité,**
  12. > **Du partage plus que de la mise en ligne,**
  13. > **De l'inconfort plus que de la sécurité,**
  14. > **De l'économie plus que de la performance,**
  15. > **Du savoir-être plus que du savoir-faire.**
  16. ## Utilité
  17. J'ai eu l'occasion de développer des produits de qualité. J'ai aussi eu l'occasion de développer des produits utiles. Étrange d'opposer les deux et pourtant j'ai rarement pu avoir les deux à la fois. Et rétrospectivement, ce sont clairement les produits utiles qui ont [donné du sens](/david/blog/2014/sens-utilite/) à mon savoir-faire. Un code de (sur-)qualité n'aura pas forcément [une durée de vie](/david/blog/2013/utilite-code/) plus longue mais il y a de grande chances qu'il mette beaucoup plus de temps à sortir, [ce qui met en péril le projet](/david/blog/2014/experience-conseils/) — aussi utile soit-il.
  18. ## Expérimentation
  19. Les développeurs passent (perdent ?) beaucoup trop de temps à discuter de technologies sans même les avoir essayées. Prenez [React](http://facebook.github.io/react/) par exemple, il serait facile de troller sur le fait qu'introduire du HTML directement dans du JS est une hérésie et pourtant après quelques heures de pratiques ça devient beaucoup plus pertinent. Et je prends du fun à coder avec ; sans me préoccuper des *design patterns* et autres *best practices*, il faut savoir [lâcher prise](/david/blog/2014/proteger-lacher-prise-rever/) et avancer à son rythme.
  20. ## Convivialité
  21. J'ai déjà eu l'occasion d'exposer ce que j'entendais par [Open-Source conviviale](/david/blog/2013/open-source-conviviale/) et mon désir de [rendre l'informatique plaisante](/david/blog/2013/informatique-plaisante/). Je suis fatigué des *frameworks* que l'on sort systématiquement pour publier une page statique, de ces bibliothèques qui cachent un manque de compréhension du langage et de toute la complexité dans laquelle s'enferme le développement Web [sur l'autel de son industrialisation](/david/blog/2012/api-proletarisation/). Il faut savoir revenir à la base : du contenu, des liens et des interactions.
  22. ## Partage
  23. Le partage va plus loin que [de la solidarité entre développeurs](/david/blog/2013/open-source-solidarite/), il y a [une notion d'apprentissage](/david/blog/2013/apprentissage-eponge/) et de retour d'expérience. Libérer son code est une chose, expliquer ses choix d'implémentation, ses échecs et les leçons apprises est autrement plus intéressant. [Github](/david/blog/2013/monopole-decentralise/) et Stack Overflow sont les *fast-foods* du code, je veux prendre le temps de raconter ma recette et l'enrichir avec d'autres.
  24. ## Inconfort
  25. Plus un milieu est changeant, plus il en va de sa survie d'explorer et de s'adapter rapidement ; c'est difficile à accepter mais le confort d'aujourd'hui est la mise au rebut de demain dans un domaine comme le Web. Il ne s'agit pas forcément d'aller dans le sens du courant mais d'avoir la curiosité de découvrir de nouveaux domaines et le goût [d'explorer de nouveaux concepts](/david/blog/2013/python-javascript/). Sortir de sa zone de confort est ce qui rend ce métier si stimulant.
  26. ## Économie
  27. La création d'usines à gaz génère forcément [un gaspillage numérique](/david/blog/2014/gaspillage-numerique/) non négligeable. On construit des 4x4 numériques dont on essaye d'optimiser la consommation alors que l'on aurait besoin de simples vélos ! De [bons défauts](/david/blog/2014/dogmatiques-defauts/) sont l'une des conditions pour obtenir un produit minimaliste qui soit pertinent mais ne suffisent pas, il faut avoir [une évolution culturelle](/david/blog/2013/opendata-culture/) et une démarche de [co-création](/david/blog/2013/opendata-citoyennete/).
  28. ## Savoir-être
  29. Enfin, je n'ai pas envie de travailler avec un gourou, un ninja ou une rockstar. J'ai [envie de collaborer](/david/blog/2013/scopyleft-valeurs/) avec quelqu'un à l'écoute, qui sait faire preuve de diplomatie dans sa critique, qui arrive à me faire douter sans forcément passer par la confrontation. La sur-compétence technique est contre-productive à toute forme d'échanges car elle crée un déséquilibre malsain.
  30. Est-ce que ce manifeste fait pour autant l'apologie du *code-poubelle* codé à la RACHE™ ? Je ne pense pas. **Il s'agit avant tout de revenir à un développement responsable qui donne du sens à notre métier et aux relations que l'on peut avoir avec nos pairs.**