Aller au contenu principal
Version: v20 R4 BETA

Operators

Un opérateur est un symbole ou un groupe de symboles que vous utilisez pour vérifier, modifier ou combiner des valeurs. Vous connaissez déjà la plupart des opérateurs. Par exemple, 1 + 2 utilise l'opérateur d'addition (ou le signe "plus") pour additionner deux nombres, et a pour résultat le chiffre 3. Les opérateurs de comparaison, comme = ou >, vous permettent de comparer deux valeurs ou plus.

Le langage 4D prend en charge les opérateurs que vous connaissez peut-être déjà dans d'autres langages tels que le C ou JavaScript. Toutefois, l'opérateur d'affectation est := pour éviter qu'il ne soit utilisé par erreur lorsque l'opérateur "égal à" (=) est prévu. Les opérateurs de base tels que les opérateurs arithmétiques (+, -, *, /, %...) et les opérateurs de comparaison (=, >, >=...) peuvent être utilisés avec des nombres, mais aussi avec des types de données au format booléen, texte, date, heure, pointeur ou image. Tout comme JavaScript, le langage 4D prend en charge le concept de valeurs truthy et falsy, qui sont utilisées dans les opérateurs de court-curcuit.

Terminologie

Le langage 4D prend en charge les opérateurs binaires et ternaires :

  • les opérateurs binaires opèrent sur deux cibles (comme 2 + 3) et apparaissent entre leurs deux cibles.
  • les opérateurs ternaires opèrent sur trois cibles. Comme le C, 4D ne possède qu'un seul opérateur ternaire, l'opérateur conditionnel ternaire (a ? b : c).

Les valeurs que les opérateurs affectent sont des opérandes. Dans l'expression 1 + 2, le symbole + est un opérateur binaire et ses deux opérandes sont les valeurs 1 et 2.

Opérateur d'assignation

L'opérateur d'affectation (a:=b) initialise ou met à jour la valeur de a avec la valeur de b :

$myNumber:=3 //assigne 3 à la variable MyNumber
$myDate:=!2018/01/21! //assigne une date littérale
$myLength:=Length("Acme") //assigne le résultat de la commande (4) à $myLength
$col:=New collection //$col est initialisé avec une collection vide

Attention à ne PAS confondre l'opérateur d'affectation := avec l'opérateur de comparaison d'égalité =. Un opérateur d'affectation différent (et non pas =) a été choisi délibérément pour éviter les problèmes et la confusion qui surviennent souvent avec == ou === dans d'autres langages de programmation. De telles erreurs sont souvent difficiles à reconnaître pour le compilateur et conduisent à un dépannage fastidieux.

Opérateurs basiques

Les résultats des opérateurs dépendent des types de données auxquels ils sont appliqués. Ils sont décrits avec les types de données, dans les sections suivantes :

Opérateurs d'affectation composés

Historique
VersionModifications
v19 R4Ajout

4D fournit des opérateurs d'affectation composés qui combinent l'affectation avec une autre opération. L'opérateur d'affectation d'addition (+=) en est un exemple :

$a:=1 
$a+=2 // $a=3

Les opérateurs d'affectation composés suivants sont pris en charge :

OpérateurSyntaxeAssigneExemple
AdditionText += TextText$t+=" World" //$t:=$t+" World"
Number += NumberNumber$n+=5 //$n:=$n+5
Date += NumberDate$d+=5 //$d:=$d+5
Time += TimeTime$t1+=$t2 //$t1:=$t1+$t2
Time += NumberNumber$t1+=5 //$t1:=$t1+5
Picture += PicturePicture$p1+=$p2 //$p1:=$p1+$p2 (add $p2 to the right of $p1)
Picture += NumberPicture$p1+=5 //$p1:=$p1+5 (move $p1 horizontally 5 pixels to the right)
SoustractionNumber -= NumberNumber$n-=5 //$n:=$n-5
Date -= NumberDate$d-=5 //$d:=$d-5
Time -= TimeTime$t1-=$t2 //$t1:=$t1-$t2
Time -= NumberNumber$t1-=5 //$t1:=$t1-5
Picture -= NumberPicture$p1-=5 //$p1:=$p1-5 (déplacer horizontalement $p1 de 5 pixels vers la gauche)
DivisionNumber /= NumberNumber$n/=5 //$n:=$n/5
Time /= TimeTime$t1/=$t2 //$t1:=$t1/$t2
Time /= NumberNumber$t1/=5 //$t1:=$t1/5
Picture /= PicturePicture$p1/=$p2 //$p1:=$p1/$p2 (ajouter $p2 vers le bas de $p1)
Picture /= NumberPicture$p1/=5 //$p1:=$p1/5 (déplacer verticalement $p1 de 5 pixels)
MultiplicationText *= NumberText$t*="abc" //$t:=$t*"abc"
Number *= NumberNumber$n*=5 //$n:=$n*5
Time *= TimeTime$t1*=$t2 //$t1:=$t1*$t2
Time *= NumberNumber$t1*=5 //$t1:=$t1*5
Picture *= NumberPicture$p1*=5 //$p1:=$p1*5 (redimensionner $p1 de 5)

Ces opérateurs s'appliquent à toutes les expressions assignables (à l'exception des images en tant que propriétés d'objet ou éléments de collection).

L'opération "source operator value" n'est pas strictement équivalente à "source := source operator valeur" car l'expression désignant la source (variable, champ, propriété d'objet, élément de collection) n'est évaluée qu'une seule fois. Par exemple, dans une expression telle que getPointer()->+=1, la méthode getPointer n'est appelée qu'une seule fois.

L'indexation des caractères dans le texte et l'indexation des octets dans le blob ne prennent pas en charge ces opérateurs.

Exemples

// Addition
$x:=2
$x+=5 //$x=7

$t:="Hello"
$t+=" World" //$t="Hello World"

$d:=!2000-11-10!
$d+=10 //$d=!2000-11-20!

// Soustraction
$x1:=10
$x1-=5 //$x1=5

$d1:=!2000-11-10!
$d1-=10 // $d1=!2000-10-31!

// Division
$x3:=10
$x3/=2 // $x3=5


// Multiplication
$x2:=10
$x2*=5 // $x2=10

$t2:="Hello"
$t2*=2 // $t2="HelloHello"

Opérateurs en court-circuit

Les opérateurs && et || sont des opérateurs en court-circuit. Un opérateur en court-circuit est un opérateur qui n'évalue pas nécessairement toutes ses opérandes.

La différence avec les opérateurs booléens simples & et | est que les opérateurs en court-circuit && et || ne renvoient pas de valeur booléenne. Ils évaluent les expressions comme étant truthy ou falsy, puis retournent l'une des expressions.

Opérateur en court-circuit AND (&&)

Historique
VersionModifications
v19 R4Ajout

La règle est la suivante :

Soit Expr1 && Expr2 :

L'opérateur en court-circuit AND évalue les opérandes de gauche à droite, retournant immédiatement avec la valeur du premier opérande "falsy" qu'il rencontre ; si toutes les valeurs sont truthy, la valeur du dernier opérande est retournée.

Le tableau suivant résume les différents cas de figure pour l'opérateur && :

Expr1Expr2Valeur retournée
truthytruthyExpr2
truthyfalsyExpr2
falsytruthyExpr1
falsyfalsyExpr1

Exemple 1

var $v : Variant

$v:= "Hello" && "World" //"World"
$v:=False && 0 // False
$v:=0 && False // False
$v:=5 && !00-00-00! // 00/00/00
$v := 5 && 10 && "hello" //"hello"

Exemple 2

Supposons que vous ayez une boutique en ligne et que certains produits soient soumis à une taxe, alors que d'autres ne le sont pas.

Pour calculer la taxe, vous multipliez le prix par le taux de taxe, qui peut ne pas avoir été spécifié.

Vous pouvez donc écrire ceci :

var $tax : Variant

$tax:=$item.taxRate && ($item.price*$item.taxRate)

$tax sera NULL si le taxRate est NULL (ou undefined), sinon il stockera le résultat du calcul.

Exemple 3

Les opérateurs en court-circuit sont utiles dans les tests tels que :

If(($myObject#Null) && ($myObject.value>10))
//code
End if

Si $myObject est Null, le second argument n'est pas exécuté, donc aucune erreur n'est levée.

Opérateur en court-circuit OR (||)

Historique
VersionModifications
v19 R4Ajout

L'opérateur || retourne la valeur d'une des opérandes spécifiées. L'expression est évaluée de gauche à droite et testée pour une éventuelle évaluation en "court-circuit" en utilisant la règle suivante :

Soit Expr1 || Expr2 :

Si Expr1 est truthy, Expr2 n'est pas évalué et le calcul renvoie Expr1.

Si Expr1 est falsy, le calcul renvoie Expr2.

Le tableau suivant résume les différents cas de figure et la valeur retournée pour l'opérateur ||:

Expr1Expr2Valeur retournée
truthytruthyExpr1
truthyfalsyExpr1
falsytruthyExpr2
falsyfalsyExpr2

Exemple 1

Supposons que vous avez une table appelée Employee. Certains employés ont saisi un numéro de téléphone, d'autres non. Cela signifie que $emp.phone pourrait être NULL, et vous ne pouvez pas assigner NULL à une variable texte. Mais vous pouvez écrire :

var $phone : Text

$phone:=$emp.phone || "n/a"

Dans ce cas, $phone stockera soit un numéro de téléphone, soit la chaîne "n/a".

Exemple 2

On dispose d'une table appelée Person avec un champ name , ainsi qu'un champ maiden name pour les femmes mariées.

L'exemple suivant vérifie s'il y a un nom de jeune fille et le stocke dans une variable, sinon il stocke simplement le nom de la personne :

var $name: Text

$name:=$person.maidenName || $person.name

Priorité

Les opérateurs && et || ont la même priorité que les opérateurs logiques & et |, et sont évalués de gauche à droite.

Cela signifie que a || b && c est évalué comme (a || b) && c.

Opérateur ternaire

Historique
VersionModifications
v19 R4Ajout

L'opérateur conditionnel ternaire vous permet d'écrire des expressions conditionnelles sur une seule ligne. Par exemple, il peut remplacer une séquence complète d'instructions If…Else .

Il prend trois opérandes dans l'ordre suivant :

  • une condition suivie d'un point d'interrogation (?)
  • une expression à exécuter si la condition est truthy, suivie de deux points (:)
  • une expression à exécuter si la condition est falsy

Syntaxe

La syntaxe est la suivante :

condition ? exprIfTruthy : exprIfFalsy

Étant donné que la syntaxe avec tokens utilise des deux-points, nous recommandons d'insérer un espace après les deux-points : ou d'entourer les tokens à l'aide de parenthèses pour éviter tout conflit.

Exemples

Exemple simple

var $age : Integer
var $beverage : Text

$age:=26
$beverage:=($age>=21) ? "Beer" : "Juice"

ALERT($beverage) // "Beer"

Traitement des données depuis une table

Cet exemple stocke le nom complet d'une personne dans une variable, et gère le cas où aucun prénom ou nom de famille n'a été spécifié :

var $fullname : Text

// Si un des noms est manquant, stocker celui qui existe, sinon stocker une chaîne vide
$fullname:=($person.firstname && $person.lastname) ? ($person.firstname+" "+$person.lastname) : ($person.lastname || $person.firstname) || ""

Truthy et falsy

Historique
VersionModifications
v19 R4Ajout

En plus d'un type, chaque valeur possède également une valeur booléenne inhérente, généralement connue sous le nom de truthy ou falsy.

Les valeurs truthy et falsy ne sont évaluées que par les opérateurs en court-circuit et ternaires.

Les valeurs suivantes sont falsy:

  • false
  • Null
  • undefined
  • Null object
  • Null collection
  • Null pointer
  • Null picture
  • Null date !00-00-00!
  • "" - Chaînes vides
  • [] - Collections vides
  • {} - Objets vides

Toutes les autres valeurs sont considérées comme truthy, notamment :

  • 0 - zéro numérique (Entier ou autre)

Dans 4D, l'évaluation à truthy et falsy reflète la possibilité d'utilisation d'une valeur, ce qui signifie qu'une valeur truthy existe et peut être traitée par le code sans générer d'erreurs ou de résultats inattendus. L'objectif est de fournir un moyen pratique de gérer les valeurs undefined et null dans les objets et les collections, de sorte qu'un nombre réduit d'instructions If…Else soit nécessaire pour éviter les erreurs d'exécution.

Par exemple, lorsque vous utilisez un opérateur en court-circuit OR :

$value:=$object.value || $defaultValue

... vous obtenez la valeur par défaut chaque fois que $object ne contient pas la propriété value OU quand elle est null. Cet opérateur vérifie donc l'existence ou la possibilité d'utilisation de la valeur et non une valeur spécifique. Notez que puisque la valeur numérique 0 existe et est utilisable, elle n'est pas traitée spécialement, donc elle est truthy.

En ce qui concerne les valeurs représentant des collections, des objets ou des chaînes, les valeurs "vides" sont considérées comme falsy. C'est pratique lorsque vous voulez assigner une valeur par défaut chaque fois qu'une valeur vide est rencontrée.

$phone:=$emp.phone || "n/a"