KRIEGSSPIELE!
Вы хотите отреагировать на этот пост ? Создайте аккаунт всего в несколько кликов или войдите на форум.

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Страница 2 из 2 Предыдущий  1, 2

Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Сб Апр 03, 2021 1:11 am

3.7.МНОГОЗАДАЧНЫЙ РЕЖИМ

Запуская на исполнение какое-либо форт-слово, программист имеет возможность исполнить следующее только по завершении исполнения предыдущего. Если исполнение данного слова требует значительного времени счета, то длительные перерывы в диалоге создают определенное неудобство. Ввиду этого представляется весьма привлекательной идея МНОГОЗАДАЧНОЙ ФОРТ-СИСТЕМЫ, в которой программист может создавать фоновые задачи и запускать их на исполнение, не прерывая диалога. Текстовый интерпретатор такой системы, обеспечивающий диалог, является одной из задач и разделяет центральный процессор наряду с другими задачами. Идея многозадачного режима привлекательна еще и тем, что разные задачи могут разделять значительную часть кода - практически все ядро форт-системы. Из стандартных слов только системные переменные ( STATE , BASE и другие) и списки слов ( FORTH , ASSEMBLER ) не могут одновременно участвовать в нескольких вычислительных процессах (задачах), поскольку их код (значение поля параметров) в процессе работы может изменяться. В то же время вся остальная часть кода форт-системы, включая все слова, определенные через двоеточие и CONSTANT , в процессе работы не меняется и может даже размещаться в постоянной оперативной памяти (ПЗУ). Чтобы снять это ограничение, во многих реализациях выделены особая область для размещения значений, которые могут изменяться во время счета. Эта область называется ПОЛЬЗОВАТЕЛЬСКОЙ и обычно располагается в конце адресного форт-пространства рядом со стеками и буферным пулом. Распределение памяти внутри пользовательской области выполняет сам программист через определяющее слово USER (пользовательский):

: USER ( N:СМЕЩЕНИЕ ---> ) CREATE ,
DOES> ( PFA ---> A:АДРЕС) @ U0 + ;

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

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

Дальнейшие уточнения конкретного варианта многозадачного режима зависят от многих частных причин. Для примера рассмотрим реализацию системы ПОЛИФОРТ фирмы "Форт" [31]. Эта система реализована для целого ряда ЭВМ, включая персональный компьютер ИБМ. Использованный в ней механизм переключения задач основан на кольцевом принципе: все задачи связаны в кольцо через начальную часть своей пользовательской области (рис.3.2). Задачи, составляющие кольцо, по очереди получают центральный процессор и удерживают его до тех пор, пока не исполнят слово PAUSE (пауза) или STOP (стоп). Для определений в машинном коде предусмотрен аналогичный код WAIT (ждать). Многие слова, которые выполняют асинхронные операции обмена ( TYPE , EXPECT , BLOCK , BUFFER ), содержат код WAIT или переход на STOP , чтобы в то время, когда они ждут завершения обмена, другие задачи могли использовать центральный процессор. Задачи, в которых для выполнения длительных вычислений нет необходимости обращаться к операциям обмена, должны сами периодически предоставлять процессор другим задачам, выполняя слово PAUSE.

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 G9bn0910
Рис.3.2. Кольцевой принцип реализации многозадачного режима

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

Для пробуждения задач часто используются асинхронные подпрограммы обработки прерываний. Например, если выход по прерыванию, установленный в слове EXPECT, распознает код возврата каретки, которым заканчивается вводимая строка, то он будит задачу, запросившую данный ввод с терминала, засылая команду WAKE (разбудить) на место ее команды JMP . Для этого часто используется какая-нибудь команда перехвата (например, для ЭВМ СМ-4 это команды TRAP и ЕМТ). Когда цикл передач управления по кольцу задач дойдет до этой команды, она передаст управление специальной подпрограмме-побудчику, которая и возобновит исполнение данной задачи от точки последнего остановка. При этом на место команды WAKE будет вновь заслана команда JMP , и исполнение данной задачи будет продолжаться до следующей операции PAUSE , STOP или WAIT . Пример цикла ввода и обработки данных с возобновлением по прерыванию дает следующее определение:

: СБОР ( --->) BEGIN ВВОД STOP ОБРАБОТКИ AGAIN ;

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

: СЧЕТ ( --->) 30000 0 DO ШАГ PAUSE LOOP ;

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

Действие STOP (для определений, заданных в машинном коде, аналогичное ему действие WAIT ) состоит в сохранении текущего состояния задачи (указателя интерпретации, указателя вершины стека данных и указателя вершины стека возвратов) в ее пользовательской области и передаче управления по адресу из ее звена связи в кольце задач. В результате центральный процессор будет исполнять цикл из передач управления по кольцу задач, пока не встретит команду WAKE . Действие PAUSE отличается от описанного действия STOP только тем, что предварительно засылает команду WAKE в начало области данной задачи, обеспечивая тем самым пробуждение данной задачи после полного круга передач управления. Действие WAKE заключается в том, что команда JMP засылается на отведенное ей место в начало пользовательской области, восстанавливается текущее состояние данной задачи из ее области сохранения, управление передается на точку NEXT адресного интерпретатора. В результате исполнение задачи возобновляется от точки останова.

Для определения ФОНОВОЙ ЗАДАЧИ используется определяющее слово BACKGROUND (фон), которое снимает со стека три числа: размер пользовательской области, размер стека данных и размер стека возвратов. Это слово резервирует в словаре память указанного объема и указатели на эти области компилирует в поле параметров создаваемой статьи, например, 40 60 50 BACKGROUND T . При исполнении слова T на стеке оставляется адрес его поля параметров, через который можно добраться до пользовательской области и стеков задачи T . Данное описание только подготавливает задачу, но не включает ее в кольцо задач и не запускает на исполнение.

При запуске форт-системы в кольце задач присутствует только одна задача-OPERATOR (оператор), звено связи которой указывает на нее же. Для встраивания в кольцо новых задач используется слово BUILD (построить), например T BUILD . Это слово, используя адрес поля параметров статьи для задачи, инициализирует ее пользовательскую область и включает ее в кольцо задач после задачи OPERATOR . При этом в начало области вписывается команда JMP , предохраняющая данную задачу от преждевременного исполнения. Заметим, что форт-слова, составляющие программу данной задачи, могут быть определены значительно позже. Обратное действие - исключение задачи из кольца задач - выполняет аналогичное по употреблению слово RUIN (разрушить).

Для запуска задачи используется слово ACTIVATE (запустить), которое снимает со стека адрес поля параметров статьи для задачи. Оно очищает стек данных и стек возвратов задачи, сбрасывая на начало указатели их вершин в области сохранения, а в качестве точки возобновления засылает свой адрес возврата, указывающий на следующее за ним слово. Поскольку адрес снимается со стека возвратов, то слово ACTIVATE аналогично слову EXIT возвращает управление на точку вызова определения, его вызвавшего. Последним действием слова ACTIVATE является подготовка задачи к пробуждению путем засылки команды WAKE в начало ее пользовательской области. Приведем пример использования слова ACTIVATE и запуска задачи на исполнение:

: СЧЕТ ( PFA --->) ACTIVATE BEGIN ШАГ PAUSE LOOP ;
Т СЧЕТ

Задача T будет выполнять бесконечный цикл, разделяя центральный процессор с текстовым интерпретатором форт-системы - задачей OPERATOR . Исполнение задачи можно оставить с помощью слова HALT (останов):

: HALT ( PFA --->) ACTIVATE STOP ;

если в рамках задачи OPERATOR исполнить текст T HALT . После такого останова данную задачу можно запустить на счет с какой-нибудь другой форт-программой.

При работе в многозадачном режиме возникает проблема СИНХРОНИЗАЦИИ ЗАДАЧ, разделяющих общие ресурсы, которые требуют монопольного использования. Примерами таких ресурсов являются внешние устройства, общие области оперативной памяти, куда осуществляется запись данных, общие подпрограммы, не допускающие параллельного использования. Опишем простой механизм СЕМАФОРОВ, позволяющий управлять использованием таких ресурсов в многозадачном режиме.

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

Определим слова GET (получить) и RELEASE (освободить), аналогичные семафорным операциям Дейкстры [8]. В определениях этих слов используется вспомогательное слово FREE (свободен), проверяющее, свободен ли ресурс. Заметим, что ресурс свободен с точки зрения данной задачи, если он не занят или занят этой же задачей.

: FREE ( A:СЕМАФОР ---> A,F:ПРИЗНАК СВОБОДНОСТИ )
@ DUP 0= SWAP U0 = OR ;
: GET ( A:СЕМАФОР --->)
BEGIN PAUSE FREE UNTIL U0 SWAP ! ;
: RELEASE ( A:СЕМАФОР --->)
FREE IF 0 SWAP ! ELSE DROP THEN ;

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

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

VARIABLE ДИСК VARIABLE ЛЕНТА
: ШАГ1 ДИСК GET ЛЕНТА GET ... ;
: ШАГ2 ЛЕНТА GET ДИСК GET ... ;

Если слова ШАГ1 и ШАГ2 исполняются в разных задачах, то это может привести к их взаимной блокировке. Наилучший способ избежать такой ситуации - не запрашивать более одного ресурса единовременно. Например, в случае работы с диском и лентой, задача может запросить ресурс ДИСК , выполнить слово BLOCK для получения данных, затем переслать эти данные в свою локальную область и, освободив ДИСК , запросить ресурс ЛЕНТА.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Вс Апр 04, 2021 12:45 am

3.8.СОПРОГРАММЫ

Представление задачи в виде взаимодействующих СОПРОГРАММ (процессов) в теории программирования стало уже традиционным [15,16]. Но на практике этот метод используется редко, так как большинство распространенных языков высокого уровня не имеют необходимых конструкций. В стандарт языка Форт также не включены средства для сопрограммной работы. Вызвано это в основном тем, что такие средства обычно зависят от конкретного приложения и могут варьироваться очень сильно. Тем не менее, используя только стандартные для большинства систем слова, можно реализовать необходимые конструкции.

Рассмотрим достаточно простую и экономную реализацию сопрограмм. Направления, в которых можно ее усовершенствовать, рассмотрены ниже.

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

Будем считать, что адрес области памяти текущей сопрограммы находится в переменной Т-С . Используя ее, введем слова для доступа к полям этой области. Для простоты в данной реализации отводится участок памяти размером 128 байт. В его начале находятся: Т-ПРОГ - указатель начала шитого кода, соответствующего исполняемой программе, Т-СТЕК - указатель вершины стека данных на момент последней приостановки данной сопрограммы (указатель вершины стека возвратов сохраняется на стеке данных) и Т-ВЫЗВ - адрес аналогичной области для сопрограммы, вызвавшей данную. В остальной памяти участка размещаются стек данных и стек возвратов по 60 байт каждый.

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

Перед началом работы все сопрограммы должны быть проинициализированы словом START (старт), завершение работы сопрограммного механизма вызывает слово STOP (стоп).

Сопрограмма определяется через слово СОПРОГРАММА , которое по своему употреблению аналогично двоеточию. Вслед за ним идет имя сопрограммы и форт-текст, задающий требуемую программу. Обычно она состоит из цикла, внутри которого используется слово RESUME (возобновить) для приостановки данной сопрограммы и возобновления сопрограммы, ее вызвавшей. Выход по EXIT или ; приводит к завершению работы всего сопрограммного механизма и возобновлению текстовой интерпретации.

QUAN Т-С ( АДРЕС ОБЛАСТИ ТЕКУЩЕЙ СОПРОГРАММЫ)
: Т-ПРОГ ( ---> A:АДРЕС НАЧАЛА ПРОГРАММЫ) Т-С ;
: Т-СТЕК ( ---> A:АДРЕС УКАЗАТЕЛИ СТЕКИ ) Т-С 2+ ;
: Т-ВЫЗВ ( ---> A:АДРЕС ВЫЗВАВШЕЙ СОПРОГРАММЫ) Т-С 4 + ;
CREATE ВНЕШ 6 ALLOT ( ОБЛАСТЬ ДЛЯ ВНЕШНЕЙ ПРОГРАММЫ)
: RESUME ( ---> ОСТАНОВИТЬ ТЕКУЩ. И ВОЗОБН. ВЫЗВАВШУЮ)
RP@ SP@ Т-СТЕК ! ( СОХРАНИТЬ СОСТОЯНИЕ ТЕКУЩЕЙ)
Т-ВЫЗВ @ TO Т-С ( ПЕРЕКЛЮЧИТЬСЯ НА ВЫЗВАВШУЮ ДАННУЮ)
Т-СТЕК @ SP! RP! ; ( ВОЗОБНОВИТЬ ПРИОСТАНОВЛЕННУЮ)
: STOP ( ---> ЗАВЕРШЕНИЕ ВСЕХ СОПРОГРАММ) QUIT ;
: (START) ( A:АДРЕС ОБЛАСТИ СОПРОГРАММЫ-> ИНИЦИАЛИЗ)
DUP TO Т-С Т-ПРОГ @ OVER 126 + ! DUP 126 +
OVER 66 + ! 66 + Т-СТЕК ! ВНЕШ TO Т-С ;
: СОПРОГРАММА ( ---> ОПРЕДЕЛЕНИЕ СОПРОГРАММЫ) CREATE HERE
DUP 132 + , 126 ALLOT HERE 2+ , ['] STOP , (START) ]
DOES> ( PFA:ОБЛАСТЬ СОПРОГРАММЫ->) RP@* SWAP >R
SP> Т-СТЕК ! Т-С R> TO Т-С Т-ВЫЗВ !
Т-СТЕК @ SP! RP! ;
: START ( ---> ИНИЦИАЛИЗИРОВАТЬ СОПРОГРАММУ)
' >BODY [COMPILE] LITERAL STATE @
IF COMPILE (START) ELSE (START) THEN ; IMMEDIATE

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

Применяя описанный механизм, определим две сопрограммы ВВОД и ВЫВОД, которые обмениваются между собой через однобайтный буфер ТЕК-СИМ, и слово ЗАДАЧА, которое выполняет требуемую перепись данных:

QUAN ТЕК-СИМ ( ОЧЕРЕДНОЙ ОБМЕНИВАЕМЫЙ СИМВОЛ)
CREATE ВХОД-БУФ 80 ALLOT ( БУФЕР ВВОДА)
CREATE ВЫХ-БУФ 64 ALLOT ( БУФЕР ВЫВОДА)
СОПРОГРАММА ВВОД
ОТКРЫТЬ-ВВОД BEGIN ВХОД-БУФ ЧИТАТЬ WHILE
ВХОД-БУФ 80 + ВХОД-БУФ DO I С@ TO ТЕК-СИМ
RESUME LOOP
REPEAT ЗАКРЫТЬ-ВВОД ЗАКРЫТЬ-ВЫВОД ;
СОПРОГРАММА ВЫВОД
ОТКРЫТЬ-ВЫВОД BEGIN ВЫХ-БУФ 64 + ВЫХ-БУФ DO
ТЕК-СИМ I С! RESUME LOOP
ВЫХ-БУФ ПИСАТЬ AGAIN ;
: ЗАДАЧА
START ВВОД START ВЫВОД
BEGIN ВВОД ВЫВОД AGAIN ;

Два ряда слов ОТКРЫТЬ-ВВОД , ЧИТАТЬ , ЗАКРЫТЬ-ВВОД и ОТКРЫТЬ-ВЫВОД , ПИСАТЬ , ЗАКРЫТЬ-ВЫВОД обеспечивают взаимодействие с входным и выходным файлами. Слова ЧИТАТЬ и ПИСАТЬ требуют в качестве параметра адрес буфера ( ВХОД-БУФ для ввода и ВЫХ-БУФ для вывода), а слово ЧИТАТЬ , кроме того, возвращает логический результат - признак успешного завершения чтения.

В заключение рассмотрим направления, в которых можно развить данную реализацию.
1. Если сопрограммы могут использовать общий стек данных, то можно сохранять и восстанавливать только указатель стека возвратов.
2. Можно передавать параметры при начале работы сопрограммы, а также при каждом возобновлении. Для этого потребуется специальное слово, пересылающее указанное число элементов стека вызывающей сопрограммы на стек вызываемой.
3. Предусмотрев поле связи для сцепления всех сопрограмм в список, можно получить состояние всей совокупности взаимодействующих сопрограмм.
4. Можно предусмотреть вызов асинхронного выхода "Окончание задачи". Идентификация этого выхода может быть как статической, так и динамической.
5. Часть действий можно выполнять в состоянии исполнения, а не компиляции. Среди этих действий могут быть следующие: создание сопрограммы без имени и отведение заказываемого участка памяти в динамически распределяемой памяти, инициализация этой области памяти, освобождение области памяти сопрограммы при ее завершении.
6. Если использовать косвенный вызов через переменную типа VECT , можно динамически определять возобновляемую сопрограмму.

Возможны, конечно, и любые другие изменения, диктуемые конкретной обстановкой.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Пн Апр 05, 2021 12:32 am

3.9.ЗАПЛАНИРОВАННОЕ ПЕРЕКРЫТИЕ

Адресное пространство форт-системы не так уж велико - 64 К байт. Это налагает известное ограничение на общее число форт-слов, одновременно присутствующих в словаре. Для снижения этого ограничения можно применить свернутый шитый код или использовать форт-систему, в которой в качестве основного вместо 16-разрядного значения выступает 32-разрядное. Можно заметно сократить требуемый объем оперативной памяти, если использовать векторное поле кода.

Опишем еще один простой способ снижения требований к памяти - ЗАПЛАНИРОВАННОЕ ПЕРЕКРЫТИЕ. Группа взаимосвязанных определений образует единый сегмент в двоичном коде, который может быть загружен на заранее заданное место в словаре из внешней памяти форт-системы. Разные сегменты, загружаемые на одно и то же место оперативной памяти, перекрывают друг друга, вот почему такая структура и названа запланированным перекрытием. Благодаря тому, что хранящийся во внешней памяти сегмент выражен в двоичном коде, а не в виде текста, его загрузка идет примерно в 50-100 раз быстрее, чем обычная текстовая интерпретация.

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

Для трансляции сегментов введем глобальную переменную (СЕГМ) , содержащую адрес начала очередного компилируемого сегмента, границы которого отмечаются словами СЕГМ-НАЧ и СЕГМ-КОН . Выгрузку и загрузку сегментов выполняют слова СЕГМ-ВЫГР и СЕГМ-ЗАГР .

VARIABLE (СЕГМ)
: СЕГМ-НАЧ ( ---> НАЧАЛО ТРАНСЛЯЦИИ СЕГМЕНТА)
HERE DUP (СЕГМ) ! 0 , ( НОМЕР ЭКРАНА)
HERE 0 C, BL C, ( ФИКТИВНОЕ ИМЯ)
FORTH DEFINITIONS LATEST , ( ЗВЕНО СВЯЗИ)
CURRENT @ ! , ( ТОЧКА ЗАГРУЗКИ)
0 , 0 , ( ДЛИНА И ПОСЛЕДНЯЯ СТАТЬЯ)
;
: СЕГМ-КОН ( ---> КОНЕЦ ТРАНСЛЯЦИИ СЕГМЕНТА)
(СЕГМ) @ >R ( ТОЧКА ЗАГРУЗКИ СЕГМЕНТА)
HERE R@ - ( ДЛИНА) DUP R@ 8 + !
FORTH DEFINITIONS LATEST R> 10 + ! ;
: СЕГМ-ВЫГР ( N:НОМЕР ЭКРАНА ---> ВЫГРУЗКА)
DUP (СЕГМ) @ >R R@ ! ( НОМЕР)
R@ SWAP ( A:АДРЕС СЕГМЕНТА,N) DUP R@ 8 + @
1023 + 1024 / ( A,N,N,N1:ЧИСЛО ЭКРАНОВ)
CR ." СЕГМЕНТ ВЫГРУЖЕН НА ЭКРАНЫ: " + SWAP DO
I . ( AI:АДРЕС СЛЕДУЮЩЕЙ ПОРЦИИ) DUP I BUFFER
1024 CMOVE UPDATE 1024 +LOOP DROP
FLUSH R> (FORGET) ;
: СЕГМ-ЗАГР ( N:НОМЕР ЭКРАНА ---> ЗАГРУЗКА)
DUP BLOCK ( N,A0:АДРЕС ПЕРВОГО БЛОКА СЕГМЕНТА)
2DUP @ - IF DROP CR . ." - БЛОК ДЛЯ ЗАГРУЗКИ?"
ABORT THEN DUP 6 + 1 (FORGET) 2DUP
HERE ( N,A0,N,A0,A1:НАЧАЛО) SWAP 8 + @ ( N,A0,N,A1,L)
DUP ALLOT 1023 + 1024 / ( N,A0,N,A1,N1:ЧИСЛО ЭКР) ROT
DUP ROT + SWAP ( ...N1+N,N) DO I BLOCK OVER 1024 CMOVE
1024 + LOOP 2DROP ( N) BLOCK 10 + @ CURRENT @ ! ;

Слово СЕГМ-НАЧ строит заголовок сегмента, который располагается в его начале и содержит начальный номер экрана во внешней памяти, фиктивную словарную статью, адрес начала сегмента в оперативной памяти, длину сегмента и адрес начала его последней словарной статьи. Номер экрана определяется программистом при выгрузке сегмента во внешнюю память, впоследствии именно с этого экрана начинается его загрузка. Слово СЕГМ-ЗАГР проверяет, содержат ли первые 2 байта сегмента данный номер, и выдает сообщение об ошибке, если это не так.

Фиктивная словарная статья в заголовке сегмента аналогична полю параметров для слов, определенных через VOCABULARY , и служит для включения определений данного сегмента в список FORTH при загрузке сегмента. Она сцепляется с последней статьей списка FORTH на момент начала трансляции сегмента. При загрузке сегмента список FORTH устанавливается на последнее определение внутри данного сегмента. Таким образом, словарные статьи сегмента вновь включаются в словарь форт-системы. При изменениях состояний словаря, связанных с загрузкой и выгрузкой сегментов, в качестве вспомогательного используется слово (FORGET) , которое корректным образом понижает вершину словаря, исключая из него все системные ссылки на исключаемые статьи. В качестве параметра это слово использует новый адрес вершины словаря (см. модель форт-системы в приложении 1).
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Вт Апр 06, 2021 12:19 am

3.10.ЭЛЕМЕНТАРНАЯ МАШИННАЯ ГРАФИКА

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

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

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

В случае использования алфавитно-цифрового терминала задача состоит в том, чтобы отобразить в нем график функции, заданной вектором своих значений. Введем понятие вектора, элементы которого нумеруются от нуля, по аналогии со словом QUAN (см. п.3.4). Для получения адреса элемента вектора и для присваивания ему нового значения можно использовать те же слова AT и TO .

: ?+ ( N->N) DUP 0< ABORT" ОТРИЦАТЕЛЬНОЕ ЗНАЧЕНИЕ" ;
: В-АДР ( I:ИНДЕКС,PFA ---> A[I]:АДРЕС) 2DUP @ U<
IF SWAP 1+ 2* + EXIT THEN SWAP CR
. ." - НЕДОПУСТИМЫЙ ИНДЕКС ДЛЯ ВЕКТОРА "
BODY> BODY> BODY> >NAME ID. ABORT ;
: В-АДР0 DOES> ( I:ИНДЕКС,PFA ---> A[I]:АДРЕС) В-АДР ;
: В-ПРИСВ DOES> ( N:3НАЧ,I:ИНДЕКС,2CFA --->) 2+ В-АДР ! ;
: VQUAN ( N:ВЕРХН.ИНДЕКС --->) ?+ CREATE В-ПРИСВ HERE 2- @ ,
В-АДР0 HERE 4 - @ , 1+ DUP , 2* HERE SWAP DUP ALLOT
ERASE DOES> ( I:ИНДЕКС,1CFA ---> N[I]:ЗНАЧ) 4 + В-АДР @ ;
: В-РАЗМ ( ---> N:ЧИСЛО ЭЛЕМЕНТОВ)
' 6 + @ [COMPILE] LITERAL ; IMMEDIATE

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

( 18.06.86 SIN COS) ( ТАБЛИЦА СИНУСОВ ОТ 0 ДО 90 ГРАД.) HERE
00000 , 0175 , 0349 , 0523 , 0698 , 0872 , 1045 , 1219 , 1392 ,
1564 , 1736 , 1908 , 2079 , 2250 , 2419 , 2588 , 2756 , 2924 ,
3090 , 3256 , 3420 , 3584 , 3746 , 3907 , 4067 , 4226 , 4384 ,
4540 , 4695 , 4848 , 5000 , 5150 , 5249 , 5446 , 5592 , 5736 ,
5878 , 6018 , 6157 , 6293 , 6428 , 6561 , 6691 , 6820 , 6947 ,
7071 , 7193 , 7314 , 7431 , 7547 , 7660 , 7771 , 7880 , 7986 ,
8090 , 8192 , 8290 , 8387 , 8480 , 8572 , 8860 , 8746 , 8829 ,
8910 , 8988 , 9063 , 9135 , 9205 , 9772 , 9336 , 9397 , 9455 ,
9511 , 9563 , 9613 , 9659 , 9703 , 9744 , 9781 , 9816 , 9840 ,
9877 , 9903 , 9925 , 9945 , 9962 , 9976 , 9986 , 9994 , 9998 ,
10000 , : SIN180 ( N ---> SIN N, 0<=N<=180)
DUP 90 > IF 180 SWAP - THEN 2* [ DUP ] LITERAL + @ ; DROP
: SIN ( N->SIN N) 360 MOD DUP 0< IF 360 + THEN
DUP 180 > IF 180 - SIN180 NEGATE ELSE SIN180 THEN ;
: COS ( N>-COS N) 90 SWAP - SIN ;

Аналогично и другие элементарные функции можно с успехом вычислять по классическим итерационным схемам:

( DSQRT SQRT ИЗВЛЕЧЕНИЕ КОРНЯ ПО СХЕМЕ НЬЮТОНА)
: DSQRT ( D1 ---> D2) 2DUP
D0< ABORT" ОТРИЦАТЕЛЬНЫЙ АРГУМЕНТ"
2DUP 2. D< IF EXIT THEN
( ДАЛЕЕ ПО СХЕМЕ: X[0]=X/2; X[I+1]=X[I]/2+X/X[I]/2)
2DUP 2. D/ SWAP
BEGIN 2OVER 2OVER D/ 2OVER D+ 2. D/ 2SWAP 2OVER
D- DABS 2. D< UNTIL
2SWAP 2DROP ;
: SQRT ( N1 ---> N2) S>D DSQRT DROP ;

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

Используя описанные вспомогательные средства, можно задавать векторы со значениями интересующих нас функций. Работая с простыми значениями, будем пользоваться их описанием через слово QUAN . Пусть наша функция в обычной записи имеет вид: y = sin 3x + sin 120x. Зададим ее определение через введенные инструментальные определения, выбрав 100 в качестве масштабного множителя:

70 VQUAN U
: U! ( ---> УСТАНОВКА ВЕКТОРА U) В-РАЗМ U 0 DO
3 I * SIN 120 I * SIN + 100 / I TO U LOOP ;
U!

При желании можно проверить правильность установки значений, распечатав их как числа:

: B-? ( ---> РАСПЕЧАТКА ВЕКТОРА) >IN @ >R
[COMPILE] В-РАЗМ R> >IN ! ' SWAP 0 DO
I OVER EXECUTE 8 .R LOOP DROP ;
B-? U

В результате будет напечатан следующий текст:

0 93 -78 15 109 -62 30 124
-47 45 138 -34 58 151 -21 70
162 -10 80 172 0 9 179 4
95 185 9 98 188 11 100 188
10 9 186 7 95 181 2 89
177 -4 80 166 -14 70 155 -25
-67 15 99 -83 0 83 -99 -15
67 -114 -30 52 -129 -45 OK

Для построения графика определим список слов PLOT (график) и в нем ряд вспомогательных переменных:

VOCABULARY PLOT PLOT DEFINITIONS
QUAN RHO 4 TO RHO ( ШИРИНА СТОЛБЦА ДЛЯ Y-КООРД.)
QUAN MU0 16 TO MU0 ( МАКСИМАЛЬНАЯ ВЫСОТА ОКНА)
QUAN NU0 64 RHO - TO NU0 ( МАКСИМАЛЬНАЯ ШИРИНА ОКНА)
QUAN MSTA ( АДРЕС НАЧАЛА ОКНА)
QUAN MU ( ТЕКУЩАЯ ВЫСОТА ОКНА)
QUAN NU ( ТЕКУЩАЯ ШИРИНА ОКНА)
QUAN WX ( X-КООРДИНАТА ОКНА)
QUAN WY ( Y-КООРДИНАТА ОКНА)
QUAN KAPPA ( ЧИСЛО ЗНАЧЕНИЙ СИГНАЛА)
QUAN LAMBDA ( ДИАПАЗОН ЗНАЧЕНИЙ СИГНАЛА)
QUAN MA ( МАКСИМАЛЬНОЕ ЗНАЧЕНИЕ СИГН.)
QUAN MIN0 ( МИНИМАЛЬНОЕ ЗНАЧЕНИЕ В ОКНЕ)
QUAN VAL ( ВЕКТОР СИГНАЛА)

Пусть прямоугольный экран терминала, на котором строится график, содержит MU0 строк по NU0 литер каждая. Первые RH0 позиций в каждой строке занимает надпечатка ее координаты по оси ординат. Общий размер графика определяется значениями LAMBDA (диапазон значений функций) и KAPPA (число значений). Этот прямоугольник может как умещаться целиком на экране терминала, так и заметно превышать его. Определим понятие "окна", которое перемещается по графику и показывает на экране терминала соответствующую его часть. Переменные WX и WY задают координаты левого верхнего угла окна относительно левого верхнего угла графика. Определим слова, выполняющие инициализацию и перемещение окна по полю графика:

FORTH DEFINITIONS PLOT
: НАЧАТЬ ( ---> ИНИЦИАЛИЗАЦИЯ) PLOT
HERE NU0 MU0 * ALLOT TO WSTA ;
PLOT DEFINITIONS
: ВВЕРХ ( N ---> СДВИНУТЬ ОКНО НА N ПОЗИЦИЙ ВВЕРХ)
?+ WY SWAP - 0 MAX TO WY ;
: ВЛЕВО ( N ---> СДВИНУТЬ ОКНО НА N ПОЗИЦИЙ ВЛЕВО)
?+ WX SWAP - 0 MAX TO WX ;
: ВНИЗ ( N ---> СДВИНУТЬ ОКНО НА N ПОЗИЦИЙ ВНИЗ)
?* WY + MU + LAMBDA MIN MU - TO WY ;
: ВПРАВО ( N ---> СДВИНУТЬ ОКНО НА N ПОЗИЦИИ ВПРАВО)
?+ WX + NU * KAPPA MIN NU - TO WX ;

Определим также слова для вычисления параметров графика и распечатки окна по его текущим координатам. Вспомогательное слово MU по значению функции определяет, где находится соответствующая точка графика: ниже окна, внутри или выше него. Если точка попадает в окно, будем отмечать ее положение знаком * (звездочка), а если точка находится выше или ниже окна, то соответственно в самой верхней или самой нижней строке окна поставим знак + (плюс), чтобы видеть направление, в котором следует искать данную точку на графике. Ось абсцисс, если она попадает в окно, будем отмечать строкой из знаков "минус". Надпечатку координат по оси абсцисс будем выполнять дважды - в верхней и нижней строках терминала.

: -MU ( N:ЗНАЧЕНИЕ ---> -1:НИЖЕ ОКНА/
M:СМЕЩЕНИЕ ОТ ВЕРХА ОКНА ВНИЗ,0/
+1:ВЫШЕ ОКНА )
MIN0 - DUP 0< IF DROP -1 EXIT THEN
MU 1- SWAP - DUP 0< IF DROP 1 EXIT THEN 0 ;
: ФУНКЦИЯ ( ---> СЛЕДУЮЩЕЕ СЛОВО: ИМЯ ВЕКТОРА ЗНАЧЕНИЙ)
>IN @ >R [COMPILE] В-РАЗМ R> >IN !
DUP TO KAPPA NU0 MIN TO NU ' TO VAL
( ВЫЧИСЛЕНИЕ MA И LAMBDA )
0 VAL DUP ( X[0],X[0] )
KAPPA 0 DO I VAL ( MIN[I-1],MAX[I-1],X[I] )
DUP >R MAX SWAP R> MIN ( MAX[I],MIN[I]) SWAP LOOP
DUP TO MA SWAP - 1+ DUP TO LAMBDA MU0 MIN TO MU
0 TO WX 0 TO WY ;
: ОСЬ-X ( НАДПЕЧАТКА ОСИ X) CR RH0 SPACES WX NU 1- RH0 - WX
BEGIN DUP 10 MOD DUP IF 10 SWAP - THEN DUP >R + 2DUP >=
WHILE R> SPACES C" ! EMIT DUP 0 <# #S #> DUP >R TYPE
1+ R> + REPEAT RDROP 2DROP ;
: ГРАФИК ( ---> РИСОВАТЬ ГРАФИК ПО СИГНАЛУ И КООРДИНАТАМ ОКНА)
MA WY - MU 1- - TO MIN0 ( УСТАНОВИТЬ MIN0)
WSTA MU NU * BLANK ( ЗАЧИСТИТЬ ОКНО)
0 -MU 0= IF NU * WSTA + NU C" - FILL THEN ( ПРОВЕСТИ ОСЬ X)
( ЦИКЛ ПО ОСИ X ДЛЯ ЗАПОЛНЕНИЯ ОКНА) WX NU + WX DO
I VAL ( X[I]) -MU DUP IF ( ВНЕ ОКНА) 1+ IF ( ВЫШЕ ОКНА)
C" + 0 ELSE ( НИЖЕ ОКНА) C" + MU 1- THEN
ELSE DROP C" * SWAP THEN
NU * I WX - + WSTA + C! LOOP
ОСЬ-X MU 0 DO CR MA WY - I - RH0 .R I NU * WSTA +
NU TYPE LOOP ОСЬ-X ;

Следующий протокол показывает работу введенных определений по вычерчиванию графика интересующей нас функции:

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 G9bn1010

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 G9bn1110

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

ГРАФИК XY X ОТ 0 ДО 4 ШАГ 1
Y ЛОГАРИФМ ОТ 1 ДО 100
Х ШТРИХ РАЗМЕР 0.25 РАМКА
ЗАГОЛОВОК" ЧЕРТЕЖ 1" РИСУЙ

В результате будет нарисована прямоугольная рамка с заголовком "ЧЕРТЕЖ 1" надпечаткой оси абсцисс в виде штрихов, пересекающих рамку, и логарифмической разметкой оси ординат. Огромное число других значений, необходимых для построения чертежа, принимается по умолчанию. Далее можно начертить собственно график функции, используя, например, ее задание через вектор значений:

ФУНКЦИЯ U МАСШТАБ 100 ЦВЕТ КРАСНЫЙ РИСУЙ

Аналогично наносим на чертеж дополнительные элементы:

ПОДЗАГОЛОВОК ВПРАВО
ТЕКСТ" Y=SIN 3X + SIN 120X" РИСУЙ

и т.д. Указанные действия можно не только непосредственно исполнять, но и компилировать, задавая впоследствии их исполнение через одно слово - имя скомпилированной программы.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Ср Апр 07, 2021 12:27 am

3.11.РЕАЛИЗАЦИЯ ВСТРОЕННОГО АССЕМБЛЕРА

Приводимый ниже текст является законченной реализацией встроенного структурного ассемблера для форт-систем на базе микропроцессора К580. В оттранслированном виде он занимает около 1300 байт и является типичным для 8-разрядных микропроцессоров. Для 16- или 32-разрядных процессоров в силу их большей сложности объем текста больше. Но даже в этом случае объем исходного текста и скомпилированного кода существенно меньше, чем для традиционных ассемблеров.

( FORTH-83 АССЕМБЛЕР ДЛЯ К580 ТЕМАШКИНО 1985 )
VOCABULARY ASSEMBLER
ASSEMBLER DEFINITIONS

( МАШИННЫЕ КОМАНДЫ )
DECIMAL : 8* 2* 2* 2* ;
4 CONSTANT H 5 CONSTANT L 7 CONSTANT A 6 CONSTANT PSW
2 CONSTANT D 3 CONSTANT E 0 CONSTANT B 1 CONSTANT C
6 CONSTANT M 6 CONSTANT SP
: 1MI ( ---> ) CREATE C, DOES> C@ C, ;
: 2MI ( ---> ) CREATE C, DOES> C@ + C, ;
: 3MI ( ---> ) CREATE C, DOES> C@ SWAP 8* + C, ;
: 4MI ( ---> ) CREATE C, DOES> C@ C, C, ;
: 5MI ( ---> ) CREATE C, DOES> C@ C, , ;

HEX
00 1MI NOP 76 1MI HLT F3 1MI DI FB 1MI EI
07 1MI RLC 0F 1MI RRC 17 1MI RAL 1F 1MI RAR
E9 1MI PCHL F9 1MI SPHL E3 1MI XTHL EB 1MI XCHG
27 1MI DAA 2F 1MI CMA 37 1MI STC 3F 1MI CMC
80 2MI ADD 88 2MI ADC 90 2MI SUB 98 2MI SBB
A0 2MI ANA A8 2MI XRA B0 2MI CRA B8 2MI CMP
09 3MI DAD C1 3MI POP C5 3MI PUSH 02 3MI STAX
0A 3MI LDAX 04 3MI INR 05 3MI DCR 03 3MI INX
0B 3MI DCX C7 3MI RST D3 4MI OUT DB 4MI IN
C6 4MI ADI CE 4MI ACI D6 4MI SU1 DE 4MI SBI
E6 4MI ANI EE 4MI XRI F6 4MI ORI FE 4MI CPI
22 5MI SHLD 2A 5MI LHLD 32 5MI STA 3A 5MI LDA
C4 5MI CNZ CC 5MI CZ D4 5MI CNC DC 5MI CC
E4 5MI CPO EC 5MI CPE F4 5MI CP FC 5MI CM
CD 5MI CALL C9 1MI RET C3 5MI JMP
C0 1MI RNZ C8 1MI RZ D0 1MI RNC DB 1MI RC
E0 1MI RPO E8 1MI RPE F0 1MI RP F8 1MI RM
C2 5MI JNZ CA 5MI JZ D2 5MI JNC DA 5MI JC
E2 5MI JPO EA 5MI JPE F2 5MI JP FA 5MI JM

: MOV SWAP 8* 40 + + C, ;
: MVI SWAP 8* 6 + C, C, ;
: LXI SWAP 8* 1 + C, , ;

( КОДЫ УСЛОВИЙ ДЛЯ СТРУКТУР УПРАВЛЕНИЯ )
C2 CONSTANT 0= D2 CONSTANT CS
E2 CONSTANT PE F2 CONSTANT 0<

( СТРУКТУРЫ УПРАВЛЕНИЯ )
DECIMAL
: NOT ( N:КОД УСЛОВИЯ ---> N1) 8 + ;
: THEN ( АДР,2 ---> ) 2 ?PAIRS HERE SWAP ! ;
: IF ( КОД ---> АДР,2 ) C, HERE 0 , 2 ;
: ELSE ( АДР,2 ---> АДР1,2) 2 ?PAIRS C3 IF ROT SWAP THEN 2 ;
: BEGIN ( ---> АДР,1 ) HERE 1 ;
: UNTIL ( АДР,1,КОД --->) SWAP 1 ?PAIRS С, , ;
: AGAIN ( АДР,1 --->) 1 ?PAIRS C3 C, , ;
: WHILE ( АДР,1,КОД ---> АДР,1,АДР1,4) IF 2 + ;
: REPEAT ( АДР,1,АДР1,4 --->) >R >R AGAIN R> R> 2- THEN ;

( РАБОТА С МЕТКАМИ )
10 CONSTANT LBLMAX ( МАКСИМАЛЬНОЕ ЧИСЛО ЛОКАЛЬНЫХ МЕТОК)
VARIABLE LTABLE LBLMAX 1+ 2* ALLOT
10 CONSTANT FRMAX ( МАКСИМАЛЬНОЕ ЧИСЛО ССЫЛОК ВПЕРЕД)
VARIABLE FRTABLE FRMAX 2* 2* ALLOT
: FRCHK ( ---> ПРОВЕРКА НЕРАЗРЕШЕННЫХ ССЫЛОК ВПЕРЕД )
FRMAX 0 DO I 2* 2* FRTABLE + @
ABORT" НЕРАЗРЕШЕННАЯ ССЫЛКА ВПЕРЕД"
LOOP ;
: FRCLR ( ---> ИНИЦИАЛИЗАЦИЯ ТАБЛИЦЫ ССЫЛОК ВПЕРЕД )
FRTABLE FRMAX 2* 2* ERASE
LTABLE LBLMAX 1+ 2* ERASE ;
: FRRES ( N:МЕТКА ---> РАЗРЕШЕНИЕ ССЫЛОК ВПЕРЕД )
FRMAX 0 DO I 2* 2* FRTABLE + 2DUP @ =
IF HERE OVER 2+ @ +! 0!
ELSE DROP THEN
LOOP ;
: FRADD ( N:МЕТКА ---> ДОБАВЛЕНИЕ ССЫЛКИ ВПЕРЕД В ТАБЛИЦУ )
FRMAX 1+ 0
DO FRMAX I = ABORT" СЛИШКОМ МНОГО ССЫЛОК ВПЕРЕД"
I 2* 2* FRTABLE + DUP @ 0=
IF 2DUP ! HERE 1+ SWAP 2+ ! LEAVE ELSE DROP THEN
LOOP ;

( ОПРЕДЕЛЯЮЩИЕ ВХОЖДЕНИЯ МЕТОК )
: !LT CREATE , DOES> @ FRRES HERE SWAP 2* LTABLE + ! ;
( ИСПОЛЬЗУЮЩИЕ ВХОЖДЕНИЯ МЕТОК )
: @LT CREATE , DOES> @ DUP 2*
LTABLE + @ SWAP OVER 0=
IF FRADD THEN DROP ;
1 !LT 1#: 2 !LT 2#: 3 !LT 3#: 4 !LT 4#! 5 !LT 5#:
6 !LT 6#: 7 !LT 7#: 8 !LT 8#: 9 !LT 9#! 10 !LT 10#:
1 @LT 1# 2 @LT 2# 3 @LT 3# 4 @LT 4# 5 @LT 5#
6 @LT 6# 7 @LT 7# 8 @LT 8# 9 @LT 9# 10 @LT 10#

( ПЕРЕКЛЮЧЕНИЕ В АССЕМБЛЕР )
FORTH DEFINITIONS
: BEG-ASM [ ASSEMBLER ] FRCLR [ FORTH ] ASSEMBLER
!CSP ;
: END-ASM [ ASSEMBLER ] FRCHK [ FORTH ] ?CSP

(Здесь листинг обрывается.- G.)

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

Машинные команды на языке ассемблера записываются в обратной польской форме, принятой для языка Форт: <операнды> <операция>, где <операнды> - слова, вычисляющие на стеке размещения операндов данной машинной команды, а <операция> - ее мнемоника. Для обозначения регистров микропроцессора К580 зарезервированы слова А В С D E H L , для задания регистровых пар используются слова В D H SP PSW , для косвенной адресации через регистровую пару HL - слово M . При исполнении слов, обозначающих регистры, регистровые пары и косвенную адресацию, на стеке оставляются значения, соответствующие принятым в системе команд К580 обозначениям для регистров и регистровых пар:

ABCDEHLMSPPSW
7012345666

При исполнении мнемоники машинной команды на вершину словаря компилируется соответствующая машинная инструкция. Размещения операндов при этом снимаются со стека. Порядок вычисления операндов машинной команды соответствуют порядку написания операндов на обычном языке ассемблера.

Ниже приведены для сравнения записи машинных команд на обычном языке ассемблера и на языке ассемблера данной форт-системы:

HLTHLT
DAD SPSP DAD
PUSH PSWPSW PUSH
CMP CC CMP
MOV A,MA M MVI
MVI B,2B 2 MVI
LXI 0,120+8D 120 8 + LXI
CALL 5002HHEX 5002 CALL DECIMAL

Для определения мнемоник используются определяющие слова, соответствующие форматам машинных команд ( 1MI , ..., 5MI ). Все они имеют одинаковую создающую часть, которая компилирует в поле параметров статьи для мнемоники однобайтный код маски для кода данной команды, который снимается со стека. Исполняющая часть определений, используя маску и размещения операндов, которые она снимает со стека, компилирует двоичный код, соответствующий данной команде. Так, например, через елово 1MI определяются машинные команды, не имеющие операндов. При исполнении мнемоники такой команды на вершину словаря компилируется однобайтный код операции. Слово 3MI определяет мнемоники команд, имеющих один операнд - номер регистра. Этот номер занимает разряды со 2 по 4 в однобайтном коде команды. Поэтому исполняющая часть сдвигает свой операнд - номер регистра - влево на 3 разряда исполнением слова 8* и добавляет к нему маску команды. Получившийся однобайтный код компилируется на вершину словаря. Три команды - MOV, MVI и LXI - не подходят под описанные общие форматы, поэтому они определяются непосредственно через двоеточие.

Структурные операторы встроенного ассемблера позволяют программировать разветвления и циклы без явно заданных команд перехода на метку. Их синтаксис аналогичен синтаксису соответствующих операторов языка Форт.

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

<КОД-УСЛОВИЯ> IF <ЧАСТЬ-ТО> ELSE <ЧАСТЬ-ИНАЧЕ> THEN
<КОД-УСЛОВИЯ> IF <ЧАСТЬ-ТО> THEN

Часть "то" выполняется, только если в разрядах PSW установлен заданный "код условия", в противном случае выполняется часть "иначе", если она есть.

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

BEGIN <ТЕЛО-ЦИКЛА> AGAIN
BEGIN <ТЕЛО-ЦИКЛА> <КОД-УСЛОВИЯ> UNTIL
BEGIN <ТЕЛО-1> <КОД-УСЛОВИЯ> WHILE <ТЕЛО-2> REPEAT

Цикл BEGIN-AGAIN является бесконечным, BEGIN-UNTIL прекращает выполнение при к указанном коде условия, в цикле BEGIN-WHILE-REPEAT, наоборот, указанный код условия задает продолжение цикла.
Для указания кода условия в ассемблере используются следующие слова: 0= - установлен флаг Z , 0< - флаг S , CS - флаг C , PE - флаг P . Для инвертирования кода условия используется слово NOT.

Структурные операторы компилируют на своем месте команды безусловных и условных переходов с указанным условием.

Для работы с явно задаваемыми метками в ассемблер включены слова вида 1#: 2#: ... 10#: и 1# 2# ... 10# . Слова первой группы задают определение метки, слова второй - использование. Метки имеют строго локальный характер, т.е. эти слова можно использовать только внутри определений через CODE и между словами ;CODE и END-CODE. Наряду с метками допускается использование ассемблерных структур управления.

Локальные метки рекомендуется использовать только в трехбайтных командах типа JMP , CALL , LXI . Уже определенные локальные метки могут участвовать в арифметических и стековых операциях; использующие вхождения меток, определяющие вхождения которых вводятся позднее (ссылки вперед), могут участвовать только в операциях, сводящихся к добавлению к ним числа со знаком.

Для реализации работы с метками ассемблер имеет таблицу меток LTABLE и таблицу ссылок вперед FRTABLE. Их размер определяет максимальное число разных меток и ссылок вперед в пределах одного определения в машинном коде (от слова CODE или ;CODE до слова END-CODE ). Для каждой возможной метки соответствующий элемент таблицы LTABLE содержит нуль, если метка еще не определена, или адрес, который является ее значением, если метка уже определена. Входом в эту таблицу служит номер метки. В таблице FRTABLE для каждой ссылки вперед хранятся два значения: номер метки и адрес в словаре, по которому нужно вписать ее значение. По этому адресу скомпилировано значение смещения, которое нужно добавить как число со знаком к значению данной метки.

Слова для использующих вхождений меток определяются через @LT, например 1 @LT 1# . Исполнение определенного таким образом слова 1#, обозначающего метку номер 1, состоит в обращении к таблице LTABLE по индексу 1. Если там стоит нуль, т. е. метка номер 1 еще не определена, то этот нуль выдается на стек в качестве смещения от значения метки, которое определится позднее. Одновременно в таблицу FRTABLE заносится запись о данной ссылке вперед. В качестве адреса, куда нужно будет впоследствии вписать значение метки, берется HERE 1+ . Здесь используется тот факт, что в микропроцессоре К580 операнд-адрес занимает 2 байта, следующие за однобайтным кодом операции.

Слова для определения меток определяются через слово !LT , например 1 !LT 1#: . Исполнение определенного таким образом слова 1#: определяет метку номер 1 как текущий адрес вершины словаря HERE . Его действие состоит в том, что выполняется просмотр таблицы FRTABLE с разрешением всех накопившихся ссылок на данную метку, после чего запись о данной метке заносится в таблицу LTABLE .

Последнюю группу определений составляют слова для доступа к встроенному ассемблеру при компиляции машинного кода. Помимо стандартных форт-слов CODE , ;CODE и END-CODE здесь определяются слова LABEL и NEXT; . Первое используется для создания именованных подпрограмм, к которым можно обращаться из машинного кода. Второе является сокращением для часто встречающегося окончания ассемблерных определений: NEXT JMP END-CODE . В качестве примера приведем определение слова >< , которое меняет местами байты в переданном на стеке двухбайтном значении:

CODE >< ( N1 ---> N2) H POP
A L MOV L H MOV H A MOV H PUSH NEXT;

Приведенная реализация встроенного ассемблера может быть усовершенствована по нескольким направлениям. Прежде всего, увеличив константы LBLMAX и FRMAX и добавив новые определения для слов, обозначающих метки, можно увеличить количество разных меток и ссылок вперед, которые разрешается использовать в ассемблерном определении. Далее можно ввести контроль правильности операндов, включив соответствующие проверки в исполняющую часть определяющих слов для мнемоник команд. Для проверки числа элементов на стеке обычно используется глобальная ячейка CSP и слово !CSP , которое засылает в нее текущий адрес вершины стека. Интересным расширением является возможность введения макрокоманд. Макрокоманды без локальных меток можно определять обычным образом через двоеточие:

INRN ( R:РЕГИСТР,H:ЧИСЛО РАЗ ---> )
[ ABSEMBLER ] 0 DO DUP INR LOOP DROP ;

При исполнении текста А 3 INRN будут скомпилированы три команды А INR. Если же макрорасширение должно порождать обращения к адресам через локальные метки, то потребуется более основательное расширение ассемблера.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Чт Апр 08, 2021 12:53 am

ПРИЛОЖЕНИЕ 1.
МОДЕЛЬ ФОРТ-СИСТЕМЫ

Приводимый ниже текст представляет собой ядро системы ФОРТ-ЕС (см. приложение 2), из которого исключены запускающая часть и реализации слов нижнего уровня для обмена с терминалом и внешней памятью. Общий объем ядра-8 К байт (свыше 200 слов). Текст состоит из двух частей - списка слов с их краткими спецификациями и экранов с определениями на встроенном языке ассемблера и на языке Форт.

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

Адресные операнды FIRST и SECOND обозначают соответственно первый и второй элементы стека. Макрокоманды PUSH, , POP, и PULL, можно рассматривать как команды с одним регистровым операндом. Операция PUSH, помещает на стек значение из регистра, POP, снимает верхнее значение со стека, засылая его в регистр, и PULL, копирует верхнее значение стека в регистр.

Кроме того, в ассемблерных определениях используются локальные метки [11, с.191], обозначаемые целыми числами и словами =F (для ссылки вперед) и =В (для ссылки назад). Определяется локальная метка через слово =Н, которое полагает ее равной текущему значению счетчика адреса.

Регистры общего назначения обозначаются специальными словами и имеют следующий смысл:
RW1 - рабочий регистр, старший в паре;
RW2 - рабочий регистр, младший в паре;
RI - указатель адресного интерпретатора;
RRET - абсолютный адрес вершины стека возвратов;
RSTACK - абсолютный адрес вершины стека данных;
RD - форт-адрес текущей вершины словаря;
RFORTH - абсолютный адрес начала словаря, соответствующий нулевому форт-адресу;
RNEXT - адрес точки NEXT адресного интерпретатора (тот же адрес, что и в RFORTH);
RTWO - константа 2;
RMASK - константа 65535.

Предполагается также, что в регистре 13 находится адрес области сохранения и регистры 0, 1, 14, 15 свободно используются внутри определений как рабочие.

Тексты определений представлены в виде распечаток стандартных форт-текстов и занимают экраны с номерами от 1 до 47. В последнем столбце спецификации для каждого слова указан номер экрана, на котором оно определено. Главным словом модели является слово ФОРТ-СИСТЕМА .

В списке спецификаций слова расположены по возрастанию в кодировке ДКОИ. Они могут иметь следующие отметки:
А - адрес;
М - метка;
Н - слово немедленного исполнения;
К - требуется режим компиляции;
П - переменная, размещенная в пользовательской области;
С - системная переменная, размещенная в словаре;
Э - требуется режим обработки экрана;
+ - слово из дополнения к стандарту "Форт-83";
* - нестандартное слово.

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

Для задания параметров и результатов, передаваемых через стек даннцх, используются следующие обозначения:
+N - неотрицательное целое со знаком;
А - двухбайтный форт-адрес;
С - однобайтное значение (старший байт, как правило, нулевой);
CFA - двухбайтный адрес поля кода словарной статьи;
D - четырехбайтное целое со знаком;
F - булевское значение (0 - ЛОЖЬ, не 0 - ИСТИНА);
FF - булевское значение ЛОЖЬ (0);
L - абсолютный машинный адрес (четырехбайтный);
LFA - двухбайтный адрес поля словарной статьи;
N - двухбайтное целое со знаком;
NFA - двухбайтный адрес поля имени словарной статьи;
PFA - двухбайтный адрес поля параметров словарной статьи;
Т - двухбайтный адрес строки со счетчиком;
TF - булевское значение ИСТИНА (не 0, обычно -1);
U - двухбайтное целое без знака;
UD - четырехбайтное целое без знака;
W - двухбайтное целое со знаком или без него (N или U);
WD - четырехбайтное целое со знаком или без него (D или UD).

Для некоторых слов указаны две группы результатов, отделяемые друг от друга косой чертой (/). Они различаются по булевскому значению на вершине стека: не 0 (ИСТИНА) означает успех, 0 (ЛОЖЬ) - неудачу.

....
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Чт Апр 08, 2021 12:55 am

->(ПУСТОЕ СЛОВО) - ЗАКОНЧИТЬ ИНТЕРПРЕТАЦИЮ ВХОДНОГО ПОТОКА40
[Н->ПЕРЕКЛЮЧИТЬ ТЕКСТОВЫЙ ИНТЕРПРЕТАТОР В РЕЖИМ ИСПОЛНЕНИЯ22
[']НК-> /КОМПИЛЯЦИЯ/
->CFA /ИСПОЛНЕНИЕ/
СКОМПИЛИРОВАТЬ CFA СЛЕДУЮЩЕГО СЛОВА КАК ЧИСЛОВОЙ ЛИТЕРАЛ41
[COMPILE]НК->СКОМПИЛИРОВАТЬ СЛЕДУЮЩЕЕ СЛОВО НЕЗАВИСИМО ОТ ЕГО ПРИЗНАКА "IMMEDIATE"41
.N->НАПЕЧАТАТЬ N НА ТЕРМИНАЛЕ И ДАТЬ ПРОБЕЛ38
.(Н->НАПЕЧАТАТЬ СЛЕДУЮЩИЕ ЛИТЕРЫ ДО ЗАКРЫВАЮЩЕЙ СКОБКИ ИСКЛЮЧИТЕЛЬНО28
."НК->ПРИ ИСПОЛНЕНИИ НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ СЛЕДУЮЩИЕ ЛИТЕРЫ ДО КАВЫЧКИ ИСКЛЮЧИТЕЛЬНО28
.R+N1,+N2->НАПЕЧАТАТЬ N1 НА ТЕРМИНАЛЕ В ПОЛЕ ДЛИНЫ +N2 СПРАВА38
.VOC*PFA+2->НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ ИМЯ СЛОВАРНОЙ СТАТЬИ ДЛЯ СПИСКА СЛОВ43
<N1,N2->FF НЕ НУЛЬ, ЕСЛИ N1 МЕНЬШЕ N249
<>+W1,W2->FF НЕ НУЛЬ, ЕСЛИ N1 НЕ РАВНО N214
<#->НАЧАТЬ ФОРМАТНОЕ ПРЕОБРАЗОВАНИЕ37
<MARKК->АОТМЕТИТЬ ТЕКУЩИЙ АДРЕС ДЛЯ ССЫЛКИ НАЗАД19
<RESOLVEКА->РАЗРЕШИТЬ ССЫЛКУ НАЗАД В АДРЕС А19
(Н->КОММЕНТАРИИ - ПРОПУСТИТЬ СЛЕДУЮЩИЙ ТЕКСТ ДО ЗАКРЫВАЮЩЕЙ КРУГЛОЙ СКОБКИ28
(.")->ПРОЦЕДУРА, КОМПИЛИРУЕМАЯ В ".""28
(+LOOP)*N->ТЕСТ НА ЗАВЕРШЕНИЕ ЦИКЛА "DO +LOOP" С ШАГОМ N5
(;CODE)->ЗАПИСАТЬ В ПОЛЕ КОДА ПОСЛЕДНЕЙ СТАТЬИ СЛЕДУЮЩИЙ АДРЕС И ЗАКОНЧИТЬ ОПРЕДЕЛЕНИЕ31
(#SCR)*N->А,ТПЕРЕВЕСТИ НОМЕР ЗКРАНА N В ТЕКСТ46
(A")*F->ПРОЦЕДУРА, КОМПИЛИРУЕМАЯ В "ABORT""29
(DO)W1,W2->ВХОД В ЦИКЛ СО СЧЕТЧИКОМ ОТ N2 ДО N124
(EXPECT)*А,+N1->А,+N2ВВЕСТИ С ТЕРМИНАЛА +N1 ЛИТЕР ПО АДРЕСУ А ДО ПЕРЕВОДА СТРОКИ; +N2 - ФАКТИЧЕСКОЕ ЧИСЛО ВВЕДЕННЫХ ЛИТЕР6
(FIND)*-1,AN,,,A1,T->CFA,C,TF/FFИСКАТЬ СЛОВО T В СПИСКАХ A1,,,AN; ПРИ УСПЕХЕ ДАТЬ CFA ЕГО СТАТЬИ И C - БАЙТ ДЛИНЫ С ПРИЗНАКАМИ34
(FORGET)*A->УДАЛИТЬ СЛОВАРНЫЕ СТАТЬИ ПОСЛЕ АДРЕСА A45
(LOOP)*->ТЕСТ НА ЗАВЕРШЕНИЕ ЦИКЛА "DO LOOP"5
(VOC)*PFA1+2->PFA2,N/0,NДАТЬ ЧИСЛО СТАТЕЙ N В СПИСКЕ PFA1+2 И PFA СЛЕДУЮЩЕГО СПИСКА ИЛИ НУЛЬ, ЕСЛИ ЕГО НЕТ43
+W1,W2->W3СУММА ЧИСЕЛ W1 И W217
+!W,A->УВЕЛИЧИТЬ ЗНАЧЕНИЕ ПО АДРЕСУ A НА W17
+BUF*A1->A2,FПЕРЕЙТИ К СЛЕДУЮЩЕМУ БУФЕРУ В ПУЛЕ25
+LOOPНКA1,A2,3-> /КОМПИЛЯЦИЯ/
N-> /ИСПОЛНЕНИЕ/
КОНЕЦ ЦИКЛА "DO +LOOP" С ШАГОМ N47
!W,A->ЗАСЛАТЬ ЗНАЧЕНИЕ W ПО АДРЕСУ A11
!CSP*->ЗАПОМНИТЬ АДРЕС ВЕРШИНЫ СТЕКА В "CSP"29
]->ПЕРЕКЛЮЧИТЬ ТЕКСТОВЫЙ ИНТЕРПРЕТАТОР В РЕЖИМ КОМПИЛЯЦИИ22
*N1,N2->N3ПРОИЗВЕДЕНИЕ ЧИСЕЛ N1 И N213
*/N1,N2,N3->N4ЧАСТНОЕ ОТ ДЕЛЕНИЯ N1*N2 НА N318
*/MODN1,N2,N3->N4,N5ОСТАТОК N4 И ЧАСТНОЕ N5 ОТ ДЕЛЕНИЯ ПРОИЗВЕДЕНИЯ N1*N2 НА N318
;HK->ЗАКОНЧИТЬ ОПРЕДЕЛЕНИЕ ЧЕРЕЗ ДВОЕТОЧИЕ32
;S+НЭ->ЗАКОНЧИТЬ ИНТЕРПРЕТАЦИЮ ЗКРАНА41
-W1,W2->W3ВЫЧЕСТЬ W2 ИЗ W117
->+HЭ->ИНТЕРПРЕТИРОВАТЬ СЛЕДУЮЩИЙ ЭКРАН41
-FIND*->A,NВВЕСТИ СЛОВО И ИСКАТЬ В СЛОВАРЕ; РЕЗУЛЬТАТ ТОТ ЖЕ, ЧТО И У "FIND"35
-TRAILINGA,N1->A,N2ОТСЕЧЬ КОНЕЧНЫЕ ПРОБЕЛЫ41
/N1,N2->N3ЧАСТНОЕ ОТ ДЕЛЕНИЯ N1 НА N218
/MODN1,N2->N3,N4ОСТАТОК N3 И ЧАСТНОЕ N4 ОТ ДЕЛЕНИЯ N1 НА N216
,W->СКОМПИЛИРОВАТЬ W НА ВЕРШИНУ СЛОВАРЯ11
,"*->СКОМПИЛИРОВАТЬ СТРОКУ СО СЧЕТЧИКОМ28
>N1,N2->FF НЕ НУЛЬ, ЕСЛИ N1 БОЛЬШЕ N219
>=*N1,N2->FF НЕ НУЛЬ, ЕСЛИ N1 НЕ МЕНЬШЕ N219
>BODYCFA->PFAПЕРЕЙТИ ОТ ПОЛЯ КОДА К ПОЛЮ ПАРАМЕТРОВ30
>INП->АПЕРЕМЕННАЯ - СМЕШЕНИЕ ОЧЕРЕДНОЙ ЛИТЕРЫ ВО ВХОДНОМ ТЕКСТОВОМ БУФЕРЕ ИЛИ ЭКРАНЕ8
>LINK*CFA->LFAПЕРЕЙТИ ОТ ПОЛЯ КОДА К ПОЛЮ СВЯЗИ30
>MARKК->АОТМЕТИТЬ ТЕКУЩИЙ АДРЕС ДЛЯ ССЫЛКИ ВПЕРЕД19
>NAME*CFA->NFAПЕРЕЙТИ ОТ ПОЛЯ КОДА К ПОЛЮ ИМЕНИ30
>RКW->ПЕРЕНЕСТИ W НА СТЕК ВОЗВРАТОВ9
>RESOLVEКА->РАЗРЕШИТЬ ССЫЛКУ ВПЕРЕД В АДРЕСЕ А19
?*А->НАПЕЧАТАТЬ ЗНАЧЕНИЕ ПО АДРЕСУ А38
?+*+N->+NПРОВЕРИТЬ, ЧТО +N НЕОТРИЦАТЕЛЬНО29
?ABORT*F,T->ЕСЛИ F НЕ НУЛЬ, ТО НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ СТРОКУ Т И УЙТИ НА "ABORT"29
?BRANCHКF->ЕСЛИ F "ЛОЖЬ", ТО КАК "BRANCH", ИНАЧЕ ПРОДОЛЖИТЬ ИНТЕРПРЕТАЦИЮ ОТ АДРЕСА, СЛЕДУЮЩЕГО ЗА АДРЕСОМ ПЕРЕХОДА5
?COMP*->ПРОВЕРИТЬ, ЧТО ТЕКУЩИИ РЕЖИМ - КОМПИЛЯЦИЯ29
?CSP*->ВЫДАТЬ ОШИБКУ "СБИЛСЯ УКАЗАТЕЛЬ СТЕКА", ЕСЛИ ОН НЕ РАВЕН ЗНАЧЕНИЮ В "CSP"29
?DUPW->W,WПРОДУБЛИРОВАТЬ W, ЕСЛИ ЭТО НЕ НУЛЬ9
?GAP*N->ВЫДАТЬ ОШИБКУ "ИСЧЕРПАНИЕ ПАМЯТИ", ЕСЛИ ЗАЗОР МЕЖДУ ВЕРШИНАМИ СТЕКА И СЛОВАРЯ МЕНЕЕ N БАЙТОВ29
?LOADING*->ВЫДАТЬ ОШИБКУ "НЕТ ОБРАБОТКИ ЭКРАНА", ЕСЛИ ВХОДНОЙ ТЕКСТ ИДЕТ НЕ С ЭКРАНА29
?PAIRS*W1,W2->ВЫДАТЬ ОШИБКУ, "НЕПАРНЫЕ СКОБКИ", ЕСЛИ W1 НЕ РАВНО W229
?STACK*->ВЫДАТЬ ОШИБКУ "ИСЧЕРПАНИЕ СТЕКА", ЕСЛИ ОН БОЛЕЕ, ЧЕМ ПУСТ, И "ИСЧЕРПАНИЕ ПАМЯТИ" ПРИ ЗАЗОРЕ, МЕНЬШЕМ 10 БАЙТОВ29
:->НАЧАТЬ ОПРЕДЕЛЕНИЕ СЛОВА ЧЕРЕЗ ДВОЕТОЧИЕ32
#D1->D2ДЕЛЕНИЕМ D1 НА ЗНАЧЕНИЕ "BASE" ВЫДЕЛИТЬ 1 ЦИФРУ С КОНЦА И ДОБАВИТЬ ЕЕ В БУФЕР "PAD", ОСТАВИВ ЧАСТНОЕ D237
#>D->A,+NЗАКОНЧИТЬ ФОРМАТНОЕ ПРЕОБРАЗОВАНИЕ; ДАТЬ АДРЕС А НАЧАЛА ЛИТЕР И ИХ ЧИСЛО +N37
#SD1->0,0ВЫДЕЛЯТЬ ЦИФРЫ D1 ПО СЛОВУ "#" ДО ПОЛУЧЕНИЯ НУЛЯ37
#TIBП->АПЕРЕМЕННАЯ - ЧИСЛО ЛИТЕР В БУФЕРЕ "TIB"8
@А->WДАТЬ ЗНАЧЕНИЕ ПО АДРЕСУ А11
'->CFAДАТЬ CFA ДЛЯ СЛЕДУЮЩЕГО СЛОВА41
=W1,W2->FF НЕ НУЛЬ, ЕСЛИ W1 РАВНО W219
"*HK-> /КОМПИЛЯЦИЯ/
->Т /ИСПОЛНЕНИЕ/
СКОМПИЛИРОВАТЬ СЛЕДУЮЩИЕ ЛИТЕРЫ ДО КАВЫЧКИ ИСКЛЮЧИТЕЛЬНО КАК СТРОКУ СО СЧЕТЧИКОМ28
".*Т->НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ СТРОКУ Т28
ABORTСБРОСИТЬ СТЕК И УЙТИ ПО "QUIT"28
ABORT"НК> /КОМПИЛЯЦИЯ/
F-> /ИСПОЛНЕНИЕ/
ЕСЛИ F "ИСТИНА" (НЕ НУЛЬ) ТО НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ СЛЕДУЮЩИЙ ТЕКСТ ДО КАВЫЧКИ И УЙТИ НА "ABORT"29
ABORT8*->ВЫДАТЬ ОШИБКУ "НЕПРАВИЛЬНОЕ ЗНАЧЕНИЕ"29
ABSN1->N2АБСОЛЮТНАЯ ВЕЛИЧИНА17
AGAIN+НКА,1-> /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
КОНЕЦ ЦИКЛА "BEGIN AGAIN"47
ALIGN*+N->ВЫРОВНЯТЬ ВЕРШИНУ СЛОВАРЯ НА +N10
ALIGNH*->ВЫРОВНЯТЬ ВЕРШИНУ СЛОВАРЯ НА ПОЛУСЛОВО10
ALLOTW->СМЕСТИТЬ ВЕРШИНУ СЛОВАРЯ НА W БАЙТОВ10
ALPHA*N->CПРЕОБРАЗОВАТЬ N В ЛИТЕРУ С КАК ЦИФРУ37
ANDW1,W2->W3ПОРАЗРЯДНОЕ ЛОГИЧЕСКОЕ "И"13
B/BUF*->1024ЧИСЛО БАЙТОВ В БЛОЧНОМ БУФЕРЕ7
BADWORDА->СООБЩИТЬ О НЕОПОЗНАННОМ СЛОВЕ29
BASEП->АПЕРЕМЕННАЯ - ТЕКУЩЕЕ ОСНОВАНИЕ СИСТЕМЫ СЧИСЛЕНИЯ ПРИ ВВОДЕ-ВЫВОДЕ ЧИСЕЛ8
BEGINHK->А,1 /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
НАЧАЛО ЦИКЛА "BEGIN"47
BL+->64КОНСТАНТА - КОД ПРОБЕЛА В ДКОИ7
BLANK+A,U->ЗАСЛАТЬ ПРОБЕЛЫ В U БАЙТОВ ПО АДРЕСУ А22
BLKП->АПЕРЕМЕННАЯ - НОМЕР ВХОДНОГО БЛОКА-ЭКРАНА8
BLOCK+N->AДАТЬ АДРЕС А БУФЕРА С БЛОКОМ +N25
BODY>*PFA->CFAПЕРЕЙТИ ОТ ПОЛЯ ПАРАМЕТРОВ К ПОЛЮ КОДА30
BRANCHК->ПРОДОЛЖИТЬ ИНТЕРПРЕТАЦИЮ ОТ ЗНАЧЕНИЯ СЛЕДУЮЩЕГО СКОМПИЛИРОВАННОГО АДРЕСА5
BRANCH#MПРОДОЛЖЕНИЕ ИНТЕРПРЕТАЦИИ ОТ АДРЕСА В СЛЕДУЮНЕМ ПОЛУСЛОВЕ5
BUFFER+N->AПРИПИСАТЬ БЛОКУ +N БУФЕР23
C!С,А->ЗАСЛАТЬ БАЙТ С ПО АДРЕСУ А11
C,+С->СКОМПИЛИРОВАТЬ БАЙТ С НА ВЕРШИНУ СЛОВАРЯ11
C@A->СДАТЬ БАЙТ ПО АДРЕСУ А11
C"*H-> /КОМПИЛЯЦИЯ/
->С /ИСПОЛНЕНИЕ/
СКОМПИЛИРОВАТЬ КОД ПЕРВОЙ ЛИТЕРЫ СЛЕДУЮЩЕГО СЛОВА КАК ЛИТЕРАЛ23
CMOVEA1,A2,U->ПЕРЕСЛАТЬ U БАЙТОВ ОТ А1 В А221
CMOVE>A1,A2,U->ПЕРЕСЛАТЬ U БАЙТОВ ОТ АДРЕСА А1 ПО АДРЕСУ А2 НАЧИНАЯ С БОЛЬШИХ АДРЕСОВ21
COMPILEК->КОМПИЛИРОВАТЬ СЛЕДУЮЩИЙ АДРЕС22
CONSTANTW->ОПРЕДЕЛИТЬ СЛЕДУЮЩЕЕ СЛОВО КАК КОНСТАНТУ СО ЗНАЧЕНИЕМ W32
CONTEXTП->АПЕРЕМЕННАЯ - СПИСОК, С КОТОРОГО НАЧИНАЕТСЯ ПОИСК ВВОДИМЫХ СЛОВ7
CONVERTWD1,A1,->WD2,A2ПРЕОБРАЗОВАТЬ WD1 И ЛИТЕРЫ ОТ А1+1 В WD2 И А2 - АДРЕС 1-ОЙ НЕ ЦИФРЫ39
COUNTТ->А,NДАТЬ АДРЕС ПЕРВОЙ ЛИТЕРЫ И ЧИСЛО ЛИТЕР N СТРОКИ СО СЧЕТЧИКОМ Т28
CR->ВЫВЕСТИ НА ТЕРМИНАЛ ПЕРЕВОД СТРОКИ6
CREATE->СОЗДАТЬ НАЧАЛО СТАТЬИ (ДО PFA) ДЛЯ СЛЕДУЮЩЕГО СЛОВА, ЕГО ИСПОЛНЕНИЕ КЛАДЕТ PFA НА СТЕК36
CREATE#AНАЧАЛО ИСПОЛНИТЕЛЬНОЙ ЧАСТИ "VARIABLE"3
CSP->АПЕРЕМЕННАЯ ДЛЯ КОНТРОЛЬНОГО ХРАНЕНИЯ ЗНАЧЕНИЯ УКАЗАТЕЛЯ СТЕКА8
CURRENTП->АПЕРЕМЕННАЯ - СПИСОК ДЛЯ ДОБАВЛЕНИЯ СЛОВ7
D.D->НАПЕЧАТАТЬ D НА ТЕРМИНАЛЕ И ДАТЬ ПРОБЕЛ38
D.RD,+N->НАПЕЧАТАТЬ D В ПОЛЕ ДЛИНЫ +N СПРАВА38
D<D1,D2->FF "ИСТИНА", ЕСЛИ D1 МЕНЬШЕ D215
D+WD1,WD2->WD3СУММА ДВОЙНЫХ ЧИСЕЛ WD1 И WD214
D-WD1,WD2->WD3РАЗНОСТЬ ДВОЙНЫХ ЧИСЕЛ WD1-WD214
D/*D1,D2->D3ЧАСТНОЕ D3 ОТ ДЕЛЕНИЯ D1 НА D215
D/MOD*D1,D2->D3,D4ОСТАТОК D3 И ЧАСТНОЕ D4 ОТ ДЕЛЕНИЯ ДВОЙНЫХ ЧИСЕЛ D1 НА D215
D=WD1,WD2->FF "ИСТИНА", ЕСЛИ WD1 И WD2 РАВНЫ15
DABSD1->D2АБСОЛЮТНАЯ ВЕЛИЧИНА ДВОЙНОГО ЧИСЛА14
DECIMAL->ПЕРЕЙТИ В ДЕСЯТИЧНУЮ СИСТЕМУ22
DEFINITIONS->УСТАНОВИТЬ СПИСОК "CURRENT" НА "CONTEXT"31
DEPTH->+NКОЛИЧЕСТВО ЗНАЧЕНИИ НА СТЕКЕ ДО +N20
DIGIT*C,N1->N2,TP/FFN2 - ЗНАЧЕНИЕ ЛИТЕРЫ С КАК ЦИФРЫ В СИСТЕМЕ СЧИСЛЕНИЯ ПО ОСНОВАНИЮ N139
DMAXWD1,WD2->WD3БОЛЬШЕЕ ИЗ ДВУХ ЧИСЕЛ16
DMINWD1,WD2->WD3МЕНЬШЕЕ ИЗ ДВУХ ЧИСЕЛ16
DMOD*D1,D2->D3ОСТАТОК D3 ОТ ДЕЛЕНИЯ D1 НА D215
DNEGATED1->D2РЕЗУЛЬТАТ ВЫЧИТАНИЯ D1 ИЗ НУЛЯ14
DOHK->А1,А2,3 /КОМПИЛЯЦИЯ/
N1,N2-> /ИСПОЛНЕНИЕ/
НАЧАЛО ЦИКЛА "DO" CO СЧЕТЧИКОМ ОТ N2 ДО N147
DOES>HK->НАЧАЛО "ИСПОЛНЕНИЯ" В ОПРЕДЕЛЯЮЩЕМ СЛОВЕ34
DOES#MПОДПРОГРАММА - НАЧАЛО РАСШИРЕНИЯ "DOES>"3
DP!*A->УСТАНОВИТЬ ВЕРШИНУ СЛОВАРЯ НА АДРЕС A10
DPL->АПЕРЕМЕННАЯ - ПОЗИЦИЯ ПОСЛЕДНЕЙ ТОЧКИ В ПОСЛЕДНЕМ ВВЕДЕННОМ ЧИСЛЕ ОТ КОНЦА8
DROPW->УБРАТЬ СО СТЕКА ВЕРХНЕЕ ЗНАЧЕНИЕ9
DU<UD1,UD2->FF "ИСТИНА", ЕСЛИ UD1 МЕНЬШЕ UD214
DUMP+A,U->РАСПЕЧАТАТЬ НА ТЕРМИНАЛЕ U БАЙТОВ ОТ АДРЕСА U42

...
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Чт Апр 08, 2021 12:57 am

DUPW->W,WПРОДУБЛИРОВАТЬ ВЕРХНЕЕ ЗНАЧЕНИЕ9
D0<D->FF "ИСТИНА", ЕСЛИ D МЕНЬШЕ НУЛЯ15
D0=WD->FF "ИСТИНА", ЕСЛИ WD НУЛЬ15
D2/D1->D2РАЗДЕЛИТЬ НА ДВА15
ELSEHKA1,2->A2,2 /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
НАЧАЛО 2-ОЙ ВЕТВИ ВЕТВЛЕНИЯ "IF"47
EMITС->ВЫВЕСТИ НА ТЕРМИНАЛ ЛИТЕРУ С КОДОМ С6
EMPTY-BUFFERS+->ОЧИСТИТЬ БУФЕРНЫЙ ПУЛ25
ENCLOSE*A,C->A,N1,N2,N3ВВОД СЛОВА27
ERASE+A,U->ЗАСЛАТЬ НУЛИ В U БАЙТОВ ПО АДРЕСУ А22
ERCOND8MСИГНАЛИЗАЦИЯ О НЕПРАВИЛЬНОМ ЗНАЧЕНИИ4
EXECUTECFA->ИСПОЛНИТЬ СЛОВО ПО CFA ЕГО СТАТЬИ11
EXITК->ЗАКОНЧИТЬ ИСПОЛНЕНИЕ ТЕКУЩЕГО ОПРЕДЕЛЕНИЯ4
EXIT#MТОЧКА "EXIT" АДРЕСНОГО ИНТЕРПРЕТАТОРА4
EXPECTA,+N->ВВЕСТИ С ТЕРМИНАЛА +N ЛИТЕР ПО АДРЕСУ A, В ПЕРЕМЕННУЮ "SPAN" ЗАСЛАТЬ ФАКТИЧЕСКОЕ ЧИСЛО ВВЕДЕННЫХ ЛИТЕР, ЛИТЕРЫ НАПЕЧАТАТЬ НИ ТЕРМИНАЛЕ40
FENCE->AПЕРЕМЕННАЯ - ГРАНИЦА ЗАЩИТЫ ОТ "FORGET"7
FILLA,U,C->ЗАСЛАТЬ С В U БАЙТОВ ПО АДРЕСУ А22
FINDT->A,NИСКАТЬ СЛОВО Т В ТЕКУЩЕМ КОНТЕКСТЕ ЕСЛИ N=0, ТО А=Т И СЛОВО НЕ НАЙДЕНО, ИНАЧЕ A=CFA НАЙДЕННОЙ СТАТЬИ, N=1 ДЛЯ СЛОВ "IMMEDIATE" И N=-1 ДЛЯ ОСТАЛЬНЫХ35
FIRST*->АКОНСТАНТА - АДРЕС НАЧАЛА БУФЕРНОГО ПУЛА2
FIRST#MЗНАЧЕНИЕ КОНСТАНТЫ "FIRST"2
FL#АПОЛЕ СВЯЗИ ДЛЯ СПИСКОВ В ПОЛЕ ПАРАМЕТРОВ СЛОВАРНОЙ СТАТЬИ СЛОВА "FORTH"33
FLUSH->ЗАПИСАТЬ БЛОКИ НА ДИСК И ОЧИСТИТЬ ПУЛ24
FORGET->УДАЛИТЬ СЛОВАРНУЮ СТАТЬЮ СЛЕДУЮЩЕГО СЛОВА И ВСЕХ СЛОВ, ОПРЕДЕЛЕННЫХ ПОСЛЕ НЕГО45
FORTH->УСТАНОВИТЬ "CONTEXT" НА НАЧАЛЬНЫЙ СПИСОК33
FORTH-83->СТАНДАРТНЫЙ КОНТЕКСТ ФОРТ-СИСТЕМЫ33
FORTH#APFA+2 ДЛЯ СЛОВАРНОЙ СТАТЬИ "FORTH"33
GOTOMПОДПРОГРАММА ПЕРЕХОДА ПО ССЫЛКЕ4
H.+U->НАПЕЧАТАТЬ U НА ТЕРМИНАЛЕ В 16-НОЙ СИСТЕМЕ И ДАТЬ ПРОБЕЛ38
HERE->AДАТЬ АДРЕС ТЕКУЩЕЙ ВЕРШИНЫ СЛОВАРЯ10
HEX+->ПЕРЕЙТИ В ШЕСТНАДЦАТИРИЧНУЮ СИСТЕМУ22
HLD->AПЕРЕМЕННАЯ - ПОЗИЦИЯ ПОСЛЕДНЕЙ ЛИТЕРЫ, ПЕРЕНЕСЕННОЙ В БУФЕР "PAD" ПО "HOLD"8
HOLDС->ПЕРЕНЕСТИ ЛИТЕРУ С НА ВЕРШИНУ БУФЕРА PAD37
IК->WТЕКУЩЕЕ ЗНАЧЕНИЕ W СЧЕТЧИКА ЦИКЛА "ПО"24
I'+K->WКОНЕЧНОЕ ЗНАЧЕНИЕ W СЧЕТЧИКА ЦИКЛА "DO"24
ID.*NFA->НАПЕЧАТАТЬ ИМЯ СЛОВА И ДАТЬ ПРОБЕЛ31
IF->А,2 /КОМПИЛЯЦИЯ/
F-> /ИСПОЛНЕНИЕ/
НАЧАЛО ВЕТВЛЕНИЯ "IF"47
IMMEDIATE->ДАТЬ ПРИЗНАК "IMMEDIATE" ПОСЛЕДНЕЙ СОЗДАННОЙ СЛОВАРНОЙ СТАТЬЕ31
INDEX+N1,N2->РАСПЕЧАТАТЬ НАЧАЛЬНУЮ СТРОКУ ЭКРАНОВ С НОМЕРАМИ ОТ N1 ДО N246
INTERPRET+->ИНТЕРПРЕТИРОВАТЬ ВХОДНОЙ ПОТОК40
IPUSHМПОДПРОГРАММА - ПОМЕСТИТЬ НА СТЕК УКАЗАТЕЛЬ ИНТЕРПРЕТАЦИИ И ОБОЙТИ СЛЕДУЮЩУЙ СТРОКУ4
JК->WTEKУЩEE ЗНАЧЕНИЕ W СЧЕТЧИКА ВТОРОГО ОБЪЕМЛЮЩЕГО ЦИКЛА "DO"24
KEY->СВВЕСТИ ЛИТЕРУ С ТЕРМИНАЛА6
L>NAME*LFA->NFAПЕРЕЙТИ ОТ ПОЛЯ СВЯЗИ К ПОЛЮ ИМЕНИ30
LATEST*->NFAДАТЬ NFA ПОСЛЕДНЕЙ СОЗДАННОЙ СТАТЬИ31
LEAVEК->ЗАКОНЧИТЬ ИСПОЛНЕНИЕ ЦИКЛА "DO"24
LENGMASKMПОЛНОЕ СЛОВО - МАСКА ДЛЯ УДАЛЕНИЯ БИТА "IMMEDIATE" ИЗ БАЙТА ДЛИНЫ2
LENG1MSKMПОЛНОЕ СЛОВО - МАСКА ДЛЯ УДАЛЕНИЯ БИТОВ "IMMEDIATE" И "SMUDGE" ИЗ БАЙТА ДЛИНЫ2
LENG2MSKMПОЛНОЕ СЛОВО - МАСКА ДЛЯ ВЫСЕЧЕНИЯ ЧИСТОЙ ДЛИНЫ ИЗ БАЙТА ДЛИНЫ С ПРИЗНАКАМИ2
LHRW12MПОДПРОГРАММА ЗАГРУЗКИ ДВВХ ВЕРХНИХ ЗНАЧЕНИЙ НА СТЕКЕ В РЕГИСТРЫ RH2 (ВЕРХНЕЕ) И RM14
LIMIT*->AКОНСТАНТА - АДРЕС КОНЦА БУФЕРНОГО ПУЛА2
LIMIT#MЗНАЧЕНИЕ КОНСТАНТЫ "LIMIT"2
LINK>*LFA->CFAПЕРЕЙТИ ОТ ПОЛЯ СВЯЗИ К ПОЛЮ КОДА30
LIST+N->РАСПЕЧАТАТЬ НА ТЕРМИНАЛЕ ЭКРАН N46
LIT*K->WПОМЕСТИТЬ НА СТЕК СЛЕДУЮЩИЙ КОД23
LIT"*K->ТДАТЬ АДРЕС СКОМПИЛИРОВАННОЙ СТРОКИ И ПРОДОЛЖИТЬ ИНТЕРПРЕТАЦИЮ, ОБОЙДЯ ЕЕ28
LITERALHW-> /КОМПИЛЯЦИЯ/
->W /ИСПОЛНЕНИЕ/
СКОМПИЛИРОВАТЬ W КАК ЛИТЕРАЛ23
LOAD+N->ИНТЕРПРЕТИРОВАТЬ ЭКРАН С НОМЕРОМ +N41
LOOPHKA1,A2,3-> /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
КОНЕЦ ЦИКЛА "DO LOOP"47
LRW1MПОДПРОГРАММА ЗАГРУЗКИ ДВОЙНОГО ЗНАЧЕНИЯ НА ВЕРШИНЕ СТЕКА В РЕГИСТР RW14
LRW12MПОДПРОГРАММА ЗАГРУЗКИ ДВУХ ВЕРХНИХ ДВОЙНЫХ ЗНАЧЕНИЙ НА СТЕКЕ В РЕГИСТРЫ RW2 (ВЕРХНЕЕ) И RW14
M**N1,N2->DПРОИЗВЕДЕНИЕ ДВОЙНОЙ ДЛИНЫ N1 И N218
M/*D,N1->N2,N3ОСТАТОК N2 И ЧАСТНОЕ N3 ОТ ДЕЛЕНИЯ ДВОЙНОГО D НА ОДИНАРНОЕ N116
M/MOD*UD1,U2->U3,UD4ОСТАТОК U3 И ДВОЙНОЕ  ЧАСТНОЕ UD4 ОТ ДЕЛЕНИЯ UD1 НА U216
МАХN1,N2->N3БОЛЬШЕЕ ИЗ ЧИСЕЛ N1 И N222
MINN1,N2->N3МЕНЬШЕЕ ИЗ ЧИСЕЛ N1 И N222
MODN1,N2->N3ОСТАТОК ОТ ДЕЛЕНИЯ N1 НА N218
MSG*->АКОКСТАНТА - АДРЕС НАЧАЛА БУФЕРА MSG2
MSG#MЗНАЧЕНИЕ КОНСТАНТЫ "MSG"2
N>LINK*NFA->LFAПЕРЕЙТИ ОТ ПОЛЯ ИМЕНИ К ПОЛЮ СВЯЗИ30
NAME>*NFA->CFAПЕРЕЙТИ ОТ ПОЛЯ ИМЕНИ К ПОЛЮ КОДА30
NEGATEW1->М2РЕЗУЛЬТАТ ВЫЧИТАНИЯ W1 ИЗ НУЛЯ17
NEXTMВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР1
NEXT1MПРОДОЛЖЕНИЕ АДРЕСНОЙ ИНТЕРПРЕТАЦИИ ОТ ФОРТ-АДРЕСА В РЕГИСТРЕ 141
NOTN1->N2ПОРАЗРЯДНОЕ ИНВЕРТИРОВАНИЕ13
NUMBER+T->WDПРЕОБРАЗОВАТЬ СТРОКУ Т В ЧИСЛО WD39
OFFSET->АПЕРЕМЕННАЯ - ДОБАВКА К НОМЕРУ БЛОКА8
ORW1,W2->W3ПОРАЗРЯДНОЕ ЛОГИЧЕСКОЕ "ИЛИ"13
OVERW1,W2->W1,W2,W1ПРОДУБЛИРОВАТЬ ВТОРОЕ СВЕРХУ9
PAD->AДАТЬ АДРЕС ТЕКУЩЕЙ ВЕРШИНЫ БУФЕРА PAD37
PICKWN,..,,W0,+N->WN,...,W0,WNПРОДУБЛИРОВАТЬ N-E СВЕРХУ ЗНАЧЕНИЕ12
POPMВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР СО СНЯТИЕМ ВЕРХНЕГО ЗНАЧЕНИЯ С ВЕРШИНЫ СТЕКА3
POPPUT1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР СО СНЯТИЕМ ВЕРХНЕГО И ЗАМЕНОЙ ПРЕДЫДУЩЕГО НА ЗНАЧЕНИЕ ИЗ РЕГИСТРА RW13
PREV*C->АПЕРЕМЕННАЯ - ТЕКУЩИЙ БЛОЧНЫЙ БУФЕР7
PUSHRW1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР С ПОМЕЩЕНИЕМ ЗНАЧЕНИЯ ИЗ РЕГИСТРА RW1 НА ВЕРШИНУ СТЕКА3
PUSH2RW1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР С ЗАМЕНОЙ ВЕРХНЕГО НА ДВОЙНОЕ ЗНАЧЕНИЕ ИЗ РЕГИСТРА RW13
PUTRW1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР С ЗАМЕНОЙ ВЕРХНЕГО ЗНАЧЕНИЯ НИ ЭНАЧЕНИЕ ИЗ RW13
QUERY*->ВВЕСТИ С ТЕРМИНАЛА ЛИТЕРЫ В БУФЕР "TIB"; ЧИСЛО ВВЕДЕННЫХ ЛИТЕР ЗАСЛАТЬ В "#TIB"40
QUITСБРОСИТЬ СТЕК ВОЗВРАТОВ, ПЕРЕЙТИ В РЕЖИМ ИСПОЛНЕНИЯ И ПРОДОЛЖИТЬ ИНТЕРПРЕТАЦИЮ28
R.*->РАСПЕЧАТАТЬ НА ТЕРМИНАЛЕ СТЕК ВОЗВРАТОВ42
R>К->WПЕРЕНЕСТИ ЗНАЧЕНИЕ СО СТЕКА ВОЗВРАТОВ9
R@К->WСКОПИРОВАТЬ ВЕРШИНУ СТЕКА ВОЗВРАТОВ9
RBLK*А,+N->ПРОЧЕСТЬ ЭКРАН +N ПО АДРЕСУ A6
RDROP*K->СНЯТЬ ЗНАЧЕНИЕ СО СТЕКА ВОЗВРАТОВ9
RECURSE+HK->СКОМПИЛИРОВАТЬ ОБРАЩЕНИЕ К КОМПИЛИРУЕМОМУ В ДАННЫЙ МОМЕНТ ОПРЕДЕЛЕНИЮ31
REMEMBER+->ОПРЕДЕЛИТЬ СЛОВО, ИСПОЛНЕНИЕ КОТОРОГО УНИЧТОЖАЕТ ВСЕ ПОСЛЕДНИЕ ОПРЕДЕЛЕНИЯ45
RЕРЕАТHKА1,1,А2,2-> /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
КОНЕЦ ЦИКЛА "BEGIN WHILE REPEAT"47
ROLLWN,WN-1,...,W0,+N->WN-1,..,W0,WNЦИКЛИЧЕСКИ ПЕРЕСТАВИТЬ N ВЕРХНИХ ЗНАЧЕНИЙ12
ROTW1,W2,W3->W2,W3,W1ПЕРЕСТАВИТЬ ТРИ ВЕРХНИХ ЗНАЧЕНИЯ ПО ЧАСОВОЙ СТРЕЛКЕ9
RP!*A->УСТАНОВИТЬ УКАЗАТЕЛЬ ВЕРШИНЫ СТЕКА ВОЗВРАТОВ НА A20
RP@*->AАДРЕС ТЕКУЩЕЙ ВЕРШИНЫ-СТЕКА ВОЗВРАТОВ20
R0*C->АПЕРЕМЕННАЯ - АДРЕС ДНА СТЕКА ВОЗВРАТОВ7
S.*->РАСПЕЧАТАТЬ НИ ТЕРМИНАЛЕ СТЕК ДАННЫХ42
S>D*N->DРАСШИРИТЬ N ДО ЧИСЛА ДВОЙНОЙ ДЛИНЫ D14
SAVE-BUFFERS->ЗАПИСАТЬ НА ДИСК ВСЕ ИСПРАВЛЕННЫЕ БЛОКИ26
SCR->АПЕРЕМЕННАЯ - НОМЕР ЭКРАНА В "LIST"8
SIGNN->ДОБАВИТЬ В ФОРМАТНУЮ СТРОКУ ЗНАК МИНУС, ЕСЛИ ЧИСЛО N ОТРИЦАТЕЛЬНО37
SMUDGE*->УСТАНОВИТЬ В ЕДИНИЦУ ФЛАГ "SMUDGE" В ПОСЛЕДНЕЙ СОЗДАННОЙ СТАТЬЕ31
SNAPSTK*А1,А2,АЗ->РАСПЕЧАТКА СТЕКА ОТ А1 ДО А2 С ТЕКСТОМ A3; ВОЗВРАТ "ЧЕРЕЗ ОДИН"42
SP!*А->УСТАНОВИТЬ УКАЗАТЕЛЬ ВЕРВИНЫ СТЕКА НА A20
SP@+->ААДРЕС ТЕКУЩЕЙ ВЕРШИНЫ СТЕКА ДАННЫХ20
SPACE->НАПЕЧАТАТЬ НИ ТЕРМИНАЛЕ ПРОБЕЛ23
SPACES+N->НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ +N ПРОБЕЛОВ23
SPANП->АПЕРЕМЕННАЯ ДЛЯ РЕЗУЛЬТАТА "EXPECT"8
STATEП->АПЕРЕМЕННАЯ С СОСТОЯНИЕМ ТЕКСТОВОГО ИНТЕРПРЕТАТОРА: "ИСТИНА" - КОМПИЛЯЦИЯ8
SWAPW1,W2->W2,W1ОБМЕНЯТЬ МЕСТАМИ 2 ВЕРХНИХ9
S0->АПЕРЕМЕННАЯ - АДРЕС ДНА СТЕКА ДАННЫХ7
TEMPMРАБОЧАЯ ОБЛАСТЬ ИЗ ДВУХ ДВОЙНЫХ СЛОВ2
THENHKА,2-> /КОМПИЛЯЦИЯ/
-> /ИСПОЛНЕНИЕ/
КОНЕЦ ВЕТВЛЕНИЯ "IF"47
THRU++N1,+N2->ИНТЕРПРЕТИРОВАТЬ ЭКРАНЫ С НОМЕРАМИ ОТ +N1 ДО +N2 ВКЛЮЧИТЕЛЬНО41
TIB->ААДРЕС ВХОДНОГО ТЕКСТОВОГО БУФЕРА ДЛЯ ВВОДА С ТЕРМИНАЛА2
TIB#MФОРТ-АДРЕС НАЧАЛИ БУФЕРА TIB2
TYPEA,+N->НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ +N ЛИТЕР ОТ АДРЕСА А6
U.U->НАПЕЧАТАТЬ U НА ТЕРМИНАЛЕ КАК ЧИСЛО БЕЗ ЗНАКА35
U.R+U,+N->НАПЕЧАТАТЬ НА ТЕРМИНАЛЕ ЧИСЛО U В ПОЛЕ ДЛИНЫ +N СПРАВА38
U<U1,U2->FF ИСТИНА, ЕСЛИ U1 МЕНЬШЕ U216
UM*U1,U2->UDПРОИЗВЕДЕНИЕ UD ЧИСЕЛ U1 И U216
UM/MODUD,U1->U2,U3ОСТАТОК U2 И ЧАСТНОЕ U3 ОТ ДЕЛЕНИЯ UD НА U116
UNSMUDGE*->УСТАНОВИТЬ В НУЛЬ ФЛАГ "SMUDGE" В ПОСЛЕДНЕЙ СОЗДАННОЙ СТАТЬЕ31
UNTILHKA,1-> /КОМПИЛЯЦИЯ/
F-> /ИСПОЛНЕНИЕ/
КОНЕЦ ЦИКЛА "BEGIN UNTIL"47
UPDATE->ОТМЕТИТЬ ТЕКУЩИЙ БЛОК KАK ИЗМЕНЕННЫЙ25
USE*C->АПЕРЕМЕННАЯ - СЛЕДУЮЩИЙ БЛОЧНЫЙ БУФЕР7
VARIABLE->ОПРЕДЕЛИТЬ СЛЕДУЮЩЕЕ СЛОВО KАK ПЕРЕМЕННУЮ С НАЧАЛЬНЫМ ЗНАЧЕНИЕМ НУЛЬ32
VOC-LINK->АПЕРЕМЕННАЯ - АДРЕС ПОЛЯ СВЯЗИ ПОСЛЕДНЕГО СОЗДАННОГО ПО "VOCABULARY" СПИСКА СЛОВ33
VOCABULARY->ОПРЕДЕЛИТЬ СЛЕДУЮЩЕЕ СЛОВО КАК СПИСОК НАД ТЕКУЩИМ ЗНАЧЕНИЕМ "CURRENT"33
VOCABULARY#АНАЧАЛО ИСПОЛНИТЕЛЬНОЙ ЧАСТИ "VOCABULARY"33
VOCS*->РАСПЕЧАТАТЬ НИ ТЕРМИНАЛЕ ТЕКУЩИЙ ПОРЯДОК ПОИСКА СЛОВ В СЛОВАРЕ43
WBLK*A,+N->ЗАПИСАТЬ ЭКРАН +N ИЗ АДРЕСА A6
WHILEHK1->А,2 /КОМПИЛЯЦИЯ/
F-> /ИСПОЛНЕНИЕ/
ВЕТВЛЕНИЕ "WHILE" В ЦИКЛЕ "BEGIN WHILE REPEAT"47
WIDTH*->NКОНСТАНТА - МАКСИМАЛЬНАЯ ДЛИНА ИМЕНИ7
WORDС->ТВВЕСТИ СЛОВО ДО СТОП-ЛИТЕРЫ C; ДАТЬ ЕГО АДРЕС КАК СТРОКИ СО СЧЕТЧИКОМ27
WORDS+->РАСПЕЧАТАТЬ НА ТЕРМИНАЛЕ ИМЕНА СЛОВ ИЗ СПИСКА "CONTEXT"44
XORW1,W2->W3ПОРАЗРЯДНОЕ "ИСКЛЮЧАЮЩЕЕ ИЛИ"13
0*->0КОНСТАНТА НУЛЬ (ЗНАЧЕНИЕ "ЛОЖЬ")7
0<N->FF "ИСТИНА", ЕСЛИ N ОТРИЦАТЕЛЬНО13
0<>N->FF "ИСТИНА", ЕСЛИ N НЕ НУЛЬ19
0!*А->ЗАСЛАТЬ НУЛЬ ПО АДРЕСУ А11
0=W->FF "ИСТИНА", ЕСЛИ N РАВНО НУЛЮ13
1+W1->W2УВЕЛИЧИТЬ W1 НА 117
1+!+А->УВЕЛИЧИТЬ НA 1 ЗНАЧЕНИЕ ПО АДРЕСУ А17
1-W1->W2УМЕНЫШИТЬ W1 НА 117
2+W1->W2УВЕЛИЧИТЬ W1 НА 217
2!UD,A->ЗАСЛАТЬ ДВОАНОЕ WD ПО АДРЕСУ А20
2*+W1->W2АРИФМЕТИЧЕСКИЙ СДВИГ ВЛЕВО НА 120
2-W1->W2УМЕНЬШИТЬ W1 НА 217
2/W1->W2АРИФМЕТИЧЕСКИЙ СДВИГ ВПРАВО НА 120
2@A->WDДАТЬ ДВОЙНОЕ ЗНАЧЕНИЕ ПО АДРЕСУ А20
2CONSTANTWD->ОПРЕДЕЛИТЬ СЛЕДУЮЩЕЕ СЛОВО КАК КОНСТАНТУ СО ЗНАЧЕНИЕМ WD32
2DROPWD->СНЯТЬ ВЕРХНЕЕ ДВОЙНОЕ ЗНАЧЕНИЕ12
2DUPWD->WD,WDПРОДУБЛИРОВАТЬ ДВОЙНОЕ ЗНАЧЕНИЕ12
2LIT->WDПОМЕСТИТЬ НА СТЕК СЛЕДУЮЩИЕ 2 КОДА23
2LITERALWD-> /КОМПИЛЯЦИЯ/
->WD /ИСПОЛНЕНИЕ/
СКОМПИЛИРОВАТЬ WD КАК ЛИТЕРАЛ23
2OVERWD1,WD2->WD1,WD2,WD1ПРОДУБЛИРОВАТЬ ВТОРОЕ ДВОЙНОЕ СВЕРХУ12
2РОРМВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР СО СНЯТИЕМ ДВОЙНОГО ЗНАЧЕНИЯ С ВЕРШИНЫ СТЕКА3
2POPPUT1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР СО СНЯТИЕМ ДВОЙНОГО ВЕРХНЕГО ЗНАЧЕНИЯ СО СТЕКА И ЗАМЕНОЙ ПРЕДЫДУЩЕГО ДВОЙНОГО НА 4-БАЙТНОЕ ЗНАЧЕНИЕ ИЗ РЕГИСТРА RW13
2PUSHRW1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР С ПОМЕЩЕНИЕМ ДВОЙНОГО ЗНАЧЕНИЯ ИЗ RW1 НА ВЕРШИНУ СТЕКА3
2PUTRW1MВХОД В АДРЕСНЫЙ ИНТЕРПРЕТАТОР С ЗАМЕНОЙ ДВОЙНОГО ВЕРХНЕГО ЗНАЧЕНИЯ НИ 4-БАЙТНОЕ ЗНАЧЕНИЕ ИЗ РЕГИСТРА RW13
2ROTWD1,WD2,WD3->WD2,WD3,WD1ПЕРЕСТАВИТЬ ТРИ ВЕРХНИХ ДВОЙНЫХ ПО ЧАСОВОЙ СТРЕЛКЕ12
2SWAPWD1,WD2->WD2,WD1ОБМЕНЯТЬ МЕСТАМИ ДВА ВЕРХНИХ ДВОЙНЫХ ЗНАЧЕНИЯ12
2VARIABLE->ОПРЕДЕЛИТЬ СЛЕДУЮЩЕЕ СЛОВО КАК ПЕРЕМЕННУЮ ДВОЙНОЙ ДЛИНЫ С НАЧАЛЬНЫМ ЗНАЧЕНИЕМ НУЛЬ32
ФОРТ-СИСТЕМА*->ТЕКСТОВЫЙ ИНТЕРПРЕТАТОР ФОРТ-СИСТЕМЫ40

...
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

vikt144 поставил(а) лайк

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Сб Апр 10, 2021 12:30 am

Экран номер 1
( 09.09.86 НАЧАЛО МОДЕЛИ ФОРТ-СИСТЕМЫ )
DECIMAL ( КОНСТАНТЫ ПЕРИОДА КОМПИЛЯЦИИ )
128 CONSTANT &IFLAG ( ПРИЗНАК "IMMEDIATE")
32 CONSTANT &SFLAG ( ПРИЗНАК "SMUDGE")
31 CONSTANT &LENG ( МАСКА ДЛЯ ВЫСЕЧЕНИЯ ДЛИНЫ)
&SFLAG 256 * 64 + CONSTANT &DWORD ( ФИКТИВНОЕ ИМЯ )
( НАЧАЛЬНОЕ ЯДРО С АДРЕСАЦИЕЙ ОТ РЕГИСТРА RFORTH)
START-CODE *, RFORTH USING, ( АДРЕСНЫЙ ИНТЕРПРЕТАТОР)
M: NEXT 14 0 (, RI RFORTH LH, RI RTWO AR,
M: NEXT1 14 RMASK NR, 15 0 (, 14 RFORTH LH,
15 RMASK NR, 15 RFORTH AR, 14 RTWO AR, 15 BR,

Экран номер 2
( 09.09.86 СИСТЕМНЫЕ ПЕРЕМЕННЫЕ И КОНСТАНТЫ )
CONST MSG M: MSG# 0 Н, ( АДРЕС НАЧАЛА БУФЕРА MSG)
CONST FIRST M: FIRST# 0 Н, ( АДРЕС НАЧАЛА ПУЛА)
CONST LIMIT M: LIMIT# 0 Н, ( АДРЕС КОНЦА ПУЛА)
CONST TIB M: TIB# 0 Н, ( АДРЕС НАЧАЛА БУФЕРА ТIВ )
4 ALIGN
M: LENGMASK 255 &IFLAG - S>D F, ( БАЙТ ДЛИНЫ БЕЗ IMMEDIATE)
M: LENGMASK 255 &IFLAG - &SFLAG - S>D F, ( БЕЗ IMMD И SMDG)
M: LENG2MSK &LENG S>D F, ( БАЙТ ДЛИНЫ С ЧИСТОЙ ДЛИНОЙ)
8 ALIGN
M: ТЕMP 16 ALLOT ( РАБОЧАЯ ОБЛАСТЬ)

Экран номер 3
( 09.09.86 ДОПОЛНИТЕЛЬНЫЕ ВХОДЫ В АДРЕСНЫЙ ИНТЕРПРЕТАТОР)
M: DOES# RI RPUSH, RI 4 (, 15 LA, RI RFORTH SR,
A: CREATE# RW1 14 LR, ( ПОМЕСТИТЬ РFA СТАТЬИ)
M: PUSHRW1 RSTACK RTWO SR, ( ПОМЕСТИТЬ ЗНАЧЕНИЕ ИЗ RW1)
M: PUTRW1 RW1 PUT, RNEXT BR, ( ЗАМЕНИТЬ ВЕРХНЕЕ)
M: 2POP RSTACK RTWO AR, ( СНЯТЬ ДВА ВЕРХНИХ)
M: POP RSTACK RTWO AR, RNEXT BR, ( СНЯТЬ ВЕРХНЕЕ)
M: POPPUT1 RSTACK RTWO AR, ( СНЯТЬ ВЕРХНЕЕ И ЗАМЕНИТЬ)
RW1 PUT, RNEXТ BR, ( ЗНАЧЕНИЕМ ИЗ RW1)
M: 2PUSHRW1 RSTACK RTWO SR, ( ПОЛОЖИТЬ ДВОЙНОЕ НА СТЕК)
M: PUSH2RW1 RSТAСК RTWO SR, ( ЗАМЕНИТЬ ВЕРХНЕЕ НА ДВОЙНОЕ)
M: 2PUTRW1 RW1 TEMP ST, ( ЗАМЕНИТЬ ДВОЙНОЕ ВЕРХНЕЕ)
FIRST (, 4 ), TEMP MVC, RNEXT BR,
M: 2POPPUT1 RSТAСК RTWO AR, RSТAСК RTWO AR, 2PUTRM1 В,

Экран номер 4
( 09.09.86 ВСПОМОГАТЕЛЬНЫЕ ПОДПРОГРАММЫ: ВОЗВРАТ В РЕГ.14)
M: LHRW12 RW1 SECOND LH, RW2 PULL, 14 BR,
M: LRW1 TEMP (, 4 ), FIRST MVC, RW1 TEMP L, 14 BR,
M: LRW12 TEMP (, 8 ), FIRST MVC, RW1 TEMP 4 +(, L,
RW2 TEMP L, 14 BR,
M: GOTO 14 0 (, 0 14 LH, NEXT1 В,
M: IPUSH RI PUSH, RW2 RW2 SR, RW2 0 (, RI RFORTH IC,
RI 2 (, RI RW2 LA, 14 BR,
CODE EXIT
M: EXIT# RI RPOP, RI RMASK NR, RNEXT BR, END-CODE
M: ERCOND8 14 GOTO BAL, ] ABORT8 [

Экран номер 5
( 09.09.86 BRANCH ?BRANCH (LOOP/ (+LOOP/ )
CODE BRANCH M: ВRANСН#
RI 0 (, RI RFORTH LH, RI RMASK NR, RNEXT BR,
СОDE ?BRANCH RW1 POP, RW1 RW1 LTR, ВRANСН# BZ,
RI RTWO AR, RNEXT BR,
CODE (LOOP) RW1 1 LA, 1 =F B,
CODE (+LOOP) RW1 POP,
1 =H 0 RFIRST LH, 0 RSECOND SH, 0 RMASK NR,
0 RW1 AR, RW1 RFIRST AH, RW1 RFIRST STH,
0 RMASK CLR, BRANCH# BNH, RRET 6 (, 0 RRET LA,
RI RTWO AR, RNEXT BR, END-CODE

Экран номер 6
( 09.09.86 KEY CR EMIT TYPE (EXPECT/ RBLK WBLK )
( СЛЕДУЮЩИЕ ОПРЕДЕЛЕНИЯ ДАЮТ ТОЛЬКО ИМЕНА ПРОЦЕДУР)
CODE KEY ( ->С ВВЕСТИ ЛИТЕРУ С ТЕРМИНАЛА ) END-CODE
CODE CR ( -> ВЫВЕСТИ ПЕРЕВОД СТРОКИ ) END-CODE
CODE EMIT ( С-> ВЫВЕСТИ ЛИТЕРУ С КОДОМ С НА ТЕРМИНАЛ) END-CODE
CODE TYPE ( A,N-> ВЫВЕСТИ HА TEPМИНАЛ N ЛИТЕР ПО АДРЕСУ A)
END-CODE
CODE (EXPECT) ( A,N1->A,N2 ВВЕСТИ С ТЕРМИНАЛА НЕ БОЛЕЕ
N1 ЛИТЕР /ДО ПЕРЕВОДА СТРОКИ/ В БУФЕР ПО АДРЕСУ А;
N2 - ФАКТИЧЕСКОЕ ЧИСЛО ВВЕДЕННЫХ ЛИТЕР) END-CODE
CODE RBLK ( A,N-> ПРОЧИТАТЬ ЭКРАН N В БУФЕР A) END-CODE
CODE WBLK ( A,N-> ЗАПИСАТЬ ЭКРАН N ИЗ БУФЕРА А ) END-CODE

Экран номер 7
( 09.09.86 КОНСТАНТЫ И СИСТЕМНЫЕ ПЕРЕМЕННЫЕ )
64 CONSTANT BL ( КОД ПРОБЕЛА)
1024 CONSTANT B/BUF ( ДЛИНА БУФЕРА ДЛЯ ЭКРАНА)
&LENG CONSTANT WIDTH ( МАКСИМАЛЬНАЯ ДЛИНА СЛОВА )
0 CONSTANT 0 ( ЧИСЛО НОЛЬ)
VARIABLE USE ( СЛЕДУЮЩИЙ БУФЕР В ПУЛЕ)
VARIABLE PREV ( ТЕКУЩИЙ БУФЕР В ПУЛЕ)
VARIABLE S0 ( АДРЕС ДНА СТЕКА ДАННЫХ)
VARIABLE R0 ( АДРЕС ДНА СТЕКА ВОЗВРАТОВ)
VARIABLE FENCE ( ГРАНИЦА ЗАЩИТЫ ОТ "FORGET")
VARIABLE CONTEXT ( ТЕКУЩИЙ СПИСОК - НАЧАЛО ПОИСКА)
VARIABLE CURRENT ( ТЕКУЩИЙ СПИСОК - КУДА ДОБАВЛЯЕМ)

Экран номер 8
( 09.09.86 СИСТЕМНЫЕ ПЕРЕМЕННЫЕ - ОКОНЧАНИЕ)
VARIABLE OFFSET ( ДОБАВКА К НОМЕРУ ЭКРАНА)
VARIABLE BASE ( ОСНОВАНИЕ СИСТЕМЫ СЧИСЛЕНИЯ)
VARIABLE STATE ( СОСТОЯНИЕ ТЕКСТОВОГО ИНТЕРПРЕТАТОРА)
VARIABLE DPL ( ПОЗИЦИЯ ДЕСЯТИЧНОЙ ТОЧКИ В ЧИСЛЕ)
VARIABLE CSP ( ДЛЯ КОНТРОЛЬНОГО ХРАНЕНИЯ УКАЗАТЕЛЯ)
VARIABLE HLD ( УКАЗАТЕЛЬ ВЕРШИНЫ БУФЕРА "PAD")
VARIABLE BLK ( НОМЕР ВХОДНОГО ЭКРАНА ИЛИ НОЛЬ)
VARIABLE >IN ( ПОЗИЦИЯ ОЧЕРЕДНОЙ ЛИТЕРЫ НА ВХОДЕ)
VARIABLE SPAN ( ЧИСЛО ЛИТЕР, ВВЕДЕННЫХ ПО "EXPECT")
VARIABLE #TIB ( ЧИСЛО ЛИТЕР, ВВЕДЕННЫХ В БУФЕР "TIB")
VARIABLE SCR ( НОМЕР ЭКРАНА, РАСПЕЧАТАННОГО В "LIST")

Экран номер 9
( 31.03.86 DUP ?DUP DROP SWAP OVER >R R> R@ RDROP ROT )
CODE DUP ( W->W,W) RW1 PULL, PUSHRW1 B, END-CODE
: ?DUP ( W->W,W; 0->0) DUP IF DUP THEN ;
CODE DROP ( W->) RSTACK RTWO AR, RNEXT BR, END-CODE
CODE SWAР ( W1,W2->W2,W1)
14 LHRW12 BAL, RW2 SECOND STH, PUTRW1 B, END-CODE
CODE OVER ( W1,W2->W1,W2,W1) RW1 SECOND LH, PUSHRW1 B, END-CODE
CODE >R ( W->) RW1 POP, RW1 RPUSH, RNEXT BR, END-CODE
CODE R> ( ->W) RW1 RPOP, PUSHRW1 B, END-CODE
CODE R@ ( ->W) RW1 RPULL, PUSHRW1 B, END-CODE
CODE RDROP ( -> ) RRET RTWO AR, RNEXT BR, END-CODE
: ROT ( N1,N2,N3->N2,N3,N1 ) >R SWAP R> SWAP ;

Экран номер 10
( 31.03.86 HERE ALLOT ALIGN ALIGNH DP! )
CODE HERE ( ->A) RW1 RD LR, PUSHRW1 B, END-CODE
CODE ALLOT ( N->) RD FIRST AH, POP B, END-CODE
CODE ALIGN ( N->) RW1 0 (, RD RFORTH LA,
0 (, RW1 0 MVI, 1 (, 7 RW1 ), 0 (, RW1 MVC,
RW1 PULL, RW2 RW1 LCR, RD RW1 AR, RD 0 BCTR,
RD RW2 NR, POP B, END-CODE
: ALIGNH ( ->) 2 ALIGN ;
CODE DP! ( A->) RD PULL, RD RMASK NR, POP 8,
END-CODE

Экран номер 11
( 31.03.86 ! 0! @ С! С@ , С, EXECUTE )
CODE ! ( W,A->) ЗАСЛАТЬ W ПО АДРЕСУ A) 14 LHRM12 BAL,
RW2 RMASK NR, RW1 0 (, RW2 RFORTH STH, 2POP B, END-CODE
: 0! ( A->) 0 SWAP ! ;
CODE @ ( А->W РАЗЫМЕНОВАТЬ A) RW2 PULL, RW2 RMASK NR,
RW1 0 (, RW2 RFORTH LH, PUTRW1 B, END-CODE
CODE C@ ( A->C) RW2 PULL, RW2 RМASК NR, RW1 RW1 SR,
RW1 0 (, RW2 RFORTH IC, PUTRW1 B, END-CODE
CODE C! ( C,A-> ) 14 LHRW12 BAL, RW2 RMASK NR,
RW1 0 (, RW2 RFORTH STC, 2POP B, END-CODE
: , ( W->) HERE 2 ALLOT ! ;
: C, ( C->) HERE 1 ALLOT C! ;
CODE EXECUTE ( СFA->) 14 POP, NEXT1 B, END-CODE

Экран номер 12
( 31.03.86 ROLL PICK 2DUP 2DROP 2SWAP 2OVER 2ROT )
CODE ROLL ( WN,WN-1,...,W0,+N->WN-1,...,W0,WN)
RW2 PULL, RW2 RW2 AR, ERCOND8 BM, RW1 SECOND (, RW2 LH,
BEGIN, 0 FIRST (, RW2 LH, 0 SECOND (, RW2 STH,
RW2 RTWO SR, ?NP UNTIL, POPPUT1 B, END-CODE
CODE PICK ( WN,...,W0,+N->WN,...,W0,WN)
RW2 PULL, RW2 RW2 AR, ERCOND8 BM,
RW1 2 (, RW2 RSTACK LH, PUTRW1 B, END-CODE
: 2DUP ( WD->WD,WD) OVER OVER ;
: 2DROP ( WD->) DROP DROP ;
: 2SWAP ( WD1,WD2->WD2,WD1) 3 ROLL 3 ROLL ;
: 2OVER ( WD1,WD2->WD1,WD2,WD1) 3 PICK 3 PICK ;
: 2ROT ( WD1,WD2,WD3->WD2,WD3,WD1) 5 ROLL 5 ROLL ;

Экран номер 13
( 31.03.86 AND OR XOR NOT 0= 0< )
CODE AND ( W1,W2->W3)
14 LHRW12 BAL, RW1 RW2 NR, POPPUT1 B, END-CODE
CODE OR ( W1,W2->W3)
14 LHRW12 BAL, RW1 RW2 OR, POPPUT1 B, END-CODE
CODE XOR ( W1,M2->W3)
14 LHRW12 BAL, RW1 RW2 XR, POPPUT1 B, END-CODE
: NOT ( W1->W2 ) -1 XOR ;
: CODE 0= ( W->F) RW1 RW1 SR, RW2 PULL, RW2 RW2 LTR,
PUTRW1 BNZ, RW1 0 BCTR, PUTRW1 B, END-CODE
CODE 0< ( N->F) RW1 RW1 SR, RW2 PULL, RW2 RW2 LTR,
PUTRW1 BNM, RW1 0 BCTR, PUTRW1 B, END-CODE

Экран номер 14
( 31.03.86 S>D DABS DNEGATE D+ D- DU< )
CODE S>D ( N->D) RW1 PULL, PUSH2RW1 B, END-CODE
CODE DABS ( D1->D2)
14 LRW1 BAL, RW1 RW1 LPR, 2PUTRW1 B, END-CODE
CODE DNEGATE ( WD1->WD2)
14 LRW1 BAL, RW1 RW1 LCR, 2PUTRW1 B, END-CODE
CODE D+ ( WD1,WD2->WD3)
14 LRW12 BAL, RW1 RW2 AR, 2POPPUT1 B, END-CODE
CODE D- ( WD1,WD2->WD3)
14 LRW12 BAL, RW1 RW2 SR, 2POPPUT1 B, END-CODE
CODE DU< ( UD1,UD2->F) 14 LRW12 BAL, 0 0 SR, RW1 RW2 CLR,
?L IF, 0 0 BCTR, THEN, RSTACK 6 (, 0 RSTACK LA,
0 PUT, RNEXT BR, END-CODE

Экран номер 15
( 31.03.86 D/MOD D/ DMOD D0= D= D0< D< D2/ )
CODE D/MOD ( D1,D2->D3,D4) 14 LRW12 BAL, 1 RW1 LR, 0 RW2 LR,
RW1 32 SRDA, RW1 0 DR, 1 0 XR, 1 1 LTR, ?M IF, RW1 0 AR,
RW2 0 BCTR, THEN, RW1 TEMP ST, FIRST 4 +(, 4 ), TEMP MVC,
RW1 RW2 LR, 2PUTRW1 B, END-CODE
: D/ ( D1,D2->D3) D/MOD 2SWAP 2DROP ;
: DMOD ( D1,D2->D3) D/MOD 2DROP ;
: D0= ( WD->F) OR 0= ;
: D= ( WD1,WD2->F) D- DO= ;
: D0< ( D->F) SWAP DROP 0< ;
: D< ( D1,D2->F) D- D0< ;
CODE D2/ ( D1->D2) 14 LRW1 BAL, RW1 1 SRA, PUTRW1 B, END-CODE

Экран номер 16
( 09.09.86 UM/MOD U< M/MOD DMAX DMIN )
CODE UM* ( U1,U2->UD) 14 LHRW12 BAL, RW1 RMASK NR,
RW2 RMASK NR, RW1 RW1 MR, RW1 RW2 LR, 2PUTRW1 B, END-CODE
CODE UM/MOD ( UD,U1->U2,U3) 1 POP, 1 RMASK NR, 14 LRW1 BAL,
RSTACK RTWO SR, RW2 RW1 LR, RW1 RW1 SR, RW1 1 DR,
RW1 FIRST 4 +(, STH, RW1 RW2 LR, POPPUT1 B, END-CODE
CODE U< ( U1,U2->F) RW1 RW1 SR, RW2 PULL, RW2 RMASK NR,
0 SECOND LH, 0 RMASK NR, 0 RW2 CR, POPPUT1 BNL,
RW1 0 BCTR, ( РЕЗУЛЬТАТ "ИСТИНА") POPPUT1 B, END-CODE
: M/MOD ( UD1,U2->U3,UD4) >R 0 R@ UM/MOD R> SWAP >R UM/MOD R> ;
: DMAX ( D1,D2->D3) 2OVER 2OVER D< IF 2SWAP THEN 2DROP ;
: DMIN ( D1,D2->D3) 2OVER 2OVER D< NOT IF 2SWAP THEN 2DROP ;

Экран номер 17
( 31.03.86 NEGATE ABS + - 1+ 1- 2+ 2- +! 1+! )
CODE NEGATE ( W1->W2) RW1 PULL, RW1 RW1 LCR, PUTRW1 B, END-CODE
: ABS ( N1->+N2) S>D DABS DROP ;
CODE + 14 LHRW12 BAL, RW1 RW2 AR, POPPUT1 В, END-CODE
: - ( W1,W2->W3) NEGATE + ;
: 1+ ( W1->W2) 1 + ;
: 1- ( W1->W2) -1 + ;
: 2+ ( W1->W2) 2 + ;
: 2- ( W1->W2) 2 - ;
CODE +! ( W,A->) 14 LHRW12 BAL, RW2 RМASК NR, RW1 0 (,
RW2 RFORTH AН, RW1 0 (, RW2 RFORTH SТН, 2РОР B, END-CODE
: 1+! ( A->) 1 SWAP +! ;

Экран номер 18
( 03.10.86 М* M/ * /MOD / MOD */MOD */ )
CODE M* ( N1,N2->D) RH1 SECOND LH, RW1 FIRST MH, 2PUTRW1 B,
CODE M/ ( D,N1->N2,N3) 1 POP, 14 LRW1 BAL, RSTACK RTWO SR,
RW1 32 SRDA, 0 RW1 LR, RW1 1 DR, 0 1 XR, 0 0 LTR,
?M IF, RW1 1 AR, RW2 0 BCTR, THEN, RW1 FIRST 4 +(, STH,
RW1 RM2 LR, ( ЧАСТНОЕ) POPPUT1 B, END-CODE
: * ( N1,N2->N3) M* DROP ;
: /MOD ( N1,N2->N3,N4) >R S>D R> M/ ;
: / ( N1,N2->N3) /MOD SWAP DROP ;
: MOD ( N1,N2->N3) /MOD DROP ;
: */MOD ( N1,N2,N3->N4,N5) >R M* R> M/ ;
: */ ( N1,N2,N3->N4) */MOD SWAP DROP ;

Экран номер 19
( 31.03.86 CPАBHEHИЯ И РАЗРЕШЕНИЯ В ШИТОМ КОДЕ)
: 0<> ( N->F) 0= NOT ;
: = ( W1,W2->F) - 0= ;
: <> ( W1,W2->F) - 0<> ;
: < ( N1,N2->F) - 0< ;
: >MARK ( ->A) HERE 0 , ;
: >RESOLVE ( A->) HERE SWAP ! ;
: <MARK ( ->A) HERE ;
: <RESOLVE ( A->) , ;

Экран номер 20
( 31.03.86 SP@ SP! RP@ RP! 2/ 2* 2@ 2! DEPTH )
CODE SP@ ( ->A) RW1 RSTACK LR, RW1 RFORTH SR, PUSHRW1 B,
CODE SP! ( A->) RSTACK PULL, RSTACK RMASK NR,
RSTACK RFORTH AR, RNEXT BR, END-CODE
CODE RP@ ( ->A) RW1 RRET LR, RW1 RFORTH SR, PUSHRW1 B, END-CODE
CODE RP! ( A->) RRET POP, RRET RMASK NR,
RRET RFORTH AR, RNEXT BR, END-CODE
CODE 2/ ( W1->W2 ) RW1 PULL, RW1 1 SRA, PUTRW1 B, END-CODE
: 2* ( W1->W2 ) DUP + ;
: 2@ ( A->WD) DUP 2+ @ SWAP @ ;
: 2! ( WD,A->) DUP >R ! R> 2+ ! ;
: DEPTH ( ->+N) SP@ S0 @ SWAP - 2/ ;

Экран номер 21
( 31.03.86 CMOVE CMOVE> )
CODE CMOVE ( A1,A2,U->) 14 LHRW12 BAL, RW2 RMASK NR, 2 =F BZ,
RW1 RMASK NR, RW1 RFORTH AR, 1 FIRST 4 +(, LH, 1 RMASK NR,
1 RFORTH AR, 0 256 LA, 1 =F В, BEGIN,
0 (, 256 RW1 ), 0 (, 1 MVC, RW1 0 AR, 1 0 AR,
1 =Н RW2 0 SR, ?M UNTIL, RW2 0 BCTR, RW2 0 AR,
?NM IF, RW2 3 =F EX, THEN,
2 =H RSTACK 6 (, 0 RSTACK LA, RNEXT BR,
3 =H 0 (, 1 RW1 ), 0 (, 1 MVC, END-CODE
CODE CMOVE> ( A1,A2,U->) 14 LHRW12 BAL, RW2 RMASK NR, 1 =F BZ,
RW1 РМASК NR, RW1 RFORTH AR, RW1 0 BCTR,
1 FIRST 4 +(, LH, 1 RMASK NR, 1 RFORTH AR, 1 0 BCTR,
DO, 0 0 (, 1 RM2 IC, 0 0 (, RW1 RW2 STC, RW2 LOOPBCT,
1 =H RSTACK 6 (, 0 RSTACK LA, RNEXT BR, END-CODE

Экран номер 22
( 31.03.86 FILL ERASE BLANK COMPILE [ ] MIN MAX HEX DECIMAL )
: FILL ( A,U,C->) SWAP ?DUP IF >R OVER C!
DUP 1+ R> 1- CMOVE EXIT THEN 2DROP ;
: ERASE ( A,U->) 0 FILL ;
: BLANK ( A,U->) BL FILL ;
: COMPILE ( ->) R> DUP 2+ >R @ , ;
: [ ( ->) STATE 0! ; IMMEDIATE
: ] ( ->) -1 STATE ! ;
CODE MIN ( N1,N2->N3) 14 LHRW12 BAL, RW1 RW2 CR,
POP BNH, RW1 RW2 LR, POPPUT1 B, END-CODE
CODE MAX ( N1,N2->N3) 14 LHRM12 BAL, RW1 RW2 CR,
POP BNL, RW1 RW2 LR, POPPUT1 B, END-CODE
: HEX ( ->) 16 BASE ! ;
: DECIMAL ( ->) 10 BASE ! ;

Экран номер 23
( 31.03.86 LIT 2LIT LITERAL 2LITERAL SPACE SPACES )
CODE LIT ( ->W ) RW1 0 (, RI RFORTH LH,
RI RTWO AR, PUSHRW1 B, END-CODE
CODE 2LIT ( ->WD ) RW1 4 LA, RSTACK RW1 SR,
RW2 0 (, RI RFORTH LA, FIRST (, 4 ), 0 (, RW2 MVC,
RI RW1 AR, RNEXT BR, END-CODE
: LITERAL ( W->) STATE @ IF COMPILE LIT , THEN ; IMMEDIATE
: 2LITERAL ( WD->) STATE @ IF COMPILE 2LIT , , THEN ; IMMEDIATE
: SPACE ( ->) BL EMIT ;
: SPACES ( +N->) 0 OVER < IF 0 DO SPACE LOOP EXIT THEN DROP ;

Экран номер 24
( 09.09.86 ЦИКЛЫ СО СЧЕТЧИКОМ: (DO/ I I' J LEAVE)
CODE (D0) ( U1,U2->) 14 LHRW12 BAL,
1 =H 1 0 (, RI RFORTH LH, 1 RPUSH, RI RTWO AR,
RW1 RPUSH, RW2 RPUSH, 2POP B, END-CODE
CODE I ( ->U ТЕКУЩЕЕ 3HАЧЕHИE СЧЕТЧИКА ЦИКЛА)
RW1 RPULL, PUSHRW1 B, END-CODE
CODE I' ( ->U ВЕРХНЯЯ ГPAНИЦА ЦИКЛА)
RW1 RSECOND LH, PUSHRW1 B, END-CODE
CODE J ( ->U ТЕКУЩЕЕ ЗНАЧЕНИЕ СЧЕТЧИКА 2-ГО ЦИКЛА)
RW1 RFIRST 6 +(, LH, PUSHRW1 В, END-CODE
CODE LEAVE ( -> ) RI RFIRST 4 +(, LH, RI RMASK NR,
RRET 6 (, 0 RRET LA, RNEXT BR, END-CODE

Экран номер 25
( 31.03.86 +BUF BUFFER BLOCK EMPTY-BUFFERS UPDATE )
: +BUF ( A1->A2,F ПЕРЕЙТИ К СЛЕДУЮЩЕМУ БУФЕРУ В ПУЛЕ)
B/BUF 4 + + DUP LIMIT = IF DROP FIRST THEN DUP PREV @ - ;
: BUFFER ( +N->A) OFFSET @ + USE @ DUP >R
( ИЩЕМ СВОБОДНЫЙ БУФЕР) BEGIN +BUF UNTIL USE !
R@ @ 0< IF ( УСТАНОВЛЕН ПРИЗНАК "UPDATE")
R@ 2+ R@ @ 32767 AND WBLK THEN R@ ! R@ PREV ! R> 2+ ;
: BLOCK ( +N->A) OFFSET @ + >R PREV @ DUP @ R@ - DUP + IF
BEGIN +BUF 0= IF DROP R@ OFFSET @ - BUFFER DUP R@ RBLK
2- THEN DUP @ R@ - DUP + 0=
UNTIL DUP PREV ! THEN RDROP 2+ ;
: EMPTY-BUFFERS ( ->) FIRST LIMIT OVER - ERASE ;
: UPDATE ( ->) PREV @ @ 32768 OR PREV @ ! ;

Экран номер 26
( 31.03.86 SAVE-BUFFERS FLUSH )
: SAVE-BUFFERS ( ->)
LIMIT FIRST DO I @ 32768 AND
IF I @ 32767 AND DUP I !
I 2+ SWAP WBLK
THEN
B/BUF 4 + +LOOP ;
: FLUSH ( ->) SAVE-BUFFERS EMPTY-BUFFERS ;

Экран номер 27
( 31.03.66 ENCLOSE WORD )
CODE ENCLOSE ( A,C->A,N1,N2,N3) 14 LHRW12 BAL, RW1 RMASK NR,
RW1 RFORTH AR, 14 14 SR, 0 0 SR,
BEGIN, 0 0 (, 14 RW1 IC, 0 0 LTR, 2 =F BZ,
14 1 (, 0 14 LA, 0 RW2 CR, ?NE UNTIL, 14 0 BCTR,
2 =Н 14 PUT,
BEGIN, 1 14 LR, 0 0 (, 1 RW1 IC, 0 0 LTR,
2 =F BZ, 14 1 (, 0 14 LA, 0 RW2 CR, ?E UNTIL,
2 =Н 1 PUSH, RW1 14 LR, PUSHRW1 В, END-CODE
: WORD ( C->T) BLK @ IF BLK @ BLOCK ELSE TIB THEN
>IN @ + SWAP ENCLOSE >IN +!
HERE >R OVER - >R + ALIGNH HERE 1+ R@ CMOVE
HERE R> 1+ ALLOT ALIGNH HERE OVER - 2- OVER C! R> DP! ;

Экран номер 28
( 31.03.86 LIT" COUNT ," " ". (."/ ." C" ( ,( QUIT ABORT )
CODE LIT" ( ->T ) 14 IPUSH BAL, RNEXT BR, END-CODE
: COUNT ( T->A,N) DUP 1+ SWAP C@ 2DUP + С@ IF 1+ THEN ;
: ," ( ->) C" " WORD С@ 2+ ALLOT ALIGNH ;
: " ( ->T) ?COMP COMPILE LIT" ," ; IMMEDIATE
: ". ( T->) COUNT TYPE ;
CODE (.") ( ->) 14 IPUSH BAL, 14 GOTO BAL, ] ". [
: ." ( ->) ?COMP COMPILE (.") ," ; IMMEDIATE
: C" ( ->C) BL WORD 1+ С@ [COMPILE] LITERAL ; IMMEDIATE
: ( ( ->) C" ) WORD DROP ; IMMEDIATE
: .( ( ->) C" ) WORD COUNT TYPE ; IMMEDIATE
: QUIT ( ->) [COMPILE] [ S0 @ SP! R0 @ RP! ФОРТ-СИСТЕМА ;

Экран номер 29
( 31.03.86 ПРОВЕРКИ И СИГНАЛИЗАЦИИ ОБ ОШИБКАХ)
: ?ABORT ( F,T->) SWAP IF COUNT CR TYPE ABORT THEN DROP ;
CODE (A") ( F->) 14 IPUSH BAL, 14 GOTO BAL, ] ?ABORT [ END-CODE
: ABORT" ( F->) COMPILE (A") ," ; IMMEDIATE
: ABORT8 ( ->) -1 ABORT" НЕПРАВИЛЬНОЕ ЗНАЧЕНИЕ В СТЕКЕ" ;
: !CSP ( ->) SP@ CSP ! ;
: ?CSP ( ->) SP@ CSP @ - ABORT" СБИЛСЯ УКАЗАТЕЛЬ СТЕКА" ;
: ?PAIRS ( N1,N2->) - ABORT" НЕПАРНЫЕ СКОБКИ" ;
CODE ?+ ( N->N ) FIRST 128 TM, RNEXT BZR, ERCOND8 B, END-CODE
: ?COMP ( ->) STATE @ NOT ABORT" ТРЕБУЕТСЯ РЕЖИМ КОМПИЛЯЦИИ" ;
: BADWORD ( T->) CR ". ." ?" ABORT ;

Экран номер 30
( 31.03.86 >BODY BODY> >LINK LINK> L>NAME N>LINK >NAME NAME> )
: >BODY ( CFA->PFA) 2+ ;
: BODY> ( PFA->CFA>) 2- ;
: >LINK ( CFA->LFA) 2- ;
: LINK> ( LFA->CFA) 2+ ;
CODE L>NAME ( LFA->NFA) RW2 PULL, RW2 RMASK NR, RW1 RW2 LR,
14 &LENG LA, 1 1 SR, DO, RW1 RTWO SR, 1 0 (, RW1 RFORTH IC,
1 LENG1MSK N, 0 2 (, 1 RW1 LA, 0 RW2 CR, PUTRW1 BE,
14 LOOPBCT, PUTRW1 B, END-CODE
: N>LINK ( NFA->LFA) DUP С@ 31 AND + 2+ ;
: >NAME ( CFA-NFA) >LINK L>NAME ;
: NAME> ( NFA->CFA) N>LINK LINK> ;

Экран номер 31
( 31.03.86 LATEST DEFINITIONS SMUDGE UNSMUDGE IMMEDIATE ID. )
: LATEST ( ->NFA) CURRENT @ @ ; ( (;CODE/ RECURSE )
: DEFINITIONS ( ->) CONTEXT @ CURRENT ! ;
: SMUDGE ( ->) LATEST С@ [ &SFLAG ] LITERAL OR LATEST C! ;
: UNSMUDGE ( ->) LATEST С@ [ 255 &SFLAG - ] LITERAL
AND LATEST С! ;
: IMMEDIATE ( ->) LATEST С@ [ &IFLAG ] LITERAL OR LATEST C! ;
: ID. ( NFA->) DUP 1+ SWAP С@ [ &LENG ] LITERAL AND
2DUP + C@ IF 1+ THEN TYPE SPACE ;
: (;CODE) ( ->) R> LATEST NAME> ! ;
: RECURSE ( ->) LATEST NAME> , ; IMMEDIATE

Экран номер 32
( 31.03.86 CONSTANT VARIABLE 2CONSTANT 2VARIABLE : ; )
: ?LOADING ( ->) BLK @ 0= ABORT" НЕТ ОБРАБОТКИ ЭКРАНА" ;
: ?GAP ( N->) HERE + SP@ SWAP U< ABORT" ИСЧЕРПАНИЕ ПАМЯТИ" ;
: ?STACK ( ->) S0 @ SP@ U< ABORT" ИСЧЕРПАНИЕ СТЕКА" 10 ?GAP ;
: CONSTANT ( W->) CREATE , ;CODE
RW1 0 (, 14 RFORTH LH, PUSHRW1 B, END-CODE
: VARIABLE ( ->) CREATE 0 , ;
: 2VARIABLE ( ->) CREATE 0 , 0 , ;
: 2CONSTANT ( WD->) CREATE , , DOES> 2@ ;
: : ( -> ) !CSP CREATE ] SMUDGE ;CODE
RI RPUSH, RI 14 LR, RNEXT BR, END-CODE
: ; ( -> ) ?CSP COMPILE EXIT UNSMUDGE [COMPILE] [ ; IMMEDIATE

Экран номер 33
( 09.09.86 FORTH FORTH# FL# VOC-LINK VOCABULARY VOCABULARY# )
VOC FORTH &DWORD H, ( FORTH-83)
A: FORTH# LASTWORD ( ВХОД В СПИСОК СЛОВАРНЫХ СТАТЕЙ)
A: FL# 0 Н, ( ПОЛЕ СВЯЗИ ДЛЯ СПИСКОВ СТАТЕЙ)
CREATE VOC-LINK FL# ( ВХОД В СПИСОК СПИСКОВ СТАТЕЙ)
: VOCABULARY ( ->) CREATE [ &DWORD ] LITERAL ,
LIT [ FORTH# ]
CONTEXT @ - IF CONTEXT @ 2- ELSE 0 THEN ,
HERE VOC-LINK @ , VOC-LINK ! DOES>
[ THERE 4 - :A: VOCABULARY# ]
2+ CONTEXT ! ;
: FORTH-83 ( ->) FORTH DEFINITIONS DECIMAL ;

Экран номер 34
( 31.03.86 (FIND/ )
CODE (FIND) ( -1,AN,..,,A1,Т->СFA,С,TF/FF ) RW2 POP,
RW2 RMASK NR, RW2 RFORTH AR, ( ОБРАЗЕЦ) 0 0 SR,
0 0 (, 0 RW2 IC, 0 LENG1MSK N, ( ДЛИНА) 1 1 SR, 1 0 BCTR,
BEGIN, RW1 PULL, ( ВХОД В ОЧЕРЕДНОЙ СПИСОК СЛОВ) 2 =F В,
BEGIN, RW1 RFORTH AR, 14 0 (, 0 RW1 IC, 14 LEHGMASK N,
14 0 CR, ?E IF, 14 4 =F EX, 3 =F BE, THEN,
14 LENG1MSK N, RW1 2 (, 14 RW1 LH,
2 =H RW1 RMASK NR, ?Z UNTIL,
RSTACK RTWO AR, 1 FIRST CH, ?E UNTIL, PUTRW1 B,
BEGIN, RSTACK RTWO AR, 3 =H 1 FIRST CH, ?E UNTIL,
0 0 (, 0 RW1 IC, RW1 RFORTH SR, RW1 4 (, 14 RW1 LA,
RW1 PUT, 0 PUSH, RW1 1 LR, PUSHRW1 B,
4 =H 1 (, 1 RW1 ), 1 (, RW2 CLC, END-CODE

Экран номер 35
( 31.03.86 FIND -FIND )
: FIND ( T->A,N)
DUP >R -1 LIT [ FORTH# ] @
CURRENT @ @ 2DUP = IF DROP THEN
CONTEXT @ @ 2DUP = IF DROP THEN
R> (FIND) DUP IF
DROP ROT DROP [ &IFLAG ] LITERAL AND IF 1 ELSE -1 THEN
THEN ;
: -FIND ( ->A,N) BL WORD FIND ;

Экран номер 36
( 09.09.86 CREATE DOES> )
: CREATE ( ->) 100 ?GAP
ALIGNH -FIND SWAP DROP IF
HERE ID. ." УЖЕ ЕСТЬ " THEN
HERE DUP С@ WIDTH AND 2+ ALLOT ALIGNH
HERE OVER - 2- OVER C! LATEST , CURRENT @ !
LIT [ CREATE# ] , ;
: DOES> ( ->) COMPILE (;CODE) 2LIT
[ DOES# B, ] , , ; IMMEDIATE

Экран номер 37
( 31.03.86 PAD HOLD ALPHA <# #> # #S SIGN )
: PAD ( ->A) HERE 100 + ;
: HOLD ( C->) -1 HLD +! HLD @ С! ;
CODE ALPHA ( N->C) RW2 FIRST LH,
RW1 RW1 SR, RW1 1 =F (, RW2 IC, PUTRW1 B,
1 =H C,' 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
END-CODE
: <# ( ->) PAD HLD ! ;
: #> ( D->A,+N) 2DROP HLD @ PAD OVER - ;
: # ( D1->D2) BASE @ M/MOD ROT ALPHA HOLD ;
: #S ( D->0,0) BEGIN # 2DUP OR 0= UNTIL ;
: SIGN ( N->) 0< IF C" - HOLD THEN ;

Экран номер 38
( 31.03.86 D.R D. .R . H. U. U.R ? )
: D.R ( D,+N->) ?+ >R DUP >R DABS
<# #S R> SIGN #> R> OVER - SPACES TYPE ;
: D. ( D->) 0 D.R SPACE ;
: .R ( N1,+N2->) >R S>D R> D.R ;
: . ( N->) S>D D. ;
: H. ( N->) BASE @ SWAP 0 HEX <# # # # # #> TYPE SPACE
BASE ! ;
: U. ( U->) 0 D. ;
: U.R ( U,+N->) >R 0 R> D.R ;
: ? ( A->) @ . ;

Экран номер 39
( 31.03.86 DIGIT CONVERT NUMBER )
: DIGIT ( C,N1->N2,TF/FF) 0 ROT ROT 0
DO I ALPHA OVER - IF 2DROP I -1 0 LEAVE THEN LOOP DROP ;
: CONVERT ( WD1,A1->WD2,A2)
BEGIN 1+ DUP >R C@ BASE @ DIGIT WHILE
SWAP BASE @ UM* DROP ROT BASE @ UM* D+
DPL @ 1+ IF DPL 1+! THEN R> REPEAT R> ;
: NUMBER ( T->WD)
0 0 ROT DUP >R COUNT OVER + OVER С@ С" - =
DUP >R SWAP >R IF ELSE 1- THEN -1
BEGIN DPL ! CONVERT DUP R@ < WHILE DUP С@
С" . <> IF RDROP RDROP R> BADWORD THEN 0
REPEAT DROP RDROP R> IF DNEGATE THEN RDROP ;

Экран номер 40
( 31.03.86 EXPECT QUERY INTERPRET ФОРТ-СИСТЕМА X )
: EXPECT ( A,+N->) DUP >R (EXPECT) DUP SPAN !
TYPE R> SPAN @ - IF SPACE THEN ;
: QUERY ( ->) TIB 80 EXPECT >IN 0! BLK 0! SPAN @ #TIB ! ;
: INTERPRET ( ->) BEGIN -FIND ?DUP IF
1+ IF EXECUTE ELSE STATE @ IF , ELSE EXECUTE THEN THEN
ELSE NUMBER DPL @ 1+ IF [COMPILE] 2LITERAL
ELSE DROP [COMPILE] LITERAL THEN THEN ?STACK AGAIN ;
: ФОРТ-СИСТЕМА ( ->) BEGIN QUERY INTERPRET AGAIN ;
CODE X ( ->) ЗАБИТЬ-Х ( НУЛЕВОЙ КОД ВМЕСТО БУКВЫ "X")
EXIT# B, END-CODE IMMEDIATE

Экран номер 41
( 31.03.86 -TRAILING ' ['] [COMPILE] LOAD THRU ;S --> )
CODE -TRAILING ( A,N1->A,N2) 14 LHRW12 BAL, RW1 RMASK NR,
RW1 RFORTH AR, 0 RW1 LR, RW1 RW2 AR, BEGIN, RW1 0 CR,
1 =F BNH, RW1 0 BCTR, 0 (, RW1 64 CLI, ?NE UNTIL, 0 0 BCTR,
1 =H RW1 0 SR, PUTRW1 В, END-CODE
: ' ( ->CFA) -FIND 0= IF BADWORD THEN ;
: ['] ( ->) ?COMP ' [COMPILE] LITERAL ; IMMEDIATE
: [COMPILE] ( ->) -FIND IF , EXIT THEN BADWORD ; IMMEDIATE
: LOAD ( N-> ИНТЕРПРЕТИРОВАТЬ БЛОК С НОМЕРОМ N)
>IN @ >R BLK @ >R BLK ! >IN 0! INTERPRET R> BLK ! R> >IN ! ;
: THRU ( N1,N2-> ИНТЕРПРЕТИРОВАТЬ БЛОКИ ОТ N1 ДО N2)
1+ SWAP DO I LOAD LOOP ;
: ;S ( ->) ?LOADING RDROP ; IMMEDIATE
: --> ( ->) ?LOADING >IN 0! BLK 1+! ; IMMEDIATE

Экран номер 42
( 09.09.86 DUMP SNAPSTK S. R. )
: DUMP ( A,U-> РАСПЕЧАТАТЬ U БАЙТОВ) DUP IF
BASE @ >R HEX OVER + SWAP DO CR I <# C" * HOLD
0 15 DO DUP I + C@ HOLD -1 +LOOP С" * HOLD
0 15 DO BL HOLD DUP I + C@ 0 # # 2DROP -1 +LOOP BL HOLD
BL HOLD 0 # # # # # #> TYPE 16 +LOOP R> BASE ! ELSE 2DROP THEN ;
: SNAPSTK RDROP CR ". ." , ВСЕГО ЗНАЧЕНИЙ "
2DUP SWAP - 2/ DUP . 0 SWAP < IF ." (ВЕРШИНА СПРАВА)" CR
2- DO I @ . -2 +LOOP ELSE 2DROP THEN ;
: S. ( ->) SP@ S0 @ " СТЕК ДАННЫХ" SNAPSTK ;
: R. ( ->) RP@ 2+ R0 @ " СТЕК ВОЗВРАТОВ" SNAPSTK ;

Экран номер 43
( 31.03.86 .VOC (VOC/ VOCS )
: .VOC ( PFA+2->) 2- BODY> >NAME ID. ;
: (VOC) ( PFA1+2->PFA2,N) @ 0
BEGIN OVER DUP IF @ [ &DWORD ] LITERAL <> THEN
WHILE 1+ ( СЧЕТЧИК СЛОВ) SWAP N>LINK @ SWAP REPEAT ;
: VOCS ( ->) -1 ['] FORTH >BODY 2+
CURRENT @ ." СПИСОК CURRENT: " DUP .VOC OVER @ OVER @ =
IF DROP THEN CONTEXT @ ." СПИСОК CONTEXT: " DUP .VOC
OVER @ OVER @ = IF DROP THEN
CR ." СТАНДАРТНЫЙ ПОРЯДОК ПОИСКА: "
BEGIN 2- BEGIN 2+ DUP .VOC (VOC) DROP DUP 0= UNTIL
DROP DUP -1 = UNTIL DROP
CR ." НАЛИЧНЫЕ СПИСКИ СЛОВ: " VOC-LINK @
BEGIN DUP 2- .VOC @ DUP 0= UNTIL DROP ;

Экран номер 44
( 31.03.86 WORDS )
: WORDS ( -> )
." СПИСОК " CONTEXT @ DUP .VOC DUP (VOC)
." ВСЕГО СЛОВ - " . ." СЛЕДУЮЩИЙ СПИСОК - "
?DUP IF 2+ .VOC THEN
CR @ BEGIN DUP DUP IF @ [ &DWORD ] LITERAL <> THEN
WHILE DUP С@ [ &SFLAG ] LITERAL AND 0=
IF DUP ID. SPACE THEN
N>LINK @ REPEAT DROP ;

Экран номер 45
( 31.03.86 (FORGET/ FORGET REMEMBER FORGET0 )
: (FORGET) ( A-> ИСКЛЮЧИТЬ ВСЕ СЛОВА ВЫШЕ АДРЕСА А)
DUP FENCE @ U< ABORT" ЗАЩИТА ПО FENCE"
>R VOC-LINK @
BEGIN R@ OVER U< WHILE FORTH DEFINITIONS
@ DUP VOC-LINK !
REPEAT ( ДОШЛИ ДО СПИСКА, ГДЕ ЕСТЬ ЭТО СЛОВО)
BEGIN DUP 4 -
BEGIN N>LINK @ DUP R@ U< UNTIL
OVER 2- ! @ ?DUP 0= UNTIL R> DP! ;
: FORGET ( ->) ' >NAME (FORGET) ;
: REMEMBER ( ->) CREATE DOES> (FORGET) ;

Экран номер 46
( 31.09.86 (#SCR/ LIST SCR? INDEX )
: (#SCR) ( N->A,T ПЕРЕВЕСТИ НОМЕР N ЭКРАНА В ТЕКСТОВОЕ ИМЯ)
BASE @ >R DECIMAL 0 <# #S #> R> BASE ! ;
: LIST ( N-> РАСПЕЧАТАТЬ ЭКРАН N, ЗАПОМНИТЬ ЕГО В "SCR")
DUP SCR ! CR ." ЭКРАН " DUP (#SCR) TYPE
BLOCK 16 0 DO DUP I 64 * +
CR I 3 .R SPACE 64 TYPE LOOP DROP ;

Экран номер 47
( 31.03.86 СТАНДАРТНЫЕ СТРУКТУРЫ УПРАВЛЕНИЯ )
: BEGIN ?COMP <MARK 1 ; IMMEDIATE
: UNTIL 1 ?PAIRS COMPILE ?BRANCH <RESOLVE ; IMMEDIATE
: AGAIN 1 ?PAIRS COMPILE BRANCH <RESOLVE ; IMMEDIATE
: IF ?COMP COMPILE ?BRANCH >MARK 2 ; IMMEDIATE
: THEN 2 ?PAIRS >RESOLVE ; IMMEDIATE
: ELSE 2 ?PAIRS COMPILE BRANCH >MARK
SWAP >RESOLVE 2 ; IMMEDIATE
: WHILE 1 ?PAIRS 1 [COMPILE] IF ; IMMEDIATE
: REPEAT >R >R [COMPILE] AGAIN
R> R> [COMPILE] THEN ; IMMEDIATE
: DO ?COMP COMPILE (DO) >MARK <MARK 3 ; IMMEDIATE
: LOOP 3 ?PAIRS COMPILE (LOOP) <RESOLVE >RESOLVE ; IMMEDIATE
: +LOOP 3 ?PAIRS COMPILE (+LOOP) <RESOLVE >RESOLVE ; IMMEDIATE

ЗАМЕЧАНИЕ

Опять обратите внимание, что экран #6 - пустой. Это не досадное недоразумение, а следствие важнейшего FORTH-принципа. FORTH-система всегда строится поверх Операционной Системы! И этот экран должен содержать обращения к ней. Если Операционной Системы на момент написания FORTН-системы нет, ее придется написать самому. Пусть совсем простенькую - только символьный ввод-вывод и дисковую память. То, что нужно процедуре ОК.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Сб Апр 10, 2021 12:33 am

ПРИЛОЖЕНИЕ 2.
РАСПРОСТРАНЕННЫЕ ФОРТ-СИСТЕМЫ

ФИГ-ФОРТ. Система разработана в 1978-1980гг. группой из 9 системных программистов в США - Группой по языку Форт (FORTH Interest Group), желавших сделать этот язык удобным средством программирования для персональных ЭВМ [28]. Система реализована для целого ряда ЭВМ с различной архитектурой. В нашей стране получила распространение на ЭВМ СМ-4 с операционными системами ОС РВ, РАФОС и без операционной системы. Ее ядро, написанное на макроязыке ассемблера, занимает от 4 до 5К байт и после загрузки в память ЭВМ позволяет вводить следующие определения уже непосредственно на языке Форт. Общий объем словаря - около 8К (220 слов). В реализации применен косвенный шитый код. Имеются загружаемый ассемблер и текстовый редактор.

ФОРТ-СМ. Система разработана в Ленинграде С.Б.Кацевым (ЛГУ) и И.А.Шендриковым (ЛИТМО) на основе стандарта "Форт-83". Используется с 1985г. на ЭВМ СМ-3, СМ-4, ДВК, "Электроника-60", БК0010. Словарь включает около 350 слов, его общий объем - 10.5К. В зависимости от генерации может работать под операционными системами ОС РВ, РАФОС или без операционной системы с перфоленточной загрузки. В реализации применен косвенный шитый код. Имеются связь с файловой системой соответствующей ОС, загружаемый структурный ассемблер с метками, строковый и экранный редакторы, целевая компиляция.

ФОРТ-ТАРТУ. Система разработана в ВЦ Тартуского государственного университета Р.В.Вяйнасте и А.Э.Юуриком для операционных систем ОС РВ (используется с 1983г.) и ЮНИКС (с 1985г.). Ядро системы занимает 8К байт и включает 270 слов. Система является расширением стандарта "Фиг-форт". В реализации применен прямой шитый код. Имеется встроенный ассемблер, в оттранслированном виде занимающий 1К байт. Встроенный текстовый редактор для ОС РВ имеет только строковый режим, для ОС ЮНИКС реализован экранный вариант. Система используется в учебном процессе и как инструментальное средство для НИР [20].

ФОРТ-К580. Система разработана в ЛГУ В.А.Кириллиным, А.А.Клубовичем и Н.Р.Ноздруновым для микропроцессора К580. Используется с 1983г. Система легко переносится на любое оборудование на базе К580, в частности она успешно перенесена на ЕС-7970, СМ-1800 (под управлением ОС "Си-Пи-Эм"), К1-10, КТС ЛИУС, КУВТ "Ямаха", КУВТ "Корвет" и большое число мелкосерийных микроЭВМ. Включена в комплект заводской поставки ЕС-7970 в составе программного комплекса ЯНУС. Ядро системы занимает от 8 до 12К байт и насчитывает около 300 слов. Система является расширением стандарта "Форт-83", включает все стандартные расширения и ряд слов для взаимодействия с операционной системой и аппаратурой устройств, а также для разработки и отладки программ; Имеются отдельно загружаемые пакеты для работы с числами в формате с плавающей точкой, для диалогового обучения языку Форт, для целевой компиляции и построения конечного программного продукта, размещаемого в ПЗУ и (или) ОЗУ. В реализации применен прямой шитый код. Встроенный структурный ассемблер разрешает использование меток. Имеется два текстовых редактора - построчный и поэкранный.

ФОРТ-ЕС. Система разработана в Ленинградском институте информатики и автоматизации АН СССР (ЛИИАН) С.Н.Барановым для ЕС ЭВМ [2] под управлением ОС ЕС и СВМ ЕС. Ядро системы занимает 13 К байт и насчитывает 350 слов. Система является расширением стандарта "Форт-83", включает все стандартные расширения и ряд слов для взаимодействия с операционной системой, для работы с четырехбайтными машинными адресами, для разработки и отладки программ. Имеются отдельно загружаемые пакеты для работы с числами в формате с плавающей точкой, для связи с файловой системой, для справочной подсистемы с диалоговым учебником по языку Форт. В реализации применен косвенный шитый код. Встроенный структурный ассемблер разрешает использование меток. Текстовый редактор работает в режимах построчного и поэкранного редактирования. Система имеет отдельно загружаемый пакет целевой компиляции и средства для построения независимого программного продукта.

ФОРТ-ИСКРА-226. Эта развитая операционная система на базе языка Форт [6] разработана в Институте социально-экономических проблем (ИСЭП) АН СССР. Используется с 1986г. Включена в комплект заводской поставки ЭВМ "Искра-226". Объем - около 32К байт (свыше 400 слов). Система базируется на стандарте "Фиг-форт", расширенном рядом слов в соответствии с ее функциональным назначением. Среди них встроенный диспетчер, средства для параллельного выполнения директив, работа с файлами и базами данных, работа с адресным пространством до 128К байт. Важным встроенным средством является программная реализация элементарных математических функций и операций для работы с плавающей точкой. В реализации применен прямой шитый код. Встроенный экранный редактор имеет режим работы с окнами.

ФОРТ-М6000. Система разработана В.Н.Патрышевым (Ленинград) для ЭВМ М6000 под управлением ДОС РВ, РТЕ-2 и для работы без операционной системы. Используется с 1985г. Ядро занимает 14К байт (300 слов). Система ориентирована на стандарт "Форт-83". В реализации использован прямой шитый код. Имеются своя файловая система, средства для связи с операционной системой, строковый редактор, ориентированный на файловую систему.

ФОРТ-БЭСМ-6. Система разработана в Институте теоретической астрономии (ИТА) АН СССР И.Р.Агамирзяном для ЭВМ БЭСМ-6. Используется с 1984г. Работает под управлением ОС ДИСПАК и имеет интерфейс с файловой системой КРАБ. Общий объем - 24К байт (500 слов). По входному языку система ближе всего к стандарту "Фиг-форт", вместе с тем используется ряд слов из стандарта "Форт-83". Сравнительно большой объем памяти связан с отсутствием в ЭВМ БЭСМ-6 байтовой адресации. Для представления стандартного двухбайтного значения используется шести-байтное машинное слово БЭСМ-6. По той же причине для работы с байтовыми значениями вместо слов С@, С! и других введен ряд специальных слов. Из-за особенностей системы команд в реализации применен подпрограммиый шитый код. Это позволяет включать ассемблерные вставки непосредственно в шитый код и наоборот - высокоуровневые слова как обращения к подпрограммам внутрь ассемблерных определений. Прототипом для встроенного ассемблера является ассемблер МАДЛЕН БЭСМ-6. В качестве текстового редактора используется стандартный редактор операционной системы.

ФОРТ-ЭЛЬБРУС. Система разработана на математико-механическом факультете ЛГУ А.Е.Соловьевым для МВК "Эльбрус". Работает с 1986г. под управлением ОС "Эльбрус". Ядро занимает 4.5К байт (200 слов). Система ориентирована на стандарт "Форт-83", имеет ряд специальных инструментальных слов и средства для связи с процедурами на языке Эль-76.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Сб Апр 10, 2021 12:35 am

СПИСОК ЛИТЕРАТУРЫ

1. Астановскнй А.Г., Ломунов. В.Н. Процессор, ориентированный на язык Форт//Программирование микропроцессорной техники. Таллин: Ин-т кибернетики АН ЭССР, 1984. С.50-67.
2. Баранов С.Н. Система Форт-ЕС. Л., 1986. 48с. (Препринт ЛИИАН #1).
3. Баранов С.Н. Стандарты языка Форт/ЛИИАН, 1987. 88с. Деп. в ВИНИТИ. 04.06.87. ФН 4012-887.
4. Баранов С.Н., Кириллин В.А., Ноздрунов Н.Р. Реализация языка Форт на дисплейном комплексе ЕС-7970//Программирование микропроцессорной техники. Таллин: Ии-т кибернетики АН ЭССР, 1984. С.41-49.
5. Берс А.А., Поляков В.Г., Руднев С.Б. Основные принципы разработки системы программирования для микропро-цессоров//Программное обеспечение задач информатики. Новосибирск: ВЦ СОАН, 1982. С.5-25.
6. Болдырев А.Ю., Веретенова Н.Н., Лезин Г.В. ФОС: интерактивная система программирования для ЭВМ ИСКРА-226. Л., 1986. 74с. (Препринт ИСЭП).
7. Вулф А. Операционные системы реального времени в русле развития вычислительной техники//Электроника. 1985. #17. С.46-56.
8. Дейкстра Э.Д. Взаимодействие последовательных процессов//Языки программирования/ Пер. с англ. М.: Мир, 1972. С.9-86.
9. Диалоговые микропроцессорные системы/Под ред. Н.П.Брусенцова и А.М.Шаумана. М.: Изд-во МГУ, 1986. 148с.
10. Ершов А.П. О сущности трансляции//Программирование. 1977. #5. С.21-39.
11. Кнут Д. Искусство программирования для ЭВМ/Пер.
с англ. Т.1. М.: Мир, 1976. 735с.
12. Котляров В.П., Морозов Н.Б. Технологические комплексы разработки программного обеспечения встроенных микроЭВМ// Индивидуальные диалоговые системы на базе микроЭВМ (персональные компьютеры) ДИАЛОГ-84-МИКРО. Л.: Наука, 1984. С.93-96.
13. Липаев В. В. Тестирование программ. М.: Радио и связь, 1986. 296 с.
14. Липаев В.В., Каганов Ф.А., Керданов А.В. Система автоматизации проектирования программ на базе персональных ЭВМ (система ПРА)//Микропроцессорные средства и системы. 1985. #4. С.42-45.
15. Новиков Б.А. Снова сопрограммы//Программирование. 1986. #4. С.59-62.
16. Новиков Б.А., Романовский И.В. Сопрограммы в ОС ЕС// Кибернетика. 1985. #1. С.34-37, 44.
17. Руднев С.Б., Четвернин В.А. Переносимая рабочая смесь - ядро программного обеспечения персональной ЭВМ//Персональные ЭВМ в задачах информатики. Новосибирск: ВЦ СОАН. 1984. С.58-72. Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #121, АБЗАЦ #2074Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
18. Сахаров А.Л. Д/М - диалоговый язык для управления пакетами прикладных программ//Управляющие системы и машины. 1985. #3. С.105-109.
19. Технология проектирования компонентов программ АСУ/В.В.Липаев, Л.А.Серебровский, П.Г.Гаганов и др. М: Радио и связь, 1983. 264с.
20. Томбак М.О., Пеял Я.Р., Соо В.К. Использование расширяемого языка в СПТ//Тр. Вычислит, центра Тартус. ун-та. Вып.52. 1985. с.39-54.
21. Ballard В. FORTH Direct Execution Processors in the Hopkins Ultraviolet Telescope//J. FORTH Appl. and Res. 1984. Vol.2. #1. P.33-47.
22. Dewar R.K. Indirect Threaded Code//CACM. 1975. Vol.18. #6. P.330-331.
23. FORTH-83 Standard. Mountain View (USA): FORTH Standards Team, 1983. 82p.
24. Harris K. The FORTH Philosophy//Dr.Dobb's J. 1981. Vol.6. #59. P.6-11.
25. Loeliger R.G. Threaded Interpretative Languages. Peter-bourgh: Byte Books, 1980. 251p.
26. McCabe С.К. FORTH-83: Evolution Continues//BYTE. 1984. Vol.9. #8. P.137-138, 412-415, 418-421.
27. Moore С.H. FORTH: A New Way to Program a Mini-Computer//Astr. and Astrophys. Suppl. 1974. Vol.5. P.497-511.
28. Ragsdale W.F. Fig-FORTH Installation Manual. Glossary. Model. Editor. San Carlos: FORTH Interest Group, 1980. 61p.
29. Ritter Т., Walker G7 Varieties of Threaded Code for Language Implementation//BYTE. 1980. Vol.5. #9. P.206-227.
30. Tello E. PolyFORTH and PC/FORTH//BYTE. 1984. Vol.9. #12. P.303-310, 312, 314.
31. Walker R.V., Rather E.D. PolyFORTH II Reference Manual. S.L.: FORTH Inc., 1983. 524p.
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Empty Re: Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988

Сообщение автор Gudleifr Сб Апр 10, 2021 1:03 am

Ссылки на эту книгу с других тем Форума:
2.1.ШИТЫЙ КОД И ЕГО РАЗНОВИДНОСТИ -- Интерпретатор Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #42, АБЗАЦ #408Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.2.СТРУКТУРА СЛОВАРНОЙ СТАТЬИ -- Управление словарными статьями Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #50, АБЗАЦ #481Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.3.СТЕК ВОЗВРАТОВ И РЕАЛИЗАЦИЯ СТРУКТУР УПРАВЛЕНИЯ -- Структуры управления Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #53, АБЗАЦ #490Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.4.УПРАВЛЕНИЕ ПОИСКОМ СЛОВ -- Распознавание символа - FIND и NUMBER Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #25, АБЗАЦ #139Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.5.РЕАЛИЗАЦИЯ ОПРЕДЕЛЯЮЩИХ СЛОВ -- Компилирующие слова Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #54, АБЗАЦ #504Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.6.ВСТРОЕННЫЙ АССЕМБЛЕР -- FORTH-ассемблер Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #29, АБЗАЦ #212Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.7.РАБОТА С ВНЕШНЕЙ ПАМЯТЬЮ -- Блоковая память Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #51, АБЗАЦ #484Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
2.9.ЦЕЛЕВАЯ КОМПИЛЯЦИЯ И МОДЕЛЬ ФОРТ-СИСТЕМЫ -- Написание своего FORTH Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #30, АБЗАЦ #224Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
3.4.ВЕКТОРНОЕ ПОЛЕ КОДА -- Эмуляция механизма данных Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #55, АБЗАЦ #520Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
" -- Компилирующие слова Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #54, АБЗАЦ #510Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
3.11.РЕАЛИЗАЦИЯ ВСТРОЕННОГО АССЕМБЛЕРА -- FORTH-ассемблер Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #29, АБЗАЦ #212Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
ПРИЛОЖЕНИЕ.1 - Написание своего FORTH Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10ТЕМА #30, АБЗАЦ #225Баранов, Ноздрунов. Язык ФОРТ и его реализации. 1988 - Страница 2 Leaf10
Gudleifr
Gudleifr
Admin

Сообщения : 3219
Дата регистрации : 2017-03-29

Вернуться к началу Перейти вниз

Страница 2 из 2 Предыдущий  1, 2

Вернуться к началу

- Похожие темы

 
Права доступа к этому форуму:
Вы не можете отвечать на сообщения