|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
|||||||||||||||||||||||||||||||||||||||||||||||||||
Пишем свой интерпретатор языка BASIC20.06.2009, 20:03. Показов 253253. Ответов 464
Метки нет (Все метки)
Благодаря форуму и Evg в частности интерпретатор развивается, потихоньку превращаясь в простенький интерпретатор QBASIC.
Некоторые из самых старых версий сохранились в теме и ссылки на них будут добавлены в это сообщение,а также ссылки на другие темы,связанные с этой. Репозиторий с проектом находится тут, там же есть возможность в браузере посмотреть историю ревизий (английский в логах весьма примитивен,комментарии и рекомендации можете писать в личку),а также скачать самый последний архив репозитория в формате .tar.gz Если кто-то пользуется Subversion,скачать исходники можно так:
Технический приём для формирования согласованных данных https://www.cyberforum.ru/c-linux/thread46096.html Вопрос по svn (Subversion) Создание системы тестирования ПО. Вопрос про разные реализации бэйсиков Можно ли выразить порядковый номер элемента массива через индексы? [C++] Какие флаги указать линкеру для компиляции программы? Как можно определить переменную в файле configure.in,чтобы её можно было использовать в Makefile? Странный SIGSEGV, или что зависит от порядка написания интерфейса класса https://www.cyberforum.ru/c-linux/thread61324.html Альтернативная версия интерпретатора от Evg на C Это простая реализация разбора выражений, написанная Evg на C: Представление выражения в двоичном дереве ***************** Первое сообщение: ***************** Задание(Страуструп,из книги,по готовому коду): Введите программу калькулятора и заставьте её работать.Например,при вводе
LexicalAnalyzer.h
LexicalAnalyzer.cpp
main.cpp
Анализатор-то работает,но конечное значение не вычисляется.Более того,если вводим
Добавлено через 2 часа 5 минут 30 секунд Пришлось решать влоб с дебаггером.У Страуструпа опечатка (или намеренная ошибка,что более вероятно ) Вот в этом куске кода в функции get_token():
Добавлено через 16 минут 19 секунд И ещё опечатка была
31
|
|||||||||||||||||||||||||||||||||||||||||||||||||||
| 20.06.2009, 20:03 | |
|
Ответы с готовыми решениями:
464
Пишем свой интерпретатор языка BASIC
Пишем свой чекер |
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
||
| 23.03.2010, 22:08 [ТС] | ||
|
отсюда http://basin.svn.sourceforge.net/ можно скачать последний архив с репозитория, а тут https://sourceforge.net/projects/basin/ просто архивы,которые я вручную закачиваю. Я бы с радостью отредактировал, но у меня нет прав на редактирование данной темы,к сожалению.
1
|
||
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
||||||
| 24.03.2010, 21:48 [ТС] | ||||||
|
RazorQ: Попробовал сейчас скомпилить твою версию, не компилится.Видимо,ты ещё что-то забыл
0
|
||||||
|
591 / 357 / 16
Регистрация: 06.02.2009
Сообщений: 1,386
|
|||
| 25.03.2010, 08:02 | |||
|
Добавлено через 3 минуты
1
|
|||
|
0 / 0 / 0
Регистрация: 13.03.2010
Сообщений: 17
|
|
| 25.03.2010, 20:03 | |
|
Evg, скажите как вы считаете что нужно каждому программисту
0
|
|
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
||
| 25.03.2010, 20:49 [ТС] | ||
0
|
||
| 26.03.2010, 08:32 | |
|
1
|
|
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
|
| 28.05.2010, 19:58 [ТС] | |
|
Сделал 79 ревизию,где была добавлена инструкция SUB,но уже понял,что поторопился,у меня там отсутствует механизм выхода из функции(точнее выход реализован с помощью метки,которая меняется в зависимости от места вызова,но я там конкретно напутал),так как я хотел обойтись без дополнительных списков.Теперь буду думать,как всё это поправить с минимальными правками.
0
|
|
|
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
|
||||||
| 08.06.2010, 01:05 | ||||||
|
#pragma, Извини, лень читать километр темы в поисках вопроса. Как ты делал переменные во вложенных блоках?
Например
Но как сделать со вложенным блоком? Там ведь эта переменная k каждую итерацию новая? А старая должна быть уничтожена? Добавлено через 5 минут Кстати как ты делал: чисто интерпретатор или с генерацией внутреннего представления?
1
|
||||||
|
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
|
|
| 08.06.2010, 19:52 | |
|
1
|
|
|
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
|
|
| 08.06.2010, 20:00 | |
|
Какое именно внутренне представление программы?
Просто я до этого делал чисто интерпретатор и с циклами было совсем плохо - на каждой итерации все лексемы считывались заново. Сейчас хочу переделать, думаю как лучше? Полностью записать программу в виде полиза, или дерева, или просто записать все лексемы последовательно в список, чтобы не читать по сто раз?
1
|
|
|
|
|
| 08.06.2010, 20:12 | |
|
По части представления проще посмотреть исходники, чем объяснять на пальцах. В посте 139 есть некая печать промежуточного представления моего варианта в виде цепочки statement'ов. Хз будет ли понятно. У #pragma'ы то же что-то наподобие этого.
Добавлено через 1 минуту Вообще, если почитаешь всю тему (если столько вообще возможно осилить), найдёшь ответы на многие вопросы. Но так чисто в воздухе без исходников это малопонятно скорее всего Добавлено через 1 минуту Мой вариант в посте 232. Там в общем-то нужно смотреть файл statement.h (вроде). Там более менее откомментировано
1
|
|
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
|
| 08.06.2010, 22:37 [ТС] | |
|
>Но как сделать со вложенным блоком? Там ведь эта переменная k каждую итерацию новая? А старая должна быть уничтожена?
В нашем интерпретаторе все переменные глобальны,и только в последнее время,с появлением функций ,должны появится локальные списки переменных. Надеюсь скоро подумать над этим,так как то,что я сделал в 79 ревизии-полная лажа. >Там ведь эта переменная k каждую итерацию новая? А старая должна быть уничтожена? У списков переменных должна быть стековая структура,также,возможно,нужно делать стек выходов из функции(в C/С++ вспомогательную роль для этого,как я понял,выполняет слово return). Или возможно,нужно делать что-то,о чём говорил Evg (если я понял правильно) - подобие двух представлений,что-то навроде представления первого уровня со всеми точками входа и выхода из функций,пока даже слабо это вижу,как это должно быть технически. А вообще в этой теме есть как раз мои биения с циклами,и закономерный вывод,на который меня наталкивал Evg-нужно делать промежуточное представление. Если у тебя блок программы пропускается по тем или иным причинам-то как проверить синтаксис в этом блоке(это была проблема в моём случае,с IF)?
0
|
|
|
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
|
||
| 08.06.2010, 23:46 | ||
|
1
|
||
|
|
||
| 09.06.2010, 00:09 | ||
|
1
|
||
| 09.06.2010, 00:09 | |
|
Помогаю со студенческими работами здесь
380
пишем свой троян с нуля Пишем свой класс, спецификатор доступа protected Интерпретатор небольшого языка программирования на С++ Не удается откомпилировать интерпретатор М-языка
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|