ENTIER LONG VERS BLOB

4D - Documentation   Français   English   German   4e Dimension, Commandes par thèmes   4e Dimension, Liste alphabétique des commandes   4e Dimension, Constantes par thèmes   Retour   Précédent   Suivant

version 6.0


ENTIER LONG VERS BLOB (entierLong; blob; ordreOctets{; offset | *})

ParamètreTypeDescription
entierLongNumériqueValeur de type Entier long à écrire dans BLOB
blobBLOBBLOB devant recevoir l'entier long
ordreOctetsNumérique0  Ordre d'octets natif
1  Ordre d'octets Macintosh
2  Ordre d'octets PC
offset | *Variable | *Offset (en octets) dans le BLOB
ou * pour ajouter la valeur à la fin du BLOB
Nouvel offset après l'écriture si * omis

Description

La commande ENTIER LONG VERS BLOB écrit la valeur de type Entier long (4 octets) entierLong dans le BLOB blob.

Le paramètre ordreOctet fixe l'ordre des octets ("byte ordering") de la valeur Entier long à écrire. Vous passez une des constantes fournies par 4e Dimension :

ConstanteTypeValeur
Ordre octets natifEntier long0
Ordre octets MacintoshEntier long1
Ordre octets PCEntier long2

Note sur l'indépendance de plate-forme : Si vous échangez des BLOBs entre les plates-formes Macintosh et PC, il vous incombe de traiter les conversions d'octets ("byte swapping") lorsque vous utilisez cette fonction.

Si vous passez le paramètre optionnel *, l'entier long sur 4 octets est ajouté à la fin du BLOB et la taille de blob est modifiée en conséquence. Ainsi, à l'aide du paramètre optionnel *, vous pouvez stocker les unes derrière les autres autant de valeurs de type Entier, Entier long, Numérique ou Texte (référez-vous aux autres commandes sur les BLOBs) que vous voulez dans un BLOB, la seule limite étant celle de la mémoire disponible.

Si vous ne passez pas le paramètre optionnel * ni de variable dans le paramètre offset, l'entier long est stocké au début de blob en remplaçant son contenu précédent, et la taille du BLOB est modifiée en conséquence.

Si vous passez une variable dans le paramètre offset, l'entier long est écrit à partir de l'offset offset, exprimé en octets (à partir de zéro), du BLOB. Quel que soit l'endroit où vous placez l'entier long, la taille du BLOB sera augmentée si nécessaire en fonction de l'emplacement que vous avez défini (plus jusqu'à 4 octets le cas échéant). Les octets redéfinis (autres que ceux que vous venez d'écrire) sont initialisés à la valeur zéro.

Après l'exécution de la commande, la variable du paramètre offset est incrémentée du nombre d'octets ayant été écrits. Vous pouvez par conséquent réutiliser la même variable avec une autre commande d'écriture de BLOB afin de placer une autre valeur juste après celle que vous venez d'écrire.

Exemples

(1) Après l'exécution de ce code :

   ENTIER LONG VERS BLOB (0x01020304;vxBlob;Ordre octets natif)

La taille de vxBlob est 4 octets

SurMacintosh vxBLOB{0}=$01, vxBLOB{1}=$02, vxBLOB{2}=$03, vxBLOB{3}=$04

Sur PC vxBLOB{0}=$04, vxBLOB{1}=$03, vxBLOB{2}=$02, vxBLOB{3}=$01

(2) Après l'exécution de ce code :

   ENTIER LONG VERS BLOB (0x01020304;vxBlob;Ordre octets Macintosh)

La taille de vxBlob est 4 octets

Sur toutes les plates-formes vxBLOB{0}=$01, vxBLOB{1}=$02, vxBLOB{2}=$03, vxBLOB{3}=$04

(3) Après l'exécution de ce code :

   ENTIER LONG VERS BLOB (0x01020304;vxBlob;Ordre octets PC)

La taille de vxBlob est 4 octets

Sur toutes les plates-formes vxBLOB{0}=$04, vxBLOB{1}=$03, vxBLOB{2}=$02, vxBLOB{3}=$01

(4) Après l'exécution de ce code :

   FIXER TAILLE BLOB (vxBlob;100)
   ENTIER LONG VERS BLOB (0x01020304;vxBlob;Ordre octets PC)

La taille de vxBlob est 104 octets

Sur toutes les plates-formes vxBLOB{100}=$04, vxBLOB{101}=$03, vxBLOB{102}=$02, vxBLOB{103}=$01

Les autres octets du BLOB sont inchangés

(5) Après l'exécution de ce code :

   FIXER TAILLE BLOB (vxBlob;100)
   vlOffset:=50
   ENTIER LONG VERS BLOB (0x01020304;vxBlob;Ordre octets Macintosh;vlOffset)

La taille de vxBlob est 100 K

Sur toutes les plates-formes vxBLOB{50}=$01, vxBLOB{51}=$02, vxBLOB{52}=$03, vxBLOB{53}=$04

Les autres octets du BLOB restent inchangés

La variable vlOffset a été incrémentée de 4 (et est alors égale à 54)

Référence

BLOB vers entier, BLOB vers entier long, BLOB vers reel, BLOB vers texte, ENTIER VERS BLOB, REEL VERS BLOB, TEXTE VERS BLOB.


4D - Documentation   Français   English   German   4e Dimension, Commandes par thèmes   4e Dimension, Liste alphabétique des commandes   4e Dimension, Constantes par thèmes   Retour   Précédent   Suivant