Add 2016 november recap

This commit is contained in:
2017-11-24 12:29:35 +03:00
parent 11469209ee
commit ebb11bb49c
12 changed files with 569 additions and 2 deletions

View File

@@ -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

View 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

Binary file not shown.

After

Width:  |  Height:  |  Size: 322 KiB