Table des matières

Mais rien n'apparaît ??! C'est normal...

En effet, n’ont été créés que les 2 fichiers utiles au fonctionnement de Blockly : le créateur du bloc et le générateur de code. Mais Blockly@rduino ne sait toujours pas que ces fichiers existent et qu’il faut les utiliser, voici dnc comment terminer la procédure.

On les appelle

Il faut éditer les 2 fichiers ‘\blocks\arduino_resume.js’ (qui contient la liste de toutes les définitions de blocs dans lesquelles piocher pour les construire) ET\generators\arduino_resume.js’ (qui contient la liste de toutes les traductions des blocs en langage Arduino dans lesquelles piocher pour les traduire).

Respectons un peu d’ordre, il suffit de copier une ligne existante et de changer le dossier ET le nom du fichier :

Il ne reste plus qu’à rafraîchir la page de Blockly@rduino et admirer le travail !!!

Bon, ben là, il ne se passe toujours rien…si tout est normal c’est déjà que vous n’avez pas rajouté d’erreur…

Il en manque...

Il sait qu’il doit examiner ces contenus, mais il les affiche quand ? A quel endroit dans le menu ? Ah mais oui, nom de Zeus la toolbox !!!

La ‘toolbox’ est le nom donné par Blockly pour les menus, les différents fichiers sont enregistrés dans le dossier ‘\toolbox\’ :

Libre à vous de créer d’autres toolbox en n’oubliant pas de modifier index.html :

Bref ouvrons donc la ou les toolbox à modifier et rajoutons les lignes correspondantes en s’inspirant de ce qui existe déjà :

C’est facile à décrypter :

Dans mon exemple j’ai choisi de le disposer avant la catégorie ‘CAT_BQ’. Ce n’est pas le nom qui apparaît…

Courage on y est presque !

Comme nous n’avons utilisé que des variables, les textes portent pour l’instant le nom de la variable et non pas son contenu ! Là c’est très facile car il suffit de porter les équivalences dans les fichiers de langue ad-hoc dans le dossier ‘\lang\blocks\’(merci de compléter au moins le english en plus) :

TRUC & ASTUCE: comme il s’agit de variables, par aspect pratique, j’ai fait des équivalences de variables : Blockly.Msg.FLYCAM_STOP_INPUT = Blockly.Msg.FLYCAM_SWITCH_INPUT; car la variable Blockly.Msg.FLYCAM_SWITCH_INPUT est définie juste au-dessus. Car le système lit les informations dans l’ordre des lignes !

Ca y est !!! A vous la gloire d'avoir contribué à ce magnifique projet !!!

Et la joie de debugger si comme moi vous faites régulièrement des fautes de frappe, d’oubli de points virgule ; , etc…

Ok, mais ce n'est plus suffisant !

En effet, en programmation héritée des langages C, il est indispensable de définir la nature des objets, donc le type des variables. Grâce à l’excellent script du créateur d’Ardublockly (et pas Ardublock), tous les types sont recensés dans le fichier ‘\core_Ardublockly\static_typing.js’ :

Donc il va aussi falloir expliquer à Blockly@rduino de quelle nature/type (en référence aux noms dans le fichier ci-dessus) est chaque bloc créé :

Blockly.Types.CHARACTER            // Single character
Blockly.Types.TEXT                  // General text string type
Blockly.Types.BOOLEAN               // Can only have two values, generally 0 for false, or 1 for true
Blockly.Types.NUMBER                // A general number type
Blockly.Types.VOLATIL_NUMBER        // Volatil specific for interruption
Blockly.Types.SHORT_NUMBER          // Short integer number
Blockly.Types.LARGE_NUMBER          // Number in a large range
Blockly.Types.DECIMAL               // Number type for numbers with a fractional part
Blockly.Types.ARRAY                 // Array of any type of items
Blockly.Types.NULL                  // Used as a "no type" wild card natively
Blockly.Types.UNDEF                 // Can be used to delegate type assignment
Blockly.Types.CHILD_BLOCK_MISSING   // Set when no child block (meant to define the variable type) is connected

Créez pour mon exemple le fichier ‘blocksflycamone-eco-v2blocks_typing.js’ et rajoutez les lignes ad-hoc en bas :

Cela permet de typer automatiquement les variables en fonction des blocs en entrée :

Puis finir en recensant ce nouveau fichier de typages dans le fichier centralisateur ‘blocksblocks_typing.js’

Ouf c'est fini !

Il ne vous reste plus qu’à envoyer un petit mail à canet.s@free.fr pour un petit merci, un petit coucou et surtout contribuer en proposant de rajouter à cette aventure collective vos travaux !

Il en manque...

Il sait qu’il doit examiner ces contenus, mais il les affiche quand ? A quel endroit dans le menu ? Ah mais oui, nom de Zeus la toolbox !!!

La ‘toolbox’ est le nom donné par Blockly pour les menus, les différents fichiers sont enregistrés dans le dossier ‘\toolbox\’ :

Libre à vous de créer d’autres toolbox en n’oubliant pas de modifier index.html :

Bref ouvrons donc la ou les toolbox à modifier et rajoutons les lignes correspondantes en s’inspirant de ce qui existe déjà :

C’est facile à décrypter :

Dans mon exemple j’ai choisi de le disposer avant la catégorie ‘CAT_BQ’. Ce n’est pas le nom qui apparaît…

Courage on y est presque !

Comme nous n’avons utilisé que des variables, les textes portent pour l’instant le nom de la variable et non pas son contenu ! Là c’est très facile car il suffit de porter les équivalences dans les fichiers de langue ad-hoc dans le dossier ‘\lang\blocks\’(merci de compléter au moins le english en plus) :

TRUC & ASTUCE: comme il s’agit de variables, par aspect pratique, j’ai fait des équivalences de variables : Blockly.Msg.FLYCAM_STOP_INPUT = Blockly.Msg.FLYCAM_SWITCH_INPUT; car la variable Blockly.Msg.FLYCAM_SWITCH_INPUT est définie juste au-dessus. Car le système lit les informations dans l’ordre des lignes !

Ca y est !!! A vous la gloire d'avoir contribué à ce magnifique projet !!!

Et la joie de debugger si comme moi vous faites régulièrement des fautes de frappe, d’oubli de points virgule ; , etc…

Ok, mais ce n'est plus suffisant !

En effet, en programmation héritée des langages C, il est indispensable de définir la nature des objets, donc le type des variables. Grâce à l’excellent script du créateur d’Ardublockly (et pas Ardublock), tous les types sont recensés dans le fichier ‘\core_Ardublockly\static_typing.js’ :

Donc il va aussi falloir expliquer à Blockly@rduino de quelle nature/type (en référence aux noms dans le fichier ci-dessus) est chaque bloc créé :

Blockly.Types.CHARACTER            // Single character
Blockly.Types.TEXT                  // General text string type
Blockly.Types.BOOLEAN               // Can only have two values, generally 0 for false, or 1 for true
Blockly.Types.NUMBER                // A general number type
Blockly.Types.VOLATIL_NUMBER        // Volatil specific for interruption
Blockly.Types.SHORT_NUMBER          // Short integer number
Blockly.Types.LARGE_NUMBER          // Number in a large range
Blockly.Types.DECIMAL               // Number type for numbers with a fractional part
Blockly.Types.ARRAY                 // Array of any type of items
Blockly.Types.NULL                  // Used as a "no type" wild card natively
Blockly.Types.UNDEF                 // Can be used to delegate type assignment
Blockly.Types.CHILD_BLOCK_MISSING   // Set when no child block (meant to define the variable type) is connected

Créez pour mon exemple le fichier ‘blocksflycamone-eco-v2blocks_typing.js’ et rajoutez les lignes ad-hoc en bas :

Cela permet de typer automatiquement les variables en fonction des blocs en entrée :

Puis finir en recensant ce nouveau fichier de typages dans le fichier centralisateur ‘blocksblocks_typing.js’

Ouf c'est fini !

Il ne vous reste plus qu’à envoyer un petit mail à canet.s@free.fr pour un petit merci, un petit coucou et surtout contribuer en proposant de rajouter à cette aventure collective vos travaux !