Sanscript
Реализация языка программирования SanscriptРодная (и единственная) среда разработки языка Sanscript. Разработана Northwoods Software. В апреле 2000 года была сделана бесплатной, но при этом поддержка разработчиков была прекращена. Написана на C++/MFC.
Ссылки:
Примеры:
Hello, World!:
Пример для версий Sanscript 2.2Диаграмма функций для этого примера состоит из двух функций — константы “Hello, World!” и “Display Message”, которая выводит эту константу на экран.
Hello, World! на Sanscript
Факториал:
Пример для версий Sanscript 2.2Первый скриншот показывает главную диаграмму потоков. Ее основной частью является функция Repeat
(аналог циклов в других языках), которая рассчитывает факториалы чисел и записывает их в список. У этой функции две пары входных и выходных контактов, которые соответствуют глобальным переменным в других языках, — factorial
(хранит текущее значение факториала) и message
(список строк текста (n)! = (n!)). Кроме того, есть еще один входной контакт N
, который задает нужное количество итераций.
Входные контакты инициализируются константами и пустым списком, и цикл начинается. После конца вычислений message
нужно вывести на печать. Это можно сделать при помощи функции Write List as Text
, которая конкатенирует элементы списка в одну строку с заданным разделителем. Разделитель задается входным контактом sep
; в данном случае это символ новой строки, сгенерированный функцией Char
, которая преобразует ASCII-код в соответствующий символ. Наконец, полученная строка показывается функцией Display Message
.
Второй скриншот демонстрирует внутренности функции Repeat
. Элемент, обозначенный как “1, 2 …”, — счетчик цикла, начинающийся с 1 и увеличивающийся на 1 каждую итерацию. На каждой итерации factorial
умножается на значение счетчика (функция Times
). После этого новое значение конкатенируется со счетчиком и константой "! = "
(функция Append Text
). Наконец, полученная строка добавляется в список message
(функция Add Last Item
).
Факториал на Sanscript - главная диаграмма потоков
Факториал на Sanscript - блок Repeat
Числа Фибоначчи:
Пример для версий Sanscript 2.2Числа Фибоначчи вычисляются так же, как факториал: цикл-Repeat
вычисляет список чисел, начиная с двух первых, после чего список конкатенируется в выводимое сообщение. Внутри цикла текущее число добавляется к списку и заменяется на следующее, а следующее — на сумму текущего и следующего.
Числе Фибоначчи на Sanscript - главная диаграмма потоков
Числе Фибоначчи на Sanscript - блок Repeat
Квадратное уравнение:
Пример для версий Sanscript 2.2Этот пример содержит много условных переходов, а в Sanscript каждая ветвь описывается отдельной диаграммой.
Квадратное уравнение - главная диаграмма потоков
Квадратное уравнение - условие A=0
Квадратное уравнение - условие A=default
Квадратное уравнение - условие D=0
Квадратное уравнение - условие D=default (!=0)
Квадратное уравнение - условие D>0
Квадратное уравнение - условие D<0
CamelCase:
Пример для версий Sanscript 2.2На первой диаграмме текст, введенный пользователем, переводится в нижний регистр и передается в цикл посимвольной обработки. На второй — блок Split Text
используется для выделения очередного символа строки, который затем сравнивается со строками-ограничителями (ASCII-коды которых равны a-1 и z+1), и результат сравнения передается в блок выбора действия. На третьей — если символ является буквой, то в зависимости от значения lastSpace
к результату добавляется либо сам символ, либо он же, переведенный в верхний регистр; кроме того, значение lastSpace
устанавливается в FALSE
. На четвертой — если символ не является буквой, то только изменяется значение lastSpace
.
CamelCase - главная диаграмма потоков
CamelCase - блок Repeat
CamelCase - обработка символа-буквы
CamelCase - обработка символа-разделителя
Комментарии
]]>blog comments powered by Disqus
]]>