Что это?
cJass - это еще одно расширение языка JASS, которое полностью совместимо с популярным vJass. Цель его создания - дать программистам еще больше возможностей по созданию простого и качественного кода. Основными направлениями являются:
- Макросредства и стандартная библиотека - избавляют от рутины, позволяя сконцентрироваться на основном коде.
- Упрощение синтаксиса - мы не хотим снова начинать спор, какой синтаксис лучше (блоки через begin & end или {}), и более того, мы не навязываем свою точку зрения - все конструкции cJass имеют JASS-style аналоги, тем не менее мы предоставляем выбор.
- Оптимизация карты - основная концепция cJass - это то, что все языковые конструкции не должны сказываться на качестве генерируемого кода. Также мы работаем над встроенным оптимизатором.
Как это использовать?
Просто скачайте дистрибутив (пароль для архива: cjass), распакуйте и запустите инсталлятор. У вас уже должен быть установлен Jass New Gen Pack.
Ознакомиться с возможностями можно, прочитав руководство пользователя cJass (off-line версия этого файла также имеется в директории программы).
Что-то не работает!
В настоящий момент мы активно дополняем язык всевозможными конструкциями, поэтому полноценная проверка синтаксиса пока отсутствует. Но мы всегда внимательно изучаем
bug-репорты, которые можно оставить в этой теме.
bug-репорты, которые можно оставить в этой теме.
У меня есть идея: а не плохо бы...
Мы всегда рады выслушать Ваши идеи и предложения по внесению каких либо новых возможностей в язык, расширению стандартной библиотеки и т.д. Иногда мы даже действительно делаем то, что Вы нам предлагаете ;) Наша секция обратной связи ждет Вас!
И напоследок немного истории.
А история программы начинается на ресурсе wc3c.net, когда Vexorian, выслушав предложение от ADOLF'a сделать инструкции инкремента и декремента создает ветку с обсуждением синтаксиса... и благополучно забывает об этом. Тогда ADOLF подумал: "А неплохо было бы сделать свой парсер и включить в него всяких вкусностей". Изначально программа весила меньше заветных 9000 байт, распространялась по сети ICQ/Jabber и ее использовали несколько человек.
Однажды один из ее пользователей - Van Damm (впоследствии стал соавтором) сказал "это очень удобно!" (это было сказано про то, что можно вызывать функции без ключевого слова call) - и тогда мы решили, что если это удобно, почему бы не выложить программу на публичное обозрение. Благодаря zibade у нас появился сайт, где сразу стал отписываться Dark Dragon, который помог выявить львиную долю багов и внес множество интересных предложений.
С тех пор прошло много времени, мы сделали много новых версий, вес программы вырос в 3 раза (сейчас 26 Кбайт). На данный момент у нас есть планы, касающиеся многих конструкций, оптимизатора, и всего прочего.
private:
public:
ну то есть чтобы не перед каждой функцией, переменной, константой, дефином писать их область видимости, а чтобы сразу разбить всё по сегментам)))
(вроде такого нет, правда?)
Проверил - игнорит доллар, а 0х работает.
Хотелось бы нормальную подсветку кастом функций
проблемы были толи в хелпере векса, толи в пЖасс
constant real x = 0.
define xx = 0.
08C9E0A0 fx+0000 00 00 05 05 00000eaf CREATE_LOCAL const {real (5)}
08C9E0A8 fx+0008 00 05 68 0e 0000024a MOV_VAR_REG x => #68 {real (5)}
08C9E0B0 fx+0010 00 00 68 11 00000eaf MOV_REG_VAR #68 => const
08C9E0B8 fx+0018 00 00 05 05 00000eb0 CREATE_LOCAL def {real (5)}
08C9E0C0 fx+0020 00 05 69 0c 00000000 MOV_VAL_REG 0 => #69 {real (5)}
08C9E0C8 fx+0028 00 00 69 11 00000eb0 MOV_REG_VAR #69 => def
08C9E0D0 fx+0030 00 00 00 27 00000000 RETURN
08C9E0D8 fx+0038 00 00 00 04 00000000 STUB_FUNC_END
mov eax, dword ptr [40000000h] ; address
mov eax, 10h ; value
In the second case, you just move the value to the register - it's much faster.
Вот простейшая функция:
whilenot (i++ >= pow) {
res *= num
}
return res
endfunction
function test takes integer num, integer pow returns integer
local integer res = 1
local integer i = 0
loop
exitwhen (i >= pow)
set i = i + 1
set res = res * num
endloop
return res
endfunction[/code][/quote]
мне кажется, что следует поставить инкремент счетчика цикла в конец его действий, т.к. если мы по счетчику забиваем массив то пропадает нулевой элемент.
Препроцессор cJass получил однозначную команду: посчитать условие и увеличить i.
i должно быть увеличено сразу после вычисления условия, а не там, где кому-то хочется.
Кстати, ADOLF, при невыполнении условия i тоже надо увеличивать! Это ошибка в справке?
{
private void=nothing
private int=integer
private bool=boolean
}
hashtable HashTable=InitHashtable()
setdef hash = HashTable
#endif
{
hash=hash
}
Elf_Stratigo, у меня сохранило все правильно, поясните подробнее, что именно неработает
Кстати, а почему отказался от варианта i++ => (++i-1) ?
:)
#if 0==0
hashtable HashTable=InitHashtable()
#endif
endglobals from System
trigger gg_trg_____________________________________001=null
endglobals[/code]
такто я для уверенности несколько раз позапускал AHupdate.exe - результат - окошко "cJass is up to date."
ок, переставлю через инсталятор...
это так, предложение для следующих версий