2016-12-15_2016-november-recap-ru.md 3.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. Title: Ноябрь 2016 кратко
  2. Date: 2016-12-15 00:00
  3. Category: News
  4. Slug: 2016-november-recap
  5. Lang: ru
  6. ![November recap][screenshot]
  7. Эта статья описывает начало разделения библиотеки MJIN на модули.
  8. Как только мы собрали OpenSceneGraph для Android, стало очевидно, что часть функционала MJIN не нужна на Android. Например, UIQt - это основа интерфейса Редактора. Раз Редактор - это приложение для ПК, то UIQt не нужен на Android.
  9. Мы решили рассмотреть два подхода к разделению MJIN на модули: во время сборки (build-time) и исполнения (run-time).
  10. Разделение **во время сборки** означает гибкую систему настроек MJIN, что позволит собирать её различно под каждую платформу.
  11. Разделение **во время исполнения** означает разделение MJIN на несколько небольших библиотек с последующим соединением во время исполнения, что позволит легко менять функционал без повторной сборки.
  12. **Исследование разделения во время исполнения.**
  13. Т.к. разделение во время исполнения имеет больше преимуществ, мы начали с этого подхода.
  14. Самый простой способ достичь его заключался в использовании C API, т.к. правила C ABI намного проще правил C++ ABI.
  15. Мы создали маленький проект, включающий в себя приложение, библиотеку и плагин.
  16. **Приложение** было слинковано с библиотекой и использовало её для загрузки плагина.
  17. **Библиотека** предоставляла функции для регистрации плагина и вызывала его функции.
  18. **Плагин** предоставлял функции для библиотеки и вызывал её функции.
  19. Исследование прошло на ура: проект работал в полном соответствии с нашими ожиданиями на Linux и Windows.
  20. Тем не менее, т.к. MJIN на текущий момент является большой монолитной сущностью, мы отложили применение C API до окончания разделения во время сборки.
  21. **Начало разделения во время сборки.**
  22. Мы выделили следующие модули из MJIN:
  23. *
  24. Android: предоставляет Java Native Interface (JNI) к MJIN
  25. *
  26. Sound: предоставляет доступ к OpenAL
  27. *
  28. UIQt: предоставляет доступ к Qt
  29. Модули Sound и UIQt на текущий момент статически линкуются в MJIN, тогда как модуль Android линкуется динамически из-за ограничений JNI.
  30. В следующем году мы изменим структуру MJIN так, чтобы её можно было легче собрать под разные платформы.
  31. На этом мы заканчиваем статью о начале разделения библиотеки MJIN на модули.
  32. [screenshot]: {attach}/images/2016-12-15_2016-november-recap.png