Ruby Core

Avec l’arrivée de Ruby 2.0, participer au développement du langage est certainement plus attrayant que jamais. Les nouveaux talents et les bonnes volontés sont les bienvenus, que ce soit pour participer au cœur du code ou à la documentation. Mais par où commencer ?

Cette page couvre les sujets suivants :

Utiliser Subversion pour suivre le développement de Ruby

Pour récupérer la dernière version du code source Ruby, il faut réaliser un check out en se connectant au compte anonyme du dépôt Subversion. Dans un terminal :

$ svn co https://svn.ruby-lang.org/repos/ruby/trunk ruby

Le répertoire ruby contient maintenant le code source de Ruby 1.9.x (tronc) dans sa dernière version. Le tronc a été dupliqué en Janvier 2009 pour donner naissance à la branche stable 1.9.1. Actuellement, les patchs pour le tronc sont ensuite rétroappliqués à la branche 1_9_1 (voir détails ci-après).

Si vous êtes plutôt intéressé par le suivi des patchs appliqués à Ruby 1.9.1 plutôt qu’à la branche de développement (tronc instable), il vous faut récupérer la branche stable par :

$ svn co https://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1

Si vous êtes intéressés par la branche 1.8.6 ou 1.8.7 :

$ svn co https://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8_*

* est 6 ou 7.

Les développeurs travaillant sur Ruby 1.8 doivent migrer leurs modifications sur la branche principale, de sorte qu’en général, les deux branches sont assez similaires, avec la notable exception des améliorations portées sur le langage lui-même par Matz et Nobu.

Vous pouvez également parcourir le dépôt Subersion en ligne.

Pour des informations sur le logiciel Subversion en lui-même, voyez la Subversion FAQ et le Subversion book. Un excellent livre introductif est Pragmatic Version Control with Subversion.

Utiliser Git

Pour ceux d’entre-vous qui préfèrent Git, il existe un miroir de développement sur GitHub. Des instructions précises et différenciées sont disponibles pour les développeurs possédant le droit de commit et les autres.

Améliorer Ruby, patch par patch

Rubyforge maintient un système de suivi des bugs permettant de transmettre patchs et rapports de bugs à Matz et l’équipe de développement. Ces rapports parviennent également à la liste de diffusion Ruby-Core, ils ne passent donc pas inaperçus.

Pour résumer, les grandes étapes pour proposer un patch sont :

  1. Récupérer une copie de travail de Ruby 1.8 depuis Subversion, sur la branche ruby_1_8 branch.

     $ svn co https://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8
    
  2. Ajouter vos améliorations dans le code (dans le répertoire/dossier ruby_1_8 en local).
  3. Créer un patch.

     $ svn diff > ruby-1.8-changes.patch
    
  4. Envoyer ce patch.

Note importante: les patchs doivent être au format unified diff. Pour plus d’informations sur les patchs, leur devenir, voyez the diffutils reference.

Les discussions portant sur le développement de Ruby sont toutes regroupées sur la liste de diffusion Ruby-Core. Donc, si vous êtes curieux du devenir de votre patch, ou si vous voulez lancer une discussion sur le futur de Ruby, n’hésitez pas à venir y faire un tour. Prenez garde à ne pas lancer des hors-sujets, ils ne sont pas tolérés sur cette liste dont le niveau de bruit doit rester très bas. Les sujets doivent être précis, bien rédigés et conçus. Parmi les intervenants figurent les créateurs de Ruby, le respect mutuel est donc la norme.

Gardez également à l’esprit que les développeurs principaux de Ruby résident au Japon, et si la plupart parlent un excellent anglais, il y a un décalage horaire conséquent. Il existe également tout un groupe de listes de diffusion entièrement en japonais, similaires à leurs équivalent en anglais. Soyez patients, et n’hésitez pas à intervenir de nouveau après quelques jours si votre question n’a pas reçu de réponse.

Règles et usages pour les développeurs principaux

Les développeurs de Ruby devraient évidemment être à l’aise avec le code source et le style utilisé par l’équipe principale. Les principales règles à vérifier avant tout envoi vers le dépôt Subversion sont :

  • tout check in doit être décrit dans le ChangeLog, en respectant les conventions GNU. Plusieurs développeurs principaux utilisent le mode add-log d’Emacs à cette fin, mode s’activant par la combinaison C-x 4 a ;
  • les dates de check in doivent être données au Japan Standard Time (UTC+9) ;
  • les différents items de votre ChangeLog doivent également être mentionnés dans le résumé Subversion, car ce message est automatiquement transmis à la liste de diffusion Ruby-CVS après le commit ;
  • les prototypes de fonctions sont utilisés dans l’ensemble du code source de Ruby et des extensions liées ;
  • pas de commentaire en style C++ (//), seul le commentaire multiligne est utilisé (/* .. */).