Auteur Sujet: ArduiEmulator  (Lu 38831 fois)

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
ArduiEmulator
« le: octobre 18, 2017, 04:15:13 pm »
Pour moi qui développe professionnellement au quotidien avec Visual Studio de Microsoft sous Windows 10, utiliser l'IDE et ses ressources pour identifier un problème dans mes développements Arduino est une 'souffrance' permanente. Pas de vrai débogueur, un éditeur minimaliste... Alors dès le début de mes pérégrinations Arduinesques, j'ai tenté de trouver le moyen d'utiliser visual plutôt que l'IDE, mais aussi et surtout de tester mon code sans utiliser d'Arduino !

Des émulateurs existent sur le net ou ailleurs, mais ils ne permettent pas de voir l'évolution des variables pendant l'exécution, ni de suivre la progression du programme sur chaque ligne de code exécutée... Et ça, c'est dans le meilleurs des cas, lorsqu'ils permettent d'utiliser une bibliothèque maison...

Utilisant Visual Studio 2015 à l'époque, j'ai créé un projet ArduiEmulator dont le but initial n'était que de pouvoir compiler et lancer un fichier .ino sans aucune émulation. Juste de quoi voir ce qui se passe dans le setup... Pour ceux que cela intéresse, ce projet est en C++ managé, c'est à dire dans le Framework .Net. Si ces mots ne vous disent rien, ce n'est pas grave, ils ne seront utiles qu'à ceux qui voudront modifier l'émulateur. Rapidement, le besoin d'une véritable émulation pour les broches et un écran Lcd ont été nécessaires. En particulier au moment de développer et tester LcdUI.

Aujourd'hui, le projet s'est étendu, et il permet de simuler une mémoire EEPROM, une liaison série bidirectionnelle, un écran Lcd. Il dispose d'une console série pour voir passer les messages, d'une zone de saisie pour en envoyer par la liaison série, d'une liste des broches actives avec possibilité de les nommer pour plus de clarté, de la possibilité de cliquer dessus pour en changer l'état, etc...

Pour s'en servir il faut un Visual Studio 2015 ou 2017 Community qui est gratuit (https://www.visualstudio.com/fr/thank-you-downloading-visual-studio/?sku=Community&rel=15). Je sais que Visual existe sous Mac, mais je ne sais pas s'il est compatible, en particulier à cause de la partie .Net qui est obligatoire pour l'émulateur. Pour simplifier, nous considéreront pour la suite que l'on parle d'une version Windows.
Les croquis créés à l'aide de l'IDE vont par défaut dans 'Mes Documents/Arduino'. C'est là qu'il faudra décompresser le ArduiEmulator.zip que vous trouverez dans le répertoire extras de toutes mes bibliothèques (très) récentes. C'est d'ailleurs le même zip partout, il n'y a pas une version par bibliothèque...

Visual a besoin d'une 'solution' (un fichier .sln) pour travailler. Une solution est un ensemble de projets (fichiers .vcxproj) dont ArduiEmulator fait partie. Toujours dans mes bibliothèques récentes, se trouve un répertoire vstudio contenant une solution. Par exemple Accessories contient dans le répertoire 'Mes documents/Arduino/libraries/Accessories/vstudio' un fichier AccessoriesTestExe.sln qui permet de travailler avec l'émulateur.
Pour utiliser un fichier ino particulier, il faut modifier le fichier InoProjet.cpp dans Visual en remplaçant l'include du type

#include "../examples/locoduino.org/programme6/programme6.ino"

par le vôtre :

#include "../../MonCroquis/MonCroquis.ino"

Ensuite, F5 pour compiler et lancer, et vous vous retrouvez dans l'émulateur !

Il est également disponible pour Commanders, Accessories, LcdUi et DcDccNanoController. Bien sûr, certaines choses ne sont pas traitées, comme le DCC ou les bus CAN, I2C ou SPI. Mais si vous utilisez Commanders, alors vous aurez à disposition un nouveau type de bouton ButtonsCommanderKeyboard qui permet d'utiliser le clavier pour simuler des poussoirs. Il y a aussi une fonction pinName() pour nommer une broche. Pour les parties de code spécifiques à Visual, il y a un define VISUALSTUDIO pour faire la différence entre compilation dans Visual et ailleurs:

#ifdef VISUALSTUDIO
...
#endif

Cela permet par exemple d'isoler une partie liée au bus I2C puisque l'émulateur n'en fera rien.
Lors d'une compilation sur Visual Studio, on compile pour un Mega2560 avec 200 broches ! Les macros comme ACCESSORIES_DEBUG_MODE et ACCESSORIES_PRINT_ACCESSORIES sont activées par défaut.

Beaucoup de fonctions ne sont que purement décoratives et ne font rien, sauf permettre de compiler, comme la gestion des interruptions ou la bibliothèque Wire utilisée par le bus SPI. D'autres ont été complètement implémentées pour fonctionner, comme LiquidCrystal ou Serial. Je ne serais pas contre un peu d'aide pour continuer à étendre les fonctionnalités de cet émulateur !
« Modifié: octobre 19, 2017, 08:57:40 am par Thierry »

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #1 le: octobre 18, 2017, 05:21:42 pm »
bonjour,

j'ai ouvert la solution AccessoriesTestExe.sln avec VS2015.
après avoir rafraichit les chemins pour ArduiEmulator, j'ai lancé une compilation:

1ère erreur pour Test.exe: il demande DIO2.dll
j'essaye de compiler le projet DIO2: erreur arduino.h introuvable
j'ajoute arduino.h (se trouvant dans les sources de ArduiEmulator) dans le projet DIO2
encore erreur: arduiemulator.inc introuvable (et effectivement manquant dans les sources ArduiEmulator)

peux tu corriger tout cela et également mettre à jour ton sujet pour expliquer les imbrications des projets et les étapes à effectuer avant de pouvoir exécuter l'émulation arduino avec un .ino ?

Merci beaucoup

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #2 le: octobre 18, 2017, 08:37:16 pm »
Je dois faire des essais.
Tu es le premier utilisateur de cette solution qui n'était pas destinée à une diffusion mondiale ! Il faut donc que je teste un peu en situation réelle (biblio fraîchement installées...) pour me retrouver dans le même cas que toi et pouvoir corriger... L'autre excuse, si je devais en avoir une, c'est que la plupart des autres contributeurs du site travaillent sous Linux ou Mac. Je n'avais donc pas la pression pour mettre ArduiEmulator à disposition, vu qu'il ne tourne pas dans ces environnements.
Je reviens au plus vite pour apporter des réponses.

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #3 le: octobre 18, 2017, 08:42:51 pm »
Tu n'as pas besoin de t'excuser :)
Je trouve déjà formidable cette émulation en pouvant charger des sketch !  :D

Prends ton temps.
De mon coté je suis plus occuper sur les autres librairies ;)

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #4 le: octobre 19, 2017, 05:38:39 pm »
J'ai refait les tests, ajouté les fichiers manquants et poussé toutes les bibliothèques avec les bonnes versions partout : DIO2, Accessories, Commanders, LcdUI et DcDccNanoController.
Je te conseille vivement d'enlever toutes ces bibliothèques, de les ré-installer, ainsi que ArduiEmulator. Chez moi, en partant d'un Libraries vide et sans ArduiEmulator du tout, j'ai  tout installé et cliqué sur les fichiers sln de Accessories, LcdUi et DcDccNanoController, et tout à démarré au premier F5...

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #5 le: octobre 20, 2017, 09:49:09 am »
Bonjour,

J'ai récupéré les nouveaux fichiers, tout remplacé.
J'ai ouvert la solution AccessoriesTestExe.sln, fait F5....
Mais à la compilation j'ai toujours ce problème de dll manquante:
Error   C1192   #using failed on 'Documents\Arduino\libraries\Accessories\VStudio\x64\Debug\DIO2.dll'   TestExe   Documents\Arduino\libraries\Commanders\src\ButtonsCommander.cpp   1   
Et pour le projet DIO2, le fichier arduino.h manquant.

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #6 le: octobre 21, 2017, 10:50:01 am »
Deux pistes rapides :

L'emplacement de ArduiEmulator. Pour que ça marche le fichier Arduino.h doit se trouver avec une arborescence comme "Mes Documents\Arduino\ArduiEmulator\ArduiEmulator\Arduino.h" . Oui, oui, avec deux fois ArduiEmulator. C'est une erreur sans conséquence du début du projet que je n'ai pas pris le temps de corriger....

La compilation doit se faire en debug/x64. Je n'ai rien testé d'autre !

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #7 le: octobre 21, 2017, 11:21:25 am »
Bonjour,

Je suis d'accord pour l'emplacement à respecter mais arduino.h n'existe pas dans les sources de DIO2.

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #8 le: octobre 21, 2017, 01:34:52 pm »
C'est parce qu'il n'y est pas ! Il est présent dans ArduiEmulator et doit y rester. C'est la configuration du projet qui dit d'aller chercher les includes dans ArduiEmulator. Pour retrouver cette configuration :

propriétés du projet DIO2
C/C++/General
première ligne Additionnal Include Directories : $(VisualStudioDir)\..\Arduino\ArduiEmulator\ArduiEmulator

dans le contexte $(VisualStudioDir) est remplacé par 'Mes documents/Visual Studio 2017'.

Je me rend compte en écrivant cette réponse que c'est peut être Visual lui-même le problème. J'utilise 2017 en anglais, et je viens d'essayer avec un 2015 en français et le résultat n'est pas bon. Je dois creuser, mais on m'attend pour aller au théâtre, alors ce sera pour demain. Bonne fin de journée !

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #9 le: octobre 21, 2017, 02:27:57 pm »
OK.
Pour ma part je ne pourrai vérifier que lundi sur VS2015...

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #10 le: octobre 22, 2017, 03:13:03 pm »
Que faire pour que ça compile sur VS2015 :

Dans le projet DIO2, changer dans Linker/Debugging : 'Generate Debug Info' en 'Optimize for debugging (/DEBUG)'

Dans les trois projets changer dans General : 'Platform Toolset' en 'Visual Studio 2015 (v140)'

Pour moi, cela a corrigé les problèmes. L'autre solution est d'utiliser VS 2017 !

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #11 le: octobre 23, 2017, 10:01:02 am »
bonjour,

Oui j'avais déjà modifié "Platform Toolset" pour correspondre avec VS2015.

J'ai enfin réussi à compiler et exécuter TestExe.exe !  :D
J'ai dû en plus:
- pour chaque projet, reconfigurer "Output Directory"
- TestExe:
    ajouter dans "Additonnal Include Directory" les répertoires sources de ArduiEmulator, DIO2, Commanders
    ré-inclure en dépendances les projets ArduiEmulator et DIO2 après qu'ils ait été recompilés.

L'exemple programme2.ino fonctionne bien dans l'émulateur  8)

Par contre programme6.ino plante sur EEPROMClass ligne 343 dans InoProject.cpp, mais bon ton projet émulateur est en plein développement donc je ne m'inquiète pas d'avoir des possibles plantages  ;)

Encore bravo pour cet émulateur, et je suis prêt à t'aider (plus en tant que beta testeur qu'en tant que développeur) pour continuer son développement :)

Thierry

  • Global Moderator
  • Hero Member
  • *****
  • Messages: 810
    • Voir le profil
Re : ArduiEmulator
« Réponse #12 le: octobre 23, 2017, 10:17:58 am »
Bravo. Content que ça marche.
Pour l'EEPROM, je n'ai pas réussi à reproduire les fonctions get et put via des macros/templates/generics. Rien n'y fait, je n'y arrive pas. En désespoir de cause, j'ai fini par ajouter une alternative qui permet de tester quand même au prix d'un #ifdef VISUALSTUDIO bien peu élégant...
Dans l'état actuel des choses, à part ce problème je n'ai rien de prévu pour encore améliorer l'émulateur. Mais si tu as des suggestions, je suis preneur.

bagou91

  • Jr. Member
  • **
  • Messages: 52
    • Voir le profil
Re : ArduiEmulator
« Réponse #13 le: octobre 23, 2017, 10:25:31 am »
une suggestion:
si on peut livrer une release (beta) avec les dll sans avoir besoin de recompiler ce serait bien:
peut être ajouter un bouton sur l'interface pour choisir le sketch à exécuter.

savignyexpress

  • Invité
Re : ArduiEmulator
« Réponse #14 le: avril 24, 2018, 02:24:02 pm »
Bonjour Thierry,

J'ai lu avec grand intérêt les échanges autour de la bibliothèque ArduiEmulator.

Développant sous Linux avec gcc, je serais intéressé d'adapter le concept pour mettre au point des programmes Arduino comme je fais déjà en C natif pour AVR.

Cela implique de créer un Makefile ou passer sous Eclipse pour cela, mais il me faudrait les sources. Mais je n'ai pas trouver d'où les télécharger.

Merci pour l'info.
Meilleures salutations.

Marc-Henri