Add 2016 november recap
This commit is contained in:
@@ -0,0 +1,53 @@
|
||||
Title: Ноябрь 2016 кратко
|
||||
Date: 2016-12-15 00:00
|
||||
Category: News
|
||||
Slug: 2016-november-recap
|
||||
Lang: ru
|
||||
|
||||
![November recap][screenshot]
|
||||
|
||||
|
||||
Эта статья описывает начало разделения библиотеки MJIN на модули.
|
||||
|
||||
Как только мы собрали OpenSceneGraph для Android, стало очевидно, что часть функционала MJIN не нужна на Android. Например, UIQt - это основа интерфейса Редактора. Раз Редактор - это приложение для ПК, то UIQt не нужен на Android.
|
||||
|
||||
Мы решили рассмотреть два подхода к разделению MJIN на модули: во время сборки (build-time) и исполнения (run-time).
|
||||
Разделение **во время сборки** означает гибкую систему настроек MJIN, что позволит собирать её различно под каждую платформу.
|
||||
Разделение **во время исполнения** означает разделение MJIN на несколько небольших библиотек с последующим соединением во время исполнения, что позволит легко менять функционал без повторной сборки.
|
||||
|
||||
**Исследование разделения во время исполнения.**
|
||||
|
||||
Т.к. разделение во время исполнения имеет больше преимуществ, мы начали с этого подхода.
|
||||
Самый простой способ достичь его заключался в использовании C API, т.к. правила C ABI намного проще правил C++ ABI.
|
||||
|
||||
Мы создали маленький проект, включающий в себя приложение, библиотеку и плагин.
|
||||
**Приложение** было слинковано с библиотекой и использовало её для загрузки плагина.
|
||||
**Библиотека** предоставляла функции для регистрации плагина и вызывала его функции.
|
||||
**Плагин** предоставлял функции для библиотеки и вызывал её функции.
|
||||
|
||||
Исследование прошло на ура: проект работал в полном соответствии с нашими ожиданиями на Linux и Windows.
|
||||
Тем не менее, т.к. MJIN на текущий момент является большой монолитной сущностью, мы отложили применение C API до окончания разделения во время сборки.
|
||||
|
||||
**Начало разделения во время сборки.**
|
||||
|
||||
Мы выделили следующие модули из MJIN:
|
||||
|
||||
*
|
||||
Android: предоставляет Java Native Interface (JNI) к MJIN
|
||||
|
||||
*
|
||||
Sound: предоставляет доступ к OpenAL
|
||||
|
||||
*
|
||||
UIQt: предоставляет доступ к Qt
|
||||
|
||||
|
||||
|
||||
|
||||
Модули Sound и UIQt на текущий момент статически линкуются в MJIN, тогда как модуль Android линкуется динамически из-за ограничений JNI.
|
||||
|
||||
В следующем году мы изменим структуру MJIN так, чтобы её можно было легче собрать под разные платформы.
|
||||
|
||||
На этом мы заканчиваем статью о начале разделения библиотеки MJIN на модули.
|
||||
|
||||
[screenshot]: {attach}/images/2016-12-15_2016-november-recap.png
|
||||
52
pelican/content/articles/2016-12-15_2016-november-recap.md
Normal file
52
pelican/content/articles/2016-12-15_2016-november-recap.md
Normal file
@@ -0,0 +1,52 @@
|
||||
Title: November 2016 recap
|
||||
Date: 2016-12-15 00:00
|
||||
Category: News
|
||||
Slug: 2016-november-recap
|
||||
Lang: en
|
||||
|
||||
![November recap][screenshot]
|
||||
|
||||
|
||||
This article describes the start of MJIN library separation into modules.
|
||||
|
||||
Once we built OpenSceneGraph for Android, it became obvious that some MJIN functionality is not suitable for Android. For example, UIQt provides a basis for OGS Editor UI. Since OGS Editor is a desktop application, we don't need UIQt for Android.
|
||||
|
||||
We decided to have a look at two approaches to separate MJIN into modules: build-time separation and run-time one.
|
||||
**Build-time** separation means MJIN becomes highly configurable and each platform gets specifically tailored MJIN build.
|
||||
**Run-time** separation means MJIN is divided into smaller libraries that are connected at run-time, which makes it easy to change functionality without rebuilding.
|
||||
|
||||
**Run-time separation research.**
|
||||
|
||||
Since run-time separation has more benefits, we started researching it first.
|
||||
The easiest way to achieve it was to use C API, because C ABI rules are much simpler than C++ one's.
|
||||
|
||||
We created a sample project consisting of the application, library, and plugin.
|
||||
**The application** has been linked to the library and used it to load the plugin.
|
||||
**The library** provided functions to register plugins and call their functions.
|
||||
**The plugin** provided functions for the library and called library functions.
|
||||
|
||||
The research was successful: the sample project worked correctly under Linux and Windows. However, since MJIN is currently a single large entity, we postponed C API application until we finish build-time separation.
|
||||
|
||||
**Build-time separation start.**
|
||||
|
||||
We extracted the following modules from MJIN:
|
||||
|
||||
*
|
||||
Android: provides Java Native Interface (JNI) to MJIN
|
||||
|
||||
*
|
||||
Sound: provides access to OpenAL
|
||||
|
||||
*
|
||||
UIQt: provides access to Qt UI
|
||||
|
||||
|
||||
|
||||
|
||||
Sound and UIQt modules are currently statically linked into MJIN library, while Android module is already a separate library due to JNI requirements.
|
||||
|
||||
In the coming year, we're going to significantly restructure MJIN so that it suits as many platforms as possible.
|
||||
|
||||
That's it for describing the start of MJIN library separation into modules.
|
||||
|
||||
[screenshot]: {attach}/images/2016-12-15_2016-november-recap.png
|
||||
BIN
pelican/content/images/2016-12-15_2016-november-recap.png
Normal file
BIN
pelican/content/images/2016-12-15_2016-november-recap.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 322 KiB |
Reference in New Issue
Block a user