12. Utilisation du Yocto-PT100 en C#
Console.Write("Module: serial= "
Console.WriteLine(" / name= "
} else {
Console.Write("not connected (check identification and USB
}
YAPI.FreeAPI();
}
}
}
Attention, le nombre de cycles d'écriture de la mémoire non volatile du module est limité. Passé cette
limite plus rien ne garantit que la sauvegarde des réglages se passera correctement. Cette limite,
liée à la technologie employée par le micro-processeur du module se situe aux alentour de 100000
cycles. Pour résumer vous ne pouvez employer la fonction
100000 fois au cours de la vie du module. Veillez donc à ne pas appeler cette fonction depuis
l'intérieur d'une boucle.
Enumeration des modules
Obtenir la liste des modules connectés se fait à l'aide de la fonction
qui renvoie le premier module trouvé, il suffit ensuite d'appeler la méthode
objet pour trouver les modules suivants, et ce tant que la réponse n'est pas un
petit exemple listant les module connectés
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace
ConsoleApplication1
{
class
Program
{
static
void
Main(string[] args)
{
YModule
m;
string
errmsg
if
(YAPI.RegisterHub("usb",
Console.WriteLine("RegisterHub error: "
Environment.Exit(0);
}
Console.WriteLine("Device
m
= YModule.FirstModule();
while
(m
!= null) {
Console.WriteLine(m.get_serialNumber() +
m
= m.nextModule();
}
YAPI.FreeAPI();
}
}
}
12.5. Gestion des erreurs
Lorsque vous implémentez un programme qui doit interagir avec des modules USB, vous ne pouvez
pas faire abstraction de la gestion des erreurs. Il y aura forcément une occasion où un utilisateur
aura débranché le périphérique, soit avant de lancer le programme, soit même en pleine opération.
La librairie Yoctopuce est prévue pour vous aider à supporter ce genre de comportements, mais
votre code doit néanmoins être fait pour se comporter au mieux pour interpréter les erreurs signalées
par la librairie.
La manière la plus simple de contourner le problème est celle que nous avons employé pour les
petits exemples précédents de ce chapitre: avant d'accéder à un module, on vérifie qu'il est en ligne
avec la méthode
isOnline()
seconde nécessaire à exécuter les lignes de code suivantes. Ce n'est pas parfait, mais ça peut
82
+ m.get_logicalName());
= "";
ref errmsg) !=
list");
et on suppose ensuite qu'il va y rester pendant la fraction de
+ m.get_serialNumber());
YModule.saveToFlash()
YAPI.SUCCESS) {
+ errmsg);
" ("
+ m.get_productName() + ")");
cable");
YModule.yFirstModule()
nextModule()
. Ci-dessous un
null
www.yoctopuce.com
que
de cet