ГОСТ Р ИСО/ТО 10303-12-2000 Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 12. Методы описания. Справочное руководство по языку EXPRESS-1

Обложка ГОСТ Р ИСО/ТО 10303-12-2000 Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 12. Методы описания. Справочное руководство по языку EXPRESS-1
Обозначение
ГОСТ Р ИСО/ТО 10303-12-2000
Наименование
Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 12. Методы описания. Справочное руководство по языку EXPRESS-1
Статус
Действует
Дата введения
2002.01.01
Дата отмены
-
Заменен на
-
Код ОКС
25.040.40


ГОСТ Р ИСО/ТО 10303-12-2000

Группа П87



ГОСУДАРСТВЕННЫЙ СТАНДАРТ РОССИЙСКОЙ ФЕДЕРАЦИИ


Системы автоматизации производства и их интеграция

ПРЕДСТАВЛЕНИЕ ДАННЫХ ОБ ИЗДЕЛИИ И ОБМЕН ЭТИМИ ДАННЫМИ

Часть 12

Методы описания. Справочное руководство по языку EXPRESS-I

Industrial automation systems and integration. Product data representation and exchange. Part 12. Description methods. The EXPRESS-I language reference manual

ОКС 25.040.40

ОКСТУ 4002

Дата введения 2002-01-01



Предисловие

1 РАЗРАБОТАН Всероссийским научно-исследовательским институтом стандартизации (ВНИИстандарт) при участии Научно-технического центра "ИНТЕГРО-Д"

ВНЕСЕН Техническим комитетом по стандартизации ТК 431 "СALS-технологии"

2 ПРИНЯТ И ВВЕДЕН В ДЕЙСТВИЕ Постановлением Госстандарта России от 14 ноября 2000 г. N 292-ст

3 Настоящий стандарт содержит полный аутентичный текст международного стандарта ИСО/ТО 10303-12-97 "Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 12. Методы описания. Справочное руководство по языку EXPRESS-I"

4 ВВЕДЕН ВПЕРВЫЕ

Введение

Стандарты серии ГОСТ Р ИСО 10303 распространяются на машинно-ориентированное представление данных об изделии и обмен этими данными. Целью является создание механизма, позволяющего описывать данные об изделии на протяжении всего жизненного цикла изделия независимо от конкретной системы. Характер такого описания делает его пригодным не только для обмена инвариантными файлами, но также и для создания баз данных об изделиях, коллективного пользования этими базами и архивации соответствующих данных.

Стандарты серии ГОСТ Р ИСО 10303 представляют собой набор отдельно издаваемых стандартов (частей). Части данной серии стандартов относятся к одной из следующих тематических групп: методы описания, интегрированные ресурсы, прикладные протоколы, комплекты абстрактных тестов, методы реализации и аттестационное тестирование. Группы стандартов данной серии описаны в ГОСТ Р ИСО 10303-1. Настоящий стандарт входит в группу методов описания.

Настоящий стандарт определяет элементы языка EXPRESS-I. Каждый элемент языка представляется в своем собственном контексте с примерами. Сначала вводятся простые элементы, а затем представляются более комплексные идеи в порядке нарастания их сложности.

Обзор языка

EXPRESS-I - это название языка формального представления данных и спецификации абстрактных тестовых (контрольных) примеров. Он может быть использован для описания информационных требований других стандартов серии ГОСТ Р ИСО 10303 и родственен языкам EXPRESS и EXPRESS-G. Язык базируется на целом ряде целей проектирования, в частности:

- размеры и сложность стандартов серии ГОСТ Р ИСО 10303 требуют обеспечить читабельность языка как для компьютера, так и для человека. Выразительные средства стандартов данной серии призваны облегчить формальное выявление несоответствий в представлениях или спецификациях при использовании средств автоматизации;

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

- обойтись, насколько это возможно, без рассмотрения конкретной реализации;

- обеспечить средства отображения малых совокупностей EXPRESS-схем;

- обеспечить средства поддержки спецификации комплектов абстрактных тестов для процессоров информационных моделей.

В EXPRESS-I экземпляры объектов представляются в терминах значений атрибутов: особенностей либо характеристик, считающихся важными для использования и понимания. Эти атрибуты имеют представление, которое может быть простым типом данных (таким, как целочисленный) либо типом другого объекта. Геометрическая точка может быть определена в терминах трех вещественных (действительных) чисел. Атрибутам, образующим определение объекта, даются имена. Так, для геометрической точки три вещественных числа могут иметь имена х, у и z. Устанавливается отношение между определяемым объектом и определяющими его атрибутами и, аналогичным образом, между атрибутом и его представлением.

Язык EXPRESS-I обеспечивает средства для отображения реализацией элементов данных языка EXPRESS. Язык разработан, в основном, для восприятия человеком и для облегчения отображения экземпляров EXPRESS-I на определении в EXPRESS-схеме. В некоторых стандартах серии ГОСТ Р ИСО 10303, например в ГОСТ Р ИСО 10303-21, установлены требования к рациональным машинным реализациям схем. EXPRESS-I не предназначен для замены этих методов.

Основные элементы языка показаны на рисунке 1. Язык имеет две главные части. Первая часть служит для отображения экземпляров данных. Данные могут быть отображены на основе объект-объект, на основе схемы либо как набор экземпляров схем, предназначенный для отображения некоторой информационной модели рассматриваемой предметной области. В языке EXPRESS-I эти данные называются экземплярами предмета (object instances), экземплярами данных схемы (schema data instances) и моделью (model). На рисунке 1 предполагается, что информационная модель определена с помощью языка EXPRESS.

Рисунок 1 - Главные элементы языка EXPRESS-I

Вторая часть языка служит для специфицирования абстрактных тестовых (контрольных) примеров с целью формального описания тестов, выполняемых над реализацией информационной модели, заданной на языке EXPRESS. Конструкциями языка, предназначенными для этой цели, являются контрольный пример (test case) и контекст (context). Данный раздел языка использует также процедурные аспекты языка EXPRESS. Экземпляры данных могут быть параметризованы и сохранены в контексте. Многие различные контрольные примеры могут присваивать значения параметризованным данным в контексте и использовать эти данные как часть спецификации данного теста.

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

Примечание - Примеры использования EXPRESS-I в настоящем стандарте не согласованы с правилами какого-либо конкретного стиля. В самом деле, иногда примеры используют не лучший стиль, чтобы достичь краткости либо показать гибкость. Примеры не претендуют на отражение содержания информационных моделей, определяемых в других стандартах серии ГОСТ Р ИСО 10303. Их функция - показать конкретные особенности EXPRESS-I. Любую аналогию между этими примерами и обязательными информационными моделями или абстрактными контрольными примерами, определенными в других стандартах серии ГОСТ Р ИСО 10303, следует игнорировать.

1 Область применения

Настоящий стандарт определяет язык, на котором может быть описан (отображен) экземпляр (часть) рассматриваемой предметной области. Стандарт также определяет метод формального описания для поддержки спецификаций абстрактных тестовых (контрольных) примеров. Данный язык называется EXPRESS-I. Этот язык родственен языку EXPRESS, определенному в ГОСТ Р ИСО 10303-11.

EXPRESS-I является языком реализации для языка концептуальной схемы, как определено в ИСО/ТО 9007 [1], а конкретным языком концептуальной схемы, послужившим отправной точкой для EXPRESS-I, является EXPRESS. Язык EXPRESS-I позволяет отображать состояние предметов, принадлежащих к рассматриваемой предметной области, и блоки информации, относящиеся к этим предметам.

В область применения настоящего стандарта входят:

- отображение экземпляров схем;

- отображение экземпляров типов и объектов (сущностей);

- данные абстрактного тестового (контрольного) примера;

- преобразование EXPRESS-схем и типов данных в экземпляры EXPRESS-I.

В область применения настоящего стандарта не входят:

- преобразование из других языков (концептуальных схем) в EXPRESS-I;

- определение форматов базы данных;

- определение форматов файла;

- определение форматов передачи данных;

- управление процессом;

- обработка информации;

- обработка исключительных ситуаций.

EXPRESS-I не является языком программирования.

2 Нормативные ссылки

В настоящем стандарте использованы ссылки на следующие стандарты:

ГОСТ Р ИСО 10303-1-99 Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 1. Общие представления и основополагающие принципы

ГОСТ Р ИСО 10303-11-2000 Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 11. Методы описания. Справочное руководство по языку EXPRESS

ГОСТ Р ИСО 10303-21-99 Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 21. Методы реализации. Кодирование открытым текстом структуры обмена

ИСО/МЭК 8824-1-95* Информационная технология. Взаимосвязь открытых систем. Абстрактная синтаксическая нотация версии один (АСН.1). Часть 1. Спецификация основной нотации

___________

* Оригиналы стандартов ИСО (ИСО/МЭК) - во ВНИИКИ Госстандарта России.

ИСО 10303-31-94* Системы автоматизации производства и их интеграция. Представление данных об изделии и обмен этими данными. Часть 31. Методология и основы аттестационного тестирования. Общие положения

___________

* Оригиналы стандартов ИСО (ИСО/МЭК) - во ВНИИКИ Госстандарта России.

ИСО/МЭК 10646-1-93* Информационная технология. Универсальный многобайтно-кодированный набор символов. Часть 1. Архитектура и основной многоязычный уровень

___________

* Оригиналы стандартов ИСО (ИСО/МЭК) - во ВНИИКИ Госстандарта России.

3 Определения

3.1 Термины, определенные в ГОСТ Р ИСО 10303-1

В настоящем стандарте использованы следующие термины, определенные в ГОСТ Р ИСО 10303-1:

- данные;

- информация;

- информационная модель.

3.2 Термины, определенные в ГОСТ Р ИСО 10303-11

В настоящем стандарте использованы следующие термины, определенные в ГОСТ Р ИСО 10303-11:

- граф подтип/супертип; ;

- значение;

- константа;

- лексема;

- объект;

- совокупность;

- тип данных сложного объекта;

- тип данных;

- экземпляр сложного объекта;

- экземпляр объекта;

- экземпляр простого объекта;

- экземпляр.

3.3 Термины, определенные в ИСО 10303-31

В настоящем стандарте использованы следующие термины, определенные в ИСО 10303-31:

- абстрактный тестовый (контрольный) пример;

- критерий вердикта;

- цель теста.

3.4 Другие определения

В настоящем стандарте использованы следующие термины с соответствующими определениями:

3.4.1 атрибут (attribute): Особенность, качество или свойство, характеризующее объект.

3.4.2 информационная база (information base): Набор экземпляров типов, соответствующих друг другу и информационной модели, принадлежащий экземпляру рассматриваемой предметной области.

Примечание - Информационная база может либо не может быть пригодной для компьютерной обработки. Например, ее не следует считать пригодной для компьютерной обработки, если она имеет форму рукописного документа. С другой стороны, если она задана в виде базы данных или компьютерного файла, то ее следует считать пригодной для компьютерной обработки и, следовательно, ее можно также называть объектной базой.

3.4.3 объектная база (object base): Информационная база, пригодная для компьютерной обработки.

3.4.4 схема (schema): Набор тесно связанных элементов, образующий информационную модель либо ее часть.

3.4.5 тип (type): Представление области (домена) допустимых значений.

3.4.6 рассматриваемая предметная область (universe of discourse): Все те объекты (предметы) реального мира, которые представляют потенциальный интерес. Они являются подмножеством всех предметов (объектов) реального мира.

4 Требования соответствия

4.1 Формальные спецификации, записанные на EXPRESS-I

Формальная спецификация, записанная на EXPRESS-I, должна быть согласована с заданным уровнем соответствия, как определено ниже. Формальная спецификация соответствует данному уровню, когда для нее успешно выполнены все проверки, предусмотренные для данного и всех нижележащих уровней.

4.1.1 Уровни соответствия

Уровень 1. Проверка ссылок.

Этот уровень включает проверку формальной спецификации на корректность синтаксиса и ссылок. Формальная спецификация синтаксиса верна, если она соответствует синтаксису, образованному расширением первичных синтаксических правил, приведенных в приложении А. Формальная спецификация верна по ссылкам, если все ссылки на элементы EXPRESS-I соответствуют области действия и правилам видимости, определенным в разделе 11.

Уровень 2. Проверка типов.

Данный уровень включает проверку формальной спецификации на совместимость типов в выражениях и операторах присваивания, как определено для проверок уровня 2 в ГОСТ Р ИСО 10303-11.

Уровень 3. Проверка значений.

Данный уровень включает проверку формальной спецификации на соответствие условиям, определяемым проверками уровня 3 по ГОСТ Р ИСО 10303-11.

Уровень 4. Полная проверка.

Данный уровень включает проверку формальной спецификации на соответствие всем формулировкам требований, установленным в настоящем стандарте.

4.2 Реализации EXPRESS-I

Реализация синтаксического анализатора языка EXPRESS-I должна обеспечивать синтаксический разбор любой формальной спецификации, записанной на EXPRESS-I, в соответствии с ограничениями, связанными с данной реализацией, которые определены в ЗСРП (приложение В). Синтаксический анализатор языка EXPRESS-I должен быть продекларирован на соответствие конкретному уровню (как это определено в 4.1.1), если он может реализовать все проверки, предусмотренные для данного уровня (и всех нижележащих уровней) для формальной спецификации, записанной на EXPRESS-I.

Разработчик синтаксического анализатора языка EXPRESS-I должен указать все ограничения, которые реализация накладывает на число и длину идентификаторов, диапазон обрабатываемых чисел и максимальную точность вещественных чисел. Такие ограничения должны документироваться для аттестационного тестирования в виде, определенном в приложении В.

5 Основные принципы

Предполагается, что читатель настоящего стандарта знаком с языком EXPRESS, описанным в ГОСТ Р ИСО 10303-11.

Использование EXPRESS-I для отображения экземпляров не требует и не предполагает наличия соответствующего набора объектов или других определений. Это означает, что EXPRESS-I может использоваться как язык со своими собственными правилами. Однако обычно вводится сопутствующий набор определений, описанных формальным образом на основе языка типа EXPRESS.

EXPRESS-I не описывает среду реализации. В частности, EXPRESS-I не определяет:

- как организован доступ или вывод данных экземпляра;

- как организовано хранение или обслуживание данных экземпляра;

- как разрешены ссылки на EXPRESS-схемы;

- как и когда проверяются ограничения или о них сообщается.

6 Элементы языка

В данном разделе установлены основные элементы, из которых формируют предложения языка EXPRESS-I: набор символов, примечания, знаки, зарезервированные слова и идентификаторы.

Определения синтаксиса, приведенные в настоящем стандарте в прямоугольных рамках, являются выдержками из синтаксиса языка EXPRESS-I, установленного в приложении А, которое определяет полный синтаксис языка и любые языковые конструкции, не представленные в настоящем разделе. Метод спецификации синтаксиса является расширением множества, используемого для EXPRESS в соответствии с разделом 6 ГОСТ Р ИСО 10303-11.

Примечание 1 - Для удобства читателя метод определения EXPRESS повторен в приложении D вместе с расширениями для EXPRESS-I.

Базовые элементы языка компонуются в поток исходного текста, обычно разделяемого на физические строки. Физической строкой является любое число символов (включая ноль), заканчивающееся символом новой строки (см.6.1.5.2).

Примечание 2 - Исходный текст EXPRESS-I легче читать, если операторы представлены отдельными строками, а для разделения различных конструкций использованы пробелы.

6.1 Набор символов

В исходном тексте EXPRESS-I следует использовать только символы из следующего набора: символы, размещенные в ячейках 20-7Е ряда 00 уровня 00 группы 00 ИСО/МЭК 10646-1 и специальный символ \n, обозначающий новую строку. Этот набор называется набором символов EXPRESS-I. Элементы этого набора ссылаются на соответствующие ячейки ИСО/МЭК 10646-1, в которых определены данные символы; номера этих ячеек определены в шестнадцатеричной системе. Печатаемые символы данного набора (ячейки 21-7Е из ИСО/МЭК 10646-1) комбинируются для образования лексем языка EXPRESS-I. Лексемами EXPRESS-I являются ключевые слова, идентификаторы, знаки, литералы или значения. Дальнейшая классификация набора символов EXPRESS-I приведена ниже.

Определенный таким образом набор символов является абстрактным набором символов; он не зависит от его представления в реализации. В частности, фактическая реализация может использовать некоторые управляющие коды, определенные в ИСО/МЭК 6429 [2]. Такие коды интерпретируются реализацией и в результате могут приводить к включению в окончательный исходный текст одного или нескольких абстрактных символов из набора символов EXPRESS-I.

Пример 1 - Управляющий код TAB может интерпретироваться реализацией как добавление одного или нескольких символов пробела к абстрактным символам, образующим определение EXPRESS-I.

Примечание - Данный раздел определяет только символы, используемые для определения исходного текста на EXPRESS-I, но не определяет область символов, допустимых внутри строкового значения.

6.1.1 Цифры

В EXPRESS-I используются арабские цифры 0-9 (ячейки 30-39 набора символов ЕХPRESS-I).

Синтаксис:

120 digit = < как в EXPRESS > .

6.1.2 Буквы

В EXPRESS-I используются прописные и строчные буквы английского алфавита (ячейки 41-5А и 61-7А набора символов EXPRESS-I). Тип букв имеет значение только внутри явных строковых значений.

Примечание - EXPRESS-I может быть описан с использованием прописных, строчных или и тех, и других букв.

Синтаксис:

124 letter = < как в EXPRESS > .

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

Специальные символы (печатаемые символы, не являющиеся буквами или цифрами) используются, в основном, для пунктуации и в качестве операторов. Некоторые из указанных специальных символов не используются как часть языка. Они, однако, могут использоваться внутри примечаний и строковых значений. Такие специальные символы находятся в ячейках 21-2F, 3A-3F, 40, 5В-5Е, 60 и 7В-7Е набора символов EXPRESS-I.

Синтаксис:

134 special = < как в EXPRESS > .

6.1.4 Подчеркивание

Символ подчеркивания ( _ , ячейка 5F набора символов EXPRESS-I ) может быть использован в идентификаторах и ключевых словах, но он не должен использоваться в качестве первого символа.

6.1.5 Пробел

Пробел определяется в следующих подпунктах и в 6.1.6. Пробел должен использоваться для разделения лексем в исходном тексте EXPRESS-I.

Примечание - Свободное, в рамках допустимого, использование пробелов может улучшить структуру и читабельность исходного текста на EXPRESS-I.

6.1.5.1 Символ пробела

Один или несколько пробелов (ячейка 20 набора символов EXPRESS-I ) могут появиться между двумя лексемами или внутри строкового значения. Обозначение \s можно использовать для представления символа пробела в синтаксисе языка.

6.1.5.2 Новая строка

Новая строка помечает физический конец строки внутри формальной спецификации, записанной на EXPRESS-I. Новая строка обычно выступает как пробел, но требуется и по существу, когда она завершает концевое примечание или появляется внутри строкового значения. Новая строка представляется обозначением \n в синтаксисе языка.

Представление новой строки определяется реализацией.

6.1.6 Примечания

Примечание используется для документирования и должно интерпретироваться синтаксическим анализатором EXPRESS-I как пробел. Имеются две формы примечания: встроенное и концевое.

6.1.6.1 Встроенное примечание

Пара символов (* обозначает начало встроенного примечания, а пара символов *) обозначает его конец. Встроенное примечание может появляться между любыми двумя лексемами.

Синтаксис:

142 embedded_remark = < как в EXPRESS > .

Любой символ из набора символов EXPRESS-I может находиться между началом и концом встроенного примечания, включая символ новой строки; поэтому встроенные примечания могут занимать несколько физических строк.

Встроенные примечания могут быть вложенными.

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

Пример 2 - Пример встроенных вложенных примечаний.

(* Знак `(*` начинает встроенное примечание, а знак `*)` заканчивает его. *)

6.1.6.2 Концевое примечание

Концевое примечание записывается в конце физической строки. Два последовательных дефиса (--) служат началом концевого примечания, а последующий символ новой строки завершает его.

Синтаксис:

144 tail_remark = < как в EXPRESS > .

Пример 3 - Концевое примечание.

- - Это концевое примечание, и оно завершается символом новой строки.

6.2 Зарезервированные слова

Зарезервированными словами в EXPRESS-I являются ключевые слова и имена встроенных констант, функций и процедур. Зарезервированные слова не должны использоваться в качестве идентификаторов. Зарезервированные слова EXPRESS-I описаны ниже.

6.2.1 Ключевые слова

В EXPRESS-I используется подмножество ключевых слов EXPRESS вместе с некоторыми дополнительными ключевыми словами.

В таблице 1 перечислены ключевые слова, общие для EXPRESS-I и EXPRESS. В таблице 2 перечислены дополнительные ключевые слова EXPRESS-I.

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

Таблица 1 - Ключевые слова, общие для EXPRESS-I и EXPRESS

ABSTRACT

AGGREGATE

ALIAS

ARRAY

BAG

BEGIN

BINARY

BOOLEAN

BY

CASE

CONSTANT

CONTEXT

DERIVE

ELSE

END

END_ALIAS

END_CASE

END_CONSTANT

END_CONTEXT

END_ENTITY

END_FUNCTION

END_IF

END_LOCAL

END_MODEL

END_PROCEDURE

END_REPEAT

END_TYPE

ENTITY

ENUMERATION

ESCAPE

FIXED

FOR

FUNCTION

GENERIC

IF

INTEGER

INVERSE

LIST

LOCAL

LOGICAL

MODEL

NUMBER

OF

ONEOF

OPTIONAL

OTHERWISE

PROCEDURE

QUERY

REAL

REPEAT

RETURN

SELECT

SET

SKIP

STRING

SUBTYPE

SUPERTYPE

THEN

ТO

TYPE

UNIQUE

UNTIL

VAR

WHERE

WHILE

Таблица 2 - Дополнительные ключевые слова EXPRESS-I

CALL

CRITERIA

END_CALL

END_CRITERIA

END_NOTES

END_OBJECTIVE

END_PARAMETER

END_PURPOSE

END_REALIZATION

END_REFERENCES

END_SCHEMA_DATA

END_TEST_CASE

IMPORT

NOTES

OBJECTIVE

PARAMETER

PURPOSE

REALIZATION

REFERENCES

SCHEMA_DATA

SUBOF

SUPOF

TEST_CASE

USING

WITH

6.2.2 Зарезервированные слова, являющиеся операторами

Операторы, определяемые зарезервированными словами, указаны в таблице 3. Это те же самые операторы, что и операторы EXPRESS, определенные в разделе 12 ГОСТ Р ИСО 10303-11.

Таблица 3 - Использование в EXPRESS-I операторов EXPRESS

AND

ANDOR

DIV

IN

LIKE

MOD

NOT

OR

XOR

6.2.3 Встроенные константы

Имена встроенных констант EXPRESS-I приведены в таблице 4. Это те же константы, что и константы EXPRESS, определенные в разделе 14 ГОСТ Р ИСО 10303-11.

Таблица 4 - Использование в EXPRESS-I констант EXPRESS

?

CONST_E

FALSE

PI

SELF

TRUE

UNKNOWN

6.2.4 Встроенные функции

Имена функций EXPRESS, которые могут использоваться в EXPRESS-I, приведены в таблице 5.

Таблица 5 - Использование в EXPRESS-I функций EXPRESS

ABS

ACOS

ASIN

ATAN

BLENGTH

COS

EXISTS

EXP

FORMAT

HIBOUND

HIINDEX

LENGTH

LOBOUND

LOG

LOG10

LOG2

LOINDEX

NVL

ODD

ROLESOF

SIN

SIZEOF

SQRT

TAN

TYPEOF

USEDIN

VALUE

VALUE_IN

VALUE_UNIQUE

Определения этих функций приведены в разделе 15 ГОСТ Р ИСО 10303-11.

6.2.5 Встроенные процедуры

Имена EXPRESS-процедур, которые могут быть использованы в EXPRESS-I, приведены в таблице 6. Процедуры определены в разделе 16 ГОСТ Р ИСО 10303-11.

Таблица 6 - Использование в EXPRESS-I процедур EXPRESS

INSERT

REMOVE

6.3 Знаки

Знаками являются специальные символы или группы специальных символов, имеющие специфический смысл в EXPRESS-I. Знаки используются в EXPRESS-I в качестве ограничителей и операторов. Ограничитель используется для начала, разделения или завершения соседних лексических или синтаксических элементов. Интерпретация этих элементов была бы невозможной без разделителей. Операторы означают, что над операндами должны быть совершены действия, связанные с оператором. Знаки EXPRESS-I приведены в таблицах 7 и 8.

Таблица 7 - Знаки, общие для EXPRESS-I и EXPRESS

.

,

;

:

*

+

-

=

%

'

\

/

<

>

[

]

{

}

|

e

(

)

<=

< >

>=

:=

||

**

- -

(*

*)

:=:

:<>:

Таблица 8 - Дополнительные знаки EXPRESS-I

@

!

= =

"

6.4 Идентификаторы и ссылки

Идентификаторами являются имена, присвоенные элементам, объявленным в реализации EXPRESS-I. Идентификатор не должен совпадать с зарезервированными словами EXPRESS-I или EXPRESS.

Синтаксис:

187 constant_id = < как в EXPRESS > .

198 entity_id = < как в EXPRESS > .

282 schema_id = < как в EXPRESS > .

140 simple_id = < как в EXPRESS > .

51i ComplexEntityInstanceld = SimpleEntitylnstanceld `[` SupSubld `]` .

58i Contextld = simple_id .

69i Entitylnstanceld = ComplexEntitylnstanceld |

SimpleEntitylnstanceld .

73i Enumerationld = type_ref .

75i EnumerationInstanceld = simple_id .

92i Modelld = simple_id .

100i Parameterld = simple_id .

115i Selectld = type_ref .

117i Selectlnstanceld = simple_id .

120i SimpleEntitylnstanceld = simple_id .

122i Simplelnstanceld = simple_id .

125i SupSubld = digits .

129i TestCaseld = simple_id .

136i Typeld = type_ref .

138i Typelnstanceld = simple_id .

Первым символом простого идентификатора должна быть буква. Остальные символы, при их наличии, могут быть любой комбинацией букв, цифр и символа подчеркивания. Внутри идентификаторов не должно быть ни одного пробела.

Разработчик синтаксического анализатора EXPRESS-I должен установить максимальное число символов идентификатора, которое может распознаваться данной реализацией (см. приложение В).

Примечание - Буквы, используемые для формирования идентификаторов, не чувствительны к типу, т.е. заглавные и строчные буквы воспринимаются как одинаковые.

Пример 4 - Правильные простые идентификаторы

POINT

line

Circle

AnEntity

item507

An_integer.

Пример 5 - Неправильные простые идентификаторы

_POINT

подчеркивание не может быть первым символом

line?

? не может быть частью идентификатора

3dThing

цифра не может быть первым символом

Pi

Pi является ключевым словом EXPRESS-I

Пример 6 - Правильные идентификаторы экземпляра сложного объекта

complex[101]

complex[12]

an_ent[23]

an_ent[77]

Синтаксис:

146 constant_ref = < как в EXPRESS > .

154 type_ref = < как в EXPRESS > .

36i ContextRef = Contextld .

39i ParameterRef = Parameterld .

На элемент можно ссылаться по его идентификатору. На элементы - константа и параметр - можно ссылаться по соответствующему идентификатору.

Синтаксис:

34i ComplexEntitylnstanceRef = `@` SipmleEntitylnstanceld .

37i EntitylnstanceRef = ComplexEntitylnstanceRef |

SimpleEntitylnstanceRef .

38i EnumerationlnstanceRef = `@` Enumerationlnstanceld .

96i ObjectlnstanceRef = EntitylnstanceRef | EnumerationlnstanceRef |

SelectlnstanceRef | SimplelnstanceRef |

TypelnstanceRef .

40i SelectlnstanceRef = `@` Selectlnstanceld .

41i SimpleEntitylnstanceRef = `@` SimpleЕntitylnstanceld .

42i SimplelnstanceRef = `@` Simplelnstanceld .

43i SupSubRef = `@` SupSubld .

44i TypelnstanceRef = `@` Typelnstanceld .

Первым символом ссылки на экземпляр объекта (entity), перечисления (enumeration), типа (type) или выбора (select) должен быть @ с последующим хотя бы одним символом. Символы после начального @ могут быть любой комбинацией букв, цифр и символа подчеркивания, которые образуют правильный идентификатор объекта, перечисления, простого экземпляра, экземпляра выбора или типа. Эти ссылки в совокупности называются ссылками на экземпляр предмета.

Пример 7 - Правильные ссылки на экземпляр предмета

@POINT

@line

@Circle

@AnEntity

@item567

Пример 8 - Неправильные ссылки на экземпляр предмета.

@line?

? не может быть частью идентификатора

3dThing

@ должен быть первым символом

@subof

subof является ключевым словом EXPRESS-I

@@Circle

@ может появляться только в качестве первого символа

@567

символы, следующие за @, должны начинаться с буквы

@complex[82]

допустимы только символы букв, цифр и подчеркивания.



7 Именованные области значений

В настоящем разделе определены типы областей значений (доменов), как части языка. Области значений используются для описания допустимых значений экземпляра. Именованными областями значений являются области значений объекта, типа, перечисления или выбора.

7.1 Область значений объекта

Область значений объекта представляет класс предметов, имеющих общие атрибуты.

Синтаксис:

66i EntityDomain = [ Schemald `.` ] Entityld .

Примечание - Область значений объекта соответствует типу данных объекта в языке EXPRESS.

7.2 Область значений перечисления

Область значений перечисления охватывает область значений упорядоченное множество имен.

Синтаксис:

72i EnumerationDomain = [ Schemald `.` ] Enumerationld .

Примечание - Область значений перечисления соответствует перечисляемому типу данных в языке EXPRESS.

7.3 Область значений выбора

Область значений выбора охватывает объединение областей значений.

Синтаксис:

114i SelectDomain = [ Schemald `.` ] Seiectld .

Примечание - Область значений выбора соответствует выбираемому типу данных в языке EXPRESS.

7.4 Область значений типа

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

Синтаксис:

135i TypeDomain = [ Schemald `.` ] Typeld .

Примечание - Область значений типа соответствует определенному типу данных в языке EXPRESS, не являющемуся перечисляемым или выбираемым типом.

8 Значения и экземпляры

В данном разделе описаны реализации возможностей языка EXPRESS.

8.1 Базовые значения

Синтаксис:

48i BaseValue = SimpleValue | EnumerationValue .

123i SimpleValue = BinaryValue | BooleanValue | LogicalValue |

NumberValue | StringValue .

Простым значением является значение самоопределенной константы. Область значения зависит от того, как компонуются символы при формировании лексемы.

8.1.1 Двоичное значение

Двоичное значение представляет величину двоичной области значений.

Синтаксис:

25i BinaryValue = binary_literal .

136 binary_literal = < как в EXPRESS > .

Двоичное значение образуется из символа % и последующих одного или более битов (0 или 1).

Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальное число битов в двоичном значении, которое может распознаваться данной реализацией (см. приложение В).

Пример 9 - Правильное двоичное значение

%10100110000101

8.1.2 Булевское значение

Булевское значение представляет величину булевской области значений.

Синтаксис:

50i BooleanValue = TRUE | FALSE .

Булевским значением является одна из встроенных констант FALSE или TRUE.

8.1.3 Числовое значение

Числовым значением является целочисленное или действительное значение.

Синтаксис:

94i NumberValue = IntegerValue | RealValue .

8.1.4 Целочисленное значение

Целочисленное значение представляет величину целочисленной области значений.

Синтаксис:

29i IntegerValue = [sign] integer_literal .

138 integer_literal = < как в EXPRESS > .

286 sign = < как в EXPRESS > .

Целочисленный литерал компонуется полностью из цифр. Целочисленное значение компонуется из целочисленного литерала, возможно, предваряемого знаком. Оно определяет положительное, отрицательное либо нулевое целое число.

Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальное значение целого, которое может распознаваться данной реализацией (см. приложение В).

Пример 10 - Правильные целочисленные значения:

0

1

-1

891562934527619

Пример 11 - Неправильные целочисленные значения:

1.0

не может включать десятичную точку.

8.1.5 Логическое значение

Логическое значение представляет величину логической области значений.

Синтаксис:

88i LogicalValue = logical_literal .

242 logical_literal = < как в EXPRESS > .

Логическим значением является одна из встроенных констант FALSE, TRUE или UNKNOWN.

8.1.6 Действительное значение

Действительное (вещественное) значение представляет величину действительной области значений.

Действительным значением является математическая константа со знаком или действительный литерал со знаком.

Синтаксис:

104i RealValue = SignedMathConstant | SignedRealLiteral .

31i SignedMathConstant = [ sign ] MathConstant .

89i MathConstant = CONST_E | PI .

32i SignedRealLiteral = [ sign ] real_literal .

139 real_literal = < как в EXPRESS > .

Математической константой со знаком является одна из встроенных математических констант (то есть или ), возможно предваряемая знаком.

Математическая константа =2,7182... представляется константой CONST_E языка EXPRESS.

Математическая константа =3,1415... представляется константой PI языка EXPRESS.

Пример 12 - Математические константы со знаком:

-const_e

Pi

Действительный литерал со знаком компонуется из мантиссы (со знаком) и возможного показателя степени. Он определяет действительное число.

Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальную точность и максимальный показатель степени действительного значения, которые могут распознаваться данной реализацией (см. приложение В).

Пример 13 - Правильные действительные значения:

0.0

-1.E6

1.e-6

8915629.34527619

Пример 14 - Неправильные действительные значения:

.001

перед точкой должна быть хотя бы одна цифра

1e10

в мантиссе должна быть десятичная точка

1.0 e-12.0

в показателе не должно быть десятичной точки

CONSTE

неверно записанная встроенная константа.

8.1.7 Строковое значение

Строковое значение представляет величину строковой области значений. Имеются две формы строкового значения - явное строковое значение и кодированное строковое значение. Явное строковое значение компонуется из последовательности символов из набора символов EXPRESS-I, заключенной в апострофы ('). Апостроф внутри явного строкового значения представляется двумя последовательными апострофами. Кодированным строковым значением является кодированное четырьмя октетами представление последовательности символов из ИСО/МЭК 10646-1, заключенное в кавычки ("). Кодирование определяется следующим образом:

- первый октет = группа ИСО/МЭК 10646-1, в которой определяется символ;

- второй октет = проекция ИСО/МЭК 10646-1, в которой определяется символ;

- третий октет = строка ИСО/МЭК 10646-1, в которой определяется символ;

- четвертый октет = ячейка ИСО/МЭК 10646-1, в которой определяется символ.

Последовательность октетов должна идентифицировать один из допустимых символов из ИСО/МЭК 10646-1.

Синтаксис:

124i StringValue = SimpleStringValue | EncodedStringValue .

33i SimpleStringValue = \q { (\q \q) | not_quote | \s | \o | \n } \q .

130 not_quote = < как в EXPRESS > .

27i EncodedStringValue = ` " ` { encoded_character | \n } ` " ` .

122 encoded_character = < как в EXPRESS > .

Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальное число символов строкового значения, которое может распознаваться данной реализацией (см. приложение В).

Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальное число октетов (должно быть кратно четырем) кодированного строкового значения, которое может распознаваться данной реализацией (см. приложение В).

Примечание - Строковое значение EXPRESS отличается от строкового литерала EXPRESS, поскольку в первом случае строковое значение может занимать более чем одну физическую строку, тогда как строковой литерал EXPRESS не может занимать более одной физической строки.

Пример 15 - Правильные явные строковые значения:

`This is a string on the line.`

Читается: это строка в одну физическую строку.

`This

is

a

multiline

string` .

Читается: Это

многострочная

строка

`This string``s got a single apostrophe embedded in it`.

Читается: Эта строка содержит единственный встроенный апостроф.

Пример 16 - Неправильные явные строковые значения

`This string is invalid because there is no closing apostrophe.

Пример 17 - Правильные кодированные строковые значения

"00000041"

читается: А.

"000000C5"

читается:

Пример 18 - Неправильные кодированные строковые значения:

"000041"

Октеты должны раскладываться в группы четверок.

"00000041 000000С5"

Между октетами не должно быть пробелов.

8.1.8 Перечисляемое значение

Перечисляемое значение представляет величину перечисляемой области значений.

Синтаксис:

28i EnumerationValue = `!` simple_id .

Перечисляемое значение является простым идентификатором с предшествующим восклицательным знаком (!). Простым идентификатором является последовательность символов из букв, цифр и символа подчеркивания с буквой в качестве первого символа.

Пример 19 - Правильные перечисляемые значения:

!red

!green

!forward

8.2 Агрегатные значения

В EXPRESS различают две формы значений агрегаций - фиксированную и динамическую. Фиксированная агрегация является агрегацией аналогичных предметов, где число мест хранения не зависит от количества элементов, фактически хранящихся в агрегации. Динамическая агрегация является агрегацией аналогичных предметов, где число мест хранения зависит от числа элементов, фактически хранящихся в агрегации. Агрегатные значения могут быть вложенными.

Синтаксис:

46i AggregationValue = DynamicAggr | FixedAggr .

61i DynamicAggr = `(` [ DynamicList ] `)` .

63i DynamicList = DynamicMember { `,` DynamicMember } .

64i DynamicMember = AggregationValue | ConstantValue | DerattValue |

ParmValue | RegattValue | TypeValue .

79i FixedAggr = `[` FixedList `]` .

80i FixedList = FixedMember { `,` FixedMember } .

81i FixedMember = DynamicMember | Nil .

Допустимые области значений элементов внутри агрегации зависят от контекста области значений. Такими контекстами являются:

- константы (см. 8.8);

- вычисляемые атрибуты (см. 8.7.1.2);

- явные атрибуты (см. 9.2.2);

- параметры (см. 9.2.2);

- определенные типы данных (см. 8.4).

Правила и ограничения

a) Элементы внутри динамической агрегации не должны быть равны Nil.

b) Элементы внутри фиксированной агрегации могут быть равны Nil.

c) Значения элементов внутри агрегации должны быть совместимы с областью значений агрегации.

Пример 20 - Агрегатные значения:

(10, -10, 0)

динамическая агрегация трех целочисленных значений

(1, 1, 2, 2, 3, 3)

динамическая агрегация шести целочисленных значений

()

пустая динамическая агрегация

[1, 2, 3, 4]

фиксированная агрегация четырех целочисленных значений

([1, 2], [3, ?])

динамическая агрегация фиксированной агрегации двух значений.

8.3 Простой экземпляр

Простой экземпляр является представлением значения одного экземпляра простого значения.

Синтаксис:

121i Simplelnstance = Simplelnstanceld `=` SimpleValue `;` .

122i Simplelnstanceld = Simple_id .

123i SimpleValue = BinaryValue | BooleanValue | LogicalValue | NumberValue |

StringValue .

42i SimplelnstanceRef = `@` Simplelnstanceld .

Пример 21 - Некоторые простые экземпляры

rl = 27.0;

&1 = ` A string`;

8.4 Экземпляр типа

Экземпляр типа является представлением значения одного экземпляра области значений типа (TYPE).

Синтаксис:

137i Typelnstance = Typelnstanceld `=` TypeInstanceValue `;` .

138i Typelnstanceld = simple_id .

139i TypeInstanceValue = TypeDomain `{` TypeValue `}` .

140i TypeValue = AggregationValue | BaseValue | ConstantRef |

EntitylnstanceValue | NamedlnstanceValue |

ObjectlnstanceRef | ParameterRef .

44i TypelnstanceRef = `@` Typelnstanceld .

Правила и ограничения

а) Значение экземпляра должно быть либо простым значением, ссылкой на экземпляр объекта, ссылкой на экземпляр типа, либо агрегациями этих значений.

Пример 22 - Некоторые экземпляры типов:

t1 = a_real {27.0};

t2 = an_array_of_string {[ `one`, `two` ]};

t3 = a_dynamic_aggregate_of_integer {(1, 1, 2, 3, 5, 8, 13)};

8.5 Экземпляр выбора

Экземпляр выбора является представлением значения одного экземпляра области значений выбора (SELECT).

Синтаксис:

116i Selectlnstance = Selectlnstanceld `=` SelectlnstanceValue `;`

117i Selectlnstanceld = simple_id .

118i SelectlnstanceValue = SelectDomain `{` SelectValue `}` .

119i SelectValue = EnumerationValue | NamedlnstanceValue | ObjectlnstanceRef |

TypeValue .

40i SelectlnstanceRef = `@` Selectlnstanceld .

Правила и ограничения

а) Значение экземпляра должно быть либо ссылкой на экземпляр типа, ссылкой на экземпляр выбора, ссылкой на экземпляр перечисления, либо ссылкой на экземпляр объекта.

Пример 23 - Экземпляр выбора

&1 = type_or_entity{@e27};

8.6 Экземпляр перечисления

Экземпляр перечисления является представлением значения одного экземпляра области значений перечисления (ENUMERATION).

Синтаксис:

74i Enumerationlnstance = Enumerationlnstanceld `=`

EnumerationlnstanceValue `;` .

75i Enumerationlnstanceld = simple_id .

76i EnumerationlnstanceValue = EnumerationDamain

`{` EnumerationValue `}` .

28i EnumerationValue = `!` simple_id .

38i EnumerationlnstanceRef = `@` Enumerationlnstanceld .

Правила и ограничения

а) Значение экземпляра должно быть перечисляемым значением.

Пример 24 - Некоторые экземпляры перечисления

enum1 = an_enum{!first};

enum2 = an_enum{!second};

8.7 Экземпляр объекта

Экземпляр объекта является представлением одного экземпляра области значений объекта (ENTITY).

Синтаксис:

68i EntityInstance = Entitylnstanceld `=` EntitylnstanceValue `;` .

69i Entitylnstanceld = ComplexEntitylnstanceld |

SimpleEntitylnstanceld .

70i EntitylnstanceValue = EntityDomain `{` [ InheritsFrom ]

{ ExplicitAttr } { DerivedAttr }

{ InverseAttr } [ BequeathesTo ] `}` .

37i EntitylnstanceRef = ComplexEntitylnstanceRef |

SimpleEntitylnstanceRef .

В EXPRESS различают два вида экземпляра объекта:

- экземпляр простого объекта - экземпляр, не являющийся частью дерева наследования;

- экземпляр сложного объекта - экземпляр из дерева наследования. Он компонуется из экземпляров компонентов (объектов), которые вместе образуют все узлы дерева.

Синтаксис:

51i ComplexEntitylnstanceld = SimpleEntitylnstanceld `[` SupSubld `]` .

34i ComplexEntitylnstanceRef = `@` SimpleEntitylnstanceld .

120i SimpleEntitylnstanceld = simple_id .

41i SimpleEntitylnstanceRef = `@` SimpleEntitylnstanceld .

125i SupSubld = digits .

Идентификатором экземпляра простого объекта является простой идентификатор.

Идентификатор экземпляра сложного объекта состоит из двух частей. Первая часть является такой же как идентификатор экземпляра простого объекта. Второй частью является строка цифр, заключенная в квадратные скобки. Строка цифр во второй части (называемая в синтаксисе SupSubld) является идентификатором конкретного компонента экземпляра сложного объекта. Ссылка на экземпляр сложного объекта включает первую часть идентификатора с предшествующим ему символом @.

Правила и ограничения

a) Для данного экземпляра сложного объекта первая часть идентификатора экземпляра сложного объекта должна быть такой же, что и для каждого компонента экземпляра сложного объекта.

b) Для данного экземпляра сложного объекта вторая часть идентификатора экземпляра сложного объекта должна быть разной для каждого компонента экземпляра сложного объекта.

Пример 25 - Идентификатор экземпляра сложного объекта для двухкомпонентного экземпляра и ссылка на этот экземпляр сложного объекта.

complex[23]

- - идентификатор одного компонента

complex[111]

- - идентификатор другого компонента

@complex

- - ссылка на экземпляр сложного объекта

8.7.1 Атрибуты

Экземпляр объекта в EXPRESS может не иметь ни одного (ноль) или иметь несколько атрибутов. Атрибуты подразделяются на явные, вычисляемые и инверсные.

Пример 26 - Экземпляры пустых объектов

е2 = ent_inst{ };

eg = ent_inst{ };

8.7.1.1 Явные атрибуты

Явный атрибут является обязательным свойством объекта.

Синтаксис:

77i ExplicitAttr = RequiredAttr | OptionalAttr .

106i RequiredAttr = RoleName `` (ReqattValue | Nil) `;` .

99i OptionalAttr = RoleName `` OptattValue `;` .

107i RoleName = attribute_ref .

105i ReqattValue = AggregationValue | BaseValue | ConstantRef |

NamedlnstanceValue | ObjectlnstanceRef |

ParameterRef | SelectValue | TypeValue .

96i ObjectlnstanceRef = EntityInstanceRef | EnumerationInstanceRef |

SelectlnstanceRef | TypelnstanceRef |

SimplelnstanceRef .

93i NamedlnstanceValue = EnumerationlnstanceValue | SelectInstanceValue |

TypelnstanceValue .

98i OptattValue = ReqattValue | Nil .

30i Nil = `?` .

Явный атрибут состоит из имени роли атрибута, последующего знака ->, последующей величины области значений роли и завершающей точки с запятой. Величина области значений роли для обязательного атрибута может быть ссылкой на экземпляр объекта или типа, значением, поименованным значением, константой или параметром, либо агрегациями перечисленных значений. Величина области значений роли для необязательного атрибута является такой же, как и для обязательного атрибута, с дополнительным значением Nil, если величина области не определена.

Примечание - Явному атрибуту может быть задано значение Nil. В этом случае, если определение объекта основано на EXPRESS-объекте, тогда экземпляр не будет соответствовать EXPRESS-определению.

Пример 27 - Явные атрибуты

a_real

1.2;

an_integer

3;

a_list

(1, 2, 3);

a_boolean

TRUE;

a_logical

UNKNOWN;

an_enumeration

!enum1;

a_string

`A string`;

entity_ref

@instance2;

optional_str

?;

optional_int

42;

a_parameter

par1;

a_constant

c1;

8.7.1.2 Вычисляемый атрибут

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

Синтаксис:

60i DerivedAttr = RoleName [ `` DerattValue ] `;` .

107i RoleName = attribute_ref .

59i DerattValue = AggregationValue | Base Value | EntitylnstanceRef |

EntitylnstanceValue | EnumerationlnstanceValue |

TypelnstanceRef | TypeInstanceValue | TypeValue .

Вычисляемый атрибут состоит из имени роли атрибута, последующих необязательных знака <- и величины области значений роли и заканчивается точкой с запятой. Величина области значений роли может быть ссылкой на экземпляр объекта или типа, значением, константой либо их агрегациями. Кроме того, величина может иметь значение Nil, если она не определена.

Пример 28 - Вычисляемые атрибуты

a_real

1.2;

an_integer

3;

a_boolean

TRUE;

a_logical;

an_enumeration

!enum1;

a_string

`A string`;

entity_ref

@instance2;

null_derived

?;

8.7.1.3 Инверсный атрибут

Если экземпляр объекта установил отношение с текущим экземпляром объекта посредством ссылки в явном атрибуте на текущий экземпляр, то для описания этого отношения в контексте текущего экземпляра может быть использован инверсный атрибут.

Синтаксис:

87i InverseAttr = RoleName [ `` InvattValue ] `;` .

107i RoleName = attribute_ref .

86i InvattValue = DynamicEntityRefList .

62i DynamicEntityRefList = `(` [ EntityRefList ] `)` .

71i EntityRefList = EntitylnstanceRef { `,` EntityInstanceRef } .

Инверсный атрибут состоит из имени роли атрибута, последующих необязательных знака <- и величины области значений и заканчивается точкой с запятой. Величиной области значений роли является (возможно, пустой) динамический список ссылок на экземпляры объектов.

Пример 29 - Инверсные атрибуты

inverse_1

(@a1, @b3);

inverse_2;

inverse_3

( );

8.7.2 Супертипы и подтипы

Экземпляр сложного EXPRESS-объекта наследует атрибуты и их значения из экземпляров его супертипов (SUPERTYPE) (при их наличии) и передает атрибуты и их значения экземплярам своих подтипов (SUBTYPE) (при их наличии).

49i BequeathesTo = SUPOF DynamicSupSubRefList `;` .

85i InheritsFrom = SUBOF DynamicSupSubRefList `;` .

65i DynamicSupSubRefList = `(` [ SupSubRef { `,` SupSubRef } ] `)` .

43i SupSubRef = `@` SupSubld .

Ссылки на экземпляры компонентов (см. 8.7) непосредственного супертипа(ов), при его наличии, даются вслед за ключевом словом SUBOF и заключаются в круглые скобки.

Ссылки на экземпляры компонентов непосредственных подтипов, при их наличии, даются вслед за ключевым словом SUPOF и заключаются в круглые скобки.

Примечание - Как указано в 8.7, идентификатор экземпляра сложного объекта имеет две части: первая часть является идентификатором экземпляра в целом, а вторая часть - идентификатором компонента. Назовем, например, part1 первую часть идентификатора экземпляра сложного объекта. Тогда ссылка на компонент, скажем, @3, является ссылкой на компонент экземпляра сложного объекта, полностью идентифицируемую как part1[3].

Пример 30 - Супертипы и подтипы

i1[1]

= super{super_int 2; SUPOF(@2); };

- - имеет подтип i1[2].

i1[2]

= sub{SUBOF(@1); sub_real 23.7; };

- - имеет супертип i1[1].

i2[1]

= sub{SUBOF(@5); sub_real -42.0; };

- - имеет супертип i2[5].

i2[5]

= super{super_int 7; SUPOF(@1); };

- - имеет подтип i2[1].

8.8 Экземпляр константы

Объявление константы может быть использовано для объявления именованных констант. Областью действия идентификаторов констант, объявленных внутри блока констант, должна быть схема, в которой находится блок констант. Именованная константа, появляющаяся в объявлении константы, имеет явную инициализацию, значение константы не может быть модифицировано после инициализации. Вхождение именованной константы вне ее объявления должно быть эквивалентно вхождению исходного значения самой константы.

Синтаксис:

52i ConstantBlock = CONSTANT { ConstantSpec } END_CONSTANT `;` .

54i ConstantSpec = Constantld `= =` ConstantValue `;` .

53i ConstantValue = AggregationValue | BaseValue | EntitylnstanceValue |

NamedlnstanceValue | SelectValue | TypeValue .

35i ConstantRef = Constantld .

Значение константы может быть агрегацией значений.

Правила и ограничения

a) Каждое значение должно быть простым значением, значением экземпляра объекта, перечисляемым значением, выбираемым значением либо их агрегациями.

b) Именованная константа может появляться в объявляемом значении другой именованной константы.

Пример 31 - Блок констант

CONSTANT

zero

= = 0.0;

thousand

= =1000;

origin

= = point{x -> zero; у -> zero;};

large_circle

= = circle{center -> origin; radius -> thousand;};

z_axis

= = [0.0, 0.0, 1.0];

END_CONSTANT;

8.9 Экземпляр данных схемы

Экземпляр данных схемы (SCHEMA_DATA) определяет экземпляр (часть) представления рассматриваемой предметной области, в котором объявляемые элементы имеют определенные смысл и назначение. Например, геометрия (geometry) может быть именем данных схемы (SCHEMA_DATA), содержащих экземпляры точек, кривых, поверхностей и других соответствующих элементов. Порядок, в котором объявляются экземпляры в экземпляре SCHEMA_DATA, произволен.

Синтаксис:

109i SchemalnstanceBlock = SCHEMA_DATA Schemald `;`

[ SchemalnstanceBody ] END_SCHEMA_DATA `;` .

108i Schemald = schema_ref .

110i SchemalnstanceBody = [ ConstantBlock ] { Objectlnstance } .

95i Objectlnstance = Entitylnstance | Enumerationlnstance | Selectlnstance |

Typelnstance | Simplelnstance .

Объявление SCHEMA_DATA создает новую область действия, в которой могут быть объявлены следующие элементы:

- константы;

- экземпляры объектов;

- экземпляры перечисления;

- экземпляры выбора;

- простые экземпляры;

- экземпляры типа.

Пример 32 - Наполнение EXPRESS-схемы

SCHEMA_DATA whatsits ;

(* Константы, определяемые в EXPRESS *)

CONSTANT

one = = 1.0;

twopi = = 6.2831853;

END_CONSTANT;

(* Типы, определяемые в EXPRESS *)

n1 = name{(`Jot`, `Е`, `Bloggs`)};

n2 = name{(`Mary`, `Jones`)};

(* Объекты, определяемые в EXPRESS *)

p1 = point{x one; у twopi;};

s1 = affianced{him @n1; her @n2;};

END_SCHEMA_DATA;

8.10 Отображение модели

Понятие MODEL определяет одну конкретную реализацию данных, соответствующих информационной модели.

Синтаксис:

90i ModelBlock = MODEL Modelld `;` ModelBody END_MODEL `;` .

92i Modelld = simple_id .

91i ModelBody = { SchemalnstanceBlock } .

EXPRESS-объявление MODEL создает новую область действия, в которой могут быть объявлены следующие элементы:

- экземпляры данных схемы.

Примечание - Основным назначением MODEL является демонстрация совокупности объектной базы.

Пример 33 - Например, bugatti_35 может быть именем MODEL, содержащей данные, представляющие автомобиль типа Bugatti Type 35. Может быть несколько экземпляров данных схемы внутри MODEL: один, например, для чертежей автомобиля, и другой, содержащий данные по обслуживанию автомобиля этого типа.

Правила и ограничения

a) Каждый экземпляр данных схемы внутри MODEL должен иметь уникальный идентификатор.

b) Идентификатор каждого экземпляра внутри MODEL должен быть уникальным.

c) Значения внутри MODEL не должны быть ссылками на параметр.

Пример 34 - Набросок MODEL

MODEL a_model;

SCHEMA_DATA a_schema;

END_SCHEMA_DATA;

SCHEMA_DATA another_schema;

END_SCHEMA_DATA;

END_MODEL.

9 Определение абстрактного контрольного примера

В данном разделе описаны основные элементы языка EXPRESS-I, относящиеся к определению абстрактных контрольных примеров.

9.1 Контекст

Контекст (CONTEXT) определяет экземпляры данных и алгоритмы, относящиеся к представлению рассматриваемой предметной области, в котором элементы имеют определенные смысл и назначение. Экземпляры данных могут быть параметризованы.

Синтаксис:

56i ContextBlock = CONTEXT Contextld `;` ContextBody END_CONTEXT `;` .

58i Contextld = simple_id .

57i ContextBody = { SchemaReferenceSpec } [ FormalParameterBlock ]

{ SchemaInstanceBlock | SupportAlgorithm } .

36i ContextRef = Contextld .

EXPRESS-I-объявление CONTEXT создает новую область действия, в которой могут быть объявлены следующие элементы:

- ссылки на EXPRESS-схемы (см. 10.2);

- формальные параметры;

- экземпляры данных схемы;

- EXPRESS-функции;

- EXPRESS-процедуры.

Пример 35 - Например bugatti может быть именем CONTEXT, который содержит параметризованные (то есть обобщенные) данные, представляющие автомобиль типа Bugatti. Внутри этого CONTEXT может быть несколько экземпляров данных схемы: один, например, для чертежей автомобиля, и другой, содержащий данные по обслуживанию автомобиля этого типа.

Правила и ограничения

a) Каждый экземпляр данных схемы внутри CONTEXT должен быть экземпляром из разных схем.

b) Каждый идентификатор внутри CONTEXT должен быть уникальным.

Пример 36 - Набросок CONTEXT

CONTEXT parametrized_model;

PARAMETER

END_PARAMETER;

SCHEMA_DATA a_schema;

END_SCHEMA_DATA;

SCHEMA_DATA another_schema;

END_SCHEMA_DATA;

END_CONTEXT;

9.2 Параметры

Контекст может иметь формальные параметры. Каждый формальный параметр имеет имя и область значений. Имя является идентификатором, который должен быть уникальным внутри области действия контекста.

Контрольный пример может иметь фактические параметры, которые задают конкретные значения соответствующим формальным параметрам внутри контекста.

Для обобщения типов данных, используемых для передачи значений в контекстах, имеются области значений AGGREGATE и GENERIC. Также могут использоваться соответствующие массивы для обобщения областей значений массивов.

9.2.1 Формальный параметр

Формальный параметр может иметь значение по умолчанию, которое должно быть совместимо с областью значений. Формальные параметры, не имеющие значений по умолчанию, изначально обнуляются (имеют значение) Nil.

Синтаксис:

83i FormalParameterBlock = PARAMETERi

{ FormalParameter } END_PARAMETER `;` .

82i FormalParameter = Parameterld `:` parameter_type

[ `:=` ParmValueDefault ] `;` .

100i Parameterld = simple_id .

253 parameter_type = < как в EXPRESS > .

103i ParmValueDefault = AggregationValue | BaseValue | ConstantRef |

EntitylnstanceValue | NamedlnstanceValue |

ObjectlnstanceRef | SelectValue | TypeValue |

expression .

204 expression = < как в EXPRESS > .

39i ParameterRef = Parameterld .

Так как в контексте могут быть несколько экземпляров данных схем, содержащих параметры, может случиться, что две или более схемы имеют объекты или типы с одинаковыми именами, но разной семантикой. Использование одного из этих имен в качестве идентификатора области значений параметра оказалось бы в этом случае двусмысленным. В случаях потенциальной неоднозначности каждое имя должно быть квалифицировано предшествующим ему именем соответствующей схемы с точкой в качестве разделителя.

Пример 37 - Блок PARAMETER

PARAMETER

iv1

: INTEGER := 1;

bv1

: BOOLEAN;

p1

: name := name{first `John`; last `Doe`; married bv1;};

p2

: name := name (`Mary`, `Smith`, TRUE);

a_list

: LIST OF REAL := (0.0, 1.0, 2.0);

a_set

: SET OF STRING;

a_select

: selection := wheeled_vehicle;

from_sch1

: sch1.vector := [1.0,3.0];

from_sch2

: sch2.vector := [3.0,4.0,-0.5];

END_PARAMETER;

9.2.2 Фактический параметр

Фактический параметр состоит из ссылки на формальный параметр и значения параметра. Значение должно быть совместимым с областью значений формального параметра. Значение заменяет значение параметра по умолчанию, заданное формальным параметром.

Синтаксис:

45i ActualParameter = ParameterRef `:=` ParmValue .

39i ParameterRef = Parameterld .

102i ParmValue = ObjectlnstanceRef | expression .

204 expression = < как в EXPRESS > .

Пример 38 - Пример показывает некоторые фактические параметры для формальных параметров, заданных в примере 37.

iv1

: = 77**2;

bv1

: = FALSE;

p1

: = name(`John`, `Smith`, bv1);

a_list

: = [20.0, 1.0, 20.0, 33.72];

a_select

: = @v23;

from_sch1

: = [0.0,-1.0];

from_sch2

: = [0.5, -0.2, -0.15];

9.3 Контрольный пример

Тип TEST_CASE определяет как управляющие данные, так и данные экземпляра, которые могут быть использованы для целей абстрактного контрольного примера.

Синтаксис:

127i TestCaseBlock = TEST_CASE TestCaseld `;`

TestCaseBody END_TEST_CASE `;` .

129i TestCaseld = simple_id .

128i TestCaseBody = Schema References ObjectiveBlock TestRealization

{ SupportAlgorithm } .

111i SchemaReferences = SchemaReferenceSpec { SchemaReferenceSpec } .

Объявление TEST_CASE создает новую область действия, в которой можно объявлять либо ссылаться на следующие элементы:

- тестируемые элементы (см.10.2);

- цель теста;

- реализацию теста;

- алгоритмы поддержки.

Тип TEST_CASE позволяет ссылаться на одну или несколько EXPRESS-схем. Это могут быть ссылки на набор контекстов (CONTEXT) и, возможно, на набор значений параметров, предназначенных для определения набора тестовых данных.

Правила и ограничения

a) Значение каждого фактического параметра, объявленного в контрольном примере, должно быть совместимо с областью значений соответствующего формального параметра, объявленного в контексте.

b) Значение контрольного примера, связанное с каждым формальным параметром из контекста, должно быть объявлено в качестве фактического параметра или принято как значение формального параметра по умолчанию, если фактический параметр не объявляется.

c) Типы данных внутри контрольного примера должны ограничиваться определениями типов, установленными внутри ссылочных схем.

9.4 Цель теста

Целью теста (OBJECTIVE) являются управляющие данные, которые могут быть использованы для абстрактного контрольного примера.

Синтаксис:

97i ObjectiveBlock = OBJECTIVE { TestPurpose } { TestReference }

{ TestCriteria } { TestNotes }

END_OBJECTIVE `;` .

Объявление OBJECTIVE создает новую область действия, в которой могут быть объявлены следующие элементы:

- назначение абстрактного контрольного примера;

- ссылки на соответствующие стандарты или технические требования;

- критерий теста;

- замечания для аналитика теста.

Пример 39 - Цель теста

OBJECTIVE

NOTES Настоящая цель содержит только замечания для аналитика теста.

END_NOTES;

END_OBJECTIVE;

9.4.1 Назначение теста

Назначением теста является текст, адресуемый человеку. Он содержит описание целевого назначения теста.

Синтаксис:

133i TestPurpose = PURPOSE Description END_PURPOSE `;` .

26i Description = { \a | \s | \n } .

Текст начинается с ключевого слова PURPOSE и заканчивается ключевым словом END_PURPOSE и точкой с запятой. Текст может занимать несколько строк.

Пример 40 - Текст в данном случае занимает две строки.

PURPOSE. This test is intended to check the existance of a car instance. (Настоящий тест предназначен для проверки наличия экземпляра автомобиля). END_PURPOSE;

9.4.2 Тестовые ссылки

Тестовой ссылкой является текст, адресуемый человеку. Он содержит описание интерпретируемых человеком ссылок на соответствующие стандарты или технические требования (спецификации).

Синтаксис:

134i TestReference = REFERENCES Description END_REFERENCES `;` .

26i Description = { \a | \s | \n } .

Текст начинается с ключевого слова REFERENCES и заканчивается ключевым словом END_REFERENCES и точкой с запятой. Текст может занимать несколько строк.

Пример 41 - Ссылка на печатный документ.

REFERENCES Документ АР279, страницы 53-57. END_REFERENCES;

9.4.3 Критерий теста

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

Синтаксис:

131i TestCriteria = CRITERIA Description END_CRITERIA `;` .

26i Description = { \a | \s | \n } .

Текст начинается с ключевого слова CRITERIA и заканчивается ключевым словом END_CRITERIA и точкой с запятой. Текст может занимать несколько строк.

Пример 42 - Простой критерий

CRITERIA At least one instance of car shall be present. (Должен быть представлен по крайней мере один экземпляр автомобиля). END_CRITERIA;

9.4.4 Замечания к тесту

Замечаниями к тесту является текст, адресуемый человеку. Он обеспечивает способы описания общих замечаний, помогающих аналитику теста.

Синтаксис:

132i TestNotes = NOTES Description END_NOTES `;` .

26i Description = { \a | \s | \n } .

Текст начинается с ключевого слова NOTES и заканчивается ключевым словом END_NOTES и точкой с запятой. Текст может занимать несколько строк.

Пример 43 - Замечание в одну строку

NOTES Remember to fasten your seat belt. (He забудьте закрепить ремень безопасности). END_NOTES;

9.5 Реализация теста

Реализация теста дает определение элементов данных, относящихся к контрольному примеру.

Синтаксис:

130i TestRealization = REALIZATION { local_decl } { UseContextBlock }

{ assignment_stmt } END_REALIZATION `;` .

239 local_decl = < как в EXPRESS > .

166 assignment_stmt = < как в EXPRESS > .

Реализация начинается с ключевого слова REALIZATION и заканчивается ключевым словом END_REALIZATION и точкой с запятой.

Реализация теста может включать:

- ссылки на данные контекста и параметры (см.10.З.);

- локальные переменные (определяемые с помощью синтаксиса EXPRESS);

- операторы присваивания (определяемые с помощью синтаксиса EXPRESS).

Пример 44 - Данная реализация определяет р1 как переменную типа point (точка). Данный тип затем вызывается для создания точки с координатами (1, 2, 3), присваиваемыми экземпляру переменной p1.

REALIZATION

LOCAL

p1 : point;

END_LOCAL;

p1 : point(1.0, 2.0, 3.0);

END_REALIZATION;

10 Интерфейсы

В данном разделе установлены интерфейсы между экземплярами EXPRESS-I и EXPRESS-моделями вместе с интерфейсами между конструкциями EXPRESS-I.

10.1 Интерфейс экземпляра схемы

Синтаксис:

109i SchemalnstanceBlock = SCHEMA_DATA Schemald;

[ SchemalnstanceBody ] END_SCHEMA_DATA `;` .

108i Schemald = schema_ref .

152 schema_ref = < как в EXPRESS > .

Предполагается, что имеется связанная EXPRESS-схема (или, что то же самое, EXPRESS-G-схема); тогда Schemald ссылается на имя этой EXPRESS-схемы. Это значит, что тело экземпляра данных EXPRESS-I-схемы содержит экземпляры данных определений из идентифицированной EXPRESS-схемы. Оно не должно содержать экземпляров данных определений, являющихся внешними по отношению к данной EXPRESS-схеме.

Примечание - Ссылки на схемы, определяемые в языках, отличных от EXPRESS или EXPRESS-G, не являются предметом рассмотрения в настоящем стандарте. Тем не менее Schemald можно рассматривать как ссылку на схему, определяемую на языке, отличном от EXPRESS.

10.2 Ссылка на схему

Ссылка на схему позволяет идентифицировать конкретную EXPRESS-схему вместе с конкретными определениями внутри этой схемы.

Синтаксис:

112i SchemaReferenceSpec = WITH schema_ref [ USING `(` resource_ref

{ `,` resource_ref } `)` ] `;` .

152 schema_ref = < как в EXPRESS > .

275 resource_ref = < как в EXPRESS > .

Конструкция schema_ref, следующая за ключевым словом WITH, обозначает конкретную EXPRESS-схему. Конкретные объявления, представляющие интерес в данной EXPRESS-схеме, обозначаются в списке, следующем за ключевым словом USING.

Отсутствие списка USING означает, что все определения внутри обозначенной EXPRESS-схемы являются доступными.

Примечание - Ссылка на схему действует аналогично EXPRESS-оператору USE:

Пример 45 - Задано следующее EXPRESS-определение:

SCHEMA a_schema;

ENTITY entity1;

... END_ENTITY;

ENTITY entity2;

... END_ENTITY;

ENTITY entity7;

... END_ENTITY;

TYPE type19 =

... END_TYPE;

TYPE type21 =

... END_TYPE;

END_SCHEMA;

Тогда следующая конструкция обозначает два объекта и один тип из схемы a_schema.

WITH a_schema USING (entity1, entity7, type21);

10.3 Ссылки на данные контекста

Элементы из CONTEXT могут быть импортированы в TEST_CASE, а фактические значения могут быть заданы для формальных параметров в CONTEXT.

Синтаксис:

141i UseContextBlock = CALL ContextRef `;` UseContextBody END_CALL `;` .

36i ContextRef = Contextld .

142i UseContextBody = [ ImportSpec ] [ ParameterSpec ] .

84i ImportSpec = IMPORT `(` { Assignment } `)` `;` .

47i Assignment = variable_id `:=` SelectablelnstanceRef `;` .

101i ParameterSpec = WITH `(` { ActualParameter } `)` `;` .

113i SelectablelnstanceRef = EntitylnstanceRef | EnumerationlnstanceRef |

SelectlnstanceRef | TypelnstanceRef .

Конкретный CONTEXT обозначается посредством оператора CALL.

Экземпляры предметов, представляющие интерес для контрольного примера и существующие в CONTEXT, обозначаются в списке IMPORT. Каждое значение экземпляра должно быть присвоено переменной.

Значения формальных параметров в CONTEXT (при их наличии) задаются посредством списка WITH. Эти значения должны отменять значения обозначенных параметров, принятые по умолчанию (при их наличии).

Пример 46 - Спецификация CALL

CALL a_context;

IMPORT (ent_var := @ent_21;

ent_27 := @ent_27;);

WITH (ivl := 771;

a_set := [ `alpha`, `to`, `omega` ]; );

END_CALL;



11 Область действия и видимость

Объявление EXPRESS-I создает идентификатор, который можно использовать для ссылки на объявленный элемент в других контекстах. Некоторые конструкции EXPRESS-I неявно объявляют элементы EXPRESS путем добавления к ним идентификаторов. В тех областях, где на идентификатор объявленного элемента можно ссылаться, объявленный элемент называется видимым. На элемент можно ссылаться только там, где идентификатор видим. Относительно правил видимости см. 11.2.

Некоторые элементы EXPRESS-I определяют участок (блок) текста, называемый областью действия элемента. Эта область действия ограничивает видимость объявленных в ней идентификаторов. Области действия могут быть вложенными; это значит, что элемент EXPRESS-I, устанавливающий область действия, может быть включен в область действия другого элемента. Имеются ограничения на перечень элементов, которые могут появиться внутри области действия конкретного элемента EXPRESS-I. Эти ограничения обычно устанавливаются синтаксисом ЕХPRESS-I (см. приложение А).

Для каждого из элементов, установленных в таблицах 9 и 10, последующие подразделы настоящего раздела устанавливают границы определяемой области действия (при их наличии) и видимость объявляемого идентификатора как в общих терминах, так и в конкретных деталях.

Таблица 9 - Область действия и идентификатор, определяющие элементы EXPRESS-I

Элемент

Область действия

Идентификатор

экземпляр константы (constant instance)

контекст (context)

экземпляр объекта (entity instance)

экземпляр перечисления (enumeration instance)

модель (model)

экземпляр данных схемы (schema data instance)

экземпляр выбора (select instance)

простой экземпляр (simple instance)

контрольный пример (test case)

экземпляр типа (type instance)

Примечание - EXPRESS-I использует также различные конструкции EXPRESS, которые аналогичным образом имеют идентификаторы и области действия. Они приведены в таблице 10.

Таблица 10 - Области действия и идентификаторы, определяющие элементы EXPRESS и используемые в EXPRESS-I

Элемент

Область действия

Идентификатор

оператор переименования (alias statement)

атрибут (attribute)

константа (constant)

объект (entity)

перечисление (enumeration)

функция (function)

параметр (parameter)

процедура (procedure)

выражение запроса (query expression)

оператор цикла (repeat statement)

метка правила (rule label)

тип (type)

метка типа (type label)

переменная (variable)

Примечания

Идентификатор является неявно объявляемой переменной внутри определяемой области действия объявления.

Переменная неявно объявляется только тогда, когда устанавливается управление циклом по приращению.

11.1 Правила области действия

Ниже приведены общие правила, применяемые для всех форм определения области действия, допустимых в языке EXPRESS-I; список элементов, для которых определяются области действия, - см. в таблицах 9 и 10.

Правила и ограничения

a) Все объявления должны находиться внутри области действия.

b) Внутри одной области действия идентификатор можно объявить только один раз либо явно его импортировать из вне.

c) Области действия должны быть корректно вложенными, то есть не должны пересекаться (это предписывается синтаксисом языка).

В настоящем стандарте не устанавливается максимально допустимая глубина вложенности. Разработчик синтаксического анализатора языка EXPRESS-I должен установить максимальную глубину вложенности, поддерживаемую данной реализацией (см. приложение B).

11.2 Правила видимости

Правила видимости идентификаторов описаны ниже. Список элементов EXPRESS-I, для которых объявляются идентификаторы, см. в таблицах 9 и 10. Правила видимости идентификаторов поименованных типов данных несколько отличаются от правил видимости других идентификаторов. Эти отличия описаны в 11.2.2.

11.2.1 Общие правила видимости

Приведенные ниже общие правила применимы ко всем идентификаторам, за исключением идентификаторов поименованных типов данных, на которые правило d) не распространяется.

Правила и ограничения

a) Идентификатор видим в области действия, в которой он объявляется. Эта область действия называется локальной областью действия идентификатора.

b) Идентификатор видим в конкретной области действия, он также видим во всех областях действия, определяемых внутри данной области, согласно правилу d).

c) Идентификатор не видим ни в одной области действия за пределами его локальной области действия, согласно правилу f).

d) Если идентификатор , видимый в области действия , переобъявляется в некоторой внутренней области , заключенной в , только , объявленный в области действия , видим в и областях действия, объявленных внутри . Идентификатор , объявленный в области действия , видим в и любых внутренних областях действия, не переобъявляющих .

e) Встроенные константы, функции, процедуры и типы EXPRESS-I считаются объявленными в воображаемой универсальной области действия. Все области действия EXPRESS-I являются вложенными в эту область действия. Идентификаторы, по которым ссылаются на встроенные константы, функции, процедуры и типы EXPRESS-I, видимы во всех областях действия, определяемых EXPRESS-I.

f) Идентификаторы элементов перечисления, объявленные внутри области определенного типа данных, видимы в следующей внешней области действия, если она не содержит объявления этого же идентификатора для другого элемента.

Примечание - Если следующая внешняя область действия содержит объявление того же идентификатора, элементы перечисления остаются доступными, но должны иметь префиксом идентификатор определенного типа данных.

g) Некоторые EXPRESS-I-объявления, обычно не видимые, могут быть сделаны видимыми с помощью спецификаций интерфейса (см. раздел 10).

11.2.2 Правила видимости идентификатора поименованного типа данных

За одним исключением, идентификаторы поименованных типов данных подчиняются тем же правилам видимости, что и другие идентификаторы. Этим исключением является правило видимости d). Идентификатор объекта или определенного типа данных , объявленный в области действия , остается видимым во внутренней области , даже если он переопределяется в одним из следующих способов:

a) область действия определяется объявлением объекта, а объявляется как атрибут в этой области действия;

b) область действия определяется объявлением функции, процедуры или контекста, а объявляется как формальный параметр или переменная в этой области действия.

Пример 47 - В entity1 d относится как к типу данных объекта, так и к атрибуту.

FUNCTION example (par : INTEGER): INTEGER;

ENTITY d;

attrl : REAL;

END_ENTITY;

ENTITY entity1;

d : d; - - d в данной области действия является и объектом и атрибутом.

END_ENTITY;

END_FUNCTION;

11.3 Правила для явного элемента

В последующих пунктах настоящего подраздела более детально показано, как общие правила области действия и видимости применяются к различным элементам EXPRESS-I.

В EXPRESS-I используется многое из языка EXPRESS. Правила области действия и видимости для большинства этих элементов EXPRESS внутри EXPRESS-I идентичны правилам EXPRESS, определенным в ГОСТ Р ИСО 10303-11. В таблице 11 определены эти элементы. Кроме того, в таблице 11 определены элементы, общие для EXPRESS и EXPRESS-I, для которых ЕХPRESS-правила модифицируются при их использовании в EXPRESS-I, а также элементы, специфические для EXPRESS-I.

Таблица 11 - Правила области действия и видимости

Элемент

Правила EXPRESS

Модифицированные правила EXPRESS

Специфические правила EXPRESS-I

оператор переименования

атрибут

константа

экземпляр константы

контекст

объект

экземпляр объекта

перечисление

экземпляр перечисления

функция

модель

параметр

процедура

выражение запроса

оператор цикла

метка правила

экземпляр данных схемы

экземпляр выбора

простой экземпляр

контрольный пример

тип

экземпляр типа

метка типа

переменная

Примечание - Модификации EXPRESS-правил обусловлены, в основном, тем, что EXPRESS-I не использует EXPRESS-конструкций SCHEMA или RULE.

11.3.1 Оператор переименования

Правила области действия и видимости для оператора ALIAS определены в 10.3.1 ГОСТ Р ИСО 10303-11.

11.3.2 Атрибут

Правила области действия и видимости для атрибута определены в 10.3.2 ГОСТ Р ИСО 10303-11.

11.3.3 Константа

Видимость: Идентификатор константы видим в области действия функции или процедуры, в которой он объявлен.

Примечание - EXPRESS-спецификация (10.3.3 ГОСТ Р ИСО 10303-11) гласит: идентификатор константы видим в области действия функции, процедуры, правила или схемы, в которых он объявлен.

11.3.4 Экземпляр константы

Видимость: Идентификатор экземпляра константы видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия экземпляра данных схемы.

11.3.5 Контекст

Видимость: Идентификатор контекста видим для всех контрольных примеров.

Область действия: Объявление контекста определяет новую область действия. Эта область действия начинается с ключевого слова CONTEXT и продолжается до ключевого слова END_CONTEXT, которым заканчивается объявление контекста.

Объявления: Следующие элементы могут объявлять идентификаторы в области действия объявления контекста:

- формальный параметр;

- функция;

- процедура;

- экземпляр данных схемы.

11.3.6 Объект

Видимость: Идентификатор объекта видим в области действия функции или процедуры, в которой он объявлен. Идентификатор объекта остается видимым при условиях, определенных в 11.2.2, во внутренних областях действия, которые переобъявляют этот идентификатор.

Примечание - EXPRESS-спецификация (10.3.5 ГОСТ Р ИСО 10303-11) гласит: идентификатор объекта видим в области действия функции, процедуры, правила или схемы, в которых он объявлен. Идентификатор объекта остается видимым ....

Область действия и объявления: Область действия и допустимые объявления определены в ГОСТ Р ИСО 10303-11.

Пример 48 - Идентификаторы атрибута batt в двух объектах не взаимосвязаны, поскольку они объявлены в двух разных областях действия.

ENTITY entity1;

aatt : INTEGER;

batt : INTEGER;

END_ENTITY;

ENTITY entity2;

а

: entity1;

batt: INTEGER;

END_ENTITY;

Пример 49 - Следующая спецификация является неправильной, так как идентификатор атрибута aatt повторяется внутри области действия одного объекта. Хотя метка правила lab объявлена в обоих объектах, это не нарушает правил области действия или видимости; объявление объекта may_be_ok не видимо в объекте illegal, но правила обоих областей значений должны быть проверены.

ENTITY may_be_ok;

quantity : REAL;

WHERE

lab : quantity >= 0.0;

END_ENTITY;

ENTITY illegal

SUBTYPE OF (may_be_ok);

aatt : INTEGER;

batt : INTEGER;

aatt : REAL;

WHERE

lab : batt < 0;

END_ENTITY;

11.3.7 Экземпляр объекта

Видимость: Идентификатор экземпляра объекта видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия этого экземпляра данных схемы.

11.3.8 Элемент перечисления

Видимость: Идентификатор элемента перечисления видим в области действия функции или процедуры, в которой объявлен его тип. Это является исключением из правила видимости 11.2.1f. Идентификатор не должен объявляться с какой-либо иной целью в этой области действия, за исключением объявления другого перечисляемого типа данных в той же области действия. Если один и тот же идентификатор объявляется двумя перечисляемыми типами данных как элемент перечисления, к ссылке на каждый элемент перечисления должен быть добавлен префикс в виде идентификатора типа данных для обеспечения однозначности ссылки.

Примечание - EXPRESS-спецификация (10.3.4 ГОСТ Р ИСО 10303-11) гласит: идентификатор элемента перечисления видим в области действия функции, процедуры, правила или схемы, в которой объявлен его тип. Это является исключением ....

11.3.9 Экземпляр перечисления

Видимость: Идентификатор экземпляра перечисления видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия этого экземпляра данных схемы.

11.3.10 Функция

Видимость: Идентификатор функции видим в области действия функции, процедуры, контекста или контрольного примера, в которых он объявлен.

Примечание - EXPRESS-спецификация (10.3.6 ГОСТ Р ИСО 10303-11) гласит: идентификатор функции видим в области действия функции, процедуры, правила или схемы, в которых он объявлен.

Область видимости и объявления: Область действия и допустимые объявления определены в ГОСТ Р ИСО 10303-11.

11.3.11 Модель

Область действия: Объявление модели определяет новую область действия. Эта область действия простирается от ключевого слова MODEL до ключевого слова END_MODEL, которым заканчивается объявление модели.

Объявления: Следующие элементы могут объявлять идентификаторы в области действия объявления модели:

- экземпляр данных схемы.

11.3.12 Параметр

Видимость: Идентификатор формального параметра видим в области действия функции, процедуры или контекста, в которых он объявлен.

Примечание - EXPRESS-спецификация (10.3.7 ГОСТ Р ИСО 10303-11) гласит: идентификатор формального параметра видим в области действия функции или процедуры, в которых он объявлен.

Пример 50 - Следующее объявление является неправильным, так как идентификатор формального параметра раrm также используется в качестве идентификатора локальной переменной:

CONTEXT illegal;

PARAMETER

parm : REAL;

END_PARAMETER;

LOCAL

parm : STRING;

END_LOCAL;

END_CONTEXT;

11.3.13 Процедура

Видимость: Идентификатор процедуры видим в области действия функции, процедуры, контекста или контрольного примера, в которых он объявлен.

Примечание - EXPRESS-спецификация (10.3.8 ГОСТ Р ИСО 10303-11) гласит: идентификатор процедуры видим в области действия функции, процедуры, правила или схемы, в которых он объявлен.

Область действия и объявления: Область действия и допустимые объявления определены в 10.3.8 ГОСТ Р ИСО 10303-11.

11.3.14 Выражение запроса.

Область действия и видимость выражения QUERY определены в 10.3.9 ГОСТ Р ИСО 10303-11.

11.3.15 Оператор цикла

Область действия и видимость оператора REPEAT определены в 10.3.10 ГОСТ Р ИСО 10303-11.

11.3.16 Метка правила

Видимость: Метка правила видима в области действия объекта или типа, в которых она объявлена.

Примечания

1 EXPRESS-спецификация (10.3.12 ГОСТ Р ИСО 10303-11) гласит: метка правила видима в области действия объекта, правила или типа, в котором она объявлена.

2 Метка правила используется только в реализации. EXPRESS-I не определяет механизма для ссылок на метки правила.

11.3.17 Экземпляр данных схемы

Область действия: Объявление данных схемы определяет новую область действия. Эта область простирается от ключевого слова SCHEMA_DATA до ключевого слова END_SCHEMA_DATA, которым заканчивается объявление данных схемы.

Объявления: Следующие элементы могут объявлять идентификаторы в области действия объявления данных схемы:

- экземпляр константы;

- экземпляр объекта;

- экземпляр перечисления;

- экземпляр выбора;

- простой экземпляр;

- экземпляр типа.

11.3.18 Экземпляр выбора

Видимость: Идентификатор экземпляра выбора видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия этого экземпляра данных схемы.

11.3.19 Простой экземпляр

Видимость: Идентификатор простого экземпляра видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия этого экземпляра данных схемы.

11.3.20 Контрольный пример

Область действия: Контрольный пример определяет новую область действия. Эта область действия простирается от ключевого слова TEST_CASE до ключевого слова END_TEST_CASE, которым заканчивается данный контрольный пример.

Объявления: Следующие элементы могут объявлять идентификаторы в области действия контрольного примера:

- функция;

- процедура;

- переменная.

11.3.21 Тип

Видимость: Идентификатор типа видим в области действия функции или процедуры, в которой он объявлен. Идентификатор типа остается видимым, при определенных условиях, во внутренних областях действия, переобъявляющих этот идентификатор; для определения допустимых условий - см. 11.2.2.

Примечание - EXPRESS-спецификация (10.3.14 ГОСТ Р ИСО 10303-11) гласит: идентификатор типа видим в области действия функции, процедуры, правила или схемы, в которых он объявлен. Идентификатор типа остается видимым ....

Область действия и объявления: Область действия и допустимые объявления определены в ГОСТ Р ИСО 10303-11.

11.3.22 Экземпляр типа

Видимость: Идентификатор экземпляр типа видим в области действия экземпляра данных схемы, в котором он объявлен, и в любой внешней области действия этого экземпляра данных схемы.

11.3.23 Метка типа

Область действия и видимость определены в 10.3.15 ГОСТ Р ИСО 10303-11.

11.3.24 Переменная

Видимость: Идентификатор переменной видим в области действия функции, процедуры или контрольного примера, в которых он объявлен.

Примечание - EXPRESS-спецификация (10.3.16 ГОСТ Р ИСО 10303-11) гласит: идентификатор переменной видим в области действия функции, процедуры или правила, в которых он объявлен.

12 Отображение из EXPRESS в EXPRESS-I

В настоящем разделе установлены правила отображения определений схемы и типа из EXPRESS в экземпляры EXPRESS-I.

В таблице 12 приведен обзор отображений из EXPRESS в EXPRESS-I. Более детально они описаны ниже.

Таблица 12 - Краткий обзор отображений из EXPRESS в EXPRESS-I

EXPRESS

EXPRESS-I

ARRAY, BAG, LIST, SET

AggregationValue

CONSTANT

ConstantВlock

ContextBlock

ENTITY

Entitylnstance

ENUMERATION

Экземпляр или значение перечисления

FormalParameterBlock

FUNCTION

ModelBlock

PROCEDURE

Remark

RULE

SCHEMA

SchemaInstanceBIock

SELECT

Экземпляр или значение выбора

Simple type

SimpleValue

TestCaseBlock

TYPE

Экземпляр или значение типа

12.1 Отображение EXPRESS-схемы

EXPRESS-конструкция SCHEMA синтаксически отображается в EXPRESS-I-конструкцию экземпляра данных схемы. В таблице 13 приведен обзор соответствия между конструкциями EXPRESS и EXPRESS-I.

Таблица 13 - Обзор отображения SCHEMA

EXPRESS

EXPRESS-I

имя SCHEMA

schema_id

CONSTANT

ConstantBlock или ничего

ENTITY

Entitylnstance

ENUMERATION

EnumerationInstance или ничего

FUNCTION

ничего

PROCEDURE

ничего

REFERENCE

ничего, но см. 12.1.1

RULE

ничего

SELECT

Selectlnstance или ничего

TYPE

Typelnstance или ничего

USE

ничего, но см. 12.1.1

Правила и ограничения

a) Имя экземпляра данных EXPRESS-I-схемы должно быть таким же, как и имя соответствующей EXPRESS-схемы.

b) Каждый экземпляр объекта внутри экземпляра данных схемы должен иметь соответствующее определение объекта внутри EXPRESS-схемы.

c) Каждый экземпляр перечисления, выбора или типа внутри экземпляра данных схемы должен иметь соответствующее определение внутри EXPRESS-схемы.

d) Каждая константа внутри экземпляра данных схемы должна иметь соответствующее определение константы внутри EXPRESS-схемы.

e) Каждая спецификация области значений внутри экземпляра данных схемы должна быть уникально обозначена, при необходимости - посредством квалификации имени области значений, именем EXPRESS-схемы, содержащей определение области значений.

f) Идентификаторы экземпляров должны быть уникальными внутри экземпляра данных схемы.

12.1.1 Отображение USE и REFERENCE

EXPRESS-операторы USE и REFERENCE не отображаются в EXPRESS-I непосредственно, но их действие приводит к следующему:

- экземпляры элементов EXPRESS, внесенные в область действия EXPRESS-схемы посредством явных операторов USE или REFERENCE либо посредством неявных ссылок, могут появиться внутри соответствующего экземпляра данных EXPRESS-I-схемы;

- элементы, области значений которых переименовываются, должны иметь соответствующие области значений с новыми именами;

- если имеются конфликты между именами областей значений из исходной EXPRESS-схемы с именами областей значений, вносимыми из другой схемы, вносимые имена должны квалифицироваться именем их родительской схемы.

Пример 51 - Эти EXPRESS-схемы взаимосвязаны, так как схема с именем primary использует определение объекта с именем an_ent из схемы secondary.

SCHEMA primary;

USE FROM secondary (an_ent AS used);

ENTITY dup;

аtt1 : used

att2 : BOOLEAN;

END_ENTITY;

END_SCHEMA;

SCHEMA secondary;

ENTITY dup;

name : STRING;

int : INTEGER;

END_ENTITY;

ENTITY an_ent;

att3 : dup;

att4 : REAL;

END_ENTITY;

END_SCHEMA;

Любое использование an_ent в экземпляре схемы primary требует экземпляра объекта с именем dup, который также определяется в схеме secondary и автоматически доступен в силу семантики предложения USE. Однако в данном случае в схеме primary также имеется объект с именем dup. Две их области значений должны различаться внутри EXPRESS-I представления primary посредством квалификации имени объекта, вносимого из схемы secondary, как показано ниже.

MODEL example;

SCHEMA_DATA primary;

dup1 = dup{att1 @used1; att2 TRUE;};

used1 = used{att3 @dup2; att4 1.23;};

dup2 = secondary.dup{name `from secondary`; int 1;};

used2 = used{att3 @dup3; att4 -3.9;};

END_SCHEMA_DATA;

SCHEMA_DATA secondary;

dup3 = dup{name `in secondary`; int 3;};

dup4 = dup{name `in secondary`; int 4;};

an_ent1 = an_ent{att3 @dup3; att4 42.0;};

END_SCHEMA_DATA;

END_MODEL;

12.2 Отображение простых типов данных из EXPRESS

Отображение простого типа данных из EXPRESS в значение EXPRESS-I задано в таблице 14.

Таблица 14 - Отображение простого типа

EXPRESS

EXPRESS-I

BINARY

BinaryValue

BOOLEAN

BooleanValue

INTEGER

IntegerValue

LOGICAL

LogicalValue

NUMBER

IntegerValue

RealValue

REAL

RealValue

STRING

StringValue

Пример 52 - Отображение простых типов данных

EXPRESS

EXPRESS-I

ENTITY base;

е1 = base {

a_binary

: BINARY;

a_binary

%0110;

a_boolean

: BOOLEAN;

a_boolean

FALSE;

an_integer

: INTEGER;

an_integer

12345;

а_lgical

: LOGICAL;

а_logical

UNKNOWN;

a_number

: NUMBER;

a_number

-PI;

a_real

: REAL;

a_real

-9.99e2;

a_string

: STRING;

a_string

`Tangles`;

END_ENTITY;

};

12.3 Отображение агрегатных типов данных

Отображение агрегаций из EXPRESS в EXPRESS-I приведено в таблице 15.

Таблица 15 - Отображение AGGREGATE

EXPRESS

EXPRESS-I

AGGREGATE

Одно из следующих:

ARRAY

FixedAggr

BAG

DynamicAggr

LIST

DynamicAggr

SET

DynamicAggr

Отображение "агрегации-агрегации..." производится отображением каждой элементарной агрегации в порядке слева направо. Это значит, что самая левая EXPRESS-агрегация становится самой внешней EXPRESS-I-агрегацией.

Пример 53 - Отображения AGGREGATE

EXPRESS

EXPRESS-I

ENTITY aggr;

e1 = aggr {

an_array

: ARRAY [1:3] OF INTEGER;

an_array

[1, 2, 3];

a_bag

: BAG [0:?] OF INTEGER;

a_bag

(3, 3, 1);

a_list

: LIST [0:2] OF INTEGER;

a_list

(1);

a_set

: SET [1:?] OF INTEGER;

a_set

(9, 5, 11);

a_mix

: ARRAY [1:2] OF SET OF INTEGER;

a_mix

[(1, 2), (6, 5)];

END_ENTITY;

};

Примечание - EXPRESS ARRAY может иметь значения OPTIONAL. Если значения не определены в экземпляре ARRAY, то эти значения обозначаются в EXPRESS-I конструкцией Nil (то есть символом ?).

Пример 54 - Отображение массива sparse

EXPRESS

EXPRESS-I

ENTITY sparse;

e1 = sparse {

a1

: ARRAY [1:4] OF OPTIONAL INTEGER;

a1

[1, ?, ?, 4];

a2

: ARRAY [5:8] OF OPTIONAL INTEGER;

a2

[1, ?, 3, ?];

END_ENTITY;

};

12.4 Отображение определенного типа данных из EXPRESS

Определенный тип данных из EXPRESS отображается в EXPRESS-I одним из трех способов:

a) заменой идентификатора EXPRESS-типа значением типа;

b) заменой идентификатора EXPRESS-типа поименованным значением типа;

c) определением экземпляра типа.

Пример 55 - Отображение определенного типа данных

EXPRESS

EXPRESS-I

TYPE dd = ARRAY [1:2] OF INTEGER;

t3 = dd{[6, 8]};

END_TYPE;

ENTITY use_type;

e1 = use_type{attr [2, 4];};

attr : dd;

e2 = use_type{attr dd{[4, 6]};};

END_ENTITY;

e3 = use_type{attr @t3;};

12.5 Отображение перечисляемого типа из EXPRESS

Тип ENUMERATION из EXPRESS отображается в EXPRESS-I одним из трех способов:

a) заменой идентификатора EXPRESS-типа перечисляемым значением;

b) заменой идентификатора EXPRESS-типа поименованным перечисляемым значением;

c) определением экземпляра перечисления.

Пример 56 - Отображение перечисления

EXPRESS

EXPRESS-I

TYPE enum = ENUMERATION OF

(one, two, three);

t3 = enum{!three};

END_TYPE;

ENTITY use_enum;

e1 = use_enum{attr !one;};

attr : enum;

e2 = use_enum{attr enum{!two};};

END_ENTITY;

e3 = use_enum{attr @t3;};

12.6 Отображение выбираемого типа из EXPRESS

Тип SELECT из EXPRESS отображается в EXPRESS-I одним из трех способов:

a) заменой идентификатора EXPRESS-типа выбираемым значением;

b) заменой идентификатора EXPRESS-типа поименованным выбираемым значением;

c) определением экземпляра выбора.

EXPRESS-тип SELECT необязательно отображать в EXPRESS-I непосредственно. Детали отображения зависят от того, как формируется тип SELECT, и описаны ниже.

Тип SELECT определяет дерево. Корнем дерева является тип SELECT, а ветви из корня соответствуют типам выбора внутри SELECT. Если одним из этих типов является сам тип SELECT, то он порождает новые ветви и т. д. Листья дерева образуются из выборов, не являющихся типами SELECT. В простом случае все листья являются разными типами. В сложном случае по крайней мере два листа имеют один и тот же базовый тип.

12.6.1 Случай простого выбора

Тип выступает либо как ссылка на один из типов в списке выбора, либо как вхождение одного из типов в список выбора.

Пример 57 - Отображение простого выбора

EXPRESS

EXPRESS-I

ENTITY a;

e1 = а{аа 3;};

аа : INTEGER;

e3 = а{аа 9;};

END_ENTITY;

ENTITY b;

e2 = b{ab 6;};

ab : INTEGER;

e4 = b{ab 12;};

END_ENTITY;

TYPE s = SELECT(a, b);

s4 = s{@e4};

END_TYPE;

ENTITY с;

c1 = с{ас (@s4, @е3, @е2, @e1);};

ас : LIST [1:?] OF s;

с2 = с{ас (s{@1}, @е3, @е3);};

END_ENTITY;

12.6.2 Случай сложного выбора

В этом случае листья дерева не могут быть различимы только по их значениям. Это происходит, если:

a) листья являются определенными типами данных с идентичными базовыми типами;

b) листья являются типами ENUMERATION, множества значений которых на листьях не разобщены. Например, множества [red, green, blue] и [red, amber, green] не разобщены.

Значение экземпляра выбора в этом случае должно быть представлено в EXPRESS-I либо ссылкой на экземпляр, либо поименованным значением.

Пример 58 - Отображение сложного выбора

EXPRESS

EXPRESS-I

TYPE size = SELECT

s1 = size{@r1};

(area, radius);

s2 = size{radius{4.3}};

END_TYPE;

TYPE area = REAL;

a1 = агеа{7.5};

END_TYPE;

TYPE radius = REAL;

r1 = radius{27.89};

END_TYPE;

ENTITY circle;

c1 = circle{howbig area{PI};};

howbig : size;

c2 = circlejhowbig radius{1.0};};

WHERE

с3 = circle{howbig @s1;};

howbig > 0.0;

c4 = circle{howbig @a1};

END_ENTITY;

c5 = circle{howbig @s2};

12.7 Отображение EXPRESS-константы

EXPRESS-константа (CONSTANT) синтаксически отображается в EXPRESS-I-конструкцию constant_spec. Это значит, что в EXPRESS-I определяются только идентификатор константы и значение, а область значений константы задается в исходном EXPRESS-определении. Кроме того, значение константы должно быть полностью вычисляемым. Определение каждой константы, появляющееся в экземпляре схемы, должно быть объявлено в определении EXPRESS-схемы. Однако не требуется, чтобы каждая EXPRESS-константа присутствовала в экземпляре схемы.

Пример 59 - Отображение констант

EXPRESS

EXPRESS-I

CONSTANT

CONSTANT

zero : NUMBER := 0.0;

zero = = 0.0;

thousand : INTEGER := 1000;

thousand = = 1000;

million : INTEGER := thousand**2;

million = = 1000000;

origin : point := point(0.0, 0.0);

origin = = point{x 0.0;

y 0.0;};

z_axis : vector := [zero, zero, 1.0];

z_axis == [0.0,0.0,1.0];

a_set : SET OF INTEGER := [1,2,3*3];

a_set == (1, 2, 9);

a_bag : BAG OF INTEGER := [1, 3, 1];

boss : STRING := `sir`;

underling : STRING := `hey, you`;

underling = = `hey, you`;

END_CONSTANT;

END_CONSTANT;

Заметим, что две константы с именами a_bag и boss не отображены в данном примере.

12.8 Отображение EXPRESS-объекта

EXPRESS-конструкция объекта (ENTITY) синтаксически отображается в EXPRESS-I-конструкцию экземпляра объекта. Единственными внутренними фрагментами ENTITY, отображаемыми в EXPRESS-I, являются атрибуты и операторы SUPERTYPE и SUBTYPE, как показано в таблице 16.

Таблица 16 - Обзор отображения ENTITY

EXPRESS

EXPRESS-I

Имя ENTITY

EntityDomain

Оператор SUPERTYPE

BequeathesTo

Оператор SUBTYPE

InheritsFrom

Явный атрибут

RequiredAttr или OptionalAttr

Вычисляемый атрибут

DerivedAttr

Инверсный атрибут

InverseAttr

Оператор UNIQUE

Ничего

Оператор WHERE

Ничего

Пример 60 - Отображение простого объекта

EXPRESS

EXPRESS-I

ENTITY top;

t1 = top{a (@eg1, @eg2);};

а : SET OF bot;

t2 = top{a (@eg2, @eg3);};

END_ENTITY;

t3 = top{a ();};

ENTITY bot;

eg1 = bot{i 1;

i : INTEGER;

j 2;

DERIVE

inv (@t1);};

j : INTEGER := 2*i;

INVERSE

eg2 = bot{i 276;

inv : BAG [1:?] OF top FOR a;

j 552;

UNIQUE

inv (@t1, @t2);};

u1 : i;

WHERE

eg3 = bat{i 9876;

w1 : i > 0;

j;

END_ENTITY;

inv (@t2);};

12.9 Отображение атрибутов EXPRESS-объекта

EXPRESS-I-атрибуты должны появляться в том же порядке, что и в соответствующем ЕХPRESS-объекте. Каждый EXPRESS-атрибут должен иметь соответствующий EXPRESS-I-атрибут.

Значение EXPRESS-I-атрибута должно быть совместимо с областью значений EXPRESS-определения.

12.9.1 Явный атрибут

Явные EXPRESS-атрибуты отображаются непосредственно в EXPRESS-I-атрибуты. Описание EXPRESS-атрибута повторяется в EXPRESS-I, за исключением того, что описание типа атрибута (то есть справа от двоеточия) заменяется значением типа атрибута, а двоеточие заменяется на ->.

Значение может быть представлено простым значением, ссылкой на экземпляр предмета (то есть ссылкой на экземпляр объекта, типа, перечисления или выбора), значением перечисления, поименованным значением, ссылкой на константу, ссылкой на параметр или агрегатами данных значений. Эти значения более детально обсуждены ниже.

В случае, если явный атрибут является необязательным (OPTIONAL), значением атрибута может быть также Nil, показывающее, что значение не представлено.

Пример 61 - Отображение необязательного атрибута

EXPRESS

EXPRESS-I

ENTITY opt;

opt1 = opt{req `Opt_att given`;

req : STRING;

opt_att 5.0;};

opt_att : OPTIONAL REAL;

END_ENTITY;

opt2 = opt{req `Opt_att not given`;

opt_att ?;};

Примечание - В EXPRESS-I явный атрибут может иметь значение Nil; в этом случае экземпляр не соответствует EXPRESS-определению.

12.9.2 Вычисляемые и инверсные атрибуты

Вычисляемые EXPRESS-атрибуты отображаются в EXPRESS-I аналогично явным атрибутам, за исключением того, что двоеточие заменяется знаком <-.

Инверсные EXPRESS-атрибуты отображаются в EXPRESS-I аналогично явным атрибутам, за исключением того, что двоеточие заменяется знаком <-, а значением атрибута является динамическая агрегация ссылок на экземпляр объекта.

Не требуется, чтобы в EXPRESS-I присутствовали значения вычисляемых или инверсных атрибутов, хотя имена ролей присутствовать должны.

Примечания

1 По определению, значение вычисляемого атрибута может быть определено по значениям явных атрибутов. Аналогично, значение инверсного атрибута экземпляра объекта может быть определено по значениям атрибутов экземпляров других объектов, которые ссылаются на экземпляр объекта с данным инверсным атрибутом. Таким образом, по крайней мере, концептуально, значения как вычисляемого, так и инверсного атрибутов являются вычислимыми свойствами.

2 С другой стороны, значения явных атрибутов являются базовыми входными данными, не вычислимыми внутри системы EXPRESS-I.

3 Символы -> и <- были выбраны для индикации этой разницы в качестве значений атрибута.

12.9.3 Атрибут с простой областью значений

Если областью значений EXPRESS-атрибута является простой тип данных, это должно быть отображено как значение EXPRESS-I, принадлежащее простой области значений. Обычно это является простым значением, но может быть ссылкой на константу или параметр, областями значений которых являются простые области значений.

Правила и ограничения

a) Ссылка на константу должна использоваться только в случае, если и экземпляр объекта, и экземпляр константы находятся внутри одного и того же экземпляра данных схемы.

b) Ссылка на параметр должна использоваться только в случае, если формальный параметр и экземпляр объекта находятся внутри одного и того же контекста (CONTEXT).

c) Ссылка на параметр не должна использоваться внутри области действия MODEL.

Пример 62 - Отображение простого значения в качестве атрибута

Пусть дано EXPRESS-представление в виде:

SCHEMA a_schema;

CONSTANT

const : INTEGER:=275;

END_CONSTANT;

ENTITY an_ent;

aa : INTEGER;

END_ENTITY;

END_SCHEMA;

Тогда EXPRESS-I-представление может иметь вид:

MODEL some_data;

SCHEMA_DATA a_schema;

CONSTANT

const = = 275;

END_CONSTANT;

a1 = an_ent{aa 1;};

a2 = an_ent{aa const;};

a3 = an_ent{aa 21;};

a4 = an_ent{aa 987;};

END_SCHEMA_DATA;

END_MODEL

Это можно представить и по-другому, через контекст:

CONTEXT a_context;

PARAMETER

parm1 : INTEGER := 21;

parm2 : INTEGER := 987;

END_PARAMETER;

SCHEMA_DATA a_schema;

CONSTANT

const = = 275;

END_CONSTANT;

a1 = an_ent{aa 1;};

a2 = an_ent{aa const;};

a3 = an_ent{aa param1;};

a4 = an_ent{aa param2;};

END_SCHEMA_DATA;

END_ CONTEXT;

12.9.4 Атрибут с областью значений объекта

Если областью значений EXPRESS-атрибута является объект, то атрибут должен отображаться в значение EXPRESS-I, принадлежащие к области значений объекта. Обычно это является ссылкой на экземпляр объекта, но может быть ссылкой на константу или на параметр, областью значений которого является область значений объекта.

Правила и ограничения

a) Ссылка на константу может использоваться только в случае, если экземпляр объекта и экземпляр константы находятся в одном и том же экземпляре данных схемы.

b) Ссылка на параметр может использоваться только в случае, если формальный параметр и экземпляр объекта находятся в одном и том же контексте (CONTEXT).

c) Ссылка на параметр не должна использоваться в области применения модели (MODEL).

d) Ни ссылка на параметр, ни ссылка на константу не должны использоваться для инверсного атрибута.

Пример 63 - Отображение объекта в качестве атрибута

Пусть EXPRESS-представление задано в виде:

SCHEMA a_schema;

CONSTANT

const : an_ent := an_ent(275);

END_CONSTANT;

ENTITY an_ent;

aa : INTEGER;

END_ENTITY;

ENTITY bdyn;

ab : an_ent;

END_ENTITY;

END_SCHEMA;

Тогда EXPRESS-I-представление может иметь вид:

CONTEXT a_context;

PARAMETER

param : an_ent := an_ent{aa 42;};

END_PARAMETER;

SCHEMA_DATA a_schema;

CONSTANT

const == an_ent{aa 275;};

END_CONSTANT;

a1 = an_ent{aa 1;};

b1 = bdyn{ab @a1;};

b2 = bdyn{ab const;};

b3 = bdyn{ab param;};

END_SCHEMA_DATA;

END_CONTEXT;

12.9.5 Атрибут с областью значений типа, выбора или перечисления

Если областью значений EXPRESS-атрибута является определенный тип данных, типы SELECT или ENUMERATION, то атрибут должен отображаться как значение EXPRESS-I, принадлежащее к соответствующей области значений. Обычно это либо значение (для определенного типа данных или перечисления), либо ссылка на экземпляр объекта (для выбора), но может быть и ссылкой на экземпляр предмета, поименованным значением, либо ссылкой на константу или параметр, области значений которых совместимы с областью значений атрибута.

Правила и ограничения

a) Ссылка на константу может использоваться только в случае, если экземпляр объекта и экземпляр константы находятся в одном и том же экземпляре данных схемы.

b) Ссылка на параметр может использоваться только в случае, если формальный параметр и экземпляр объекта находятся в одном и том же контексте (CONTEXT).

c) Ссылка на параметр не должна использоваться внутри области применения модели (MODEL).

d) Ссылка на экземпляр предмета или поименованное значение должны использоваться, если фактическая область значений не однозначно определяется из значения.

Пример 64 - Отображение типов в качестве атрибутов

Пусть EXPRESS-представление задано в виде:

SCHEMA a_schema;

CONSTANT

zero : REAL := 0.0;

END_CONSTANT;

TYPE size = SELECT(area, radius); END_TYPE;

TYPE area = REAL; END_TYPE;

TYPE radius = REAL; END_TYPE;

TYPE vector = ARRAY [1:3] OF REAL; END_TYPE;

TYPE color = ENUMERATION OF (red, blue, green); END_TYPE;

ENTITY point;

x, y, z, : REAL;

END_ENTITY;

ENTITY circle;

center : point;

normal : vector;

howbig: size;

shade : color;

END_ENTITY;

END_SCHEMA;

Тогда EXPRESS-I-представление может иметь вид:

SCHEMA_DATA a_schema;

CONSTANT

zero = = 0. 0;

END_CONSTANT;

unit_rad = size{radius {1.0}};

x_axis = vector{[1.0, zero, zero ]};

z_axis = vector{[zero, zero, 1.0]};

x_color = color{!red};

p0 = point{x zero; у zero, z zero;};

p1 = point{x 1.0; у 1.0, z 1.0;};

c1 = circle{center @p0;

normal @x_axis;

howbig area{PI};

shade @x_color;);

c2 = circle{center @p0;

normal [1.0, 2.0, 3.0];

howbig radius{33.0};

shade !blue;};

c3 = circle (center @p1;

normal @z_axis;

howbig @unit_rad;

shade !blue;};

END_SCHEMA_DATA;

12.10 Отображение супертипов и подтипов

Имеется взаимно однозначное соответствие между супертипами и подтипами EXPRESS и супертипами и подтипами EXPRESS-I (см. таблицу 17).

Таблица 17- Обзор отображения SUPERTYPE и SUBTYPE

EXPRESS

EXPRESS-I

SUPERTYPE OF (...)

BequeathesTo

SUBTYPE OF (...)

InheritsFrom

В EXPRESS-I наполнение объекта, являющегося листом дерева супертипов/подтипов, требует наполнения всех его супертипов. Дерево экземпляра супертипов EXPRESS-I должно быть всегда выписано полностью.

Пример 65 - Рассмотрим ниже фрагмент дерева EXPRESS и конкретный объект :

ENTITY …

ENTITY parent SUBTYPE OF (grandparent)

SUPERTYPE OF (me ANDOR sibbing );

ENTITY me SUBTYPE OF (parent)

SUPERTYPE OF (elder ANDOR younger);

ENTITY elder SUBTYPE OF (me)

SUPERTYPE OF …

ENTITY …

Объект наследует любые атрибуты, которые могут иметь его супертипы (то есть parent, grandparent и т.д.). В свою очередь, завещает как свои наследуемые атрибуты, так и свои собственные атрибуты своим подтипам (то есть elder, younger и их последующих потомков).

В этом дереве экземпляр может также иметь либо не иметь sibling (брата). В общем дереве возможно существование многих отношений, не находящихся на прямой линии предка и потомка.

Для данного подраздела определим:

экземпляр прямого дерева (direct tree instance): Экземпляр однокоренного дерева подтипов/супертипов, имеющего единственный путь, при незаполненных ветвях, от корня к единственному листу;

экземпляр общего дерева (general tree instance): Экземпляр дерева подтипов/супертипов, не являющийся экземпляром прямого дерева.

Дерево EXPRESS, в котором все отношения SUPERTYPE являются ONEOF и ни один из SUBTYPE не имеет множественных SUPERTYPE, всегда является прямым деревом.

Наполнение дерева, включающего отношения ANDOR, будет прямым, если все отношения ANDOR наполняются как отношения ONEOF; в противном случае по крайней мере некоторая часть наполняемого дерева не будет прямой. Наполнение отношений AND всегда дает общее дерево. Наполнение объекта, имеющего множественные SUPERTYPE, всегда дает общее дерево.

В экземпляре прямого дерева должен быть представлен полный путь экземпляра от корня к листу.

Следующий набор правил определяет отображение общего дерева:

a) полный путь экземпляра от корня к месту, включающий боковые ветви, всегда должен наполняться в соответствии с приведенными ниже правилами;

b) если наполняемый объект (ENTITY) является SUBTYPE для одного или более объектов, то каждый из SUPERTYPE объектов должен наполняться;

c) если наполняемый объект (ENTITY) является SUPERTYPE для одного или более объектов (то есть имеется отношение AND либо имеется отношение ANDOR, которое наполняется, скорее, как AND, нежели как ONEOF), то SUPERTYPE и все его одновременно существующие SUBTYPE должны наполняться;

d) если SUPERTYPE объекта (ENTITY) помечен как ABSTRACT, то экземпляр этого объекта будет иметь по крайней мере один экземпляр SUBTYPE. Если SUPERTYPE не помечен как ABSTRACT, то он может иметь либо не иметь экземпляров SUBTYPE, в зависимости от конкретных данных.

Примечание - Упорядочение экземпляров объектов в дереве подтипов/супертипов не имеет значения.

Пример 66 - Отображение дерева

Пусть дано следующее EXPRESS-представление:

ENTITY root;

g_name : STRING;

END_ENTITY;

ENTITY node

SUBTYPE OF (root);

p_name : STRING;

END_ENTITY;

ENTITY leaf1

SUBTYPE OF (node);

my_name : STRING;

END_ENTITY;

ENTITY Ieaf2

SUBTYPE OF (node);

s_name : STRING;

END_ENTITY;

Тогда двумя примерами экземпляров этой структуры могут быть:

ЭКЗЕМПЛЯР 1

ЭКЗЕМПЛЯР 2

c1[1] = root{

c2[1] = root{

g_name `root`;

g_name `base`;

SUPOF(@2);};

SUPOF(@2);};

c1[2] = node{

c2[2] = node{

SUBOF(@1);

SUBOF(@1);

p_name `trunk`;

p_name `branch`;

SUPOF(@3, @4);};

SUPOF(@3);};

c1[3] = leaf1{

c2[3] = leaf1{

SUBOF(@2);

SUBOF(@2);

my_name `self`;};

my_name `twig`;};

c1[4] = Ieaf2{

SUBOF(@2);

s_name `sibling`;};

Экземпляр, помеченный 1, является экземпляром общего дерева, а экземпляр, помеченный 2, - экземпляром прямого дерева.

12.10.1 Отображение переобъявляемых атрибутов

В подтипе EXPRESS есть возможность переобъявлять атрибуты, наследуемые от супертипа. В EXPRESS-I переобъявление выступает как ограничение значения атрибута. Переобъявляемые атрибуты не должны именоваться внутри экземпляра подтипа.

Пример 67 - В примере объект real_point является подтипом point и переобъявляет его атрибуты типа NUMBER на тип REAL. Имеются два соответствующих экземпляра EXPRESS-I. Первый (то есть р1) является экземпляром простого объекта только супертипа и отображает значения атрибутов как тип NUMBER. Второй (то есть р2) является экземпляром сложного объекта, где р2[1] является компонентом супертипа, а р2[2] - компонентом подтипа. В подтипе не показаны атрибуты, но значения, отражаемые в супертипе, ограничены типом REAL.

EXPRESS

EXPRESS-I

ENTITY point;

p1 = point{x 1;

y 2;};

x : NUMBER;

у : NUMBER;

END_ENTITY;

p2[1] = point{x 1.5;

y 2,7;

ENTITY real_point;

SUPOF(@2);};

SUBTYPE OF (point);

SELF\point.x : REAL

p2[2] = real_point{SUBOF(@1);};

SELF\point.y : REAL;

END_ENTITY;

В случае переобъявления наследуемого явного атрибута на вычисляемый атрибут переобъявленный атрибут должен выступать в супертипе как вычисляемый атрибут, когда бы ни наполнялся переобъявляющий подтип.

Пример 68 - Следующее EXPRESS-представление объявляет circle как окружность, определяемую центром и радиусом. Объект circle_2pt является разновидностью circle, определяемой центром и точкой на окружности circle. Наследуемый атрибут radius переобъявляется как вычисляемый атрибут, значение которого задается расстоянием между двумя точками.

ENTITY circle;

centre : point;

radius : REAL;

END_ENTITY;

ENTITY circle_2pt

SUBTYPE OF (circle);

circum_pnt : point;

DERIVE

SELF\circle.radius : REAL := distance(SELF\circle.center, circum_pnt);

END_ENTITY;

В EXPRESS-I-представлении экземплярами circle и circle_2pt могут быть:

c1 = circle{centre [1.0, 0.0];

radius 2.0;};

c2pt[21] = circle{centre [1.0, 0.0];

radius 2.0;

SUPOF (@5);};

c2pt[5] = circle_2pt{SUBOF(@21);

circum_pnt [1.0, 2.0];};

ПРИЛОЖЕНИЕ А
(обязательное)


Описание синтаксиса EXPRESS-I

В настоящем приложении определены лексические элементы языка и грамматические правила, которым эти элементы должны подчиняться.

Примечания

1 Многие элементы языка EXPRESS доступны для использования при определении контрольных примеров. Недоступные для использования элементы EXPRESS касаются определения EXPRESS-схем, интерфейсов схем и правил. Для удобства читателя элементы EXPRESS приведены в настоящем приложении со справочными примечаниями. Для полноты описания языка также в виде комментариев приведены правила, относящиеся к недоступным для использования элементам EXPRESS.

2 В качестве дальнейшего ориентира в конструкциях, относящиеся только к EXPRESS-I, подчеркивание не используется - каждое имя в конструкции EXPRESS-I начинается с заглавной буквы. Например, DerivedAttr является конструкцией EXPRESS-I, тогда как derived_attr является конструкцией EXPRESS. Кроме того, исходная нумерация правил EXPRESS оставлена без изменений. Специфические правила EXPRESS-I пронумерованы с добавлением символа `i'.

3 Приведенное определение синтаксиса, понимаемое буквально, будет вызывать неодназначное толкование у анализаторов. Оно написано для представления информации, относящейся к использованию идентификаторов. Интерпретируемые идентификаторы определяют лексемы, являющиеся ссылками на объявляемые идентификаторы, и поэтому не разрешены в simple_id. Это требует от разработчика синтаксического анализатора представления таблицы поиска или аналогичной конструкции, позволяющей разрешать ссылку на идентификатор и возвращать лексему требуемой ссылки контролеру грамматических правил. Этот подход использован для того, чтобы помочь разработчикам синтаксических анализаторов в устранении неоднозначностей, относящихся к использованию идентификаторов.

А.1 Лексемы

Последующие правила определяют лексемы, используемые в EXPRESS-I. Внутри текста, соответствующего отдельному синтаксическому правилу следующих подразделов и разделов: A1.1, A1.2, А.2 и A3, не должны присутствовать пробелы или примечания, за исключением случаев, оговоренных в синтаксических правилах.

А.1.1 Ключевые слова

В данном подразделе приведены правила, используемые для представления ключевых слов EXPRESS-I.

Примечание - В данном подразделе придерживаются типографского соглашения, по которому каждое ключевое слово представляется синтаксическим правилом, левой частью которого является данное ключевое слово, записанное заглавными буквами. Правило 15i является исключением, обусловленным необходимостью избежать пересечения с правилом 251. Так как строковые литералы в синтаксических правилах не чувствительны к типу буквы, ключевые слова могут быть записаны в исходном коде на EXPRESS-I заглавными, строчными либо смешанного (того и другого) типа буквами.

0i

CALL = 'call' .

1i

CRITERIA = 'criteria' .

2i

END_CALL = 'end_call' .

3i

END_CRITERIA = 'end_criteria' .

4i

END_NOTES = 'end_notes' .

5i

END_OBJECTIVE = 'end_objective' .

6i

END_PARAMETER = 'end_parameter' .

7i

END_PURPOSE = 'end_purpose' .

8i

END_REALIZATION = 'end_realization' .

9i

END_REFERENCES = 'end_references' .

10i

END_SCHEMA_DATA = 'end_schema_data' .

11i

END_TEST_CASE = 'end_test_case' .

12i

IMPORT = 'import' .

13i

NOTES = 'notes' .

14i

OBJECTIVE = 'objective' .

15i

PARAMETER = 'parameter' .

16i

PURPOSE = 'purpose' .

17i

REALIZATION = 'realization' .

18i

REFERENCES = 'references' .

19i

SCHEMA_DATA = 'schema_data' .

20i

SUBOF = 'subof' .

21i

SUPOF = 'supof' .

22i

TEST_CASE = 'test_case' .

23i

USING = 'using' .

24i

WITH = 'with' .

Примечание - Следующие EXPRESS-правила от 0 до 118, за исключением 8, 37, 38, 49, 84, 89, 90 и 110, используются в EXPRESS-I.

0

ABS = 'abs' .

1

ABSTRACT = 'abstract' .

2

ACOS = 'acos' .

3

AGGREGATE = 'aggregate' .

4

ALIAS = 'alias' .

5

AND = 'and' .

6

ANDOR = 'andor' .

7

ARRAY = 'array' .

<

8 AS = 'as' . >

9

ASIN = 'asin' .

10

ATAN = 'atan' .

11

BAG = 'bag' .

12

BEGIN = 'begin' .

13

BINARY = 'binary' .

14

BLENGTH = 'blength' .

15

BOOLEAN = 'boolean' .

16

BY = 'by' .

17

CASE = 'case' .

18

CONSTANT = 'constant' .

19

CONST_E = 'const_e' .

20

CONTEXT = 'context' .

21

COS = 'cos' .

22

DERIVE = 'derive' .

23

DIV = 'div' .

24

ELSE = 'else' .

25

END = 'end' .

26

END_ALIAS = 'end_alias' .

27

END_CASE = 'end_case' .

28

END_CONSTANT = 'end_constant' .

29

END_CONTEXT = 'end_context' .

30

END_ENTITY = 'end_entity' .

31

END_FUNCTION = 'end function' .

32

END_IF = 'end_if' .

33

END_LOCAL = 'end_local' .

34

END_MODEL = 'end_model' .

35

END_PROCEDURE = 'end_procedure' .

36

END_REPEAT = 'end_repeat' .

<

37 END_RULE = 'end_rule' . >

<

38 END_SCHEMA = 'end_schema' . >

39

END_TYPE = 'end_type' .

40

ENTITY = 'entity' .

41

ENUMERATION = 'enumeration' .

42

ESCAPE = 'escape' .

43

EXISTS = 'exists' .

44

EXP = 'exp' .

45

FALSE = 'false' .

46

FIXED = 'fixed' .

47

FOR = 'for' .

48

FORMAT = 'format' .

<

49 FROM = 'from' . >

50

FUNCTION = 'function' .

51

GENERIC = 'generic' .

52

HIBOUND = 'hibound' .

53

HIINDEX = 'hiindex' .

54

IF = 'if' .

55

IN = 'in' .

56

INSERT = 'insert' .

57

INTEGER = 'integer' .

58

INVERSE = 'inverse' .

59

LENGTH = 'length' .

60

LIKE = 'like' .

61

LIST = 'list' .

62

LOBOUND ='`lobound' .


63

LOCAL = 'local' .

64

LOG = 'log' .

65

LOG10 = 'log10' .

66

LOG2 = 'Iog2' .

67

LOGICAL = 'logical' .

68

LOINDEX = 'loindex' .

69

MOD = 'mod' .

70

MODEL = 'model' .

71

NOT = 'not' .

72

NUMBER = 'number' .

73

NVL = 'nvl' .

74

ODD = 'odd' .

75

OF = 'of' .

76

ONEOF = 'oneof'.

77

OPTIONAL = 'optional' .

78

OR = 'or' .

79

OTHERWISE = 'otherwise' .

80

PI = 'pi' .

81

PROCEDURE = 'procedure' .

82

QUERY = 'query' .

83

REAL = 'real' .

<

84 REFERENCE = 'reference' . >

85

REMOVE = 'remove' .

86

REPEAT = 'repeat' .

87

RETURN = 'return' .

88

ROLESOF = 'rolesof' .

<

89 RULE = 'rule' . >

<

90 SCHEMA = 'schema' . >

91

SELECT = 'select' .

92

SELF = 'self' .

93

SET = 'set' .

94

SIN = 'sin' .

95

SIZEOF = 'sizeof' .

96

SKIP = 'skip' .

97

SQRT = 'sqrt' .

98

STRING = 'string' .

99

SUBTYPE = 'subtype' .

100

SUPERTYPE = 'supertype' .

101

TAN = 'tan' .

102

THEN = 'then' .

103

ТО = 'to' .

104

TRUE = 'true' .

105

TYPE = 'type' .

106

TYPEOF = 'typeof' .

107

UNIQUE = 'unique' .

108

UNKNOWN = 'unknown' .

109

UNTIL = 'until' .

<

110 USE = 'use' . >

111

USEDIN = 'usedin' .

112

VALUE = 'value' .

113

VALUE_IN = 'value_in' .

114

VALUE_UNIQUE = 'value_unique' .

115

VAR = 'var' .

116

WHERE = 'where' .

117

WHILE = 'while' .

118

XOR = 'xor' .

A.1.2. Классы символов

Следующие правила определяют различные классы символов, используемые при конструировании лексем в А2.

Примечание - Последующие правила EXPRESS от 119 до 135 используются в EXPRESS-I.

119

bit = '0' | '1' .

120

digit = '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9' .

121

digits = digit { digit } .

122

encoded_character = octet octet octet octet .

123

hex_digit = digit | 'a' | 'b' | 'c' | 'd' | 'e' | 'f' .

124

letter = 'a' | 'b' | 'c' | 'd' | 'e' | 'f' | 'g' | 'h' | 'i' | 'j' | 'k' | 'l' |

'm' | 'n' | 'o' | 'p' | 'q' | 'r' | 's' | 't' | 'u' | 'v' | 'w' | 'x' |


'y' | 'z' .

125

lparen_not_star = '(' not_star .

126

not_lparen_star = not_paren_star | ')' .

127

not_paren_star = letter | digit | not_paren_star_special .

128

not_paren_star_quote_special = '!' | '"' | '#' | '$' | '%' | '&' | '+' | ',' |

'-' | '.' | '/' | ':' | ';' | '<' | '=' | '>' |

'?' | '@' | '[' | '\' | ']' | '^' | '_' | '''|

'{' | '|' | '}' | '~' .

129

not_paren_star_special = not_paren_star_quote_special | '”' .

130

not_quote = not_paren_star_quote_special | letter | digit | '(' | ')' | '*' .

131

not_rparen = not_paren_star | '*' | '(' .

132

not_star = not_paren_star | '(' | ')' .

133

octet = hex_digit hex_digit .

134

special = not_paren_star_quote_special | '(' I ')' I '*' I '"' .

135

star_not_rparen = '*' not_rparen .

A.2 Лексические элементы

Следующие правила устанавливают, как определенные комбинации символов интерпретируются в качестве лексических элементов языка.

25i

BinaryValue = binary_literal .

26i

Description = { \a | \s | \n } .

27i

EncodedStringValue = '”' { encoded_character | \n } '”' .

28i

EnumerationValue = '!' simple_id .

29i

IntegerValue = [ sign ] integer_literal .


30i

Nil = '?' .

31i

SignedMathConstant = [ sign ] MathConstant .

32i

SignedRealLiteral = [ sign ] real_literal .

33i

SimpleStringValue = \q { ( \q \q ) | not_quote | \s | \o | \n } \q .

Примечание - Следующие EXPRESS-правила 136-141 используются в EXPRESS-I.

136

binary_literal = '%' bit { bit } .

137

encoded_string_literal = '”' encoded_character { encoded_character } '”' .

138

integer_literal = digits .

139

real_literal = digits '.' [ digits ] [ 'e' [ sign ] digits ] .

140

simple_id = letter { letter | digit | '_' } .

141

simple_string_literal = \q { ( \q \q ) | not_quote | \s | \x8 | \x9 | \xA

| \xB | \xC | \xD } \q .

A.2.1 Примечания

Следующие правила устанавливают синтаксис примечаний в EXPRESS-I.

Примечание - Следующие EXPRESS-правила 142-144 используются в EXPRESS-I.

142

embedded_remark = '(*' { not_lparen_star | lparen_not_star |

star_not_lparen | embedded_remark } '*)' .

143

remark = embedded_remark | tail_remark .

144

tail_remark = '--' { \a | \s | \x8 | \x9 | \xA | \xB | \xC | \xD } \n .

A.3 Интерпретируемые идентификаторы

Следующие правила определяют идентификаторы, наделенные некоторым специальным смыслом (например, объявленные где-либо как типы, функции и т. д.).

Примечание - Предполагается, что идентификаторы, соответствующие этим синтаксическим правилам, известны реализации. Каким образом реализация получает эту информацию, не является предметом определения языка. Одним из методов получения этой информации являются многопроходный анализ: первый проход собирает идентификаторы из их объявлений, так что последующие проходы позволяют отличать, например, variable_ref от function_ref.

34i

CompIexEntitylnstanceRef = '@' SimpleEntitylnstanceld .

35i

ConstantRef = Constantld .

36i

ContextRef = Contextld .

37i

EntityInstanceRef = CompIexEntitylnstanceRef | SimpleEntityInstanceRef .

38i

EnumerationlnstanceRef = '@' EnumerationInstanceld .

39i

ParameterRef = Parameterld .

40i

SelectlnstanceRef = '@' Selectlnstanceld .

41i

SimplelnstanceRef = '@' Simplelnstanceld .

42i

SimpleEntitylnstanceRef = '@' SimpleEntitylnstanceld .

43i

SupSubRef = '@' SupSubld .

44i

TypelnstanceRef = '@' Typelnstanceld .

Примечание - Следующие EXPRESS-правила 145-155 используются в EXPRESS-I.

145

attribute_ref = attribute_id .

146

constant_ref = constant_id .

147

entity_ref = entity_id .

148

enumeration_ref = enumeration_id .

149

function_ref = function_id .

150

parameter_ref = parameter_id .

151

procedure_ref = procedure_id .

152

schema_ref = schema_id .

153

type_label_ref = type_label_id .

154

type_ref = type_id .

155

variable_ref = variable_id .

A.4 Грамматические правила

Следующие правила устанавливают, как описанные выше лексические элементы можно комбинировать в конструкции EXPRESS-I. Пробелы и (или) примечания могут появляться между любыми двумя лексемами этих правил. Первичным синтаксическим правилом для EXPRESS-I служит ExpressISyntax.

45i

AcualParameter = ParametrRef ':=' ParmValue ';' .

46i

AggregationValue = DynamicAggr | FixedAggr .

47i

Assignment = variable_id ':=' SelectablelnstanceRef ';' .

48i

BaseValue = EnumerationValue | SimpIeValue .

49i

BequeathesTo = SUPOF DynamicSupSubRefList ';' .

50i

BooleanValue = TRUE | FALSE .

51i

ComplexEntitylnstanceld = SimpIeEntitylnstanceld '[' SupSubld ']' .

52i

ConstantBlock = CONSTANT { ConstantSpec } END_CONSTANT ';' .

53i

Constantld = constant_ref .

54i

ConstantSpec = Constantld '= =' ConstantValue ';' .

55i

ConstantValue = AggregationValue | BaseValue | EntitylnstanceValue |

NamedlnstanceValue | SelectValue | TypeValue .

56i

ContextBlock = CONTEXT Contextld ';' ContextBody END_CONTEXT ';' .

57i

ContextBody = { SchemaReferenceSpec } [ FormalParameterBlock ]

{ SchemalnstanceBlock | SupportAlgorithm } .

58i

Contextld = simple_id .

59i

DerattValue = AggregationValue | BaseValue | EntitylnstanceRef |

EntitylnstanceValue | EnumerationlnstanceValue |

TypelnstanceRef | TypeInstanceValue | TypeValue .

60i

DerivedAttr = RoleName [ '' DerattValue ] ';' .

61i

DynamicAggr = '(' [ DynamicList ] ')' .

62i

DynamicEntityRefList = '(' [ EntityRefList ] ')' .

63i

DynamicList = DynamicMember { ',' DynamicMember } .

64i

DynamicMember = AggregationValue | ConstantValue | DerattValue |

ParmValue | ReqattValue | TypeValue .

65i

DynamicSupSubList = '(' [ SupSubRef { ',' SupSubRef }]')'.

66i

EntityDomain = [ Schemald '.' ] Entityld .

67i

Entityld = entity_ref .

68i

Entitylnstance = Entitylnstanceld '=' EntitylnstanceValue ';' .

69i

Entitylnstanceld = ComplexEntitylnstanceld | SimpIeEntitylnstanceld .

70i

EntitylnstanceValue = EntityDomain '{'

[ InheritsFrom ]

{ ExplicitAttr }

{ DerivedAttr }

{ InverseAttr }

[ BequeathesTo ] '}' .

71i

EntityRefList = EntitylnstanceRef { ',' EntitylnstanceRef } .

72i

EnumerationDomain = [ Schemald '.' ] Enumerationld .

73i

Enumerationld = type_ref .

74i

EnumerationInstance = Enumerationlnstanceld '='

EnumerationlnstanceValue ';' .

75i

Enumerationlnstanceld = simple_id .

76i

EnumerationlnstanceValue = EnumerationDomain

'{' EnumerationValue '}' .

77i

ExplicitAttr = RequiredAttr | OptionalAttr .

78i

ExpressISyntax = { TestCaseBIock } { ContextBlock } { ModelBIock }

{ SchemalnstanceBlock } { Objectlnstance } .

79i

FixedAggr = '[' FixedList ']' .

80i

FixedList = FixedMember { ',' FixedMember } .

81i

FixedMember = DynamicMember | Nil .

82i

FormalParameter = Parameterld ':' parameter_type

[ ':=' ParmValueDefault ] ';' .

83i

FormalParameterBlock = PARAMETERi { FormalParameter }

END_PARAMETER ';' .

84i

ImportSpec = IMPORT '(' { Assignment } ')' ';' .

85i

InheritsFrom = SUBOF DynamicSupSubRefList ';' .

86i

InvattValue = DynamicEntityRefList .

87i

InverseAttr = RoleName [ '' InvattValue ] ';' .

88i

LogicalValue = logica_literal .

89i

MathConstant = CONST_E | PI .

90i

ModelBlock = MODEL Modelld ';' ModelBody END_MODEL ';' .

91i

ModelBody = { SchemalnstanceBlock } .

92i

Modelld = simple_id .

93i

NamedlnstanceValue = EnumerationlnstanceValue | SelectlnstanceValue |

TypelnstanceValue .

94i

NumberValue = IntegerValue | RealValue .

95i

Objectlnstance = Entitylnstance | Enumerationlnstance | Selectlnstance |

Typelnstance | Simplelnstance .

96i

ObjectlnstanceRef = EntitylnstanceRef | EnumerationlnstanceRef |

SelectlnstanceRef | TypelnstanceRef |

SimplelnstanceRef .

97i

ObjectiveBlock = OBJECTIVE { TestPurpose } { TestReference }

{ TestCriteria } { TestNotes } END_OBJECTIVE ';'.

98i

OptattValue = ReqattValue | Nil .

99i

OptionalAttr = RoleName '->' OptattValue ';' .

100i

Parameterld = simple_id .

101i

ParameterSpec = WITH `(` { ActualParameter } ')' ';' .

102i

ParmValue = ObjectlnstanceRef | expression .

103i

ParmValueDefault = AggregationValue | BaseValue | ConstantRef |

Entitylnstance Value | NamedlnstanceValue |

ObjectlnstanceRef | SelectValue | TypeValue |

expression .

104i

RealValue = SignedMathConstant | SignedRealLiteral .

105i

ReqattValue = AggregationValue | BaseValue | ConstantRef |

NamedlnstanceValue | ObjectlnstanceRef | ParameterRef |

SelectValue | TypeValue | .

106i

RequiredAttr = RoleName '->' ( ReqattValue | Nil ) ';' /

107i

RoleName = attribute_ref .

108i

Schemald = schema_ref .

109i

SchemalnstanceBlok = SCHEMA_DATA Schemald ';'

[ SchemalnstanceBody ] END_SCHEMA_DATA ';' .

110i

SchemalnstanceBody = [ ConstantBlock ] { Objectlnstance } .

111i

SchemaReferences = SchemaReferenceSpec { SchemaReferenceSpec } .

112i

SchemaReferenceSpec = WITH schema_ref [ USING '(' resource_ref

{ ',' resource_ref } ')' ] ';' .

113i

SelectablelnstanceRef = EntitylnstanceRef | EnumerationlnstanceRef |

SelectlnstanceRef | TypelnstanceRef .

114i

SelectDomain = [ Schemald '.' ] Selectld .

115i

Selectld = type_ref .

116i

Selectlnstance = Selectlnstanceld `=` SelectlnstanceValue ';' .

117i

Selectlnstanceld = simple_id .

118i

SelectlnstanceValue = SelectDomain '{' SelectValue '}' .

119i

SelectValue = EnumerationValue | NamedlnstanceValue |

ObjectlnstanceRef | TypeValue .

120i

SimpleEntitylnstanceld = simple_id .

121i

Simplelnstance = Simplelnstanceld '=' SimpleValue ';' .

122i

Simplelnstanceld = simple_id .

123i

SimpleValue = BinaryValue | BooleanValue | LogicalValue |

NumberValue | StringValue .

124i

StringValue = Simple StringValue | EncodedStringValue .

125i

SupSubld = digits .

126i

SupportAlgorithm = function_decl | procedure_decl .

127i

TestCaseBlock = TEST_CASE TestCaseld ';'

TestCaseBody END_TEST_CASE ';' .

128i

TestCaseBody = SchemaReferences ObjectiveBlock TestRealization

{ SupportAlgorithm } .

129i

TestCaseld = simple_id .

130i

TestRealization = REALIZATION { local_decl }

{ UseContextBIock } { assignment_stmt } END_REALIZATION ';' .

131i

TestCriteria = CRITERIA Description END_CRITERIA ';' .

132i

TestNotes = NOTES Description END_NOTES ';' .

133i

TestPurpose = PURPOSE Description END_PURPOSE ';' .

134i

TestReference = REFERENCE Description END_REFERENCE ';' .

135i

TypeDomain = [ Schemald '.' ] Typeld .

136i

Typeld = type_ref .

137i

Typelnstance = Typelnstanceld '=' TypelnstanceValue ';' .

138i

Typelnstanceld = simple_id .

139i

TypelnstanceValue = TypeDomain '{' TypeValue '}' .

140i

TypeValue = AggregationValue | BaseValue | ConstantRef |

EntitylnstanceValue | NamedlnstanceValue |

ObjectInstanceRef | ParameterRef .

141i

UseContextBIock = CALL ContextRef ';'

UseContextBody END_CALL ';' .

142i

UseContextBody = [ ImportSpec ] [ ParameterSpec ] .

Примечание - Следующие грамматические правила EXPRESS 156-318, за исключением правил 228, 246, 267, 270, 274, 277-281, 302 и 313, используются в EXPRESS-I.

156

abstract_supertype_declaration = ABSTRACT SUPERTYPE [ subtype_constraint ] .

157

actual_parameter_list = '(' parameter { ',' parameter } ')' .

158

add_like_op = '+' | '-' | OR | XOR .

159

aggregate_initializer = '[' [ element { ',' element } ] ']'.

160

aggregate_source = simple_expression .

161

aggregate_type = AGGREGATE [ ':' type_label ] OF parameter_type .

162

aggregation_types = array_type | bag_type | Iist_type | set_type .

163

algorithm_head = { declaration } [ constant_decl ] [ Iocal_decl ] .

164

alias_stmt = ALIAS variable_id FOR general_ref { qualifier } ';' stmt { stmt }

END_ALIAS ';' .

165

array_type = ARRAY bound_spec OF [ OPTIONAL ] [ UNIQUE ] base_type .

166

assignment_stmt = general_ref { qualifier } ':=' expression ';' .

167

attribute_decl = attribute_id | qualified_attribute .

168

attribute_id = simple_id .

169

attribute_qualifier = '.' attribute_ref .

170

bag_type - BAG [ bound_spec ] OF base_type .

171

base_type = aggregation_types | simple_types | named_types .

172

binary_type = BINARY [ width_spec ] .

173

boolean_type = BOOLEAN .

174

bound_1 = numeric_expression .

175

bound_2 = numeric_expression .

176

bound_spec = `[` bound_1 ':' bound_2 ']' .

177

built_in_constant = CONST_E | PI | SELF | '?' .

178

built_in_function = ABS | ACOS | ASIN | ATAN | BLENGTH | COS | EXISTS |

EXP | FORMAT | HIBOUND | HIINDEX | LENGTH |

LOBOUND | LOINDEX | LOG | LOG2 | LOG10 | NVL |

ODD | ROLESOF | SIN | SIZEOF | SQRT | TAN | TYPEOF |

USEDIN | VALUE | VALUE_IN | VALUE_UNIQUE .

179

built_in_procedure = INSERT | REMOVE .

180

case_action = case_label { ',' case_label } ':' stmt .

181

case_label = expression .

182

case_stmt = CASE selector OF { case_action } [ OTHERWISE ':' stmt ]

END_CASE ';' .

183

compound_stmt = BEGIN stmt { stmt } END ';' .

184

constant_body = constant_id ':' base_type ':=' expression ';' .

185

constant_decl = CONSTANT constant_body { constant_body }

END_CONSTANT ';' .

186

constant_factor = built_in_constant | constant_ref .

187

constant_id = simple_id .

188

constructed_types = enumeration_type | select_type .

189

declaration = entity_decl | function_decl | procedure_decl | type_decl .

190

derived_attr = attribute_decl ':' base_type ':=' expression ';'.

191

derive_clause = DERIVE derived_attr { derived_attr} .

192

domain_rule = [ label ':' ] logical_expression .

193

element = expression [ ':' repetition ] .

194

entity_body = { explicit_attr } [ derive_clause ] [ inverse_clause ]

[ unique_clause ] [ where_clause ] .

195

entity_constructor = entity_ref '(' [ expression { ',' expression } ] ')'.

196

entity_decl = entity_head entity_body END_ENTITY ';' .

197

entity_head = ENTITY entity_id [ subsuper ] ';' .

198

entity_id = simple_id .

199

enumeration_id = simple_id .

200

enumeration_reference = [ type_ref '.' ] enumeration_ref .

201

enumeration_type = ENUMERATION OF '(' enumeration_id { ',' enumeration_id } ')' .

202

escape_stmt = ESCAPE ';'.

203

explicit_attr = attribute_decl { ',' attribute_decl } ':' [ OPTIONAL ]

base_type ';'.

204

expression = simple_expression [ rel_op_extended simple_expression ] .

205

factor = simple_factor [ '**' simple_factor ] .

206

formal_parameter = parameter_ id { ',' parameter_id } ':' parameter type .

207

function_call = ( built_in_function | function_ref ) [ actual_parameter_list ] .

208

function_decl = function_head [ algorithm_head ] stmt { stmt }

END_FUNCTION ';' .

209

function_head = FUNCTION function_id [ '(' formal_parameter

{ ';' formal_parameter } ')' ] ':' parameter_type ';' .

210

function_id = simple_id .

211

generalized_types = aggregate_type | general_aggregation_types| generic_type .

212

general_aggregation_types = general_array_type | general_bag_type |

general_list_type | general_set_type .

213

general_array_type = ARRAY [ bound_spec ] OF [ OPTIONAL ] [ UNIQUE ]

parameter_type .

214

generaJ_bag_type = BAG [ bound_spec ] OF parameter_type .

215

general_Iist_type = LIST [ bound_spec ] OF [ UNIQUE ] parameter_type .

216

general_ref = parameter_ref | variable_ref .

217

general_set_type = SET [ bound_spec ] OF parameter_type .

218

generic_type = GENERIC [ ':' type_label ] .

219

group_qualifier = '\' entity_ref .

220

if_stmt = IF logical_expression THEN stmt { stmt } [ ELSE stmt { stmt } ]

END_IF ';' .

221

increment = numeric_expression .

222

increment_control = variable_id ':=' bound_1 TO bound_2 [ BY increment ] .

223

index = numeric_expression .

224

index_1 = index .

225

index_2 = index .

226

index_qualifier = '[' index_1 [ ':' index_2 ] ']' .

227

integer_type = INTEGER .

<

228 interface_specification = reference_clause | use_clause . >

229

interval = '{' interval_low interval_op interval_item interval_op

interval_high '}' .

230

interval_high = simple_expression .

231

interval_item = simple_expression .

232

interval_low = simple_expression .

233

interval_op = '<' | '<=' .

234

inverse_attr = attribute_decl ':' [ ( SET | BAG ) [ bound_spec] OF ] entity_ref

FOR attribute_ref ';' .

235

inverse_clause = INVERSE inverse_attr { inverse_attr } .

236

label = simple_id .

237

list_type = LIST [ bound_spec ] OF [ UNIQUE ] base_type .

238

literal = binary_literal | integer_literal | logical_literal | real_literal |

string_literal .

239

local_decl = LOCAL local_variable { local_variable } END_LOCAL ';' .

240

local_variable = variable_id { ',' variable_id } ':' parameter_type

[ ':=' expression ] ';' .

241

logicai_expression = expression .

242

logical_literal = FALSE | TRUE | UNKNOWN .

243

logical_type = LOGICAL .

244

multiplication_like_op = '*' ] '/' | DIV | MOD | AND | '||' .

245

named_types =entity_ref | type_ref .

<

246 named_type_or_rename = named_types [ AS ( entity_id | type_id ) ] . >

247

null_stmt = ';' .

248

number_type = NUMBER .

249

numeric_expression = simple_expression .

250

one_of = ONEOF '(' supertype_expression { ',' supertype_expression } ')' .

251

parameter = expression .

252

parameter_id = simple_id .

253

parameter_type = generalized_types | named_types | simple_types .

254

population = entity_ref .

255

precision_spec = numeric_expression .

256

primary = literal | ( qualifiable_factor { qualifier } ) .

257

procedure_call_stmt = ( built_in_procedure | procedure_ref )

[ actual_parameter_list ] ';' .

258

procedure_decl = procedure_head [ algorithm_head ] { stmt} END_PROCEDURE ';' .

259

procedure_head = PROCEDURE procedure_id [ '(' [ VAR ] formal_parameter

{ ';' [ VAR ] formal_parameter } ')' ] ';' .

260

procedure_id = simple_id .

261

qualifiable_factor = attribute_ref | constant_factor | function_call |

general_ref | population .

262

qualified_attribute = SELF group_qualifier attribute_qualifier .

263

qualifier = attribute_qualifier | group_qualifier | index_qualifier .

264

query_expression = QUERY `(` variable_id '<*' aggregate_source '|'

logical_expression')'.

265

real_type = REAL [ '(' precision_spec ')' ] .

266

referenced_attribute = attribute_ref | qualified_attribute .

<

267 reference_clause = REFERENCE FROM schema_ref [ '(' resource_or_rename

{ ',' resource_or_rename } ')' ] ';' . >

268

rel_op = '<' | '>' | '<=' | '>=' | '<>' | '=' | ':<>:' | ':=:' .

269

rel_op_extended = rel_op | IN | LIKE .

<

270 rename_id = constant_id | entity_id | function_id | procedure_id | type_id . >

271

repeat_control = [ increment_control ] [ while_control ] [ until_control ] .

272

repeat_stmt = REPEAT repeat_control ';' stmt { stmt } END_REPEAT ';' .

273

repetition = numeric_expression .

<

274 resource_or_rename = resource_ref [ AS rename_id ] . >

275

resource_ref = constant_ref | entity_ref | function_ref | procedure_ref | type_ref.

276

return_stmt = RETURN [ '(' expression ')' ] ';' .

<

277 rule_decl = rule_head [ algorithm_head ] { stmt } where_clause

END_RULE ';'. >

<

278 rule_head = RULE rule_id FOR `(` entity_ref { ',' entity_ref } ')' ';' . >

<

279 rule_id = simple_id . >

<

280 schema_body = { interface_specification } [ constant_decl ]

{ declaration | rule_decl } . >

<

281 schema_decl = SCHEMA schema_id ';' schema_body END_SCHEMA ';' . >

282

schema_id = simple_id .

283

selector = expression .

284

select_type = SELECT '(' named_types { ',' named_types } ')' .

285

set_type = SET [ bound_spec ] OF base_type .

286

sign = '+' | '-' .

287

simple_expression = term { add_like_op term} .

288

simple_factor = aggregate_jnitializer | entity_constructor |

enumeration_reference | interval | query_expression |

( [ unary_op ] ( '(' expression ')' | primary ) ) .

289

simple_types = binary_type | boolean_type | integer_type | logical_type |

number_type | real_type | string_type .

290

skip_stmt = SKIP ';' .

291

stmt = alias_stmt | assignment_stmt | case_stmt | compound_stmt | escape_stmt |

if_stmt | null_stmt | procedure_call_stmt | repeat_stmt | return_stmt |

skip_stmt .

292

string_literal = simple_string_literal | encoded_string_literal .

293

string_type = STRING [ width_spec ] .

294

subsuper = [ supertype_constraint ] [ subtype_declaration ] .

295

subtype_constraint = OF '(' supertype_expression ')' .

296

subtype_declaration = SUBTYPE OF '(' entity_ref { ',' entity_ref } ')' .

297

supertype_constraint = abstract_supertype_declaration | supertype_rule .

298

supertype_expression = supertype_factor { ANDOR supertype_factor } .

299

supertype_factor = supertype_term { AND supertype_term } .

300

supertype_rule = SUPERTYPE subtype_constraint .

301

supertype_term = entity_ref | one_of | '(' supertype_expression ')'.

<

302 syntax = schema_decl { schema_decl } . >

303

term = factor { multiplication_like_op factor } .

304

type_decl = TYPE type_id '=' underlying_type ';' [ where_clause ] END_TYPE ';' .

305

type_id = simple_id .

306

type_label = type_label_id | type_label_ref .

307

type_label_id = simple_id .

308

unary_op = '+' | '-' | NOT .

309

underlying_type = constructed_types | aggregation_types | simple_types |

type_ref .

310

unique_clause = UNIQUE unique_rule ';' { unique_rule ';' } .

311

unique_rule = [ label ':' ] referenced_attribute { ',' referenced_attribute } .

312

until_control = UNTIL logical_expression .

<

313 use_clause = USE FROM schema_ref [ '(' named_type_or_rename
{ ',' named_type_or_rename } ')' ] ';' . >

314

variable_id = simple_id .

315

where_clause = WHERE domain._rule ';' { domain_rule ';' } .

316

while_control = WHILE logical_expression .

317

width = numeric_expression .

318

width_spec = '(' width ')' [ FIXED ] .

A.5 Список перекрестных ссылок

Конструкция, указанная слева, используется в конструкциях, указанных справа.

0i

CALL

| 141i

1i

CRITERIA

| 131i

2i

END_CALL

| 141i

3i

END_CRITERIA

| 131i

4i

END_NOTES

| 132i

5i

END_OBJECTIVE

| 97i

6i

END_PARAMETER

| 83i

7i

END_PURPOSE

| 133i

8i

END_REALIZATION

| 130i

9i

END_REFERENCES

| 134i

10i

END_SCHEMA_DATA

| 109i

11i

END_TEST_CASE

| 127i

12i

IMPORT

| 84i

13i

NOTES

| 132i

14i

OBJECTIVE

| 97i

15i

PARAMETERi

| 83i

16i

PURPOSE

| 133i

17i

REALIZATION

| 130i

18i

REFERENCES

| 134i

19i

SCHEMA_DATA

| 109i

20i

SUBOF

| 85i

21i

SUPOF

| 51i

22i

TEST_CASE

| 127i

23i

USING

| 112i

24i

WITH

| 101i 112i

25i

BinaryValue

| 123i

26i

Description

| 131i 132i 133i 134i

27i

EncodedStringValue

| 124i

28i

EnumerationValue

| 48i 76i 119i

29i

IntegerValue

| 94i

30i

Nil

| 52i 81i 98i 106i

31i

SignedMathConstant

| 104i

32i

SignedRealLiteral

| 104i

33i

SimplStringValue

| 124i

34i

ComplexEntitylnstanceRef

| 37i

35i

ConstantRef

| 103i 105i 140i

36i

ContextRef

| 141i

37i

EntitylnstanceRef

| 59i 71i 96i 113i

38i

EnumerationlnstanceRef

| 96i 113i

39i

ParameterRef

| 45i 105i 140i

40i

SelectlnstanceRef

| 96i 113i

41i

SimpleInstanceRef

| 96i

42i

SimpleEntitylnstanceRef

| 37i

43i

SupSubRef

| 65i

44i

TypelnstanceRef

| 59i 96i 113i

45i

ActualParameter

| 101i

46i

AggregationValue

| 55i 59i 64i 103i 105i 140i

47i

Assignment

| 84i

48i

BaseValue

| 55i 59i 103i 105i 140i

49i

BequeathesTo

| 65i

50i

BooleanValue

| 123i

51i

CompIexEntitylnstanceld

| 69i

52i

ConstantBlock

| 110i

53i

Constantld

| 35i 54i

54i

ConstantSpec

| 52i

55i

ConstantValue

| 54i 64i

56i

ContextBlock

| 78i

57i

ContextBody

| 56i

58i

Contextld

| 36i 56i

59i

DerattValue

| 60i 64i

60i

DerivedAttr

| 70i

61i

DynamicAggr

| 46i

62i

DynamicEntityRefList

| 87i

63i

DynamicList

| 61i

64i

DynamicMember

| 63i 81i

65i

DynamicSupSubRefList

| 49i 85i

66i

EntityDomain

| 70i 93i

67i

Entityld

| 66i

68i

Entitylnstance

| 95i

69i

Entitylnstanceld

| 68i

70i

EntityInstanceValue

| 55i 59i 68i 103i 140i

71i

EntityRefList

| 62i

72i

EnumerationDomain

| 76i 93i

73i

Enumerationld

| 72i

74i

Enumerationlnstance

| 95i

75i

Enumerationlnstanceld

| 38i 74i

76i

EnumerationlnstanceValue

| 59i 74i 93i

77i

ExplicitAttr

| 70i

78i

ExpressSyntax

|

79i

FixedAggr

| 46i

80i

FixedList

| 79i

81i

FixedMember

| 80i

82i

FormalParameter

| 83i

83i

FormalParameterBlock

| 57i

84i

ImportSpec

| 142i

85i

InheritsFrom

| 70i

86i

InvattValue

| 87i

87i

InverseAttr

| 70i

88i

LogicalValue

| 52i 123i

89i

MathConstant

| 52i

90i

ModelBlock

| 78i

91i

ModelBody

| 90i

92i

Modelld

| 39i 90i

93i

NamedlnstanceValue

| 55i 103i 105i 119i 140i

94i

NumberValue

| 123i

95i

Objectlnstance

| 78i 110i

96i

ObjectlnstanceRef

| 102i 103i 105i 119i 140i

97i

ObjectiveBlock

| 128i

98i

OptattValue

| 99i

99i

OptionalAttr

| 77i

100i

Parameterld

| 39i 82i

101i

ParameterSpec

| 142i

102i

ParmValue

| 45i 64i

103i

ParmValueDefault

| 82i

104i

RealValue

| 94i

105i

RequttValue

| 64i 98i 106i

106i

RequiredAttr

| 77i

107i

RoIeName

| 60i 87i 99i 106i

108i

Schemald

| 66i 72i 109i 114i 135i

109i

SchemalnstanceBlock

| 57i 78i 91i

110i

SchemalnstanceBody

| 109i

111i

SchemaReferences

| 128i

112i

SchemaReferenceSpec

| 57i 111i

113i

SelectablelnstanceRef

| 47i

114i

SelectDomain

| 93i 118i

115i

Selectld

| 114i

116i

SelectInstance

| 95i

117i

Selectlnstanceld

| 40i 116i

118i

SelectlnstanceValue

| 93i 116i

119i

SelectValue

| 55i 103i 105i 118i

120i

SimpleEntitylnstanceld

| 34i 42i 51i 69i

121i

Simplelnstance

| 95i

122i

Simplelnstanceld

| 41i 121i

123i

SimpleValue

| 48i 121i

124i

StringValue

| 123i

125i

SupSubld

| 43i 51i

126i

SupportAlgorithm

| 57i 128i

127i

TestCaseBlock

| 78i

128i

TestCaseBody

| 127i

129i

TestCaseld

| 127i

130i

TestRealization

| 128i

131i

TestCriteria

| 97i

132i

TestNotes

| 97i

133i

TestPurpose

| 97i

134i

TestReference

| 97i

135i

TypeDomain

| 92i 139i

136i

Typeld

| 135i

137i

Typelnstance

| 95i

138i

Typelnstanceld

| 44i 137i

139i

TypelnstanceValue

| 59i 93i 137i

140i

TypeValue

| 55i 59i 64i 103i 105i 119i 139i

141i

UseContextBIock

| 130i

142i

UseContextBody

| 141i

0

ABS

| 178

1

ABSTRACT

| 156

2

ACOS

| 178

3

AGGREGATE

| 161

4

ALIAS

| 164

5

AND

| 244 299

6

ANDOR

| 298

7

ARRAY

| 165 213

8


9

ASIN

| 178

10

ATAN

| 178

11

BAG

| 170 214 234

12

BEGIN

| 183

13

BINARY

| 172

14

BLENGTH

| 178

15

BOOLEAN

| 173

16

BY

| 222

17

CASE

| 182

18

CONSTANT

| 185 52i

19

CONST_E

| 177 89i

20

CONTEXT

| 56i

21

COS

| 178

22

DERIVE

| 191

23

DIV

| 244

24

ELSE

| 220

25

END

| 183

26

END_ALIAS

| 164

27

END_CASE

| 182

28

END_CONSTANT

| 185 52i

29

END_CONTEXT

| 56i

30

END_ENTITY

| 196

31

END_FUNCTION

| 208

32

END_IF

| 220

33

END_LOCAL

| 239

34

END_MODEL

| 90i

35

END_PROCEDURE

| 258

36

END_REPEAT

| 272

37

38

39

END_TYPE

| 304

40

ENTITY

| 197

41

ENUMERATION

| 201

42

ESCAPE

| 202

43

EXISTS

| 178

44

EXP

| 178

45

FALSE

| 242 50i

46

FIXED

| 318

47

FOR

| 164 234 278

48

FORMAT

| 178

49

50

FUNCTION

| 209

51

GENERIC

| 218

52

HIBOUND

| 178

53

HIINDEX

| 178

54

IF

| 220

55

IN

| 269

56

INSERT

| 179

57

INTEGER

| 227 86i

58

INVERSE

| 235

59

LENGTH

| 178

60

LIKE

| 269

61

LIST

| 215 237

62

LOBOUND

| 178

63

LOCAL

| 239

64

LOG

| 178

65

LOG10

| 178

66

LOG2

| 178

67

LOGICAL

| 243

68

LOINDEX

| 178

69

MOD

| 244

70

MODEL

| 90i

71

NOT

| 308

72

NUMBER

| 248

73

NVL

| 178

74

OOD

| 178

75

OF

| 161 165 170 182 201 213 214 215 217 234 237 285 295 296

76

ONEOF

| 250

77

OPTIONAL

| 165 203 213

78

OR

| 158

79

OTHERWISE

| 182

80

PI

| 177 89i

81

PROCEDURE

| 259

82

QUERY

| 264

83

REAL

| 265

84

85

REMOVE

| 179

86

REPEAT

| 272

87

RETURN

| 276

88

ROLESOF

| 178

89

90

91

SELECT

| 284

92

SELF

| 177 262

93

SET

| 217 234 285

94

SIN

| 178

95

SIZEOF

| 178

96

SKIP

| 290

97

SQRT

| 178

98

STRING

| 293

99

SUBTYPE

| 296

100

SUPERTYPE

| 156 300

101

TAN

| 178

102

THEN

| 220

103

TO

| 222

104

TRUE

| 242 50i

105

TYPE

| 304

106

TYPEOF

| 178

107

UNIQUE

| 165 213 215 237 310

108

UNKNOWN

| 242

109

UNTIL

| 312

110


111

USEDIN

| 178

112

VALUE

| 178

113

VALUE_IN

| 178

114

VALUE_UNIQUE

| 178

115

VAR

| 259

116

WHERE

| 315

117

WHILE

| 316

118

XOR

| 158

119

bit

| 136

120

digit

| 121 123 127 130 140

121

digits

| 138 139 125i

122

encoded_character

| 137 27i

123

hex_digit

| 133

124

letter

| 127 130 140

125

lparen_not_star

| 142

126

not_lparen_star

| 142

127

not_paren_star

| 126 131 132

128

not_paren_star_quote_special

| 129 130 134

129

not_paren_star_special

| 127

130

not_quote

| 141 33i

131

not_rparen

| 135

132

not_star

| 125

133

octet

| 122

134

special

|

135

star_not_rparen

| 142

136

binary_literal

| 238 25i

137

encoded_string_literal

| 292

138

initeger_literal

| 238

139

real_literal

| 238

140

simple_id

| 168 187 198 199 210 236 252 260 279 282 305 307 314 28i 58i 75i 92i 100i 117i 120i 122i 129i 138i

141

simple_string_literal

| 292

142

embedded_remark

| 142 143

143

remark

|

144

tail_remark

| 143

145

attribute_ref

| 169 234 261 266 107i

146

constant_ref

| 186 275 53i

147

entity_ref

| 195 219 234 245 254 275 278 296 301 67i

148

enumeration_ref

| 200

149

function_ref

| 207 275

150

parameter_ref

| 216

151

procedure_ref

| 257 275

152

schema_ref

| 108i 112i

153

type_label_ref

| 306

154

type_ref

| 200 245 275 309 73i 115i 136i

155

variable_ref

| 216

156

abstract_supertype_declaration

| 297

157

actual_parameter_list

| 207 257

158

add_like_op

| 287

159

aggregate_initializer

| 288

160

aggregate_source

| 264

161

aggregate_type

| 211

162

aggregation_types

| 171 309

163

algorithm_head

| 208 258

164

alias_stmt

| 291

165

array_type

| 162

166

assignment_stmt

| 291 130i

167

attribute_decl

| 190 203 234

168

attribute_id

| 145 167

169

attribute_qualifier

| 262 263

170

bag_type

| 162

171

base_type

| 165 170 184 190 203 237 285

172

binary_type

| 289

173

boolean_type

| 289

174

bound_1

| 176 222

175

bound_2

| 176 222

176

bound_spec

| 165 170 213 214 215 217 234 237 285

177

built_in_constant

| 186

178

built_in_function

| 207

179

built_in_procedure

| 257

180

case_action

| 182

181

case_label

| 180

182

case_stmt

| 291

183

compound_stmt

| 291

184

constant_body

| 185

185

constant_decl

| 163

186

constant_factor

| 261

187

constant_id

| 146 184

188

constructed_types

| 309

189

declaration

| 163

190

derived_attr

| 191

191

derive_clause

| 194

192

domain_rule

| 315

193

element

| 159

194

entity_body

| 196

195

entity_constructor

| 288

196

entity_decl

| 189

197

entity_head

| 196

198

entity_id

| 147 197

199

enumeration_id

| 148 201

200

enumeration_reference

| 288

201

enumeration_type

| 188

202

escape_stmt

| 291

203

explicit_attr

| 194

204

expression

| 166 181 184 190 193 195 240 241 251 276 283 288 102i 103i

205

factor

| 303

206

formal_parameter

| 209 259

207

function_call

| 261

208

function_decl

| 189 126i

209

function_head

| 208

210

function_id

| 149 209

211

generalized_types

| 253

212

general_aggregation_types

| 211

213

general_array_type

| 212

214

general_bag_type

| 212

215

general_list_type

| 212

216

general_ref

| 164 166 261

217

general_set_type

| 212

218

generic_type

| 211

219

group_qualifier

| 262 263

220

if_stmt

| 291

221

increment

| 222

222

increment_control

| 271

223

index

| 224 225

224

index_1

| 226

225

index_2

| 226

226

index_qualifier

| 263

227

integer_type

| 289

228


229

interval

| 288

230

interval_high

| 229

231

interval_item

| 229

232

interval_low

| 229

233

interval_op

| 229

234

inverse_attr

| 235

235

inverse_clause

| 194

236

label

| 192 311

237

list_type

| 162

238

literal

| 256

239

local_decl

| 163 130i

240

local_variable

| 239

241

logical_expression

| 192 220 264 312 316

242

logical_literal

| 238 88i

243

logical_type

| 289

244

multiplication_like_op

| 303

245

named_types

| 171 253 284

246


247

null_stmt

| 291

248

number_type

| 289

249

numeric_expression

| 174 175 221 223 255 273 317

250

one_of

| 301

251

parameter

| 157

252

parameter_id

| 150 206

253

parameter_type

| 161 206 209 213 214 215 217 240 82i

254

population

| 261

255

precision_spec

| 265

256

primary

| 288

257

procedure_call_stmt

| 291

258

procedure_decl

| 189 126i

259

procedure_head

| 258

260

procedure_id

| 151 259

261

qualifiable_factor

| 256

262

qualified_attribute

| 167 266

263

qualifier

| 164 166 256

264

query_expression

| 288

265

real_type

| 289

266

referenced_attribute

| 311

267


268

rel_op

| 269

269

rel_op_extended

| 204

270


271

repeat_control

| 272

272

repeat_stmt

| 291

273

repetition

| 193

274


275

resource_ref

| 112i

276

return_stmt

| 291

277


278


279

280


281


282

schema_id

| 152

283

selector

| 182

284

select_type

| 188

285

set_type

| 162

286

sign

| 139 29i 31i 32i

287

simple_expression

| 160 204 230 231 232 249

288

simple_factor

| 205

289

simple_types

| 171 253 309

290

skip_stmt

| 291

291

stmt

| 164 180 182 183 208 220 258 272

292

string_literal

| 238

293

string_type

| 289

294

subsuper

| 197

295

subtype_constraint

| 156 300

296

subtype_declaration

| 294

297

supertype_constraint

| 294

298

supertype_expression

| 250 295 301

299

supertype_factor

| 298

300

supertype_rule

| 297

301

supertype_term

| 299

302


303

term

| 287

304

type_decl

| 189

305

type_id

| 154 304

306

type_label

| 161 218

307

type_label_id

| 153 306

308

unary_op

| 288

309

underlying_type

| 304

310

unique_clause

| 194

311

unique_rule

| 310

312

until_control

| 271

313


314

variable_id

| 155 164 222 240 264 47i

315

where_clause

| 194 304

316

while_control

| 271

317

width

| 318

318

width_spec

| 172 293


ПРИЛОЖЕНИЕ В
(обязательное)


Заявка о соответствии реализации протоколу (ЗСРП)

Является ли данная реализация синтаксическим анализатором/верификатором языка EXPRESS? Если да, то должны быть даны ответы на вопросы, приведенные в В.1.

В.1 Синтаксический анализатор языка EXPRESS-I

Для какого из уровней заявляется поддержка:

уровень 1 - проверка ссылок;

уровень 2 - проверка типов;

уровень 3 - проверка значений;

уровень 4 - полная проверка.

(Примечание - Для того чтобы заявить о поддержке конкретного уровня, должна быть обеспечена поддержка всех нижних уровней).

Каково максимальное целочисленное значение

[integer_literal]?:

Какова максимальная точность действительных значений

[real_literal]?:

Каков максимальный показатель степени действительных

значений [real_literal]?:

Какова максимальная длина строки (в символах)

[simple_string_literal]?:

Какова максимальная длина строки (в восьмибитовых

байтах) [encoded_string_literal]?:

Какова максимальная длина двоичных значений (в битах)

[binary_literal]?:

Существует ли ограничение на общее количество

объявленных уникальных идентификаторов? Если да, то

чему оно равно?:

Существует ли ограничение на количество символов в

идентификаторе? Если да, то чему оно равно?:

Существует ли ограничение на глубину вложения областей

применения? Если да, то чему оно равно?:

Как представлена стандартная константа `?`

[built_in_constant]?:


ПРИЛОЖЕНИЕ С
(обязательное)


Регистрация информационного объекта

Для того чтобы обеспечить однозначную идентификацию информационного объекта в открытой системе, настоящему стандарту присвоен идентификатор объекта:

{ iso standard 10303 part(12) version(1) }

Смысл этого значения определен в соответствии с ИСО/МЭК 8824-1 и уточнен в ГОСТ Р ИСО 10303-1.

ПРИЛОЖЕНИЕ D
(справочное)


Синтаксис спецификации языка

Нотация, используемая для представления синтаксиса языка EXPRESS-I, установлена в ГОСТ Р ИСО 10303-11. В настоящем приложении она приведена в качестве справочного материала.

Полный синтаксис языка EXPRESS-I определен в приложении А. Фрагменты этих синтаксических правил воспроизведены в разных разделах настоящего стандарта для иллюстрации синтаксиса конкретных операторов. Эти фрагменты не всегда полны, так что иногда необходимо обращаться к приложению А для просмотра пропущенных правил. Фрагменты синтаксиса в основной части настоящего стандарта представлены в прямоугольных рамках. Каждое правило внутри синтаксической рамки имеет слева уникальный номер для использования его в перекрестных ссылках с другими синтаксическими правилами.

D.1 Синтаксис спецификации

Синтаксис EXPRESS (и EXPRESS-I) устанавливается на основе нотации, производной от Синтаксической нотации Вирта (СНВ); см. для справок [3] из приложения Н.

Нотационные обозначения и самоопределенная СНВ приведены ниже.

syntax

= { production } .

production

= identifier `=` expression `.` .

expression

= term { `|` term } .

term

= factor { factor } .

factor

= identifier | literal | group | option | repetition .

identifier

= character { character } .

literal

= ```` character { character } ```` .

group

= `(` expression `)` .

option

= `[` expression `]` .

repetition

= `{` expression `}` .

- знак равенства `=` обозначает конструкцию языка. Элемент слева определяется как комбинация элементов справа. Любое число пробелов, появляющихся между элементами конструкции, не имеет значения, пока пробелы не появятся внутри литерала. Конструкция заканчивается точкой `.`.

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

- слово "литерал" используется для обозначения терминального символа, который не может быть расширен. Литералом является независимая от регистра последовательность символов, заключенная в апострофы. Символ в данном случае представляет собой любой символ, определяемый в ИСО/МЭК 10646-1 ячейками 21-7Е в группе 00, проекции 00, строке 00. Для включения в литерал апострофа он должен быть записан дважды;

- семантики охватывающих скобок определены ниже:

- фигурные скобки `{ }` означают ноль или более повторений;

- квадратные скобки `[ ]` означают необязательные параметры;

- круглые скобки `( )` означают, что группа конструкций, заключенная в круглые скобки, должна использоваться как единая конструкция;

- вертикальная черта `|` означает, что должен быть выбран только один из термов выражения.

Примечания

1 В настоящем стандарте к описанному выше мета-языку добавлена еще одна конструкция: комментарий. Комментарием является любой текст, заключенный в угловые скобки. Например, < Комментарий > - это комментарий.

2 В частности, комментарий < как в EXPRESS > используется для обозначения того, что конструкция определена в ГОСТ Р ИСО 10303-11 и, в целях совместимости между документами, не повторяется в настоящем стандарте.

Пример 69 - Синтаксис для литерала действительного числа имеет вид:

Синтаксис:

190 real_literal = integer_literal `.` [ integer_literal ]

[ `e` [ sign ] integer_literal ] .

163 integer_literal = digit { digit } .

Полное определение синтаксиса (приложение А) содержит определения для sign и digit.

Пример 70 - В соответствии с синтаксисом, приведенным в примере 69, возможны следующие альтернативы:

a) 123.

b) 123.456

c) 123.456е7

d) 123.456E-7

D.2 Нотация специального символа

Следующая нотация используется для представления полных наборов символов и некоторых специальных символов, которые сложно отображать:

- \а представляет символы в ячейках 21-7Е строки 00, проекции 00, группы 00 из ИСО/МЭК 10646-1;

- \n представляет новую строку (в зависимости от системы);

- \q является символом апострофа (`) и содержится внутри \а;

- \s является символом пробела;

- \о представляет символы в ячейках 00-1F и 7F строки 00, проекции 00, группы 00 из ИСО/МЭК 10646-1.

ПРИЛОЖЕНИЕ Е
(справочное)


Некоторые контрольные примеры

В настоящем приложении приведены некоторые абстрактные контрольные примеры. Эти примеры не претендуют на роль обязательных абстрактных контрольных примеров, задаваемых в других стандартах серии ГОСТ Р ИСО 10303, и приведены исключительно в иллюстрационных целях.

Начнем с простой EXPRESS-схемы (SCHEMA), для которой определяется контрольный пример.

*)

SCHEMA people;

TYPE name = STRING; END_TYPE;

ENTITY person;

named : name;

children : SET [0:?] OF person;

END_ENTITY;

ENTITY male

SUBTYPE OF (person);

END_ENTITY;

ENTITY female;

SUBTYPE OF (person);

END_ENTITY;

ENTITY married;

husband: male;

wife : female;

END_ENTITY;

END_SCHEMA;

(*

E.1 Контрольный пример 1

Этот контрольный пример устанавливает, что должны быть созданы три экземпляра объекта person.

*)

TEST_CASE test_cube_1;

WITH people USING (person);

OBJECTIVE

PURPOSE To test the creating of supertypes with no subtypes. END_PURPOSE;

REFERENCES None. END_REFERENCES;

CRITERIA Three instances of children PERSON shall be created.

END_CRITERIA;

NOTES None. END_NOTES;

END_OBJECTIVE;

REALIZATION

LOCAL

- - определяем переменные типа person

p1 : person;

p2 : person;

p3 : person;

END_LOCAL;

p1 := person(`Alpha`, [ ]);

- - создаем экземпляры person

p2 := person(`Beta` [ ]);

p3 := person(`Gamma`, [ ]);

END_REALIZATION;

END_TEST_CASE;

(*

Одним из возможных фрагментов результирующих данных этого контрольного примера является:

*)

MODEL case_1;

SCHEMA_DATA people;

n1 = name {`Alpha`};

n2 = name {`Beta`};

n3 = name {`Gamma`};

p1 = person{named @n1;

children ( );}

p2 = person{named @n2;

children ( );}

p3 = person{named @n3;

children ( );}

END_SCHEMA_DATA;

END_MODEL;

(*

Для последующего использования определяется следующий контекст, основанный на контрольном примере:

*)

CONTEXT context_1;

SCHEMA_DATA people;

p1[1] = person{named `Alpha`;

children ( );

SUPOF( );};

p2[1] = person{named `Beta`;

children ( );

SUPOF( );};

p3[1] = person{named `Gamma`;

children ( );

SUPOF( );};

END_SCHEMA_DATA;

END_CONTEXT;

(*

E.2 Контрольный пример 2

Данный контрольный пример создает подтипы male и female объекта person.

*)

TEST_CASE test_case_2;

WITH people USING(male, female);

OBJECTIVE To test the creation of subtypes. END_PURPOSE;

CRITERIA One instance of childless MALE and one of a childless

FEMAIL shall be created. END_CRITERIA;

END_OBJECTIVE;

REALIZATION

LOCAL

- - определяем переменные требуемых типов

m1 : male;

f1 female;.

END_LOCAL;

m1 := person(`Adam`, [ ]) || male( );

- - создаем экземпляр male

f1 := person(`Eve`, [ ]) || female( );

- - создаем экземпляр female

END_REALIZATION;

END_TEST_CASE;

(*

Одним из возможных фрагментов результирующих данных этого контрольного примера является:

*)

MODEL case_2;

SCHEMA_DATA people;

m1[1] = person{named `Adam`;

children ( );

SUPOF(@2);};

m2[2] = male{SUBOF(@1);};

f1[1] = person{ named `Eve`;

children ( );

SUPOF( @2);};

f1[2] = female{ SUBOF(@1);};

END_SCHEMA_DATA;

END_MODEL;

(*


Для последующего использования создается также следующий параметризованный контекст.

*)

CONTEXT context_2;

WITH people USING(person);

PARAMETER

c1 : SET OF person := ( );

- - параметр по умолчанию - пустое множество

c2 : SET OF person := ( );

END_PARAMETER;

SCHEMA_DATA people;

p4[1] = person{named `Adam`;

children c1;

- - параметризуется атрибут children

SUPOF(@2);};

p4[2] = male{SUBOF(@1);};

p5[1] = person{named `Eve`;

children c2;

SUPOF(@2);};

p5[2] = female{SUBOF(@1);};

END_SCHEMA_DATA;

END_CONTEXT;

(*

E.3 Контрольный пример 3

Этот пример создает экземпляр объекта married.

(*

TEST_CASE test_case_3;

WITH people USING (married);

OBJECTIVE

PURPOSE To test the creation of an entity with attributes of type entity.

END_PURPOSE;

CRITERIA One instance of a MARRIED entity shall be created.

END_CRITERIA;

END_OBJECTFVE;

REALIZATION

LOCAL

- - определяем переменные требуемых типов

reg: married;

h1 : male;

w1: female; .

END_LOCAL;

CALL context_2

- - используем данные из CONTEXT context_2

IMPORT(h1 := @р4;

w1 := @p5;);

END_CALL;

reg := married(h1, w1);

- - создаем экземпляр married

END_REALIZATION;

END TEST CASE;

(*

Одним из возможных фрагментов результирующих данных этого контрольного примера является:

*)

MODEL case_3;

SCHEMA_DATA people;

h1[1] = person{named `Adam`;

children ( );

SUPOF(@6);};

h1[6] = male{SUBOF(@3);};

w1[7] = person{named `Eve`;

children ( );

SUPOF(@8);};

w1[8] = female{ SUBOF(@7);};

reg = married{husband @h1;

wife @w1;};

END_SCHEMA_DATA;

END_MODEL;

(*

E.4 Контрольный пример 4

Этот контрольный пример собирает множество уже существующих параметризованных данных, а также создает новые данные.

*)

TEST_CASE test_case_4;

WITH people USING(person, male, female, married);

OBJECTIVE

PURPOSE To test the creation of married couple with children. END_PURPOSE;

CRITERIA Three instances of PERSON shall be created. One instance each

of MALE and FEMALE with children shall be created. One

instance of MARRIED entity shall be created. END_CRITERIA;

END_OBJECTIVE;

REALIZATION

LOCAL

- - определяем переменные требуемых типов

p1 : person;

p2 : person;

p3 : person;

m1 : male;

f1 : female;

reg : married;

END_LOCAL;

CALL context_1

IMPORT(p1 := @p1;

- - используем данные из CONTEXT context_1

p2 := @p2;

p3 := @p3;);

END_CALL;

CALL context_2;

IMPORT(m1 := @p4;

- - используем данные из CONTEXT context_2

f1 := @p5;

WITH(c1 := [p1, р3];

- - множество значений параметра

c2 := [p2, р3];);

END_CALL;

reg := married(m1, f1);

- - создаем экземпляр married

END_REALIZATION;

END_TEST_CASE;

(*

Одним из возможных фрагментов результирующих данных этого контрольного примера является:

*)

MODEL case_4;

SCHEMA_DATA people;

n1 = name{`Alpha`};

n2 = name{`Beta`};

n3 = name{`Gamma`};

p1 = person{named @n1;

children ( );}

p2 = person{named @n2;

children ( );}

p3 = person{named @n3;

children ( );}

m1[1] = person{named `Adam`;

children (@p1, @p3);

SUPOF(@2);};

m1[2] = male{SUBOF(@1);};

f1[1] = person{named `Eve`;

children (@p2, @p3);

SUPOF(@2);};

f1[2] = female{SUBOF(@1);};

reg = married{husband @m1;

wife @f1;};

END_SCHEMA_DATA;

END_MODEL;

(*

ПРИЛОЖЕНИЕ F
(справочное)


Замечания по применению стандарта

В настоящем приложении рассматриваются некоторые потенциальные сферы применения языка ЕХPRESS-I.

В предметно-ориентированной терминологии EXPRESS-объект (entity) следовало бы назвать классом (a class), а экземпляр класса - предметом (an object), один предмет может ссылаться на другой предмет. В языке EXPRESS различают объекты (entities) и типы (types) (то есть ENUMERATION, SELECT и другие определяемые типы данных) тем, что объекты могут иметь подтипы, тогда как типы не могут иметь подтипов. Физический файл, определяемый по ГОСТ Р ИСО 10303-21, четко различает объекты и типы тем, что только экземпляры объектов могут появляться в файле, а значения типов встраиваются в значения атрибутов и на них нельзя ссылаться. В языке EXPRESS-I экземпляры объектов трактуются как предметы в предметно-ориентированном смысле. Также допускается трактовка типов как предметов в смысле наличия их экземпляров, на которые можно ссылаться; альтернативно допускается трактовка типов как физического файла, в котором содержатся значения типов.

F.1 Примеры EXPRESS-данных

Простейшим применением языка EXPRESS-I являются упражнения по написанию на бумаге примеров данных, определяющих конструкции языка EXPRESS. Язык позволяет отобразить экземпляры предметов в виде предметов, на которые допускаются ссылки. Экземпляры типов также могут отображаться как предметы, доступные для ссылок, или они могут появляться в значениях других предметов как значения недоступные для ссылок. Примеры, приведенные в настоящем стандарте, показывают обе формы наполнения типов.

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

Примеры EXPRESS-схем можно отображать так же, как и отдельные предметы.

EXPRESS-I-конструкция MODEL предназначена для отображения нескольких схем. Обычно конструкция MODEL используется, когда две или более EXPRESS-схемы взаимодействуют друг с другом. Отметим, что сам язык EXPRESS не поддерживает данную конструкцию.

F.2 Абстрактные контрольные примеры

EXPRESS-I-конструкция TEST_CASE предусмотрена для формального определения контрольных примеров, проверяющих реализацию конструкций, установленных в языке EXPRESS. В самом языке EXPRESS эквивалентная конструкция отсутствует.

Для контрольного примера должен быть определен базовый набор предметов EXPRESS-I, состоящий из подлежащих тестированию предметов и относящихся к ним данных. Значения этих предметов могут быть представлены в виде параметров, формальные определения которых заданы в обобщающем контексте (CONTEXT). Затем ряд контрольных примеров может быть определен на основе CONTEXT путем задания фактических значений параметров. Тем самым единый "параметризованный" контекст может поддерживать много различных тестов (испытаний). Так же должна быть представлена документация по контрольному примеру, охватывающая назначение теста и ожидаемые результаты (см. стандарты серии ГОСТ Р ИСО 10303 по аттестационному тестированию).

F.3 Объектные базы

Предполагается наличие некоторой объектной базы, хранящей предметы, соответствующие определяемым EXPRESS-схемам. Это значит, что объектная база имеет возможность обслуживания конкретных предметов, соответствующих EXPRESS-схемам, в которых объявлены их определения. Проектирование и реализация такой объектной базы предлагается читателю в качестве упражнения.

F.3.1 Вход

В заданной объектной базе EXPRESS-I может быть использован как средство ввода предметов в объектную базу. Этот процесс мог быть либо пакетным, когда заранее подготовленный файл EXPRESS-I читается объектным процессором, либо интерактивным, когда пользователь постепенно добавляет предметы EXPRESS-I.

В зависимости от развитости объектной базы пользователю может или не может потребоваться явное задание значений вычисляемых и инверсных атрибутов.

F.3.2 Выход

В заданной наполненной объектной базе EXPRESS-I может быть использован как язык вывода данных для отображения части или всего содержимого объектной базы, воспринимаемого человеком.

В зависимости от развитости объектной базы, отображаемые объектные предметы могут или не могут включать значения вычисляемых и инверсных атрибутов. Однако, по меньшей мере имена ролей этих атрибутов выводить необходимо.

EXPRESS-I-конструкция MODEL спроектирована для отображения совокупности объектной базы.

F.3.3 Тестирование программы (кода)

В идеале реализация объектной базы должна обеспечивать функциональные возможности для оценки всех ограничений на объекты и типы EXPRESS, которые могут быть представлены предметами или значениями в объектной базе. Например EXPRESS-схема может содержать определение объекта (ENTITY), включающее вычисляемый атрибут и ограничение на вычисляемое значение. Объектная база должна обладать возможностями как определения вычисляемого атрибута, так и исключения любого предмета данного класса ENTITY, значения которого не удовлетворяют ограничениям. Для этого требуется программа на каком-либо языке программирования. EXPRESS-I может использоваться при вводе данных для тестирования такой программы.

Другими примерами программ (кодов) являются:

- определение значений инверсных атрибутов;

- проверка уникальности ограничений на совокупность предметов;

- программа реализации определяемых в EXPRESS правил (RULE).

Заметим, что эти типы функций необходимы также для систем тестирования физического файла и других видов процессоров обмена данными.

F.4 Примеры данных, отличных от EXPRESS

Поскольку экземпляры объектов EXPRESS-I имеют форму поименованных кортежей, их можно использовать также для отображения предметов или записей из языков, отличных от EXPRESS. Например, экземпляры Си-структур или состояний предметов, представляющие собой экземпляры классов объектно-ориентированных языков типа Си++ или Эйфель, могут быть отображены при помощи EXPRESS-I. Аналогичным образом, EXPRESS-I можно использовать в качестве механизма отображения в языках, поддерживающих фреймы.

Пример 71 - Структура на языке Си может быть определена следующим образом:

struct point {

int х;

int у;

};

Экземпляр на языке EXPRESS-I для этой структуры мог быть представлен в виде:

p1 = point {х 10;

y 20;};

Язык можно использовать для представления табличных данных из реляционных баз данных, где имя объекта эквивалентно имени таблицы, а каждый экземпляр является (идентифицируемой) строкой в таблице, либо сети в объектно-ориентированных баз данных. В другом случае язык может быть использован в качестве файла для данных IGES (международного стандартного обмена графическими данными), независимого от формата представления.

Пример 72 - Таблица реляционной базы данных может быть определена в SQL следующим образом:

CREATE TABLE PART

( ID

CHAR(6)

NOT NULL;

PNAME

CHAR(20)

NOT NULL;

COLOR

CHAR(6)

NOT NULL;

WEIGHT

SMALLINT

NOT NULL;

CITY CHAR(15)

NOT NULL;

PRIMARY KEY ( ID ) ;

Экземпляры двух строк наполнения таблицы PART можно представить в EXPRESS-I следующим образом:

part_row1 = PART{ID `р33`;

PNAME `Nut`;

COLOR `Red`;

WEIGHT 12;

CITY `Paris; };

part_row2 = PART{ID `p8`;

PNAME `Washer`;

COLOR `Green`;

WEIGHT 4;

CITY `Rome`; };

Пример совершенно иного использования дан Гудвином [4], который предложил EXPRESS-I в качестве формального мета-языка для Семантически Унифицированной Мета Модели [5], базирующейся, в свою очередь, на логике предикатов.

ПРИЛОЖЕНИЕ G
(справочное)


Технические подходы

В данном приложении описаны некоторые технические подходы, использованные при регламентации требований к языку EXPRESS-I, описанному в настоящем стандарте. Настоящий материал содержит хронологическое и тематическое описание дискуссий по вопросам регламентации требований к языку EXPRESS-I и результаты принятых по данным вопросам решений.

Язык EXPRESS-I был разработан в начале 1990 г. с целью удовлетворения потребностей пользователей в написании простых примеров программ EXPRESS-моделей, применяемых для проверки и понимания моделей. В связи с этим описание языка ограничивалось только отображением экземпляров объектов. Первые версии документа планировались как дополнение к справочному руководству по языку EXPRESS (ГОСТ Р ИСО 10303-11). Позднее описание языка было существенно расширено.

G.1 Абстрактные контрольные примеры

Сан-Диего, апрель 1991 г.: Язык EXPRESS-I соответствует своему назначению, но можно ли его расширить для работы с контрольными примерами, например для определения параметризованных экземпляров?

Обсуждение/Решение: Следующая версия будет расширена в соответствии с данным предложением. Кроме того, хотя физический файл не позволяет включать независимые экземпляры типов (TYPE), было бы желательно их включение в EXPRESS-I, чтобы другие виды реализации стандартов серии ГОСТ Р ИСО 10303 (ИСО 10303) могли их рассматривать в качестве предметов первого класса.

G.2 Связь с EXPRESS

Саппоро, июль 1991 г.: Насколько тесной должна быть связь между EXPRESS-I и EXPRESS? Теперь, при обеспечении описания контрольных примеров, следует ли считать EXPRESS-I более ориентированным на класс контрольного примера, чем на класс методов описания?

Обсуждение/Решение: Язык EXPRESS-I очевидно нуждается в тесной корреляции с существующей лексической* языка EXPRESS, а также с его возможными расширениями в EXPRESS версии 2. Возможно, его следует сохранить как класс документа по методам описания (метод языка для описания ). Однако, чтобы подчеркнуть разницу между описаниями информационной модели (например, EXPRESS) и описаниями реализаций и (или) тестирования, описание EXPRESS-I следует выделить в отдельный документ, а не выпускать в виде приложения к EXPRESS. РГ3/П3 обратилась в Саппоро к Секретариату ТК 184 (PMAG) с просьбой выделить описание EXPRESS-I в отдельный документ. До публикации в виде документа с конкретным обозначением его следует переписывать в виде отдельного документа, а не в виде приложения.

_______________

* Текст соответствует оригиналу. - Примечание "КОДЕКС".

G.3 Ссылки на предметы

Саппоро, июль 1991 г.: Почему имеется знак "@" перед ссылками на объект или тип?

Обсуждение/Решение: Главным пожеланием при разработке языка являлось установление лексического различия между областями значений. Это подразумевает, что лексическое представление значения должно, насколько возможно, указывать соответствующую область значения. Поэтому знак "@" используется для установления отличия того, что в языках программирования называется указателями, от других элементов значений, например целочисленных или переменных.

G.4 Агрегации

Саппоро, июль 1991 г.: Нужно ли лексически обозначать область значения каждого вида агрегации? То есть следует лексически различать мультимножества (bags), списки (lists) и наборы (sets), так как все они отличаются от массивов (arrays).

Обсуждение/Решение: Возможно, но это усложнило бы язык. На данный момент создан язык, описывающий различия между агрегациями фиксированной и переменной длины в качестве первичной характеристики поведения. Внутреннее поведение (то есть упорядочение и копирование) менее важно. В любом случае, существует базовое допущение о том, что все области значений устанавливаются вне EXPRESS-I.

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

Обсуждение/Решение: Нет. Имеется базовое допущение о существовании концептуальной модели (не обязательно описанной на языке EXPRESS), которая определяет эти характеристики. Язык EXPRESS-I используется для отображения совокупности примеров концептуальной модели.

G.5 Строковые значения

Саппоро, июль 1991 г.: Следует ли рассматривать возможность включения новых строк в строковые значения в противоположность языку EXPRESS?

Обсуждение/Решение: EXPRESS можно рассматривать как язык (концептуального) определения, и в этом смысле строка может быть неограниченной длины. EXPRESS-I ближе к языку реализации по крайней мере в смысле способности отображать строковые и другие значения. Материал (например, бумага, экран монитора), на котором отображаются данные, ограничен в размерах. Поэтому обеспечивается механизм разбиения длинных строк на более короткие с целью их отображения.

G.6 Тестирование и принятие модели

Саппоро, июль 1991 г.: Хотя данная версия EXPRESS-I и поддерживает определение абстрактного контрольного примера, достаточно ли этих средств?

Обсуждение/Решение: Мы не знаем. Исходные данные и требования к тестированию активно изучаются, например руководителем РГ6.

G.7 Расширение возможностей контрольного примера

В период с июля 1991 г. по июнь 1992 г. были получены три документа, отражающие позиции членов РГ6 в отношении требований к возможностям контрольных примеров:

- Mark Davies, Requirements for an Instantiation Language for EXPRESS, CADDETC Document D/91/0037, 9 October 1991;

- Mark Davies, EXPRESS-I Requirements, TC184/SC4/WG5/P3 N??, 22 January 1992;

- Paul Bell, Enhancements needed to EXPRESS-I to support АТС development, CADDETC Document CTS2/92/L/001/t, 1 June 1992.

Последний из этих отчетов фактически включал содержимое предыдущих и был гораздо более существенным документом.

Язык EXPRESS-I был модифицирован в июне 1992 г. с учетом требований, предложенных в этих отчетах. Это привело к коренной переработке документа.

G.8 Соответствие языку EXPRESS

На встрече в Лондоне (июль 1992 г.) был рассмотрен документ от июня 1992 г. и согласованы незначительные технические изменения в нем.

Одновременно, поскольку документ корректировался с целью включения этих изменений, он был редакционно и технически структурирован в соответствии с проектом стандарта на язык EXPRESS. В результате в него были внесены основные изменения в части введения набора символов по ИСО/МЭК 10646-1.

G.9 Опытная апробация

На встрече в Далласе в 1992 г. РГ6 решила разработать опытные абстрактные контрольные примеры на основе версии EXPRESS-I от ноября 1992 г. Эти эксперименты отчасти предназначались для определения достаточности требований к языку описания абстрактных контрольных примеров (АТС), а также для выявления дополнительных требований и, при наличии таковых, - документирования этих требований.

В это время РГ6 уже располагала некоторыми дополнительно предложенными требованиями, но было решено не включать их в язык (за исключением представления их в форме замечаний в комментариях к опытным тестам), пока работа по опытным контрольным примерам не будет рассмотрена в начале 1993 г.

Затем было отмечено, что не определено отображение переобъявляемых атрибутов. Кроме того, было бы полезным ввести в контрольный пример более четкое различие между данными управления и тестирования. Было решено добавить недостающее отображение и ввести конструкцию REALIZATION. Без учета этих изменений, описание языка должно было окончательно оформиться к началу 1993 г.

G.10 Расширения алфавита

Даллас, октябрь 1992 г.: В версии 2 EXPRESS имеется требование по поддержке неанглийских алфавитов в комментариях и идентификаторах. Это требование также применимо к EXPRESS-I.

Обсуждение/Решение: Конкретных действий намечено не было. Включение данных требований будет рассматриваться и возможное решение может быть включено в следующую (1993 г.) версию требований к языку.

G.11 Отображение супертипов

laian Morison, декабрь 1992 г.: В EXPRESS-I каждый EXPRESS-объект наполняется как сложный экземпляр с отдельным идентификатором и отношениями супертип-подтип, объявляемыми посредством "указателей" SUPOF и SUBOF. Это приводит к поддержке двух неверных представлений:

a) что один экземпляр имеет несколько возможных идентификаторов;

b) не исключается возможность того, что одно и то же множество значений супертипа совместно используется несколькими экземплярами подтипа.

Предлагается представлять сложный экземпляр аналогично определяемым наборам в EXPRESS:

i1 = me&sibling {

g_name -- > `Gr an`;

p_name -- > `Dad`;

my_name --> `self`;

s_name -- > `Sis`; };

Обсуждение/Решение: Похоже имеются три основных варианта отображения экземпляров супертипа:

a) идентифицировать лист и наследовать все атрибуты - проблема в том, что из-за конструкций ANDOR возможна множественность листьев;

b) идентифицировать корень (самый верхний супертип) и двигаться в направлении атрибутов потомков - проблема в том, что возможна множественность корней из-за множественного наследования;

c) трактовать все компоненты одинаково.

Был выбран третий вариант, поскольку он подразумевает, что не требуется оперировать со специальными случаями. Как вы заметили, снизу это означает, что единственный сложный экземпляр может иметь несколько возможных идентификаторов. Фактически все они являются переименованиями друг друга и могут быть выявлены прохождением по ссылкам SUPOF и SUBOF в EXPRESS-I.

Если смотреть на эту схему сверху, то экземпляр атрибута некоторого другого объекта может ссылаться на соответствующий тип экземпляра объекта в комплексе супертипа. Например, атрибут типа sibling может ссылаться на экземпляр sibling (и он получает при этом все другие ссылки в комплексе).

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

G.12 Комментарии по голосованию за CD-1995

Описание языка EXPRESS-I было предложено для голосования в качестве первой редакции проекта стандарта (CD) в 1995 г. Из-за большого разнообразия замечаний, явившихся результатом голосования, было решено издавать EXPRESS-I как технический отчет, а не как стандарт. Основным пунктом расхождения во мнениях голосовавших был раздел языка "абстрактный контрольный пример": некоторым он понравился, для других он был неприемлем.

Документ вида ТО (технический отчет) включает много редакционных изменений, предложенных при голосовании за CD, и других редакционных изменений, уточняющих понятия. Было сделано одно дополнительное техническое изменение, а в целом документ остался таким, каким он рассылался для голосования. Далее приводятся основные технические замечания, полученные при голосовании.

G.12.1 Обеспечение контрольного примера

Великобритания одобрила материал и использует его;

Франция имела некоторые технические замечания.

Некоторые представители США хотели исключить из языка эту часть, тогда как другие ощущали ее недостаточную проработанность.

За исключением EXPRESS-I, в серии ИСО 10303 (ГОСТ Р ИСО 10303) нет формального языка для абстрактного контрольного примера. Однако, поскольку РГ6 пока не имеет полного множества требований к такому языку, в частности, относительно тестирования реализаций, базирующихся на SDAI, возможно преждевременно стандартизовать данную часть EXPRESS-I. В основном, это заключение и привело к тому, чтобы издавать описание языка в качестве ТО, а не стандарта.

G.12.2 Сложные экземпляры объектов

Повторяющейся темой в комментариях ряда стран при голосовании было неприятие метода наполнения сложных экземпляров объекта (то есть когда экземпляр является иерархией наследования). Консенсусом голосования было решено, что у экземпляра должен быть единственный идентификатор. Это замечание было принято в языке, который, как описывается теперь в настоящем стандарте, определяет единственный идентификатор для сложного экземпляра.

G.12.3 Экземпляры типа

Швейцария возражала против возможности идентификации экземпляров EXPRESS-конструкций, отличных от объектов.

EXPRESS исходит из предположения, что каждый экземпляр объекта (в объектной базе) будет иметь уникальный идентификатор. В объектно-ориентированной терминологии он называется Oid-Object Identifier. Однако EXPRESS ничего не говорит относительна идентификаторов (Oids) для необъектов: ни запрещает их, ни допускает их существования.

Одной из целей проектирования EXPRESS-I было обеспечение возможности демонстрации экземпляров так, как они могли бы быть представлены в некоторой объектной базе (которую EXPRESS называет реализацией). EXPRESS не определяет среду реализации. Поэтому разработчик может выбрать как хранить экземпляры данных, давать уникальные Oids для поддержки экземпляров объектов. EXPRESS-I преднамеренно распространяет понятие Oid на другие виды экземпляров. Язык Smalltalk делает то же самое, рассматривая все как предмет. Разумеется, не требуется, чтобы возможности идентифицируемых экземпляров необъектов использовались, но они в языке имеются на случай необходимости.

ПРИЛОЖЕНИЕ H
(справочное)


Библиография

[1] ИСО/ТО 9007-87*) Системы обработки информации. Концепции и терминология для концептуальной схемы и информационной базы

____________________

*) Оригиналы стандартов ИСО (ИСО/МЭК) - во ВНИИКИ Госстандарта России.

[2] ИСО/МЭК 6429-92*) Информационная технология. Управляющие функции для кодированных наборов символов

____________________

*) Оригиналы стандартов ИСО (ИСО/МЭК) - во ВНИИКИ Госстандарта России.

[3] WIRTH, H.; "What can we do about the unnecessary diversity of notation for syntactic definitions?", Communications of the ACM, November 1977, vol 20, no. 11, p 822.

[4] GODWIN, A. N., GIANNASI, F. And TAHZIB, S.; "An example using the SUMM with EXPRESS and relational models", in WILSON, P. R. (editor) EUG`94: 4th Annual EXPRESS User Group International Conference, Greenville, SC, 13-14 October, 1994

[5] FULTON, J. A. et al; "Technical report on the Semantic Unification Meta-Model: Volume 1 - Semantic unification of static models", ИСО TC184/SC4 WG3 Document N175, October 1992

Предметный указатель

abstract (зарезервированное слово)

12.10

aggregate (зарезервированное слово)

9.2, 12.3

alias (зарезервированное слово)

11.3

and (зарезервированное слово)

12.10

andor (зарезервированное слово)

12.10

array (зарезервированное слово)

12, 12.3

bag (зарезервированное слово)

12, 12.3

binary (зарезервированное слово)

12.3

boolean (зарезервированное слово)

12.3

call (зарезервированное слово)

10.3

const-e (константа)

8.1.6

constant (зарезервированное слово)

8.8, 12.1, 12.7

context (зарезервированное слово)

9.1, 9.3, 10.3, 11.3.5, 12.9.3-12.9.5, F.2

criteria (зарезервированное слово)

9.3.4

end-context (зарезервированное слово)

11.3

end-criteria (зарезервированное слово)

9.4.3

end-model (зарезервированное слово)

11.3.11

end-notes (зарезервированное слово)

9.4.4

end-purpose (зарезервированное слово)

9.4.1

end-realization (зарезервированное слово)

9.5

end-references (зарезервированное слово)

9.4.2

end-schema-data (зарезервированное слово)

11.3.17

end-test-case (зарезервированное слово)

11.3.20

entity (зарезервированное слово)

7.1, 8.7, 12.1, 12.8, 12.10

enumeration (зарезервированное слово)

7.2, 8.6, 12.1, 12.5, 12.6, 12.9

false (константа)

8.1

function (зарезервированное слово)

12.1

generic (зарезервированное слово)

9.2

import (зарезервированное слово)

10.3

integer (зарезервированное слово)

12.2, 12.10

list (зарезервированное слово)

12.1, 12.2

logical (зарезервированное слово)

12.2

model (зарезервированное слово)

8.10, 11.3.11, 12.9.3-12.9.5

notes (зарезервированное слово)

9.4.4

number (зарезервированное слово)

12.2, 12.10

objective (зарезервированное слово)

9.4

oneof (зарезервированное слово)

12.10

optional (зарезервированное слово)

12.3, 12.9

parameter (зарезервированное слово)

9.2

pi (константа)

8.1.6

procedure (зарезервированное слово)

12, 12.1

purpose (зарезервированное слово)

9.4.1

query (зарезервированное слово)

11.3.14

real (зарезервированное слово)

12.2, 12.10

realization (зарезервированное слово)

9.5

reference (зарезервированное слово),

12.11

references (зарезервированное слово)

9.4.2

repeat (зарезервированное слово)

11.3.15

rule (зарезервированное слово)

11.3,12, 12.1

schema (зарезервированное слово)

9.1, 9.3, 10.2, 11.2, 12.1, приложение F

schema-data (зарезервированное слово)

8.9, 11.3.17

select (зарезервированное слово)

7.3, 8.5, 12.1, 12.6, 12.9

set (зарезервированное слово)

12, 12.3

string (зарезервированное слово)

12.2

subof (зарезервированное слово),

8.7.2, G.11

subtype (зарезервированное слово)

8.7.2, 12.8, 12.10

supertype (зарезервированное слово)

8.7.2, 12.8 12.10

supof (зарезервированное слово)

8.7.2, G.11

test-case (зарезервированное слово)

9.3, 10.3, 11.3.20

true (константа)

8.1

type (зарезервированное слово)

7.4, 8.4, 12.1

unique (зарезервированное слово)

12.8

unknown (константа)

8.1.5

use (зарезервированное слово)

10.2, 12.1.1

using (зарезервированное слово)

10.2

where (зарезервированное слово)

12.8

with (зарезервированное слово)

10.2, 10.3

видимость

11

нотация

D.2

область действия

11

Текст документа сверен по:

М.: ИПК Издательство стандартов, 2001