hjass

» опубликован
Добро пожаловать на главную стриницу проекта по разработке hjass! hjass - это попытка реализовать независимый, октрытый и кроссплатформенный компилятор для языка JASS, который уже вечность используется как основной скриптовый язык в Warcraft III. Была поставлена цель обеспечить полную поддержку оригинального JASS, а также его надстроек vJASS и cJass, и обеспечить удобный способ встраивания компилятора как библиотеки (подход compiler-as-a-librarary). Компилятор использует JIT компиляцию и базируется на широко распространенном фреймворке LLVM для создания оптимизирующих компиляторов, поэтому hjass на порядки быстрее своего прародителя.
Что на данный момент реализовано:
  • полная поддержка оригинального JASS, включая локальные массивы и ссылки на функции
  • базовая система модулей, позволяющая разделять код на дерево файлов:
import system.io.console // подключит system/io/console.j 
  • runtime библиотека для подключения своих native функций в язык, для вызова функций из hjass и проверки callback ссылок на hjass функции
Что пока не реализовано:
  • поддержка cJass, vJass
  • сборщик мусора (в альфе память от строк и делегатов не освобождается)
  • многопоточность
Бинарные сборки текущей альфа версии можно забрать тут.

FAQ

» Какова лицензия у проекта?
Используется свободная лицензия MIT, которая позволяет программистам использовать лицензируемый код в закрытом ПО при условии, что текст лицензии предоставляется вместе с этим ПО. Является GPL совместимой.
» На каком языке написан компилятор?
Весь компилятор и runtime написан на языке Haskell, однако скомпилированный в байткод hjass код не зависит от конкретного языка программирования, для реализации рантайма подходит любой язык, умеющий вызывать C функции.
» Я знать не знаю Haskell и знать не хочу! Что мне делать?
Компилятор будет поставляться, и как отдельная C библиотека (.so или .dll), так и как Haskell библиотека (с немного лучшим API). А вообще, Haskell хороший язык.
» Как подключать свои native функции?
Эта тематика будет подробно раскрыта в последующих материалах. Для сильных духом пока предлагаю заглянуть в тестовые примеры
» Какие расширения JASS будут поддерживаться?
Сейчас в планах нативная поддержка vJass и cJass, также будет развиваться свое локальное наречие на основе лучших идей предшественников.
» Какие платформы поддерживаются?
Оффициально поддерживаются Windows и GNU\Linux, остальное на усмотрение коммьюнити.
» Какие имеются существенные отличия от оригинального JASS?
  • Наличие модулей
  • Снято ограничение на строгий порядок объявления функций (но для оригинального синтаксиса сохранено правило "все native, globals и объявления типов до тел функций")
» Я хочу помочь. Что нужно делать?
Я всегда рад выслушать предложения и идеи, а также получить пару pull request'ов на страничке проекта на гитхабе. Также я сделаю подробные инструкции для потенциальных разработчиков, чтобы помочь продраться через первоначальный порог сборки зависимостей (для Windows ада уже есть страница )

 

Просмотров: 7 015

alexprey #1 - 4 года назад 0
читал ровно до момента
Весь компилятор и runtime написан на языке Haskell
Hellfim #2 - 4 года назад 0
alexprey, там дальше
Я знать не знаю Haskell и знать не хочу! Что мне делать?
У парня всё схвачено =)
NCrashed #3 - 4 года назад 0
alexprey, нус, если беспокоишься о производительности, то по классическим бенчам хаскелль идет наравне с Java, C# и Scala. А все что можно из runtime вручную переведено в LLVM ассемблер и инлайнится в программы, весь рантайм со строны Haskell - передача указателей на malloc и native функции.
alexprey #4 - 4 года назад 0
NCrashed, да меня наверное меньше всего производительность беспокоит, иначе бы я был ярый фанат асма и чистого си :D Было бы на шарпах, было бы очень круто и я бы даже поковырялся бы в этом и встроил бы в юнити для фана :3
NCrashed #5 - 4 года назад 0
alexprey, не срослось с шарпом, могу лишь предложить шарповые байндинги
alexprey #6 - 4 года назад (отредактировано ) 0
NCrashed, да не будут проблемы с кроссплатформенностью. Ну ладно не срослось и ладно)
Hanabishi #7 - 4 года назад (отредактировано ) -9
JASS
По функционалу он мягко говоря не очень на фоне реальных языков. Я считаю нет смысла его реализации, если уж так хочется, можно использовать Lua, с которого оный содран.
Любителям cJass вообще легче сразу пойти на плюсы/шарпы.
А вот например реализация гуя была бы интересной для нубов, но лично я не одобряю погромирование мышкой.
Haskell
Ахаха, а чего не на Лиспе-то? =D
Хаскель знают только 2.5 задрота в качестве хобби, реальной востребованости нет, какая ЦА у данного проекта - непонятно.
NCrashed #8 - 4 года назад 0
Hanabishi, а кроме луа альтернатив и нет, а что делать, если луа не по душе? А встроить безопасно плюсы и шарп - анреал.
А какова разница от языка реализации самого компилятора? Да хоть на брейнфаке, все равно потом С апи делать.
В защиту хаскелля скажу, что на западе много вакансий и я не раз брал оплачиваемые подработки на этом языке. Печально, что вокруг этого языка такая темная слава.
А целевой аудитории у проекта нет, это дань уважения моему первому ЯП. Пусть у XGM будет своя реализация джасса.
alexprey #9 - 4 года назад 0
NCrashed, на счет шарпов ошибаешься, этож управляемый код, его спокойно можно анализировать.
NCrashed #10 - 4 года назад 0
alexprey, с открытием языка это должно, наконец то, стать реализуемым. Моно сильно портил переносимость, как минимум необходимостью иметь две ветки проги. Но и написать анализатор не сильно проще, в hjass всего 5к строк.
prog #11 - 4 года назад 0
NCrashed, а насколько сложно будет подключить это дело к джаве, обертки небось писать и нативные либы биндить придется? Так то я предпочитаю Lua, но почему бы и не добавить разнообразия.
Что касается альтернатив - есть еще, как минимум, питон и JS.
NCrashed #12 - 4 года назад 0
prog, нужно будет написать jni обертку, ее я и сам буду для себя писать.
Про питон забыл, извиняюсь. А V8 прикручивать к проекту тоже не сахар.
J64_ #13 - 4 года назад 0
Если уж llvm то почему не сделал транслятор из jass кода в код для starcraft2, и вообще в c# и юнити или в код для доты2? Так можно будеть старые карты варки портировать, хотя вызовы нативок хз как реализовать.
насчет cjass vjass, почему бы не использовать оригинальные трансляторы(jasshelper adichelper)?
NCrashed #14 - 4 года назад 0
J64_, в моих планах создать отдельный движок, поэтому трансляция в галакси и дота скрипт не подходит. Также такая трансляция дает намного более медленный код, чем в асм.
Если мне дадут исходники, то я смогу включить их в компилятор.
J64_ #15 - 4 года назад 0
NCrashed:
J64_, в моих планах создать отдельный движок, поэтому трансляция в галакси и дота скрипт не подходит. Также такая трансляция дает намного более медленный код, чем в асм.
Насчет медленного кода, посмотри на emscripten там и вовсю линуху по браузерам пускают(тоже llvm) :)
Если мне дадут исходники, то я смогу включить их в компилятор.
jasshelper вроде бы на дельфи, adichelper на masm. А почему бы просто не поступить так: даем adichelper'у исходный код, далее даем vjass'у и потом уже в hjass?
NCrashed #16 - 4 года назад 0
Насчет медленного кода, посмотри на emscripten там и вовсю линуху по браузерам пускают(тоже llvm) :)
Так это совсем другая история, вариант компиляции "jass -> galaxy -> виртуальная машина sc2" заранее проигрывает в производительности "jass -> llvm". В промежуточной стадии я потеряю море возможностей для оптимизации. А за идею с emscirpten спасибо, можно прикрутить перевод llvm байткода в asm.js и получим jass в браузере (потому что можем).
jasshelper вроде бы на дельфи, adichelper на masm.
Эх, дельфи еще можно причесать до кроссплатформенного вида, а вот с masm точно будут большие проблемы под не-виндой.
А почему бы просто не поступить так: даем adichelper'у исходный код, далее даем vjass'у и потом уже в hjass?
Изначально я так и хотел делать, и это будет работать. Однако эта связка будет только под Windows, и я буду привязан к существующим косякам и хакам внутренней реализации в этих проектах. Лучше бы взять их документацию и реализовать по ней с нуля.
J64_ #17 - 4 года назад 0
Интересно можно ли запихнуть cil код в юнити? Если да то можно генерировать из llvm cil код...
ZLOI_DED #18 - 4 года назад 2
Молодцы! Что сказать - буду ждать :3
NCrashed #19 - 4 года назад 0
Интересно можно ли запихнуть cil код в юнити? Если да то можно генерировать из llvm cil код...
Я уже закончил базовую C обертку, поэтому можно подключить все это к юнити.
Mihahail #20 - 4 года назад (отредактировано ) 2
Хаскель - очень милый язык, по выходным осваиваю потихоньку. Очень зря про него так. И вакансии и правда есть, не надо тут про 2.5 анонимуса. Единственный минус - после него не хочется уже на других языках прогать.
Ну и за llvm вообще респект. Пошёл изучать исходники.
Одного только не понимаю, почему именно jass? почему не javascript-like или, хм, rust-like, например? Теряем же в выразительности, как бы.
NCrashed #21 - 4 года назад 0
Mihahail:
Хаскель - очень милый язык, по выходным осваиваю потихоньку. Очень зря про него так. И вакансии и правда есть, не надо тут про 2.5 анонимуса. Единственный минус - после него не хочется уже на других языках прогать.
Ну и за llvm вообще респект. Пошёл изучать исходники.
Одного только не понимаю, почему именно jass? почему не javascript-like или, хм, rust-like, например? Теряем же в выразительности, как бы.
Символично - мой первый язык был именно jass. А еще достаточно просто для изучающего llvm с нуля, базовый jass (абсолютный минимум императивного языка) - весь компилятор 5 тыщ строк хаскелля с тестами (blizzrad.j и common.j и то занимают больше половины репы), а потом можно расширять до vjass, cjass или вводить свои улучшения, итого получится скриптовый язык, который Я бы хотел видеть в варе или sc2.
Mihahail #22 - 4 года назад (отредактировано ) 0
Ну ладно:)
Просто в свое время я открыл для себя cjass и подумал про jass - какое уныние. Потом был javascript - и я недоумевал, почему его никто не юзает как скриптовый? Потом узнал про луа - и так и недовпилил его в свой недописанный сетевой космосим с сервером на эрланге(юзал это).
Потом обратил внимание на scheme/lisp - не самый плохой вариант для скриптового движка, но потом как то всё забросилось, а я так и не осилил плюсы.