http://www.rtads.org/libr25beta3.rar - ещё обновление.
- Заработало распознавание ударного окончания по прописной букве, несколько исправлений правил генератора, введены правила для слов на -ец.
- Исправил вывод сформированных sdesc...pdesc
- Включил addwordru и delwordru.
- Местный падеж практически заменил все упоминания предложного падежа.
В выложенном advr.t недоработана функция parseNounPhrase. В принципе рабочая, но путает прямой и косвенный объект.
В комплекте - тест для генератора, а также немного доработанная библиотека меню.
Неактивен
Жду комментариев и предложений по юзабилити.
Например, думал дефайнами уменьшить количество переключений раскладки, но кириллица не катит.
Как на счет того, чтобы вместо апострафов ставить двойные кавычки при gdesc, а во время компиляции превращать в обычную строку?
Ещё есть задумка вынести лексемы с метками падежей в отдельные свойства объекта. Список лексем очистится, а количество разных свойств прибавиться. Куда-то можно сослать и "затравку" для генератора после её использования (gnouns и gadjective например).
Я ранее упоминал о скрипте для отладки игры. Подробнее написано здесь:
http://teladesign.com/tads-manual/tads-b.html в параграфе "Testing Your Game".
Вкратце:
mygame.exe -o walkthru.in - записывает в файл команды по мере прохождения
htmlt2.exe -i walkthru.in -l walkthru.log mygame -запускает игру и вводит список команд, а выходящий текст записывает в файл.
Майкл Робертс предлагает сверять старые и новые результаты любой программой типа diff.
Хотел сразу на Вики, но она ещё лежит.
Неактивен
Спасибо!
Потрясающе, но факт: буква 'ё' не входит в диапазон регэкспа '[а-я]'. Аналогично для 'Ё' и '[А-Я]'.
Неактивен
http://www.rtads.org/libr25beta4.rar - налетай, торопись! Теперь генератор работает ещё лучше, ещё правильнее!
Рекомендую ставить авторам. Для публикации игр лучше подождать релиза, а для разработки можно (и нужно!) пользоваться этими библиотеками.
Неактивен
fireton написал:
Добавлены
takedesc
иdropdesc
. Теперь любому предмету можно назначить свой текст вместо банальных "Взят" и "Брошен" при взятии и бросании, соответственно.
Насчет этого не уверен. Часто прописывается схема такого вида:
doTake(actor)= { if (self.isonoriginalplace) { "Ты выдрал *что-то* с его векового места. "; incscore(5); self.isonoriginalplace:=nil; self.moveInto(Me); } else pass doTake; }
хотя правильнее вообще так:
doTake(actor)= { if (self.isonoriginalplace) { "Ты выдрал *что-то* с его векового места. "; incscore(5); self.isonoriginalplace:=nil; } pass doTake; }
В последнем случае проводятся проверки массы и объема инвентаря, а стандартное "Взято" рефлексивно вызывает параксизм довольства у любого ИЛ игрока. Без этой фразы не сразу ясно, вежливый ли это отказ, или сообщение об успехе.
Единственная польза от takedesc и dropdesc - то, что можно сменить фразу по умолчанию. Но я с трудом представляю себе ситуацию, когда нужна менее универсальная фраза. Подбирать и бросать можно в любом месте и в любой ситуации, и расширенное описание может быть весьма неуместно.
В общем, я против. Кому нужно, тот сделает или спросит на форуме.
Неактивен
Детализация, это здорово, но как ты видишь описание выкладывания вазы в случайном месте?
"Ты аккуратно поставил вазу." Куда? На пол? Посреди поля? Баллансируя на канате?
Кстати, следующему же автору понадобится передать аргументы этому методу. Чтобы стандартное сообщение менялось в зависимости от актера и локации.
Ок, я оставлю, но это только одно из сотен усовершенствований, которые можно сделать. Если все их внедрять, библиотеки распухнут и станут совсем непонятными, потому как это все не покрыто мануалом (мы не высылаем отчет о всех наших нововведениях Валентину). РТАДС уже сейчас сложен для новичков, излишние доработки только усугубят ситуацию.
Неактивен
fireton написал:
GrAndrey написал:
Детализация, это здорово, но как ты видишь описание выкладывания вазы в случайном месте?
"Ты аккуратно поставил вазу." Куда? На пол? Посреди поля? Баллансируя на канате?Если балансируя на канате, то нужно перекрыть у комнаты
roomDrop
- все предметы должны падать вниз. Для разных типов комнат можно определить разные классы и флажок в них, чтобы определить, куда ставишь. Все решаемо. Конечно, комбинаторный взрыв. Но если автор хочет идти на это, то пусть у него будут возможности. А если не хочет - у него всегда будут "Взято" и "Брошено".
Все-таки уж слишком частное решение. Почему только "взять" и "бросить"? А кинуть? А одеть-снять?
Думаю, чем завтавлять авторов искать твой takedesc или учить его использовать, так лучше научить исправлять стандартное сообщение этим способом. Выложить во все обучалки этот пример модификации.
Неактивен
Вот что я надумал:
- extendr.t нужно прочесать и даптировать стоящее в основную библиотеку
- это, а также любые другие небольшие расширения вносить как модификации в новом extendr.t
При этом код должен сопровождаться подробным комментарием для чего, он и как используется
Неактивен
fireton написал:
Но все не так просто. Бывает так, что код просто неудачно построен.
...
[Что-то] еще можно внести как дополнение, но что-то - явно нельзя...
В таких случаях в необходимый код вставляется вызов пустой функции, которую можно переопределить в модуле.
Например, так можно вставить дополнительную обработку в предпарсере.
Похожим образом я поступил с проверкой орфографии. Основной модуль запускается без неё, но простое включение сразу её активирует без изменения любых стандартных функций (типа преинита, коминита, интродьюса и т.п.), только специальной функции additionalPreparsing, по умолчанию пустой.
Неактивен
Закоммитил новую версию. Много доработок.
Тперь исправить предпарсинг и можно делать финальный релиз.
Неактивен
Ура, ура! Вышел юбилейный, 25-ый релиз библиотек! Масса изменений и усовершенствований, среди которых генератор, встроенный в систему. Качаем! http://rtads.org/libr25.rar
В скором времени подготовлю обновленную версию обучалки про волка, козу и капусту.
Просьба жестоко протестировать!
Обратите внимание:
gdesc стал просто desc
в библиотеки включен следующий код:
modify room dispBeginSdesc = "<b>" dispEndSdesc = "</b>" ;
т.е. все название комнат выделены жирным. Нужно удалить старые теги
Неактивен
fireton написал:
Андрей, спасибо!
Пожалуйста, выложи библиотеку и в SVN, мне оттуда проще забирать.
Таки сделал
Неактивен
Не видел никаких комментариев к новой версии. Есть ли недостатки и рационализаторские предложения?
Неактивен
Gesperid написал:
О великий и могучий, русский язык! О великие и могучие, регулярные выражения!
GrAndrey, при всем уважении, не думаю, что такой подход может упростить разработку.
Gesperid, не ты ли автор?
башорг написал:
Некоторым программистам, когда они сталкиваются с какой-то проблемой, приходит в голову такая мысль
— О, я знаю! Это можно сделать с помощью регулярных выражений!
Это означает, что у этого програмиста теперь ДВЕ проблемы.
Неактивен
Спасибо, очень интересно. Но при всей справедливости этой шутки, в нашем случае регекспы оказались очень эффективным и наглядным средством реализации генератора. В самой первой версии все было через ветвистые ifы, что несомненно гораздо хуже.
Неактивен
Обновил версию в гугловском репе.
П.С. Не понял, как там выложить файл для всеобщей скачки.
Неактивен
Не совсем подходящий момент, но вот текущая версия библиотек. Генератор существенно доработан благодаря самоотверженной обкатке его участником конкурса.
Доработки с момента 25 релиза:
- в advr.t добавлена функция opro, которая подставляет "об"
или "про" в зависимости от слова, с которым предлог должен
быть согласован
- исправлен механизм отдачи приказов актерам фразами
"попросить таню взять мячик", "приказать Рексу укусить Боба"
Обновременно исправлен глагол "спросить об"
- генератор доработан для определения существительных, прилагательных
и предлогов в коротких описаниях (desc). Данные флагов записывются в
список info_list. Например, для фразы "ржавый/м ключ/м от
сундука/-" он будет выглядеть как ['мп' 'мс' '+' 'п-'].
- генератор формирует местный падеж. В базе - 49 слов (+несколько
упомняуты в комментариях)
- Доработки правил. Главная - окончания -ок. Осталось небольшое
количество исключений.
- Генератор оптиимзирован. Флаги переводятся в двоичный формат,
что существенно ускоряет обработку. Для этого введены функции binarize и
debinarize.
Неактивен
Итак: после перезагрузки (reset) текущей игры не сохраняются все сгенерированные лексемы. При этом есть сгенерированные короткие описания.
Проблема есть только в игре откомпилированной для релиза.
решение: пока нет и не ясно как исправлять. Видимо, нужно обращаться к Майклу Робертсу.
Как временная мера - запретить перезагрузку или по этой команде загружать начальное состояние (это требует создания файла сохранения в папке с игрой в момент запуска и очистит экран при запуске).
Неактивен
Вообще ситуация очень странная - остаются свойства описаний, которые в реалтайме никак генерироваться не могут, но исчезают лексемы. Даже если при перезапуске программа уничтожает все динамически созданные лексемы, ещё один проход генератора (в отладочной версии он происходит) должен вернуть их на место.
Баг только в версии для релиза и потому не могу просмотреть отладчиком. Буду просматривать с помощью отладочных сообщений, решение точно найдется.
Неактивен
любой
Неактивен
нет, не писал. Сам толком ещё не разбрался
Неактивен
Толком так и не разобрался в проблеме, но сделал быстрый хак:
replace initRestart: function(parm) { global.restarting := true; #ifndef __DEBUG "\n\tПожалуйста, подождите, идет генерация падежей.\n"; generator.start; #endif }
Неактивен
Что-то мне подсказывает, что при перезагрузке стираются все динамически назначенные noun и adjective. Это правильно для объектов переименнованных в процессе игры, но не должно касаться тех свойств, что были назначены в стадию предкомпиляции. Вот об этом и нужно писать Майклу, нашему, Робертсу
2 fireton: Пожалуйста, размести отчет, - не могу зарегистрироваться на трекере. Кстати, это тоже баг
Неактивен
The following issue has been RESOLVED.
======================================================================
http://bugdb.tads.org/view.php?id=55
======================================================================
Reported By: GrAnd
Assigned To:
======================================================================
Project: TADS 2
Issue ID: 55
Category: Interpreter
Reproducibility: always
Severity: tweak
Priority: normal
Status: resolved
Fixed In Version: 2.5.14
Resolution: fixed
Fixed in Version:
======================================================================
Date Submitted: 2009-05-01 00:42 EDT
Last Modified: 2009-05-06 16:54 EDT
======================================================================
Summary: Reset of dynamically created nouns and adjectives on
game restart
Description:
Interpreter always delete all dynamically created nouns and adjectives
created in preinit phase at time of game restart. It is an obstacle for
Russian TADS libriries which generates flexions for words during
compilation. All generated "sdesc" type properties remains intact, but all
new nouns and adjectives just disappear and require repeat generation (it
could take up to 10 seconds).
Suggested solution: delete on restart only those lexemes which created on
runtime, not at preinit phase.
======================================================================
----------------------------------------------------------------------
(0000098) Michael Roberts (administrator) - 2009-05-06 16:54
http://bugdb.tads.org/view.php?id=55#c98
----------------------------------------------------------------------
I've made this change for 2.5.14. During compilation, after preinit
finishes, the compiler now marks as static all objects created with 'new'
and words added with 'addword'. This makes anything created during preinit
effectively permanent, so it won't be deleted on restart.
It's been a long time since I've looked at the design of this part of the
system, so I'm a little concerned that there might be side effects of this
change that I haven't thought of. For the time being, then, I'm considering
this a beta test feature, so I'm not uploading this update (2.5.14) to the
IF Archive yet. For now, you can get the update from the tads 2 patch page
at http://www.tads.org/t2_patch.htm. The change only affects the compiler.
Issue History
Date Modified Username Field Change
======================================================================
2009-05-01 00:42 GrAnd New Issue
2009-05-06 16:54 Michael RobertsFixed In Version => 2.5.14
2009-05-06 16:54 Michael RobertsNote Added: 0000098
2009-05-06 16:54 Michael RobertsStatus new => resolved
2009-05-06 16:54 Michael RobertsResolution open => fixed
======================================================================
Неактивен
http://www.rtads.org/libr26pre.rar - обновленная версия библиотеки с патчем для старых версий (генератор запускается заново при рестарте).
http://www.rtads.org/vkkpuzl.zip - исправленный туториал
Просьба ко всем авторам скачать и установить бета-версию нового компилятора:
http://www.tads.org/patch/aksetupd.exe
Как я понял, компилируемый код будет читаться старыми интерпретаторами, причем проблема с исчезновением лексем будет устранена.
Только что проверил - работает.
П.С. Только-что подправил патч, срабатывает на версию интерпретатора 2.5.14, потому как компилятор не выдает такой подробной инфы о своей версии. Компилировал из командной строки, сообщаемая версия интерпретатора соответствует компилятору, так что все должно работать правильно.
Отредактировано GrAndrey (07.05.2009 14:04)
Неактивен