Мультиязычная разработка

топ 100 блогов zabivator26.01.2010 Thrift is a software framework for scalable cross-language services development. It combines a software stack with a code generation engine to build services that work efficiently and seamlessly between C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk, and OCaml.
Спасибо Мультиязычная разработка [info]ptiz_kem за наводку!

Я успел дойти своими куриными мозгами до кодогенератора для RPC.
А эти ребята его УЖЕ сделали.

Смотреть я только начал, определённого ничего пока сказать не могу, кроме....
* SumTypes нету
* Исключения и спецификации исключений есть
* Продукт выращен в Facebook и потом отдам коммьюнити
* Оно живое (в баг-трекере есть свежие открытые и несвежие закрытые баги, в svn есть свежие коммиты)
* Оно УЖЕ ПОДДЕРЖИВАЕТ КУЧУ ЯЗЫКОВ

Пока что ковыряю примеры использования в различных языках (сравниваю ocaml, erlang, плюсы), следующие вопросы будут к полиморфным структурам (что вместо SumTypes) и протоколу передачи данных.

Это же просто охренеть, ребята... Вот он, тот кирпичик для мультиязычной разработки (по-английски это называется, как оказалось, cross-language development).

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

*ушёл с горящими глазами*

update
в комментах дали ссылку на ZeroC, который делает вроде тоже самое.

update 2
Ответ на вопрос: "чем это лучше COM/CORBA?" (выдержка из документации ZeroC)
Yet, neither DCOM nor CORBA succeeded in capturing a majority of the distributed computing market, for a number of reasons:
• DCOM was a Microsoft-only solution that could not be used in heterogeneous networks containing machines running a variety of operating systems.
• DCOM was impossible to scale to large numbers (hundreds of thousands or millions) of objects, largely due to the overhead of its distributed garbage collection mechanism.
• Although CORBA was available from a variety of vendors, it was rarely possible to find a single vendor that could provide an implementation for all of the environments in a heterogeneous network. Despite much standardization effort, lack of interoperability between different CORBA implementations continued to cause problems, and source code compatibility for languages such as C or C++ was never fully achieved, usually due to vendor-specific extensions and CORBA’s lack of a specification for multi-threaded environments.


ZeroC и Thrift решают одну и ту же задачу
Из очевидных минусов - у ZeroC не видать Ocaml, Erlang.
Из очевидных плюсов - сильно лучше с документацией и версия уже 3.х, а не 0.2 как thrift
Надо сравнивать...

Оставить комментарий

Архив записей в блогах:
О том что Китай может претендовать на часть российских земель в шутку и всерьез говорили уже давно. И похоже, эти перспективы становятся все реальнее. Как заявил заместитель председателя КНР, Россия обладает гигантскими земельными ресурсами, однако ей не хватает людей для того, чтобы ...
Эту фразу мне раньше говорила мама во время ссор. И это было оскорбление. Я очень долго не понимала, что она имеет в виду, почему это должно меня оскорбить. Поняла не так давно. Повзрослела, видимо. Начну с того, что у меня всегда была очень богатая фантазия. Когда мне было года 3 или 4 ...
Глянув третій спешл Доктора. Далі без спойлерів для тих хто ще не глянув ! Ну що сказати — загалом доволі прикольно. Теннант виглядає чудово, Ніл Патрік Гарріс в третьому ...
просто решила показать какие корни ...
У нашей простой пословицы "вода камень точит" есть мрачный китайский аналог антикоррупционной направленности - 水滴石穿. Якобы простой охранник попытался умыкнуть одну монету из казны и был пойман должностным лицом. - Всего лишь монетка, стоит ли наказывать меня? Ещё голову отрубите из-за ...