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

  2. Конструкт в языке представления получается заменой символов на их пред­ставления. Представление для каждого символа дается в терминах абстрактных ли­тер. Кодирование конструктов в языке представления для машинной обработки осу­ществляется заменой каждой абстрактной литеры на соответствующую ей конкрет­ную литеру и вставкой особенностей типографского набора (там, где это разрешено).

В некоторых реализациях отдельные конкретные литеры могут не иметь предс­тавлений на устройствах ввода-вывода. В таких случаях реализация должна обеспе­чить дополнительное представление соответствующих им абстрактных литер (пап ример, в виде комбинаций конкретных литер, доступных на этих устройствах). При этом, в частности, допускается расширение списка зарезервированных слов из под­пункта 3.4.1.3 данного приложения, а также введение альтернативных обозначений из разд. 10 и расширение списка представлений символов из п. 9.4.1 настоящего стан­дарта альтернативными представлениями, использующими только доступные конкрет­ные литеры.

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

  1. Отдельные представления

    1. Элементы строки

      1. Множество элементов-строки (подпункт 8.1.4.1. Ь) — это множество абст­рактных литер без кавычки и апострофа, но с символом-образ-кавычки и символом- образ-апострофа. Значение каждой абстрактной литеры есть сама литера. Соответст­вующие друг другу прописные и строчные буквы имеют различные естественные зна­чения. Символ-образ-кавычки записывают двумя соприкасающимися кавычками и его естественным значением является кавычка. Символ-образ-апострофа записывают дву­мя соприкасающимися апострофами и его естественным значением является апостроф (один апостроф может использоваться в реализациях как регистровая литера).

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

символ-апостроф,

символ-открыть,

символ-образов-управляющих-литер,

символ-закрыть.

Образы литер в списке могут задаваться целыми десятичными числами, а также их обозначениями в русской или латинской нотации по ГОСТ 27465 и должны разде­ляться запятыми.

  1. Дополнительная особенность типографского набора - „разрыв строки” - предусмотрена для использования только внутри изображений-строк и изображений- литерных и записывается как кавычка с последующими одной или более особеннос­тями типографского набора, отличными от разрыва строки, с последующей еще одной кавычкой.

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

  1. Элементы прагматов

    1. Последовательностью-элементов-ПОЯСНЕНИЯ-ОФОРМЛЕННЫХ (п. 9.2.1.с) может служить любая последовательность литер (не обязательно абстрактных), в ко­торую не входит последовательность (вместе с разделителями), представляющая сам символ-ПОЯСНЕНИЕ-ОФОРМЛЕННЫЙ (т. к. последним завершается прагмаТ). В реа­лизации возможны, однако, дальнейшие ограничения на последовательность литер, до­пустимых в прагматах (но только не в примечаниях).

    2. Предусмотрены шесть стандартных элементов-прагматов: СТРАНИЦА (PAGE), ТЧК (POINT), BP (UPPER), РЕЗ (RES), ЗАПОМНИТЬ (PUSH), ВОССТА­НОВИТЬ (ГОР) (В скобках английские эквиваленты элементов-прагматов). Эти элементы должны распознаваться хотя бы в их минимальной форме:

Символ-прагмат-ОФОРМЛЕННЫЙ,

элемент,
Символ-прагмат-ОФОРМЛЕННЫЙ.

Каждый из перечисленных элементов-прагматов записывается как последователь­ность букв, которым могут предшествовать или за которыми могут следовать особен­ности типографского набора. (Во всех выделяющих режимах символ-прагмат может быть записан как „ПРАГМ” с последующим разделителем).

    1. Новая страница

      1. При распечатке некоторого конструкта в конкретных литерах с помощью процессора Алгола 68 прагмат, содержащий элемент прагмата СТРАНИЦА (PAGE) указывает, что строчку, следующую за строчкой, содержащей замыкающий символ- прагмат, печатают с начала новой страницы. (Прагмат СТРАНИЦА не является, одна­ко, особенностью типографского набора).

    2. Запоминание режима выделения

      1. Прагмат, содержащий элемент-прагмата ЗАПОМНИТЬ (PUSH), указы­вает, что значение действующего в данном месте прагмата, определяющего режим вы­деления (подраздел 3.4 настоящего приложения), запоминается для последующего восстановления.

      2. Прагмат, содержащий элемент-прагмата ВОССТАНОВИТЬ (POP), связы­вается с последним из прагматов, содержащих элемент-прагмата ЗАПОМНИТЬ, еще не связанным с другим прагматом, содержащим элемент-прагмата ВОССТАНОВИТЬ (если такой есть), и восстанавливает действие того из прагматов, задающих режим вы­деления, который действовал перед этим прагматом.

  1. О с о б е н н о с т и типографского набора

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

  2. Слова и выделенные слова

    1. Представление слов и выделенных слов определяют „режим выделения". Существует три режима выделения: выделение точкой, выделение прописными буква­ми, резервирование слов.

Новый режим вводится прагматом, содержащим один из элементов-прагмата ТЧК (POINT), BP (UPPER), РЕЗ (RES) и начинает действовать сразу же после замы­кающего символа-прагмат. Режим не действует на „оформление” представления (так, в режимах ВР и РЕЗ „ПРАГМ” соответствует „ПРАГМ”). Приводимые ниже правила требуют наличия резделителя в некоторой позиции. В качестве разделителей можно ис­пользовать особенности типографского набора. Слова различаются только тогда, ког­да различны конкатенации их подслов, например, „конец файла”, мсжет быть записан также как „конец файла”.

  1. В режиме выделения точкой (ТЧК) выделенные слова предс­тавляются следующим образом:

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

слоги должны разделяться литерами подчеркивания, но не особенностями типог­рафского набора;

за выделенным словом должен следовать разделитель.

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

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

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

если слог не завершается литерой подчеркивания, то после него должен следовать разделитель.

  1. В режиме выделения прописными буквами (ВР) слова и выделенные сло­ва представляют как в режиме ТЧК, но только с использованием дополнительных пра­вил:

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

точка может быть опущена перед выделенным словом из прописных букв, если ему предшествует разделитель, отличный от точки, строчная буква или цифра, не яв­ляющаяся „прописной цифрой”. „Прописная цифра” - это цифра, которой предшест­вует прописная буква или прописная цифра;

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

прописные буквы могут быть использованы только в выделенных словах и в ка­честве элемента-основного-набора (подпункт 8.1.4.1.с).

  1. В режиме резервирования слов (РЕЗ) слова и выделенные слова представ­ляют как в режиме ТЧК, но с использованием дополнительных правил:

точка может опускаться перед зарезервированными словами (заданными в п. 9.4.1 как представления для символов языка), составленными из букв русского алфавита

БИТ БЫВ В ВЕЩ ВИД ВОЗБУД ВСЕ ВЫБ ВЫХОД ГЛОБ ДЛИН ДЛЯ ДМ ДО ЕСЛИ ЕСТЬ ИЗ ИМЕНИ ИМЯ ИНАЧЕ ИНЕС ИСТИНА КАНАЛ КОМПЛ КОН КОНЕЦ КОР КЦ ЛИБО ЛИВЫБ ЛИТ ЛОГ ЛОЖЬ ЛОК МД МОДУЛЬ НА НАЧ НАЧАЛО НЕСТЬ НИЛ ОБ ОП ОТ ОТКР ПАР ПОДВ ПОДКЛ ПОКА ПРАГМ ПРИМ ПРИО ПРИСИТ ПРОПУСК ПРОЦ ПУСТ ПУСТОЕ С СБРОС СЕМА СЕГМЕНТ СИТУАЦИЯ СКИП СЛОГ СРЕДА СТ СТРУКТ ТО Ф ФАЙЛ ФОРМАТ ЦЕЛ ЦК ЧЕРЕЗ ШАГ

и букв латинского алфавита

ACCESS AT BEGIN BITS BOOL BY BYTES CASE CHANNEL CHAR CO COMMENT COMPL DEF DO EGG ELIF ELSE EMPTY END ESAC ECCAPTION EXIT FALSE FED FI FILE FLEX FOR FORMAT FROM GO GOTO HEAP IF IN INT IS ISNT LOC LONG MODE NEST NIL OD OF ON OP OUSE OUT PAR POSTLUDE PR PRAGMAT PRIQ PROC PUB RAISE REAL REF SEMA SHORT SKIP STRING STRUCT THEN TO TRUE UNION VOID WHILE

если им предшествует разделитель, отличный от точки;

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

    1. Составные представления

      1. Некоторые представления, приведенные в п. 9.4.1, составленные из после­довательности двух или более литер, не являющихся буквами (” ”, =: , :=, | : , : =:, : /«=:), являются последовательностями абстрактных литер, соответствующих этим символам.

      2. Представление любого символа-ПОНЯТИЕ1-перед-ПОНЯТИЕМ2 является представлением для символа-ПОНЯТИЕ 1, за которым следует представление для символа-ПОНЯТИЕ2, (символы-ПОНЯТИЕ1-перед-ПОНЯТИЕМ2 являются составны­ми обозначениями-операций, упомянутыми в подпунктах 9.4.2.2.d, е).

    2. Другие представления

      1. Любой символ, представление которого в подразделе 9.4 соответствует абстрактной литере, представляется этой литерой. Символ-на-десять-в-степени, символ- плюс-и-на и символ-краткое-примечание не имеют представлений.

  1. Обмен

    1. Представления объектов для обмена должны использовать только абстракт­ные литеры (с тем, чтобы ввод можно было подготавливать, а вывод интерпретиро­вать без ссылки на конкретную реализацию). Запросы к обстановке зависят от абст­рактных литер следующим образом:

да „ Т ” латинская или „ Д ” русская;

нет „ F ” латинская или ,, Н ” русская;

литера ошибки „ * ”;

пробел „

  1. Вместо абстрактных литер для символа-на-десять-в-степени и для символа- плюс-и-на необходимо использовать литеры „ Е ” { латинская } или „ Е ” f русская } и'„ I ” { латинская } или ”И” [ русская} .

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

  1. Строковые значения, полученные в результате обмена и операции ПРЕД (REPR), могут содержать литеры, которые не соответствуют абстрактным литерам.

ИНФОРМАЦИОННЫЕ ДАННЫЕ

  1. ИСПОЛНИТЕЛИ

В.Ц Морозов, д-р техн, наук; Г.С. Цейтин, д-р физ.-мат. наук; А.Ф. Рар; А.Н.Терехов, канд. физ.-мат. наук; Ч.Линдси; О.Е.Климова; Н.Б. Скачков; В.В. Броль; В.Б. Яковлев; И.Б. Гиндыш; Э.В. Оленье - ва; Д.Ю. Жуков; Ю.И. Карпов; ФХ. Кабалила; OJC. Александрова;.

Е.Г. Грозная

  1. УТВЕРЖДЕН И ВВЕДЕН В ДЕЙСТВИЕ Постановлением Государст­венного комитета СССР по стандартам от 21.12.88 № 4380

  2. Срок проверки — 1996 г., периодичность проверки — 5 лет.

  3. ВВЕДЕН ВПЕРВЫЕ

  4. ССЫЛОЧНЫЕ НОРМАТИВНО-ТЕХНИЧЕСКИЕ ДОКУМЕНТЫ

Обозначение НТД, на который дана ссылка

Номер пункта, приложения

ГОСТ 27465—87

ГОСТ 27974-88

Приложение 2 (п. 3.1.1)

1, 1.1.1 -1.1.4,1.1.4.1- 1.1.4.3,1.2.1,1.2.3 1.3,2.1.1,2.1.1.1- 2.1.1.3,2.1.2,2.Г.3,2.1.4.1-2.1.4.3,2.1.5,2.2,3,3.0.1,3.0.2,3.1, 3 1,3.2.1,4,4.1.1,3.3.1,3.3.2,3.4,3.5,4.1.2,4.2-4.7,4.8.1,4.8.2, 5,5.1,’5.2Л.1',5.2.1.2,5.2.2-5.2.4,5.3.1.1,5.3.2.1,5.3.2.г,5.4.1- 5.4.4,5.5,6,6-.1.1,6.2:1,6.3-6.7,7,7.1.1,7-2.1,7.2.2,73,7.4,8,9, 9,1.-9.4,9.4.1,9.4.2,10,10.1,10.13,10.1.2,10.1.3,10.2,10.2.2, 10.1.3.0 - 10.2.3.12, 10.2.4, 10.3, 10,3.1, 10.3.1.1, 10.3.1.2, 10.3.1.3-10.3.1.6,10.3.2,10.3.3.1,10.3.3,2,10.3.4,10.3.4.1.1, 10.3.4.1.2,10.3.4.2—10.3.’4.7,10.3.‘4.8.1,10.3.4.8.2,10.3.4.9,

10.3.4.10.1, 10.3.4.10.2, 10.3.5, 10.3.5.1, 10.3.6, 10.4, 10.5.1, 10.5.2

СОДЕРЖАНИЕ

ГОСТ 27974-88

  1. Язык и метаязык 4

    1. Метод описания 4

      1. Введение 4

      2. Прагматика 5

      3. Синтаксис строгого языка 6

      4. Семантика 14

    2. Общие метаправила 18

      1. Метаправила для видов 18

      2. Метаправила, связанные с фразами и приведением 19

      3. Метаправила, связанные со средами 19

    3. Общие гиперправила 19

      1. Синтаксис общих предикатов 19

      2. Выполнимость предикатов 20

      3. Синтаксис общих конструкций 21

  2. Вычислитель и программа 22

    1. Терминология 22

      1. Объекты 22

      2. Соотношения 25

      3. Значения 26

      4. Действия • 33

      5. Сокращения 35

    2. Программа 37

      1. Синтаксис 37

      2. Семантика 37

  3. Предложения 38

    1. 1. Синтаксис 38

    2. 2. Семантика 39

    3. Замкнутые предложения 39

      1. Синтаксис 39

    4. Последовательные предложения 40

      1. Синтаксис 40

      2. Семантика 42

    5. Совместные и параллельные предложения 43

      1. Синтаксис 43

      2. Семантика 45

    6. Выбирающие предложения 45

      1. Синтаксис 47

      2. Семантика 50

    7. Циклические предложения 50

      1. Синтаксис 51

      2. Семантика 52

  4. Описания, описатели и индикаторы 54

    1. Описания 54

      1. Синтаксис 54

      2. Семантика 55

    2. Описания видов 55

      1. Синтаксис 55

      2. Семантика 55

    3. Описания приоритетов 56

      1. Синтаксис 56

      2. Семантика 56

    4. Описания идентификаторов 56

      1. Синтаксис 57

      2. Семантика 5 8

    5. Описания операций 59

      1. Синтаксис 59