4D v16.3RECEIVE PACKET |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
4D v16.3
RECEIVE PACKET
RECEIVE PACKET
La commande RECEIVE PACKET lit des caractères depuis un port série ou un document. Si docRef est spécifié, la commande récupère des données depuis un document ouvert par la fonction Open document, Create document ou Append document. Si docRef est omis, la commande récupère des données depuis un port série ou un document ouvert par la commande SET CHANNEL. Dans tous les cas, les caractères lus sont retournés dans la variable réceptVar, qui doit être une variable de type Texte, Alpha ou BLOB. Si les données ont été envoyées par la commande SEND PACKET, le type doit correspondre à celui du paquet envoyé. Notes
Si vous voulez recevoir un nombre prédéfini d'octets, passez ce nombre dans le paramètre nbOctets. Si la variable réceptVar est de type Texte, vous pouvez lire en un seul appel jusqu'à 2 Go de texte (limite théorique). Si vous voulez recevoir des données jusqu'à ce qu'une chaîne de caractères (comportant un ou plusieurs caractères) soit lue, passez-la dans le paramètre stopCar (la chaîne n'est pas retournée dans réceptVar).
Pendant l'exécution d'un RECEIVE PACKET, l'utilisateur peut interrompre l'opération en appuyant sur les touches Ctrl+Alt+Maj (sous Windows) ou Commande+Option+Maj (sous Mac OS). Cette interruption génère une erreur -9994 que vous pouvez intercepter à l'aide d'une méthode installée par la commande ON ERR CALL. Généralement, vous devez gérer les interruptions d'une réception uniquement lors d'une communication série. Lors de la lecture d'un document, le premier RECEIVE PACKET commence par lire le début du document. La lecture des paquets suivants débute au caractère situé immédiatement après le dernier octet lu. Note : Ce fonctionnement est valide avec un document ouvert par SET CHANNEL. Cependant, pour un document ouvert par Open document, Create document ou Append document, vous pouvez aussi utiliser les commandes Get document position et SET DOCUMENT POSITIONpour connaître et modifier la position à laquelle, dans le document, la prochaine écriture (SEND PACKET) ou lecture (RECEIVE PACKET) aura lieu. En cas de tentative de lecture après la fin d'un document, RECEIVE PACKET retourne les données lues jusqu'à ce point et la variable système OK prend la valeur 1. Les RECEIVE PACKET suivants retourneront une chaîne vide et OK prendra la valeur zéro. L'exemple suivant lit 20 caractères depuis un port série et les place dans la variable RécupVingt : RECEIVE PACKET(RécupVingt;20) L'exemple suivant lit des données depuis le document référencé par la variable MonDoc et les place dans la variable vData. La commande récupère les données jusqu'à ce qu'elle rencontre un retour chariot : RECEIVE PACKET(MonDoc;vData;Char(Carriage return)) L'exemple suivant lit des données du document référencé par la variable MonDoc et les place dans la variable vData. La commande récupère les données jusqu'à ce qu'elle rencontre une balise HTML de fin de tableau (</TD>) : RECEIVE PACKET(MonDoc;vData;"</TD>") L'exemple suivant lit des données d'un document et les place dans des champs. Les données sont stockées dans des champs de longueur fixe. La méthode fait appel à une sous-routine pour éliminer les espaces superflus (situés derrière les valeurs). Le code de la sous-routine est présenté après la méthode : $Doc :=Open document("";"TEXT") ` Ouverture d'un document de type Texte Les espaces superflus derrière les valeurs sont éliminés par la méthode suivante, appelée Elimine : For($i;Length($1);1;-1) ` Boucle sur la fin de la chaîne d'où démarrer Après un appel à RECEIVE PACKET, la variable système OK prend la valeur 1 si le paquet est reçu sans erreur. Sinon, OK prend la valeur 0.
Voir aussi
Get document position
|
PROPRIÉTÉS
Produit : 4D HISTORIQUE
Modifié : 4D v11 SQL MOTS-CLÉS BOM UTILISATION DE L'ARTICLE
4D - Langage ( 4D v16) |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||