Поделиться через


Синтаксис X++

Замечание

Группы интересов сообщества теперь переехали из Yammer в Microsoft Viva Engage. Чтобы присоединиться к сообществу Viva Engage и принять участие в последних обсуждениях, заполните форму " Запрос доступа к финансам и операциям Viva Engage Community " и выберите сообщество, к которому вы хотите присоединиться.

В этой статье содержится справочник по синтаксису для X++.

Ключевые слова X++

Ключевые слова X++, показанные в следующей таблице, зарезервированы. Эти ключевые слова нельзя использовать для других целей.

Зарезервированное слово Description Связанные сведения
! Не. Реляционные операторы
!= Оператор неравенства (не равный). Реляционные операторы
# Префикс имен макросов. Практическое руководство. Использование #define и #if для тестирования макроса
& Двоичный И. Арифметические операторы
&& Логический И. Реляционные операторы
( Оператор вызова функции, указывающий начало вызова функции.
) Оператор вызова функции, указывающий конец вызова функции.
* Умножать. Звездочка (*) также используется в X++ SQL. Одним из способов является подпись всех полей из таблиц в инструкции select . Другое использование — это подстановочный знак с like оператором для обозначения 0 ко многим символам любого вида. Оператор like также использует символ ? . Арифметические операторы
^ Двоичный XOR. Арифметические операторы
| Двоичный ИЛИ. Арифметические операторы
|| Логический ИЛИ. Реляционные операторы
~ Не. Арифметические операторы
+ Плюс. Арифметические операторы
++ Приращение. Операторы назначения
+= Аддитивное назначение. Операторы назначения
, Оператор запятой. Выражения, разделенные запятыми, оцениваются последовательно слева направо.
- Минус. Арифметические операторы
-- Оператор декремента. Операторы назначения
-= Подтрактивное назначение. Операторы назначения
. Например, formRun.run оператор доступа к члену класса обращается к run методу объекта типа FormRunкласса.
/ Делить. Арифметические операторы
\ Escape в строках. Экранирует дополнительные кавычки и некоторые буквы, такие как "\t" для вкладки.
@ Escape ключевых слов. Например, не удается скомпилировать без символаvar @str = 1@abstract;, который приводит к тому, @ что любая строка после нее будет рассматриваться как идентификатор. Он также влияет на литеральные строки, отрицая эффект символа \escape и позволяя строке охватывать несколько строк в исходном коде. Новая строка представлена одним символом шестнадцатеричной 0x0A, которая обычно называется каналом строк. Нет символа возврата каретки шестнадцатеричного 0x0D, как и в 0x0D0A.
: Символ двоеточия (:) используется для разделителя значений регистра в инструкции switch .
:: Используется для вызова статических (класс) методов: ClassName::methodName() и назначения литералы перечисления, например NoYes::Yes.
; Завершает инструкции. Используется в циклах или в for качестве разделителя инициализатора, обновления и проверяющих значений частей.
< Менее. Реляционные операторы
<< Сдвиг влево. Арифметические операторы
<= Меньше или равно. Арифметические операторы
= Оператор назначения. Аргумент слева от "=" имеет значение аргумента справа. Операторы назначения
== Возвращает значение true, если выражения равны. Реляционные операторы
> Больше. Реляционные операторы
>= Больше или равно. Реляционные операторы
>> Битовая смена вправо. Этот оператор сдвигает биты в левой части на сумму справа. Каждый сдвиг эффективно делит число на 2^n, где n — количество смещенных позиций. Арифметические операторы
?: Оператор тернарный. Знак вопроса (?) также используется оператором like для обозначения одного символа любого вида. Оператор like также использует символ. Оператор Ternary (?)
[ Декларатор массива, открытый. Необходимо использовать с "]".
] Декларатор массива, закрыть. Необходимо использовать с "[".
{ Запускает составную инструкцию, которая, в свою очередь, может содержать ноль или больше инструкций. Составная инструкция заканчивается ближайшим сопоставлением "}".
} Указывает конец составной инструкции, описанной выше. Перед первой из этих инструкций должно появиться значение "{".
abstract Модификатор классов и методов. Абстрактный класс нельзя создать с помощью нового ключевого слова. Только классы, производные от него, могут. Не удается вызвать абстрактный метод, только методы, которые переопределяют его. Таблицу можно изменить как абстрактную, задав для свойства Abstract значение Yes в AOT или с помощью DictTable класса. Свойство Abstract по умолчанию имеет значение No, и оно не может быть задано, если таблица не расширена другой таблицей. Каждая строка в абстрактной таблице должна иметь зависимые строки в производной таблице. Это означает, что каждая строка в абстрактной таблице имеет значение больше нуля в поле свойства InstanceRelationType . Нет других эффектов от маркировки таблицы как абстрактной. В неформальном режиме программисты часто используют термин конкретный для описания класса, который является не абстрактным. Общие сведения о наследовании таблиц модификаторов методов
anytype Тип, который может содержать значения любого типа. Anytype
как Требуется при назначении переменной базового класса производной переменной класса. Например, учитывая Derivedкласс, расширяющий Base класс, инструкция myDerived = myBase as Derived; избегает ошибки компилятора с помощью ключевого слова в качестве ключевого слова. Это ключевое слово также применяется при назначении базовой переменной таблицы производной переменной таблицы. Если значение (myBase) не является заданным типом (производным), выражение возвращает значение NULL. Операторы выражений: Is and As for Наследование
asc Параметр для orderby инструкции group или byselect предложения. Сортировка возрастает. Синтаксис инструкции Select
at Указывает позицию окна печати в рамках инструкции print . Оператор печати не должен использоваться. Операторы печати
среднее Возвращает среднее значение полей из строк, указанных group by предложением в инструкции select . Синтаксис инструкции Select
break Немедленное выход из итеративного блока кода. Операторы останова
контрольная точка Представляет точку останова, заданную для целей отладки. Чтобы задать точку останова в коде, напишите: breakpoint;
около Часть зарезервированного термина, например группировать по и заказу.
byref Указывает, что параметр, передаваемый в вызываемый метод, передается по ссылке (адресу), а не по значению. Byref используется в X++ при вызове метода .NET, который принимает параметр по ссылке (например, с ключевыми словами C# илиссылкой). Практическое руководство. Использование ключевого слова byref для взаимодействия CLR.
случай Выбор в операторе switch . Операторы switch
ловить Используется в обработке исключений. Обработка исключений с помощью try и catch Keywords
changeCompany Изменяет параметры базы данных в другую компанию. Изменение шаблона проектирования компании
класс Объявляет класс. Классы в X++
клиент Модификатор метода. Эти модификаторы больше не используются. Все методы выполняются на уровне сервера. Модификаторы методов
контейнер Задает container тип. Контейнеры содержат последовательность атомарных значений и других контейнеров. Containers
continue Принудительно выполняет следующую итерацию цикла. Инструкции "Продолжить"
число Возвращает количество записей из строк, указанных group by предложением в инструкции select . Синтаксис инструкции Select
crossCompany Приводит select к возврату данных для всех компаний, из-за которым пользователь может читать данные. Основы кода X++ для нескольких компаний
дата Указывает переменную типа date. Даты
по умолчанию Регистр по умолчанию в switch инструкциях. Блок кода в части по умолчанию выполняется, если значение переключателя не соответствует ни одному из case предложений, предоставленных в инструкции switch . Операторы switch
delegate Член класса, который может хранить несколько ссылок на методы в других классах, и вызывать все эти методы при появлении запроса на это. Делегат может хранить ссылки на различные виды методов, включая следующие:
  • статические методы в классах X++
  • методы экземпляра в классах X++
  • методы в классах .NET Framework
Терминология событий и ключевые слова X++, сравнение C#: событие
delete_from Позволяет удалять записи из базы данных. delete_from
desc Параметр для order by инструкции group by или select предложения. Сортировка по убыванию. Синтаксис инструкции Select
дисплей Модификатор метода. Метод отображения< и отображения> используется для отображения вычисляемых значений в элементе управления формой. В отличие от обычных полей, эти значения не хранятся в базе данных, но вычисляются динамически. Модификаторы методов
div Деление целочисленного числа. Арифметические операторы
делать do...while Начало цикла. Делать... в то время как циклы
edit Модификатор метода. Метод edit в X++ позволяет пользователям изменять значения в элементе управления форм при выполнении пользовательской логики. В отличие от методов, в которых display отображаются только вычисляемые значения, методы редактирования позволяют просматривать и редактировать. Модификаторы методов
иначе Условное выполнение (if...else). Часть elseif инструкции выполняется, если выражение в инструкции if вычисляется false Если и если ... Инструкции else
eventHandler Необходимо использовать каждый раз, когда вы добавляете или удаляете ссылку на метод из делегата с помощью += оператора или -= оператора. Например: myDelegate += eventHandler(OtherClass::myStaticMethod); Терминология событий и ключевые слова X++, сравнение C#: событие
Существует Используется с join предложениями в select инструкциях. Синтаксис инструкции Select
Расширяет Предложение объявления класса или интерфейса. Если класс явно не расширяет другой класс, класс считается расширением Object класса (как если бы вы написали "расширение объекта"). Создание подкласса
ложный Логический литерал. Логические значения
последний Модификатор классов и методов. Указывает, что этот метод нельзя переопределить. Модификаторы методов
firstFast Используется в select инструкциях для ускорения получения первой строки. Синтаксис инструкции Select
firstOnly Используется в select инструкциях для получения только первой записи. Ключевое firstOnly слово не гарантирует, что максимальное количество записей извлекается инструкцией X++ SQL select . Если AOS может использовать EntireTable кэш для удовлетворения требований select данных инструкции, firstOnly ключевое слово игнорируется. Кэширование на основе набора синтаксиса инструкций
firstOnly10 То же, что и firstOnly, за исключением возврата 10 строк вместо одного.
firstOnly100 То же, что и firstOnly, за исключением возврата 100 строк вместо одного.
firstOnly1000 То же, что и firstOnly, за исключением возврата 1000 строк вместо одного.
flush Очищает весь кэш таблиц. Это может быть полезно, если вы хотите убедиться, что любые изменения, внесенные в таблицу, немедленно отражаются в последующих операциях. Кэширование на основе набора
for Для итерации цикла. Для циклов
forceLiterals Используется в select инструкциях для отображения фактических значений, используемых в предложениях в where базе данных Microsoft SQL Server во время оптимизации. Синтаксис инструкции Select
forceNestedLoop Заставляет базу данных SQL Server использовать алгоритм вложенного цикла для обработки конкретной инструкции SQL, содержащей объект join. Синтаксис инструкции Select
forcePlaceholders Используется в select инструкциях для указания ядра не раскрывать фактические значения, используемые в where предложениях в базе данных Microsoft SQL Server во время оптимизации. Синтаксис инструкции Select
forceSelectOrder Принудительно заставляет базу данных SQL Server получать доступ к таблицам в соединении в указанном порядке. Синтаксис инструкции Select
forUpdate Выбирает записи исключительно для обновления. Операция, выполняемая для записей, которые извлекаются, является обновлением. В зависимости от базовой базы данных записи могут быть заблокированы для других пользователей. Синтаксис инструкции Select
from Часть инструкции select . Предложение from задает буфер таблицы, в котором существуют столбцы. Синтаксис инструкции Select
group group by Часть предложения в оператореselect. Синтаксис инструкции Select
if Условное выполнение. Если и если ... Инструкции else
Реализует interfaceРеализация . Обзор интерфейсов
insert_recordset Копирует данные из одной или нескольких таблиц в одну итоговую целевую таблицу в одной поездке сервера. insert_recordset
int Задает переменную типа integer (32-разрядная версия). Целые числа
int64 Указывает переменную типа integer (64-разрядная версия). Целые числа
interface Объявление интерфейса. Обзор интерфейсов
is Задает вопрос, является ли объект, на который ссылается переменная класса, либо наследуется от данного класса, либо имеет ли данный класс. Например, учитывая Derived класс, расширяющийBase класс, выражение (myDerived is Base) возвращает значение true. Это ключевое слово относится к наследованию классов и наследованию таблиц. Операторы выражений: Is and As for Наследование
join Таблицы объединяются по столбцам, общим для обеих таблиц. Вы можете создать один результирующий набор на основе нескольких таблиц с помощью соединений. Синтаксис инструкции Select
любить Проверяет совпадения по шаблону с подстановочными знаками "*" и "?". Реляционные операторы
maxof Возвращает максимальное количество полей из строк, указанных предложением group by . Синтаксис инструкции Select
minof Возвращает минимальное количество полей из строк, указанных предложением group by . Синтаксис инструкции Select
mod Возвращает целочисленную оставшуюся часть левого выражения1, разделенную на правое выражение2. Неофициально это иногда называется оператором модуля. (12 mod 7) == 5 имеет значение true.
Новое Оператор. Создает экземпляр класса или выделяет память для массива.
next Извлекает следующую запись в таблице или вызывает следующий метод в последовательности команд.
noFetch Указывает, что запись не должна быть возвращена. Синтаксис инструкции Select
notExists Используется с join предложениями в select инструкциях. Синтаксис инструкции Select
null Символьная константа.
оптимистическая блокировка Принудительно выполняет оператор с помощью элемента управления оптимистическим параллелизмом, даже если в таблице задано другое значение. Синтаксис инструкции Select
порядок order by Часть предложения в оператореselect. Синтаксис инструкции Select
внешний внешнее соединение. Синтаксис инструкции Select
pause Останавливает выполнение задания. Пользователю предлагается указать, следует ли продолжить выполнение. Этот оператор не следует использовать в рабочем коде. Выбор инструкций
pessimisticLock Принудительно выполняет оператор с пессимистичным элементом управления параллелизмом, даже если в таблице задано другое значение. Синтаксис инструкции Select
print Позволяет отображать выходные данные на экране. Этот оператор не следует использовать в рабочем коде. Операторы печати
частный Модификатор доступа к методу. Метод можно использовать только в классе, который объявляет метод. Управление доступом к методу
защищено Модификатор доступа к методу. Этот метод можно использовать из методов в классе, объявляющем методы, и в любых производных классах. Управление доступом к методу
public Модификатор доступа к методу. Метод может вызываться из любого класса. Управление доступом к методу
реальный Задает real тип, десятичный тип без ошибок округления. Реалов
repeatableRead Указывает, что другие транзакции не могут изменять данные, считываемые логикой внутри текущей транзакции, до тех пор, пока текущая транзакция не завершится. Явная транзакция завершается в ttsAbort или на самом внешнем объекте ttsCommit. Для автономной инструкции select длительность транзакции — это длительность команды select . Однако база данных иногда применяет эквивалент повторяемого чтения в отдельных инструкциях select даже без этого ключевого слова, отображаемого в коде X++ (в зависимости от того, как база данных решает сканировать таблицы). Дополнительные сведения см. в документации по базовому продукту реляционной базы данных.
снова пробовать Используется в обработке исключений. Обработка исключений с помощью try и catch Keywords
возвращать Возвращается из метода. Объявление методов
reverse Записи возвращаются в обратном порядке. Синтаксис инструкции Select
select Предложение select указывает, какие столбцы или представления отображаются в результирующем наборе. Выбор инструкций
сервер Модификатор метода. Этот модификатор игнорируется и не следует использовать, так как все методы выполняются на стороне сервера. Модификаторы методов
оправа Используется с командой update_recordset . update_recordset
статический Статические методы могут не ссылаться на переменные экземпляра (только для статических переменных); может вызываться с помощью имени класса, а не для экземпляра класса ("MyClass.aStaticProcedure"). Модификаторы методов
str Задает string тип. Строки
сумма Возвращает сумму полей из строк, указанных group by предложением в инструкции select . Синтаксис инструкции Select
супер Вызывает метод, переопределенный текущим методом. Методы таблицы
выключатель Оператор Switch. Операторы switch
tableLock Устаревший; tableLock больше недоступен.
этот Ссылка на текущий экземпляр класса. Используется в коде X++ внутри метода экземпляра класса. Используется для ссылки на члены метода класса.
бросать Используется в обработке исключений. Обработка исключений с помощью try и catch Keywords
истина Логический литерал. Логические значения
попытка Используется в обработке исключений. Обработка исключений с помощью try и catch Keywords
ttsAbort Откат (т. е. отмена) всех изменений в текущей транзакции. Целостность транзакций
ttsBegin Помечает начало транзакции. Целостность транзакций
ttsCommit Помечает конец транзакции, зафиксируя изменения в таблицах. Целостность транзакций
update_recordset Позволяет манипулировать наборами строк в одной операции. update_recordset
validTimeState Фильтрует строки, полученные из допустимой таблицы состояний времени с помощью инструкции X++ SQL select . Например, выберите validTimeState(myDateEffective) * из xMyTable; ... или... выберите validTimeState(myDateFrom, myDateTo) * из xMyTable; Влияние допустимых таблиц состояний времени на операции чтения и записи
пустота Определяет метод, который не возвращает значение. Объявление методов
where Часть инструкции select . Предложение where указывает условия, которые должны быть выполнены; то есть строки, которые необходимо включить в результат. Синтаксис инструкции Select
пока Оператор итерации. Выполняет инструкцию многократно, пока условие теста имеет значение true. В то время как циклы при выборе операторов
окно Позволяет изменить размер окна вывода. Используется с операторами печати и печати<>, которые не рекомендуется использовать в рабочем коде. Операторы печати

Синтаксис выражений

Выражение в X++ используется в математическом или логическом способе. Выражения основаны на типах данных языка; То есть выражение всегда возвращает значение определенного типа. Это значение можно использовать в вычислениях, назначениях, условных инструкциях и т. д.

Описание выражений EBNF в X++

Срок   Definition
Expression = Простое выражение [РеляционныйOperator Simple-expression]
РеляционныйOperator = =
Простое выражение = Простое выражение [ +
Срок = Compfactor { Mult-operator CompFactor }
Оператор Mult- = *
CompFactor = [ ! ] [ -
Фактор = Literal
Enum = EnumName :: Литерал
Variable = Идентификатор [ выражение] ] [ [ . Выражение ]
FunctionCall = [ Выражение (.
Выражение If = Выражение? Выражение: выражение

Ограничения семантики применяются к предыдущему синтаксису. Невозможно вызвать какой-либо метод с помощью оператора ::. Аналогичным образом нельзя использовать это ключевое слово без активного объекта; То есть, если вы не входите в метод экземпляра и т. д.

Примеры

Пример выражения Description
1 Целый литерал.
NoYes::No Ссылка на перечисление.
A Ссылка на переменную.
Должник::Find("1") Статический вызов метода (возвращает переменную клиента).
(A > 3 ? true: false) Выражение if, возвращающее значение true или false.
(выберите CustTable, где CustTable.Account == "100"). NameRef Выражение select-expression. Возвращает поле nameref в таблице клиента. Это строка.
A = B > Логическое выражение. Возвращает значение true или false.
A + B Арифметическое выражение. Суммы А и Б.
A + B / C Вычисляет B/C, а затем добавляет его в A.
~A + это. Value() Суммирует двоичное значение, а не A, и результат вызова метода для объекта в области (это).
Должник::Find("1"). NameRef Возвращает поле NameRef найденной записи клиента.
Должник::Find("1"). Balance() Вызов Balance метода в таблице клиента (Дебитор::Найти возвращает клиента). Возвращает баланс клиента с номером 1 учетной записи.

Обзор EBNF

Расширенная форма Backus Naur (EBNF) — это метаангуж и используется в этом руководстве для описания синтаксиса языка. Определение EBNF состоит из рабочих правил, нетерминальных и терминалов. Ключевые термины показаны в следующей таблице.

Ключевые термины Example Description
Терминалы Work_Team Терминал — это один символ или строка символов, которые никогда не изменяются.
Нетерминалы Employee Нетерминальный — это описание части допустимого предложения на языке, определяемом рабочим правилом или текстовым описанием. Нетерминальный символ всегда можно развернуть до одного или нескольких символов терминала.
Рабочие правила Employee = Developer Tester

Example

Work_Team = менеджер сотрудник {, Employee} Employee = Developer | Тестировщик в этом примере определяет Work_Team как состоящий из Manager одного или нескольких Employees. Определяется Employee как тип Developer, или .Tester Символы, используемые в примере, описаны в следующей таблице.

Специальные символы в EBNF

Symbol Description
(Выражение) Круглые скобки содержат символы (терминалы и нетерминальные) вместе. Они могут размещаться в любом месте в правой части правила рабочей среды.
Выражение1 Выражение2
[Выражение] Необязательно. Элементы между [ и ] являются необязательными. Все или ни один из элементов в квадратных скобках не включены.
{Expression} Повторите: элементы между {и } являются необязательными, но могут повторяться столько раз, сколько необходимо.

Например, если аксессуары, которые вы покупаете для велосипеда, состоят из седла, держателей бутылки воды, колоколов и рогов, и вы можете иметь либо колокол или рог, и ноль, один или несколько держателей бутылки воды, а именно один седло, это может быть выражено следующим образом: Bicycle_Accessories = седло [колокол | рог] {water_bottle_holders} Эта грамматика определяет следующие возможности: saddlesaddle bellsaddle horn седло water_bottle_holder седлый колокол water_bottle_holder седлый колокол water_bottle_holder water_bottle_holder И так далее.

Грамматика X++

В этой статье показана официальная грамматика языка X++.

Интерпретация формальной грамматики BNF

В этом разделе описывается грамматика X++ в Backus Naur Form (BNF). Ниже описан небольшой пример BNF.

AA ::= BB  CC_SYM
BB ::= JJ_SYM
   ::= KK_SYM

AA — имя рабочего правила. Требуется AA , BBза которым следует CC_SYM. А BB также является рабочим правилом. BB Поэтому не является терминалом. BB должен быть либо JJ_SYM, либо KK_SYM. Оба JJ_SYM и KK_SYM являются терминалами, так как они не являются именами других рабочих правил. CC_SYM также является терминалом.

В грамматике BNF для X++ большинство терминалов имеют _SYM в качестве суффикса их имени.

Официальная грамматика X++ в BNF

Этот раздел содержит BNF, определяющий грамматику 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

Дополнительные ресурсы

Справочник по языку X++