Синтаксис логических выражений.

 

Синтаксические правила, рассмотренные в разделе 3.3, не покрывают случай, когда логические выражения могут включать переменные и константы. Эти правила не задают структуру всех возможных допустимых строк, которые могут образовывать логические выражения. Новые правила для логических выражений приведены ниже:

 

<выражение> ::= <простое выражение>

| <простое выражение> <оператор сравнения> <простое выражение>

 

<простое выражение> ::= <простое выражение> OR <терм> | <терм>

<терм> ::= <терм> AND <множитель> | <множитель>

<множитель> ::= <переменная> | <константа> | (<выражение>) | NOT <множитель>

 

Синтаксически некорректно записывать:

X <= Y <= Z

Для того, чтобы определить, что Y имеет значение, находящееся между значениями X и Z. Вместо этого требуется записать

(X <= Y) AND (Y <= Z)

чтобы выполнить такую проверку.

 

Скобки в выражениях – часть синтаксиса Паскаля. Попытка построить синтаксическое дерево для первого выражения терпит неудачу:

 
 

 


Невозможно вывести строку X <= Y из первого <простого выражения> без введения дополнительных символов в строку (например скобок). Для второго выражения может быть построено корректное синтаксическое дерево:

 

 
 

 


Последовательные лево-ассоциативные операторы с одинаковым приоритетом применяются к их операндам в порядке слева-на-право. Таким образом, в выражении

X OR Y OR Z

подвыражение

X OR Y

будет вычислено первым. Синтаксическое дерево для этого выражения будет следующим:

 

 


Операнды для каждого OR в строке могут быть найдены поиском строк, выведенных из соотвествующего <простого выражения> и <терма>. Операндами левого OR являются X и Y, тогда как операндами правого OR являются X OR Y (строка выведенная из первого <простоего выражения>) и Z. Таким образом, левый OR применяется к операндам раньше правого. (Конечно, приоритет операторов в выражении может быть изменен с помощью скобок)

Правило синтаксиса является леворекурсивным, если определяемая величина (то, что размещается слева от ::=) также появляется на первом месте справа от ::=.

Правило для <term> леворекурсивоное:

<терм> ::= <терм> AND <множитель>

Когда оператор определяется с использованием левой рекурсии, он будет левоассоциативным, как показано на синтаксических деревьях приведенных выше.

Относительный приоритет операторов также определен синтаксическими правилами. Синтаксическое дерево для

X OR Y AND Z

иллюстрирует приоритет операторов:

 

 


Несмотря на то, что AND расположен правее OR в строке, он применяется к его операндам, Y и Z до того как OR будет применен к своим операндам, X и Y AND Z. Таким образом, AND имеет более высокий приоритет в логических выражениях, чем OR.