О русификации кодовой базы FluffOS

В каталоге packages в файле parser.c надо поместить вот эти определения вместо тех, которые там присутствуют

#define isignore(x) (x == '\'')
#define iskeep(x) (x!=' ')

И кириллица перестанет быть игнорируемой и заработают команды

say ёжиик
get палица

Собственно, не только кириллица (в любой кодировке), перестанет игнорироваться всё, что представимо в кодировке UTF-8 (то есть вообще все алфавиты)

Вот два мада, уже пропатченных таким образом:

https://github.com/prool/deadsouls

https://github.com/prool/lima

Текущие новости

Мы с Пацифистом бросили DeadSouls и взялись за Лиму, которая тоже построена на базе FluffOS, но показалась проще, по крайней мере say привет работает там “из коробки” (то есть показывает кириллическое сообщение).

Всё, что наработано на текущий момент в DS здесь https://github.com/prool/deadsouls
Последнее достижение: взят кириллический объект. Бросить его пока нельзя 🙂 См. тестовую команду prool, которая берет всё, включая мобов и игроков! 🙂 🙂 🙂

А Лима здесь: https://github.com/quixadhal/lima или более старая версия http://lpmuds.net/files/lima_fluffos_v1.zip

Кстати, работа с DS не прошла даром: мы поняли немного о структуре драйвера FluffOS и его библиотек.

Тестовый мад на Лиме работает здесь mud.kharkov.org 7878 (это у них такой номер порта по умолчанию)

FluffOS, Dead Souls, UTF-8 cyrillic and other stuff

Мы тут с коллегой Пацифистом бросили один проект (QiuckMUD) и начали другой – русификацию Dead Souls (этот мад сделан на основе движка FluffOS и муд-базы Dead Souls). Даже не русификацию DS, а создание на ее базе чего-то своего

Технически русифицировать FluffOS не надо, там понимание UTF-8 есть изначально. Надо переводить сообщения, создавать кириллические команды и т.д.

Мой форк dead souls вот https://github.com/prool/deadsouls

О Винде

Я только сейчас сообразил: Виндовые сборки по сути уже не нужны. В Windows 10 входит вполне работающая Убунта в виде подсистемы. Не далее как вчера коллега Пацифист почти без проблем собрал там QiuckMUD+lua

Впрочем, я думаю, некоторые консерваторы сидят на Windows 7 или XP и не хотят переходить на 10-ю версию…

О русификации QuickMUD-lua

С подачи товарища Пацифиста начал русифицировать QuickMUD+lua (Авраам породил Иакова, ROM породил QuickMUD, а потом товарищ Odoth добавил туда lua). В общем, все делается примерно по тому же шаблону, что и ранее слегка русифицированный tbaMUD. Русские команды лучше и проще реализовывать не в общей таблице, а отдельным обработчиком, вызываемым до основного. А то всякие глюки выползают из-за UTF-8

Всё здесь:

https://bitbucket.org/prool/quickmud-lua-russian

А вот взгляд на проблему с другой стороны: http://muder.ru/blog/172.html

Статистика русскоязычных мадов

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

Я уже начал эту работу, вот первые три мада

http://muds.kharkov.org

Кстати, исходники своих плагинов потом я выложу на github примерно сюда

https://github.com/prool/prool-utilities
(там появится подкаталог)

Как я получаю информацию:

1. У некоторых мадов (у малого количества) статистика (число игроков онлайн в данный момент) есть на сайте мада. Сайт посещает каждые 5 минут мой бот (curl) и парсит

2. У тех мадов, у которых этого нету, я зарегистрирую персонажа и специальным скриптом для клиента tintin++ буду заходить каждые 5 минут, выдавать команду КТО и выходить. И парсить

Тут меня и забанят 😉

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

* * *

UPDATE. Прагматические замечания по программированию.

Как оказалось, tintin++ не умеет запускаться по крону, так как у крона терминал dumb, а тинтину нужен, например vt100. Я не придумал ничего умнее, чем под бота выделить отдельное окно скрина 🙂

И не надо забывать, что плагины Мунина запускаются от пользователя nobody

Внезапно я написал примитивнейший скрипт для tintin++, осуществлябщий вход в мад, выполнение одной команды (для примера взята команда users), а затем выход из мада и из tintin’а.

#action {ENTER} {i}
#action {MUDQUIT} {#zap;#zap}
#sess s0 mud.kharkov.org 3333
5
мудер парольмудера
users
quit
0

где i – это любая строка, главное, что в конце выдается enter,
3333 – порт моего тестового мада (у основного порт 3000),
5 – номер кодировки,
0 – пункт меню по выходу из мада

Для чего можно использовать этот скрипт?

Для периодического захода во все русские мады, выдачи команды КТО и построения графика посещаемости их при помощи munin. (Пока не забанят робота)

Или для того, чтобы в маде, например в Былинах, где игрок экспирится, заходить и обновлять его

Инструкции новым иммам

Я веду переписку с некоторыми начинающими иммами, которые поднимают у себя копии Виртустанмада или Прульзеркала. Свои ответы, которые в некотором смысле являются инструкциями для новых имморталов, буду приводить здесь

1-й вопрос. О командах имма

Первое. Список команд имморталов – команда wizhelp

А потом справку по каждой команде ты можешь смотреть обычным образом, командой help или помощь

например

помощь shutdown

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

Смотришь файл lib/misc/privilege.lst

Его структура интуитивно должна быть понятна.

Видишь строку, начинающуюся с имени имма Пруль, вместо Пруля пишешь свое имя

А дальше сложнее, после имени надо ввести uin – цифровой идентификатор игрока. Находишь его среди файлов в подкаталогах каталога
lib/plrs

В каком именно подкаталоге будет твой файл, зависит от первой буквы имени твоего перса. UIN там в четвертой строке

Второй вопрос, о создании вещей и мобов

Создание объекта

load obj 411

где 411 – номер объекта

Объект возникает в инвентаре

Создание моба

load mob 411

моб возникает в комнате

А как узнать номера объектов и мобов?

команда

olist 1000 1999

выдается список объектов в номерами от 1000 до 1999

аналогичные команды

mlist список мобов

rlist список комнат

zlist список зон

Обрати внимание на систему нумерации

Например, зона 10, в ней объекты, мобы и комнаты нумеруются от 1000 до 1098

Номеров, заканчивающихся на 99 не бывает

Еще введи команду

РЕЖИМ ФЛАГИ

ты начнешь видеть номера комнат, объектов и мобов

И полезная команда

прыжок 4000

она переносит в комнату с номером 4000

А если ты спрашивал о создании новых объектов, которых еще не существует в маде, то есть команды редактирования (используй их осторожно, чтобы не испортить уже существующие в маде объекты).

med 1200 редактирование моба номен 1200

аналогично red
oed

Найди номера, которые не используются, и аккуратно создавай новые объекты, мобов, комнаты, если хочешь

А чтобы понять, какие бывают параметры, можно набрать, например, oed на уже существующий объект, изучить параметры и выйти из редактирования не сохраняя объект. И уже потом создавать что-то своё

И снова о переводе мадов

Я еще немного пописал свой модуль перевода для tintin++. Теперь в его словарь можно на лету добавлять пары слов:

#addword sword,меч

Неправильные переводы можно удалять

#addword sword,мечь
#delword sword
#addword sword,меч

И целые словосочетания можно сразу переводить
#addword You are carrying,Вы несете

Потом надо не забыть сохранить словарь командой #writedic

И заменить старый файл словаря новым

mv slovarb2.csv slovarb.csv

https://github.com/prool/virtustan

Прагматические замечания по сборке Былин в Debian 8 i386

sudo apt-get install libz-dev cmake g++ clang python3.4-dev libboost-python-dev libboost-system-dev git libgtest-dev

Также после установки Boost’а необходимо указать переменную окружения BOOST_ROOT, где находится сама библиотека Boost (заголовочные файлы), а также библиотеки python3, system и filesystem.

Или можно указать переменную BOOST_LIBRARYDIR, указывающую на путь, куда инсталлированы библиотеки пакета BOOST после компиляции его исходников, которые можно взять, например, с официального сайта BOOST (чаще всего BOOST_LIBRARYDIR=/usr/local/lib)

gtest тоже нужно компилировать и устанавливать в CMakefile.txt переменную GTEST_LIB