Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
Note
Les groupes d’intérêt communautaire sont maintenant passés de Yammer à Microsoft Viva Engage. Pour participer à une communauté Viva Engage et participer aux dernières discussions, renseignez le formulaire Demander l’accès à la communauté Finance et Operations Viva Engage , puis choisissez la communauté que vous souhaitez rejoindre.
Cet article contient la référence de syntaxe pour X++.
Mots clés X++
Les mots clés X++ indiqués dans le tableau suivant sont réservés. Ces mots clés ne peuvent pas être utilisés à d’autres fins.
| Mot réservé | Descriptif | Informations connexes |
|---|---|---|
| ! | Non. | Opérateurs relationnels |
| != | Opérateur d’inégalité (différent de). | Opérateurs relationnels |
| # | Préfixe sur les noms de macros. | Guide pratique pour utiliser #define et #if pour tester une macro |
| & | BINAIRE ET. | Opérateurs arithmétiques |
| && | AND logique. | Opérateurs relationnels |
| ( | Opérateur d’appel de fonction, qui indique le début de l’appel de fonction. | |
| ) | Opérateur d’appel de fonction, qui indique la fin de l’appel de fonction. | |
| * | Multiplier. L’astérisque (*) est également utilisé dans X++ SQL. Une utilisation consiste à signer tous les champs des tables d’une select instruction. Une autre utilisation est un caractère générique avec l’opérateur like , pour signer 0 à de nombreux caractères de n’importe quel type. L’opérateur like utilise également le caractère ? |
Opérateurs arithmétiques |
| ^ | XOR binaire. | Opérateurs arithmétiques |
| | | OR binaire. | Opérateurs arithmétiques |
| || | OR logique. | Opérateurs relationnels |
| ~ | Non. | Opérateurs arithmétiques |
| + | Plus. | Opérateurs arithmétiques |
| ++ | Augmentation. | Opérateurs d’affectation |
| += | Affectation additive. | Opérateurs d’affectation |
| , | Opérateur de virgule. Les expressions séparées par des virgules sont évaluées séquentiellement de gauche à droite. | |
| - | Moins. | Opérateurs arithmétiques |
| -- | Opérateur de décrémentation. | Opérateurs d’affectation |
| -= | Affectation soustractive. | Opérateurs d’affectation |
| . | Par exemple, formRun.run l’opérateur d’accès membre de classe accède à la run méthode d’un objet du type FormRunde classe. |
|
| / | Diviser. | Opérateurs arithmétiques |
| \ | Échappement dans des chaînes. Échappe des guillemets supplémentaires, ainsi que certaines lettres telles que « \t » pour l’onglet. | |
| @ | Échappement de mots clés. Par exemple, var @str = 1@abstract; ne parvient pas à compiler sans le @ caractère qui provoque l’affichage d’une chaîne suivante comme identificateur. Elle affecte également les chaînes littérales, en négation de l’effet du caractère d’échappement \ et en permettant à la chaîne d’étendre plusieurs lignes dans le code source. La nouvelle ligne est représentée par un caractère de 0x0A hexadécimal, communément appelé flux de ligne. Aucun caractère de retour chariot de 0x0D hexadécimal n’est inclus, comme dans 0x0D0A. | |
| : | Le caractère deux-points ( :) est utilisé pour délimiter les valeurs de casse dans l’instruction switch . |
|
| :: | Utilisé pour appeler des méthodes statiques (classe) : ClassName ::methodName() et désigner des littéraux d’énumération, comme NoYes ::Yes. | |
| ; | Termine les instructions. Utilisé dans for des boucles ou en tant que séparateur d’initialiseur, de mise à jour et de parties de vérification de valeur. |
|
| < | Moins de. | Opérateurs relationnels |
| << | Maj gauche. | Opérateurs arithmétiques |
| <= | Inférieur ou égal. | Opérateurs arithmétiques |
| = | Opérateur d’affectation. L’argument à gauche de «= » est défini sur la valeur de l’argument à droite. | Opérateurs d’affectation |
| == | Retourne true si les expressions sont égales. | Opérateurs relationnels |
| > | Plus grand que. | Opérateurs relationnels |
| >= | Supérieur ou égal. | Opérateurs relationnels |
| >> | Maj droite au niveau du bit. Cet opérateur déplace les bits du côté gauche par la quantité située sur le côté droit. Chaque décalage divise efficacement le nombre par 2^n, où n correspond au nombre de positions décalées. | Opérateurs arithmétiques |
| ?: | Opérateur ternaire. Le caractère point d’interrogation ( ?) est également utilisé par l’opérateur like pour signer exactement un caractère de n’importe quel type. L’opérateur like utilise également le caractère. |
Opérateur ternaire ( ?) |
| [ | Déclarateur de tableau, ouvert. Doit être utilisé avec « ] ». | |
| ] | Déclarateur de tableau, fermer. Doit être utilisé avec « [ ». | |
| { | Démarre une instruction composée qui peut à son tour contenir zéro ou plusieurs instructions. L’instruction composée se termine par le « } » correspondant le plus proche. | |
| } | Indique la fin de l’instruction composée décrite ci-dessus. Un « { » doit apparaître avant la première de ces instructions. | |
| abstract | Modificateur de classe et de méthode. Une classe abstraite ne peut pas être construite avec le nouveau mot clé : seules les classes dérivées de celle-ci peuvent. Une méthode abstraite ne peut pas être appelée, seules les méthodes qui le remplacent peuvent. Une table peut être modifiée comme abstraite en définissant sa propriété Abstract sur Oui dans l’AOT ou à l’aide de la DictTable classe. La propriété Abstract a la valeur Non par défaut et elle ne peut pas être définie, sauf si la table est étendue par une autre table. Chaque ligne d’une table abstraite doit avoir une ligne dépendante dans une table dérivée. Cela signifie que chaque ligne d’une table abstraite a une valeur supérieure à zéro dans son champ de propriété InstanceRelationType . Il n’y a aucun autre effet de marquer une table comme abstraite. De façon informelle, les programmeurs utilisent souvent le terme concret pour décrire une classe qui n’est pas abstraite. |
Vue d’ensemble de l’héritage des tables modificateurs de méthode |
| anytype | Type qui peut contenir des valeurs de n’importe quel type. | Anytype |
| comme | Nécessaire lorsque vous affectez une variable de classe de base à une variable de classe dérivée. Par exemple, étant donné une Derived classe qui étend une Base classe, l’instruction myDerived = myBase as Derived; évite une erreur du compilateur à l’aide du mot clé. Ce mot clé s’applique également lorsque vous affectez une variable de table de base à une variable de table dérivée. Si la valeur (myBase) n’est pas du type désigné (dérivé), l’expression retourne null. |
Opérateurs d’expression : Is and As for Inheritance |
| asc | Option sur la ou orderla clause d’une bygroupby instruction.select Le tri est croissant. |
Syntaxe de l’instruction Select |
| at | Spécifie la position d’une fenêtre d’impression dans le cadre d’une print instruction. L’instruction print ne doit pas être utilisée. |
Instructions d’impression |
| avg | Retourne la moyenne des champs des lignes spécifiées par la group by clause dans une select instruction. |
Syntaxe de l’instruction Select |
| break | Sortie immédiate d’un bloc de code itératif. | Instructions break |
| Breakpoint | Représente un point d’arrêt défini à des fins de débogage. Pour définir un point d’arrêt dans votre code, écrivez : breakpoint; |
|
| par | Partie d’un terme réservé, tel que le groupe par et l’ordre par. | |
| byref | Spécifie que le paramètre passé à la méthode appelée est passé par référence (adresse), au lieu de la valeur. Byref est utilisé dans X++ lors de l’appel d’une méthode .NET qui prend un paramètre par référence (par exemple, avec les mots clés C# out ou ref). | Guide pratique pour utiliser le mot clé byref pour l’interopérabilité CLR. |
| case | Sélection dans une switch instruction. |
Instructions Switch |
| catch | Utilisé dans la gestion des exceptions. | Gestion des exceptions avec try et intercepter des mots clés |
| changeCompany | Modifie les paramètres de base de données d’une autre entreprise. | Modifier le modèle de conception de l’entreprise |
| classe | Déclare une classe. | Classes dans X++ |
| client | Modificateur de méthode. Ces modificateurs ne sont plus utilisés. Toutes les méthodes sont exécutées sur le niveau serveur. | Modificateurs de méthode |
| conteneur | Désigne le container type. Les conteneurs contiennent une séquence de valeurs atomiques et d’autres conteneurs. |
Containers |
| continue | Force l’itération suivante d’une boucle. | Instructions Continue |
| nombre | Retourne le nombre d’enregistrements des lignes spécifiées par la group by clause dans une select instruction. |
Syntaxe de l’instruction Select |
| crossCompany | Provoque un select retour de données pour toutes les entreprises à partir de laquelle l’utilisateur est autorisé à lire. |
Concepts de base du code X++ inter-entreprises |
| date | Spécifie une variable de type date. |
Dates |
| par défaut | Cas par défaut dans les switch instructions. Le bloc de code dans la partie par défaut est exécuté si la valeur du commutateur ne correspond à aucune des case clauses fournies dans l’instruction switch . |
Instructions Switch |
| delegate | Membre de classe capable de stocker plusieurs références à des méthodes dans d’autres classes et d’appeler toutes ces méthodes lorsque vous y êtes invité. Un délégué peut stocker des références à différents types de méthodes, notamment :
|
Terminologie des événements et mots clés X++, comparaison C# : événement |
| delete_from | Vous permet de supprimer des enregistrements de la base de données. | delete_from |
| Desc | Option sur la ou order by la clause d’une group byselect instruction. Le tri est décroissant. |
Syntaxe de l’instruction Select |
| montrer | Modificateur de méthode. Une méthode d’affichage/affichage<> est utilisée pour afficher les valeurs calculées dans un contrôle de formulaire. Contrairement aux champs réguliers, ces valeurs ne sont pas stockées dans la base de données, mais sont calculées dynamiquement. |
Modificateurs de méthode |
| div | Division entière. | Opérateurs arithmétiques |
| faire | Début d’une do...while boucle. |
Faire... boucles while |
| edit | Modificateur de méthode. Une edit méthode dans X++ permet aux utilisateurs de modifier des valeurs dans un contrôle de formulaire lors de l’exécution d’une logique personnalisée. Contrairement aux display méthodes, qui affichent uniquement les valeurs calculées, les méthodes de modification permettent l’affichage et la modification.
|
Modificateurs de méthode |
| else | Exécution conditionnelle (if...else). La else partie de l’instruction if est exécutée si l’expression dans l’instruction if est évaluée à false |
si et si ... else, instructions |
| eventHandler | Doit être utilisé chaque fois que vous ajoutez ou supprimez une référence de méthode d’un délégué à l’aide de l’opérateur ou += de l’opérateur-=. Par exemple : myDelegate += eventHandler(OtherClass ::myStaticMethod) ; | Terminologie des événements et mots clés X++, comparaison C# : événement |
| Existe | Utilisé avec join des clauses dans select les instructions. |
Syntaxe de l’instruction Select |
| S' étend | Clause de déclaration de classe ou d’interface. Si votre classe n’étend pas explicitement une autre classe, votre classe est considérée comme étendre la Object classe (comme si vous aviez écrit « étend l’objet »). |
Création d’une sous-classe |
| faux | Littéral booléen. | Valeurs booléennes |
| final | Modificateur de classe et de méthode. Spécifie que cette méthode ne peut pas être substituée. | Modificateurs de méthode |
| firstFast | Utilisé dans select les instructions pour accélérer la récupération pour la première ligne. |
Syntaxe de l’instruction Select |
| firstOnly | Utilisé dans select les instructions pour extraire uniquement le premier enregistrement. Le firstOnly mot clé ne garantit pas qu’un maximum d’un enregistrement est récupéré par une instruction SQL select X++. Si l’AOS peut utiliser le EntireTable cache pour répondre aux demandes de données de l’instruction select , le firstOnly mot clé est ignoré. |
Sélection de la mise en cache basée sur l’ensemble d’instructions |
| firstOnly10 | Identique à firstOnly, sauf retourne 10 lignes au lieu d’une. | |
| firstOnly100 | Identique à firstOnly, sauf retourne 100 lignes au lieu d’une. | |
| firstOnly1000 | Identique à firstOnly, sauf retourne 1 000 lignes au lieu d’une. | |
| flush | Efface l’intégralité du cache de table. Cela peut être utile lorsque vous souhaitez vous assurer que toutes les modifications apportées à la table sont immédiatement reflétées dans les opérations suivantes. | Mise en cache basée sur un ensemble |
| for | Itération de boucle. | Boucles For |
| forceLiterals | Utilisé dans select les instructions pour révéler les valeurs réelles utilisées dans where les clauses de la base de données Microsoft SQL Server au moment de l’optimisation. |
Syntaxe de l’instruction Select |
| forceNestedLoop | Force la base de données SQL Server à utiliser un algorithme de boucle imbriquée pour traiter une instruction SQL particulière contenant un join. |
Syntaxe de l’instruction Select |
| forcePlaceholders | Utilisé dans select les instructions pour indiquer au noyau de ne pas révéler les valeurs réelles utilisées dans where les clauses à la base de données Microsoft SQL Server au moment de l’optimisation. |
Syntaxe de l’instruction Select |
| forceSelectOrder | Force la base de données SQL Server à accéder aux tables d’une jointure dans l’ordre spécifié. | Syntaxe de l’instruction Select |
| forUpdate | Sélectionne les enregistrements exclusivement pour la mise à jour. L’opération à effectuer sur les enregistrements extraits est une mise à jour. Selon la base de données sous-jacente, les enregistrements peuvent être verrouillés pour d’autres utilisateurs. | Syntaxe de l’instruction Select |
| from | Partie d’une select instruction. La from clause spécifie la mémoire tampon de table dans laquelle les colonnes existent. |
Syntaxe de l’instruction Select |
| groupe | Partie de la group by clause dans une select instruction. |
Syntaxe de l’instruction Select |
| si | Exécution conditionnelle. | si et si ... else, instructions |
| Implémente | Implémentation d’un interface. |
Vue d’ensemble des interfaces |
| insert_recordset | Copie les données d’une ou de plusieurs tables dans une table de destination résultante sur un seul voyage de serveur. | insert_recordset |
| int | Spécifie une variable de type integer (32 bits). |
Entiers |
| int64 | Spécifie une variable de type integer (64 bits). |
Entiers |
| interface | Déclaration d’interface. | Vue d’ensemble des interfaces |
| is | Demande si l’objet référencé par une variable de classe hérite de la classe donnée ou est de la classe donnée. Par exemple, étant donné une Derived classe qui étend une Base classe, l’expression (myDerived is Base) retourne true. Ce mot clé s’applique à l’héritage de classe et à l’héritage de table. |
Opérateurs d’expression : Is and As for Inheritance |
| unir | Les tables sont jointes sur des colonnes communes aux deux tables. Vous pouvez générer un jeu de résultats unique basé sur plusieurs tables à l’aide de jointures. | Syntaxe de l’instruction Select |
| comme | Teste les correspondances par modèle, avec des symboles génériques « * » et « ? ». | Opérateurs relationnels |
| maxof | Retourne le maximum des champs des lignes spécifiées par la group by clause. |
Syntaxe de l’instruction Select |
| minof | Retourne le minimum des champs des lignes spécifiées par la group by clause. |
Syntaxe de l’instruction Select |
| mod | Retourne le reste entier de l’expression de gauche1 divisé par l’expression de droite2. De façon informelle, il s’agit parfois de l’opérateur modulo.
(12 mod 7) == 5 est vrai. |
|
| Nouveau | Opérateur. Crée une instance d’une classe ou alloue de la mémoire pour un tableau. | |
| next | Récupère l’enregistrement suivant dans une table ou appelle la méthode suivante dans une séquence de commandes en chaîne. | |
| noFetch | Indique qu’aucun enregistrement ne doit être récupéré maintenant. | Syntaxe de l’instruction Select |
| notExists | Utilisé avec join des clauses dans select les instructions. |
Syntaxe de l’instruction Select |
| zéro | Constante symbolique. | |
| optimisteLock | Force une instruction à s’exécuter avec un contrôle d’accès concurrentiel optimiste, même si une valeur différente est définie sur la table. | Syntaxe de l’instruction Select |
| commande | Partie de la order by clause dans une select instruction. |
Syntaxe de l’instruction Select |
| extérieur | jointure externe. | Syntaxe de l’instruction Select |
| pause | Arrête l’exécution d’un travail. L’utilisateur est invité à indiquer si l’exécution doit continuer. Vous ne devez pas utiliser cette instruction dans le code de production. | Sélectionner des instructions |
| pessimisticLock | Force une instruction à s’exécuter avec un contrôle d’accès concurrentiel pessimiste, même si une valeur différente est définie sur la table. | Syntaxe de l’instruction Select |
| Vous permet d’afficher la sortie à l’écran. Vous ne devez pas utiliser cette instruction dans le code de production. | Instructions d’impression | |
| privé | Modificateur d’accès aux méthodes. La méthode ne peut être utilisée que dans la classe qui déclare la méthode. | Contrôle d’accès aux méthodes |
| protégé | Modificateur d’accès aux méthodes. La méthode peut être utilisée à partir de méthodes dans la classe déclarant les méthodes et dans toutes les classes dérivées. | Contrôle d’accès aux méthodes |
| public | Modificateur d’accès aux méthodes. La méthode peut être appelée à partir de n’importe quelle classe. | Contrôle d’accès aux méthodes |
| real | Désigne le real type, un type décimal sans arrondi d’erreurs. |
Réals |
| repeatableRead | Spécifie qu’aucune autre transaction ne peut modifier les données qui ont été lues par logique à l’intérieur de la transaction actuelle, jusqu’à ce que la transaction actuelle se termine. Une transaction explicite se termine à ttsAbort ou à l’extérieur de ttsCommit. Pour une instruction select autonome, la durée de la transaction est la durée de la commande select . Toutefois, la base de données applique parfois l’équivalent de repeatableRead dans des instructions select individuelles, même sans ce mot clé apparaissant dans votre code X++ (selon la façon dont la base de données décide d’analyser les tables). | Pour plus d’informations, consultez la documentation relative au produit de base de données relationnelle sous-jacent. |
| réessayer | Utilisé dans la gestion des exceptions. | Gestion des exceptions avec try et intercepter des mots clés |
| rendre | Retourne à partir d’une méthode. | Déclaration des méthodes |
| inverse | Les enregistrements sont retournés dans l’ordre inverse. | Syntaxe de l’instruction Select |
| select | La select clause désigne les colonnes ou vues affichées dans le jeu de résultats. |
Sélectionner des instructions |
| serveur | Modificateur de méthode. Ce modificateur est ignoré et ne doit pas être utilisé, car toutes les méthodes sont exécutées côté serveur. | Modificateurs de méthode |
| réglage | Utilisé avec la commande update_recordset . | update_recordset |
| statique | Les méthodes statiques peuvent ne pas faire référence à des variables d’instance (uniquement aux variables statiques) ; peut être appelé à l’aide du nom de classe plutôt que sur une instance de la classe ( »MyClass.aStaticProcedure « ). |
Modificateurs de méthode |
| str | Désigne le string type. |
Chaînes |
| somme | Retourne la somme des champs des lignes spécifiées par la group by clause dans une select instruction. |
Syntaxe de l’instruction Select |
| super | Appelle la méthode remplacée par la méthode actuelle. | Méthodes de table |
| interrupteur | Instruction Switch. | Instructions Switch |
| tableLock | Obsolète; tableLock n’est plus disponible. | |
| ceci | Référence à l’instance actuelle de la classe. Utilisé dans le code X++ à l’intérieur d’une méthode d’instance de la classe. Utilisé pour référencer les membres de la méthode de la classe. | |
| jeter | Utilisé dans la gestion des exceptions. | Gestion des exceptions avec try et intercepter des mots clés |
| vrai | Littéral booléen. | Valeurs booléennes |
| essayer | Utilisé dans la gestion des exceptions. | Gestion des exceptions avec try et intercepter des mots clés |
| ttsAbort | Restaurez (c’est-à-dire ignorer) toutes les modifications apportées à la transaction actuelle. | Intégrité des transactions |
| ttsBegin | Marque le début d’une transaction. | Intégrité des transactions |
| ttsCommit | Marque la fin d’une transaction, en validant les modifications apportées aux tables. | Intégrité des transactions |
| update_recordset | Autorise la manipulation des jeux de lignes dans une seule opération. | update_recordset |
| validTimeState | Filtre les lignes récupérées à partir d’une table d’état de temps valide par une instruction SQL select X++. Par exemple : select validTimeState(myDateEffective) * from xMyTable ; ... ou... select validTimeState(myDateFrom, myDateTo) * from xMyTable ; |
Effets des tables d’état de temps valides sur les opérations de lecture et d’écriture |
| vide | Identifie une méthode qui ne retourne pas de valeur. | Déclaration des méthodes |
| where | Partie d’une select instruction. La where clause spécifie les conditions à satisfaire ; autrement dit, les lignes que vous souhaitez inclure dans le résultat. |
Syntaxe de l’instruction Select |
| pendant que | Instruction itération. Exécute une instruction à plusieurs reprises tant que la condition de test est vraie. | Boucles While lors de la sélection d’instructions |
| fenêtre | Vous permet de modifier la taille de la fenêtre de sortie. Utilisé avec des instructions d’impression</impression> qui ne sont pas recommandées dans le code de production. |
Instructions d’impression |
Syntaxe des expressions
Une expression en X++ est utilisée de manière mathématique ou logique. Les expressions sont basées sur les types de données du langage ; autrement dit, une expression retourne toujours une valeur d’un certain type. Cette valeur peut être utilisée dans les calculs, les affectations, les instructions conditionnelles, et ainsi de suite.
Description EBNF des expressions dans X++
| Terme | Definition | |
|---|---|---|
| Expression | = | Expression simple [RelationalOperator Simple-expression ] |
| RelationalOperator | = | = |
| Expression simple | = | Expression simple [ + |
| Terme | = | Compfactor { Mult-operator CompFactor } |
| Mult-operator | = | * |
| CompFactor | = | [ ! ] [ - |
| Facteur | = | Literal |
| Enum | = | EnumName :: Littéral |
| Variable | = | Identificateur [ [ Expression ] ] [ . Expression ] |
| FunctionCall | = | [ Expression (. |
| If-expression | = | Expression? Expression : Expression |
Les restrictions sémantiques s’appliquent à la syntaxe précédente. Vous ne pouvez pas appeler de méthode à l’aide de l’opérateur :: . De même, vous ne pouvez pas utiliser ce mot clé sans objet actif ; autrement dit, si vous n’êtes pas dans une méthode d’instance, et ainsi de suite.
Examples
| Exemple d’expression | Descriptif |
|---|---|
1 |
Littéral entier. |
| NoYes ::No | Référence d’énumération. |
A |
Référence de variable. |
| Débiteur ::Find(« 1 ») | Un appel de méthode statique (retourne une variable client). |
| (A > 3 ? true : false) | Expression if qui retourne true ou false. |
| (sélectionnez CustTable où CustTable.Account == « 100 »). NameRef | Expression de sélection. Retourne le champ nameref dans la table client. Il s’agit d’une chaîne. |
| A >= B | Expression logique. Retourne true ou false. |
| A + B | Expression arithmétique. Somme A et B. |
| A + B / C | Calcule B/C, puis l’ajoute à A. |
| ~A + ceci. Value() | Sums binary not A et the result of the method-call Value on the object in scope (this). |
| Débiteur ::Find(« 1 »). NameRef | Retourne le champ NameRef de l’enregistrement client trouvé. |
| Débiteur ::Find(« 1 »). Solde() | Un appel de méthode dans Balance la table client (Débiteur ::Find retourne un client). Retourne le solde du client avec le numéro de compte 1. |
Vue d’ensemble d’EBNF
Extended Backus Naur Form (EBNF) est un métalanguage et est utilisé dans ce guide pour décrire la syntaxe du langage. Une définition EBNF se compose de règles de production, de terminaux et de terminaux non déterminaux. Les termes clés sont indiqués dans le tableau suivant.
| Termes clés | Example | Descriptif |
|---|---|---|
| Bornes | Work_Team | Un terminal est un caractère ou une chaîne de caractères qui ne changent jamais. |
| Non détermins | Employee |
Une expression non déterministe est une description d’une partie d’une phrase valide dans la langue définie par une règle de production ou une description textuelle. Un symbole non déterministe peut toujours être étendu à un ou plusieurs symboles terminal. |
| Règles de production | Employé = Développeur | Tester |
Example
Work_Team = Employé responsable {, Employee} Employee = Developer | Testeur Cet exemple définit une Work_Team comme composée d’un Manager ou plusieurs Employees. Un Employee est défini comme étant un Developer, ou un Tester. Les symboles utilisés dans l’exemple sont décrits dans le tableau suivant.
Symboles spéciaux dans EBNF
| Symbol | Descriptif |
|---|---|
| (Expression) | Les parenthèses contiennent les symboles (terminaux et non déterminaux) ensemble. Ils peuvent être placés n’importe où sur le côté droit d’une règle de production. |
| Expression1 | Expression2 |
| [Expression] | Facultatif : les éléments entre [ et ] sont facultatifs. Tous ou aucun des éléments entre crochets n’est inclus. |
| {Expression} | Répétez : les éléments compris entre { et } sont facultatifs, mais peuvent être répétés autant de fois que nécessaire. |
Par exemple, si les accessoires que vous achetez pour votre vélo se composent d’une selle, de porte-bouteilles d’eau, de cloches et de cornes, et que vous pourriez avoir une cloche ou une corne, et zéro, un ou plusieurs porte-bouteilles d’eau, et exactement une selle, cela peut être exprimé comme : Bicycle_Accessories = selle [cloche | corne] {water_bottle_holders} Cette grammaire définit les possibilités suivantes : saddlesaddle bellsaddle horn selle water_bottle_holder cloche de selle water_bottle_holder cloche de selle water_bottle_holder water_bottle_holder Et ainsi de suite.
Grammaire X++
Cet article présente la grammaire formelle du langage X++.
Comment interpréter la grammaire BNF formelle
Cette section décrit la grammaire de X++ dans Backus Naur Form (BNF). Un petit exemple de BNF est décrit ici.
AA ::= BB CC_SYM
BB ::= JJ_SYM
::= KK_SYM
AA est le nom d’une règle de production. Une AA requête nécessite un BBCC_SYM, suivi d’une CC_SYM. A BB est également une règle de production. Par conséquent, BB n’est pas un terminal.
BB doit être un JJ_SYM ou un KK_SYM. Les deux JJ_SYM et KK_SYM sont des terminaux, car ils ne sont pas les noms d’autres règles de production. CC_SYM est également un terminal.
Dans la grammaire BNF pour X++, la plupart des terminaux ont _SYM comme suffixe de leur nom.
Grammaire X++ formelle dans BNF
Cette section contient le BNF qui définit la grammaire de X++.
CMPL_UNIT ::= RETTYPEID FUNC_HDR FUNC_HEAD BODY
::= RETTYPEID DATA_HDR CLASS_DECL
::= EXPR_HDR IF_EXPR SEMIOPT
::= RETTYPEID FUNC_HDR EVENT_DECL BODY
SEMIOPT ::= SEMICOLON_SYM
::=
CLASS_DECL ::= CLASS_HEADER LEFTBR_SYM DCL_EVENTMAP DCL_LIST RIGHTBR_SYM
CLASS_HEADER ::= ATTRIBUTE_DEF CLASS_MODIFIERS CLASSORINTERFACE STD_ID EXTENDS IMPLEMENTS
ATTRIBUTE_DEF ::= LEFT_BRKT_SYM ATTRIBUTE_INIT ATTRIBUTE_LIST RETTYPEID RGHT_BRKT_SYM
::=
ATTRIBUTE_INIT ::=
.
ATTRIBUTE_LIST ::= ATTRIBUTE
::= ATTRIBUTE_LIST LIST_SEP_SYM ATTRIBUTE
ATTRIBUTE ::= STD_ID
::= ATTRIBUTE_WITH_ARGS_BEGINS ATTRIBUTE_WITH_ARGS_ENDS
ATTRIBUTE_WITH_ARGS_BEGINS ::= STD_ID LEFT_PAR_SYM
ATTRIBUTE_WITH_ARGS_ENDS ::= ATTRIBUTE_ARGS RGHT_PAR_SYM
ATTRIBUTE_ARGS ::= ATTRIBUTE_CONSTANT
::= ATTRIBUTE_ARGS LIST_SEP_SYM ATTRIBUTE_CONSTANT
ATTRIBUTE_CONSTANT ::= INT_SYM
::= DBL_SYM
::= STR_SYM
::= DATE_SYM
::= DATETIME_SYM
::= STD_ID DBLCOLON_SYM STD_ID
::= TRUE_SYM
::= FALSE_SYM
::= INT64_SYM
::= ATTRIBUTE_INTRINSIC
ATTRIBUTE_INTRINSIC ::= INTRI_ID LEFT_PAR_SYM IARGS RGHT_PAR_SYM
CLASSORINTERFACE ::= CLASS_SYM
::= INTERFACE_SYM
CLASS_MODIFIERS ::= CLASS_MODS
::=
CLASS_MODS ::= CLASS_MODIFIER
::= CLASS_MODS RETTYPEID CLASS_MODIFIER
CLASS_MODIFIER ::= PUBLIC_SYM
::= FINAL_SYM
::= STATIC_SYM
::= ABSTRACT_SYM
::= PRIVATE_SYM
EXTENDS ::= EXTENDS_SYM STD_ID
::=
IMPLEMENTS ::= IMPLEMENTS_SYM IMPLEMENTLIST
::=
IMPLEMENTLIST ::= STD_ID
::= IMPLEMENTLIST LIST_SEP_SYM STD_ID
DCL_EVENTMAP ::=
EVENT_DECL ::= ATTRIBUTE_DEF EVENT_HEADER PARM_DCL_LIST
EVENT_HEADER ::= EVENT_MODIFIER VOID_TYPE_SYM STD_ID
EVENT_MODIFIER ::= EVENT_SYM
FUNC_HEAD ::= ATTRIBUTE_DEF FUNCNAME PARM_DCL_LIST
FUNCNAME ::= FUNCTYPE STD_ID
FUNCTYPE ::= FUNC_MODIFIERS DECL_TYPE
FUNC_MODIFIERS ::= FUNC_MODS
::=
FUNC_MODS ::= RETTYPEID FUNC_MODIFIER
::= FUNC_MODS RETTYPEID FUNC_MODIFIER
FUNC_MODIFIER ::= PUBLIC_SYM
::= PRIVATE_SYM
::= PROTECTED_SYM
::= FINAL_SYM
::= STATIC_SYM
::= ABSTRACT_SYM
::= DISPLAY_SYM
::= EDIT_SYM
::= SERVER_SYM
::= CLIENT_SYM
BODY ::= LEFTBR_SYM DCL_FUNC_LIST SEMIOPT SECAUTHZCHECK STMTLIST SECAUTHZEND RIGHTBR_SYM
SECAUTHZCHECK ::=
SECAUTHZEND ::=
RETTYPEID ::=
FUNCTION_DEF ::= FUNC_HEADER PARM_DCL_LIST LOCAL_BODY
FUNC_HEADER ::= DECL_TYPE STD_ID
PARM_DCL_LIST ::= RETTYPEID PARM_START PARM_LIST_OPT RGHT_PAR_SYM RETTYPEID
PARM_START ::= LEFT_PAR_SYM
PARM_LIST_OPT ::= PARM_LIST
::=
PARM_LIST ::= DCL_INIT
::= PARM_LIST LIST_SEP_SYM DCL_INIT
LOCAL_BODY ::= LEFTBR_SYM DCL_LIST SEMIOPT STMTLIST RETTYPEID RIGHTBR_SYM
DCL_LIST ::= DCL_LIST2
::=
DCL_LIST2 ::= DCL_STMT
::= DCL_LIST2 DCL_STMT
DCL_FUNC_LIST ::= DCL_FUNC_LIST2
::=
DCL_FUNC_LIST2 ::= DCL_STMT
::= FUNCTION_DEF
::= DCL_FUNC_LIST2 DCL_STMT
::= DCL_FUNC_LIST2 FUNCTION_DEF
DCL_STMT ::= DCL_INIT_LIST RETTYPEID SEMICOLON_SYM
DCL_INIT_LIST ::= DCL_INIT
::= DCL_CLIST ASG_CLAUSE
DCL_CLIST ::= DCL_INIT_LIST LIST_SEP_SYM STD_ID ARR_DCL_IDX
DCL_INIT ::= DECL ASG_CLAUSE
DECL ::= DECL_TYPE STD_ID ARR_DCL_IDX
DECL_TYPE ::= STR_TYPE_SYM STR_LEN
::= INT_TYPE_SYM
::= DBL_TYPE_SYM
::= DATE_TYPE_SYM
::= DATETIME_TYPE_SYM
::= TYPE_ID
::= QUEUE_TYPE_SYM
::= VOID_TYPE_SYM
::= ANY_TYPE_SYM
::= GUID_TYPE_SYM
::= INT64_TYPE_SYM
::= CLR_TYPE
CLR_TYPE ::= CLR_NAMESPACE TYPE_ID CLR_ARRAY_TYPE_EXT
::= CLR_NAMESPACE CLR_TYPE
CLR_NAMESPACE ::= TYPE_ID PERIOD_SYM
CLR_ARRAY_TYPE_EXT ::= CLR_ARRAY_SPEC
::=
CLR_ARRAY_SPEC ::= CLR_ARRAY_PART
::= CLR_ARRAY_SPEC CLR_ARRAY_PART
CLR_ARRAY_PART ::= CLR_ARRAY_LEFT_PART CLR_RECTANGULAR_LIST RGHT_BRKT_SYM
CLR_ARRAY_LEFT_PART ::= LEFT_BRKT_SYM
CLR_RECTANGULAR_LIST ::= CLR_COMMA_LIST
::=
CLR_COMMA_LIST ::= LIST_SEP_SYM
::= CLR_COMMA_LIST LIST_SEP_SYM
STR_LEN ::= INT_SYM
::=
ARR_DCL_IDX ::= LEFT_BRKT_SYM RANGE ARRAY_MEM RGHT_BRKT_SYM
::=
RANGE ::= IF_EXPR
::=
ARRAY_MEM ::= LIST_SEP_SYM IF_EXPR
::=
ASG_CLAUSE ::= INIT_START IF_EXPR
::=
INIT_START ::= ASG_SYM
ASG_STMT ::= LVAL_FLD ASSIGN IF_EXPR
::= LVAL_LIST ASG_SYM IF_EXPR
::= LVAL_FLD ASG_INC_DEC
::= ASG_INC_DEC LVAL_FLD
::= LVAL_FLD ASG_EVENT_HANDLER
ASSIGN ::= ASG_SYM
::= ASGINC_SYM
::= ASGDEC_SYM
ASG_INCDEC ::= ASGINC_SYM
::= ASGDEC_SYM
ASG_EVENT_HANDLER ::= ASG_INCDEC EVENTHANDLER_SYM LEFT_PAR_SYM QUALIFIER STD_ID RGHT_PAR_SYM
::= ASG_INCDEC EVENTHANDLER_SYM LEFT_PAR_SYM STD_ID DBLCOLON_SYM STD_ID RGHT_PAR_SYM
::= ASG_INCDEC EVENTHANDLER_SYM LEFT_PAR_SYM QUALIFIER EVAL_CLR_TYPE DBLCOLON_SYM STD_ID RGHT_PAR_SYM
ASG_INC_DEC ::= INC_SYM
::= DEC_SYM
LVAL_FLD ::= FIELD
LVAL_START ::= LEFT_BRKT_SYM
LVAL_LIST ::= LVAL_START LVALUES RGHT_BRKT_SYM
LVALUE ::= FIELD
LVALUES ::= LVALUE
::= LVALUES NEXTLVAL LVALUE
NEXTLVAL ::= LIST_SEP_SYM
IF_EXPR ::= COND_TRUE IF_EXPR
::= BOOL_EXPR
COND_TRUE ::= COND_TEST IF_EXPR COLON_SYM
COND_TEST ::= BOOL_EXPR QUEST_SYM
BOOL_EXPR ::= BOOL_EXPR LOGOP EXPR
::= EXPR
LOGOP ::= AND_SYM
::= OR_SYM
EXPR ::= SMPL_EXPR RELOP SMPL_EXPR
::= SMPL_EXPR AS_SYM STD_ID
::= SMPL_EXPR IS_SYM STD_ID
::= SMPL_EXPR AS_SYM EVAL_CLR_TYPE
::= SMPL_EXPR IS_SYM EVAL_CLR_TYPE
::= SMPL_EXPR
RELOP ::= LT_SYM
::= LE_SYM
::= EQ_SYM
::= NE_SYM
::= GT_SYM
::= GE_SYM
::= LIKE_SYM
SMPL_EXPR ::= SMPL_EXPR ADDOP TERM
::= TERM
ADDOP ::= PLUS_SYM
::= MINUS_SYM
::= PHYSOR_SYM
TERM ::= TERM MULOP CMPL_FACT
::= CMPL_FACT
MULOP ::= MULT_SYM
::= DIV_SYM
::= MOD_SYM
::= INTDIV_SYM
::= SHIFTL_SYM
::= SHIFTR_SYM
::= PHYSAND_SYM
::= PHYSXOR_SYM
CMPL_FACT ::= NOT_SYM SGND_FACT
::= SGND_FACT
SGND_FACT ::= SIGNOP FACTOR
::= FACTOR
SIGNOP ::= UMINUS_SYM
::= PHYSNOT_SYM
FACTOR ::= LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
::= CONSTANT
::= FIELD
::= DIRSEARCH
::= FUNCTION
::= INTRINSICS
::= EVAL
::= CONLITTERAL
::= NEW_CLR_ARRAY
NEW_CLR_ARRAY ::= NEW_SYM EVAL_CLR_TYPE NEW_CLR_ARRAY_PART LEFT_PAR_SYM RGHT_PAR_SYM
NEW_CLR_ARRAY_PART ::= CLR_SIZED_ARRAY CLR_NOSIZED_ARRAY_SPEC
CLR_SIZED_ARRAY ::= LEFT_BRKT_SYM CLR_SMPL_EXPR_COMMA_LIST RGHT_BRKT_SYM
CLR_SMPL_EXPR_COMMA_LIST ::= SMPL_EXPR
::= CLR_SMPL_EXPR_COMMA_LIST LIST_SEP_SYM SMPL_EXPR
CLR_NOSIZED_ARRAY_SPEC ::= CLR_NOSIZED_ARRAY_LIST
::=
CLR_NOSIZED_ARRAY_LIST ::= CLR_NOSIZED_ARRAY
::= CLR_NOSIZED_ARRAY_LIST CLR_NOSIZED_ARRAY
CLR_NOSIZED_ARRAY ::= LEFT_BRKT_SYM CLR_EMPTY_COMMA_LIST RGHT_BRKT_SYM
CLR_EMPTY_COMMA_LIST ::= CLR_EMPTY_RECT_COMMA_LIST
::=
CLR_EMPTY_RECT_COMMA_LIST ::= LIST_SEP_SYM
::= CLR_EMPTY_RECT_COMMA_LIST LIST_SEP_SYM
CONLITTERAL ::= LEFT_BRKT_SYM IF_EXPR EXPR_LIST RGHT_BRKT_SYM
CONSTANT ::= INT_SYM
::= DBL_SYM
::= STR_SYM
::= DATE_SYM
::= DATETIME_SYM
::= STD_ID DBLCOLON_SYM STD_ID
::= TRUE_SYM
::= FALSE_SYM
::= NULL_SYM
::= INT64_SYM
::= QUALIFIER EVAL_CLR_TYPE DBLCOLON_SYM STD_ID
::= QUALIFIER STD_ID DBLCOLON_SYM STD_ID
DIRSEARCH ::= DIRS_HEADER PERIOD_SYM STD_ID ARR_IDX
::= DIRS_HEADER PERIOD_SYM FLD_NUM ARR_IDX
DIRS_HEADER ::= LEFT_PAR_SYM SET_DIRS FIND_JOIN RGHT_PAR_SYM
SET_DIRS ::=
FIELD ::= QUALIFIER STD_ID ARR_IDX
::= QUALIFIER FLD_NUM ARR_IDX
::= STD_ID ARR_IDX
QUALIFIER ::= EVAL PERIOD_SYM
::= STD_ID PERIOD_SYM
FLD_NUM ::= LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
ARR_IDX ::= LEFT_BRKT_SYM SMPL_EXPR RGHT_BRKT_SYM
::=
EXPR_LIST ::= EXPR_LIST2
::=
EXPR_LIST2 ::= LIST_SEP_SYM IF_EXPR
::= EXPR_LIST2 LIST_SEP_SYM IF_EXPR
FUNCTION ::= FUNC_ID LEFT_PAR_SYM EVAL_FUNCTION_NAME PAR_LIST RGHT_PAR_SYM
EVAL_FUNCTION_NAME ::=
EVAL_NAME ::= EVAL_ID LEFT_PAR_SYM
::= STD_ID LEFT_PAR_SYM
::= STD_ID DBLCOLON_SYM STD_ID LEFT_PAR_SYM
::= SUPER_SYM LEFT_PAR_SYM
::= NEW_SYM STD_ID LEFT_PAR_SYM
::= NEW_SYM EVAL_CLR_TYPE LEFT_PAR_SYM
::= QUALIFIER EVAL_CLR_TYPE DBLCOLON_SYM STD_ID LEFT_PAR_SYM
::= QUALIFIER STD_ID LEFT_PAR_SYM
::= QUALIFIER STD_ID DBLCOLON_SYM STD_ID LEFT_PAR_SYM
EVAL_CLR_TYPE ::= NAMESPACE STD_ID
::= NAMESPACE EVAL_CLR_TYPE
NAMESPACE ::= STD_ID PERIOD_SYM
EVAL ::= EVAL_NAME PAR_LIST RGHT_PAR_SYM
PAR_LIST ::= PRM_LIST
::=
PRM_LIST ::= PAR_ELEM
::= PRM_LIST LIST_SEP_SYM PAR_ELEM
PAR_ELEM ::= IF_EXPR
::= BYREF_SYM FIELD
INTRINSICS ::= INTRI_ID LEFT_PAR_SYM IARGS RGHT_PAR_SYM
IARGS ::= STD_ID
::= STR_SYM
::= STD_ID LIST_SEP_SYM STD_ID
::=
STMTLIST ::= STATEMENTS
::=
STATEMENTS ::= STATEMENT
::= STATEMENTS STATEMENT
STATEMENT ::= COMPOUND_STMT
::= WHILE_STMT
::= FOR_STMT
::= DO_STMT
::= SEARCH_STMT
::= FIND_STMT
::= PRINT_STMT
::= WINDOW_STMT
::= IF_STMT
::= SWITCH_STMT
::= EXPR_STMT
::= PAUSE_STMT
::= BP_CLAUSE
::= BREAK_STMT
::= CONTINUE_STMT
::= RETURN_CLAUSE
::= MOVE_REC_STMT
::= THROW_STMT
::= TRY_STMT
::= RETRY_STMT
::= TTS_STMT
::= FLUSH_STMT
::= TBLLOCK_STMT
::= CHANGE_STMT
::= UPDATE_STMT
::= INSERT_STMT
::= UNCHECKED_STMT
COMPOUND_STMT ::= LEFTBR_SYM STMTLIST RIGHTBR_SYM
THROW_STMT ::= THROW_SYM IF_EXPR SEMICOLON_SYM
TRY_STMT ::= TRY_BLOCK CATCH_LIST
TRY_BLOCK ::= TRY_START STATEMENT
TRY_START ::= TRY_SYM
CATCH_LIST ::= CATCH_STMT
::= CATCH_LIST CATCH_STMT
CATCH_STMT ::= CATCH_EXPR PRE_CATCH STATEMENT POST_CATCH
CATCH_EXPR ::= CATCH_SYM LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
::= CATCH_SYM LEFT_PAR_SYM IF_EXPR LIST_SEP_SYM TABLEINSTANCE RGHT_PAR_SYM
::= CATCH_SYM
PRE_CATCH ::=
POST_CATCH ::=
TABLEINSTANCE ::= INSTANCENAME
INSTANCENAME ::= QUALIFIER STD_ID ARR_IDX
::= STD_ID ARR_IDX
RETRY_STMT ::= RETRY_SYM SEMICOLON_SYM
WHILE_STMT ::= WHILE_TEST STATEMENT
WHILE_TEST ::= WHILE LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
WHILE ::= WHILE_SYM
DO_STMT ::= DO_BODY DO_TEST SEMICOLON_SYM
DO_BODY ::= DO_HEADER STATEMENT
DO_HEADER ::= DO_SYM
DO_TEST ::= WHILE_SYM LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
FOR_STMT ::= FOR_HEADER STATEMENT
FOR_HEADER ::= FOR_TEST SEMICOLON_SYM FOR_ASG RGHT_PAR_SYM
FOR_TEST ::= FOR_INIT SEMICOLON_SYM IF_EXPR
FOR_INIT ::= FOR_SYM LEFT_PAR_SYM FOR_ASG
FOR_ASG ::= LVAL_FLD ASSIGN IF_EXPR
::= LVAL_FLD ASG_INC_DEC
::= ASG_INC_DEC LVAL_FLD
JOIN_LIST ::= JOIN_SPECS
::=
JOIN_SPECS ::= JOIN_SPEC
::= JOIN_SPECS JOIN_SPEC
JOIN_SPEC ::= JOIN_ORDER WHERE IF_EXPR
::= JOIN_ORDER
JOIN_ORDER ::= JOIN_USING
::= JOIN_USING ORDER_GROUP
JOIN_USING ::= JOIN_CLAUSE USING_INDEX STD_ID
::= JOIN_CLAUSE USING_INDEX HINT_SYM STD_ID
::= JOIN_CLAUSE
JOIN_CLAUSE ::= OUTER JOIN_SYM SELECTOPT TABLE
OUTER ::= OUTER_SYM
::= EXISTS_SYM
::= NOTEXISTS_SYM
::=
SEARCH_STMT ::= SEARCH_JOIN STATEMENT
SEARCH_JOIN ::= SEARCH_WHERE JOIN_LIST
SEARCH_WHERE ::= SEARCH_ORDER WHERE IF_EXPR
::= SEARCH_ORDER
WHERE ::= WHERE_SYM
SUM_ELEM ::= SUM_FUNC LEFT_PAR_SYM STD_ID RGHT_PAR_SYM
SUM_FUNC ::= SUM_SYM
::= AVG_SYM
::= CNT_SYM
::= MINOF_SYM
::= MAXOF_SYM
SEARCH_ORDER ::= SEARCH_USING
::= SEARCH_USING ORDER_GROUP
ORDER_GROUP ::= ORDERBY_CLAUSE OPT_GROUPBY
::= GROUPBY_CLAUSE OPT_ORDERBY
OPT_GROUPBY ::= GROUPBY_CLAUSE
::=
OPT_ORDERBY ::= ORDERBY_CLAUSE
::=
ORDERBY_CLAUSE ::= ORDER_SYM OPT_BY ORDER_ELEM
::= ORDERBY_CLAUSE LIST_SEP_SYM ORDER_ELEM
GROUPBY_CLAUSE ::= GROUP_SYM OPT_BY ORDER_ELEM
::= GROUPBY_CLAUSE LIST_SEP_SYM ORDER_ELEM
ORDER_ELEM ::= STD_ID INDEX DIRECTION
::= ORDER_QUALIFIER STD_ID INDEX DIRECTION
ORDER_QUALIFIER ::= STD_ID PERIOD_SYM
INDEX ::= LEFT_BRKT_SYM INT_SYM RGHT_BRKT_SYM
::=
DIRECTION ::= ASCEND_SYM
::= DESCEND_SYM
::=
OPT_BY ::= BY_SYM
::=
SEARCH_USING ::= SEARCH_CLAUSE USING_INDEX STD_ID
::= SEARCH_CLAUSE USING_INDEX HINT_SYM STD_ID
::= SEARCH_CLAUSE
USING_INDEX ::= INDEX_SYM
SEARCH_CLAUSE ::= WHILE_SYM SELECT_SYM SELECTOPT CROSSCOMPANY_CLAUSE VALIDTIMESTATE_CLAUSE TABLE
CROSSCOMPANY_CLAUSE ::= CROSSCOMPANY_SYM
::= CROSSCOMPANY_SYM COLON_SYM STD_ID
::=
VALIDTIMESTATE_CLAUSE ::= VALIDTIMESTATE_SYM LEFT_PAR_SYM STD_ID LIST_SEP_SYM STD_ID RGHT_PAR_SYM
::= VALIDTIMESTATE_SYM LEFT_PAR_SYM STD_ID RGHT_PAR_SYM
::=
SELECTOPT ::=
::= SELECTOPT REVERSE_SYM
::= SELECTOPT FIRSTFAST_SYM
::= SELECTOPT FIRSTONLY_SYM
::= SELECTOPT FIRSTONLY_SYM1
::= SELECTOPT FIRSTONLY_SYM10
::= SELECTOPT FIRSTONLY_SYM100
::= SELECTOPT FIRSTONLY_SYM1000
::= SELECTOPT FORUPDATE_SYM
::= SELECTOPT NOFETCH_SYM
::= SELECTOPT FORCE_SELECT_ORDER_SYM
::= SELECTOPT FORCE_NESTED_LOOP_SYM
::= SELECTOPT FORCE_LITERALS_SYM
::= SELECTOPT FORCE_PLACEHOLDERS_SYM
::= SELECTOPT REPEATABLEREAD_SYM
::= SELECTOPT OPTIMISTICLOCK_SYM
::= SELECTOPT PESSIMISTICLOCK_SYM
::= SELECTOPT GENERATEONLY_SYM
FIND_STMT ::= FIND_JOIN SEMICOLON_SYM
FIND_JOIN ::= FIND_WHERE JOIN_LIST
FIND_WHERE ::= FIND_ORDER WHERE IF_EXPR
::= FIND_ORDER
FIND_ORDER ::= FIND_USING
::= FIND_USING ORDER_GROUP
FIND_USING ::= FIND_TABLE USING_INDEX STD_ID
::= FIND_TABLE USING_INDEX HINT_SYM STD_ID
::= FIND_TABLE
FIND_TABLE ::= SELECT_SYM SELECTOPT CROSSCOMPANY_CLAUSE VALIDTIMESTATE_CLAUSE TABLE
::= DELETE_SYM SELECTOPT CROSSCOMPANY_CLAUSE VALIDTIMESTATE_CLAUSE TABLE
TABLE ::= FLD_LIST OPT_FROM
FLD_LIST ::= MULT_SYM
::= FIELD_LIST
FIELD_LIST ::= FIELD_SPEC
::= FIELD_LIST LIST_SEP_SYM FIELD_SPEC
FIELD_SPEC ::= STD_ID INDEX
::= SUM_ELEM
OPT_FROM ::= FROM_SYM STD_ID
::=
SETFIELDSMODE ::=
UPDATE_STMT ::= UPDATETABLE SET_SYM SETFIELDSMODE FIELDASSIGNMENTS OPT_WHERE JOIN_LIST SEMICOLON_SYM
UPDATETABLE ::= UPDATE_SYM SELECTOPT CROSSCOMPANY_CLAUSE STD_ID
OPT_WHERE ::= WHERE IF_EXPR
::=
FIELDASSIGNMENTS ::= FIELDASSIGNMENTS LIST_SEP_SYM FIELDASSIGNMENT
::= FIELDASSIGNMENT
FIELDASSIGNMENT ::= STD_ID INDEX ASG_SYM IF_EXPR
INSERT_PART ::= INSERT_SYM CROSSCOMPANY_CLAUSE INSERT_NAME LEFT_PAR_SYM INSERTFIELDLIST RGHT_PAR_SYM
INSERT_NAME ::= STD_ID
INSERT_STMT ::= INSERT_PART FIND_JOIN SEMICOLON_SYM
INSERTFIELDLIST ::= INSERTFIELD
::= INSERTFIELDLIST LIST_SEP_SYM INSERTFIELD
INSERTFIELD ::= STD_ID INDEX
PRINT_STMT ::= PRINT_CLAUSE AT_CLAUSE SEMICOLON_SYM
PRINT_CLAUSE ::= PRINT IF_EXPR EXPR_LIST
PRINT ::= PRINT_SYM
AT_CLAUSE ::= AT_SYM IF_EXPR LIST_SEP_SYM IF_EXPR
::=
WINDOW_STMT ::= WINDOW_SYM IF_EXPR LIST_SEP_SYM IF_EXPR AT_CLAUSE SEMICOLON_SYM
IF_STMT ::= ELSE_STMT
::= IF_CONDS
IF_CONDS ::= IF_COND STATEMENT
IF_COND ::= IF_SYM LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
ELSE_STMT ::= ELSE STATEMENT
ELSE ::= IF_CONDS ELSE_SYM
SWITCH_STMT ::= CASE_LIST RIGHTBR_SYM
CASE_LIST ::= SWITCH_SYM LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM LEFTBR_SYM
::= CASE_TESTS STMTLIST
CASE_TESTS ::= CASE_HEADER COLON_SYM
::= CASE_LIST DEFAULT_SYM COLON_SYM
CASE_HEADER ::= CASE IF_EXPR
::= CASEALT IF_EXPR
CASE ::= CASE_LIST CASE_SYM
CASEALT ::= CASE_HEADER LIST_SEP_SYM
EXPR_STMT ::= ASG_STMT SEMICOLON_SYM
::= FUNCTION SEMICOLON_SYM
::= INTRINSICS SEMICOLON_SYM
::= EVAL SEMICOLON_SYM
PAUSE_STMT ::= PAUSE_SYM SEMICOLON_SYM
BP_CLAUSE ::= BP_SYM SEMICOLON_SYM
BREAK_STMT ::= BREAK_SYM SEMICOLON_SYM
CONTINUE_STMT ::= CONTINUE_SYM SEMICOLON_SYM
RETURN_CLAUSE ::= RETURN_SYM SEMICOLON_SYM
::= RETURN_SYM IF_EXPR SEMICOLON_SYM
TTS_STMT ::= TTSABORT_SYM SEMICOLON_SYM
::= TTSBEGIN_SYM SEMICOLON_SYM
::= TTSEND_SYM SEMICOLON_SYM
FLUSH_STMT ::= FLUSH ID_LIST SEMICOLON_SYM
FLUSH ::= FLUSH_SYM
TBLLOCK_STMT ::= TABLELOCK ID_LIST SEMICOLON_SYM
TABLELOCK ::= TABLELOCK_SYM
ID_LIST ::= STD_ID
::= ID_LIST LIST_SEP_SYM STD_ID
MOVE_REC_STMT ::= NEXT_SYM TABLE SEMICOLON_SYM
CHANGE_STMT ::= CHANGE_HEADER STATEMENT
CHANGE_HEADER ::= CHANGE LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM
CHANGE ::= CHANGECOMP_SYM
::= CHANGESITE_SYM
UNCHECKED_STMT ::= UNCHECKED_HEADER STATEMENT
UNCHECKED_HEADER ::= UNCHECKED_SYM LEFT_PAR_SYM IF_EXPR RGHT_PAR_SYM