webarchitect609/bitrix-neverinclude
最新稳定版本:v1.1.2
Composer 安装命令:
composer require webarchitect609/bitrix-neverinclude
包简介
Automatic Bitrix modules loader helps you to forget about CModule::IncludeModule and Loader::includeModule.
README 文档
README
Автозагрузчик модулей Битрикс, который поможет вам забыть про вызовы CModule::IncludeModule и Loader::includeModule
Как использовать
1 Установите через composer:
composer require webarchitect609/bitrix-neverinclude
2 Если необходимо, то в init.php укажите список модулей, которые следует исключить из обработки данного автолоадера:
\WebArch\BitrixNeverInclude\BitrixNeverInclude::addExcludedModules(['foo.bar',]);
Данный пакет совместим с новыми версиями andreyryabin/sprint.migration: >=3.0
3 В init.php после подключения vendor/autoload.php добавьте вызов:
\WebArch\BitrixNeverInclude\BitrixNeverInclude::registerModuleAutoload();
Больше подключать модули не нужно, за исключением некоторых ситуаций, описанных ниже.
Особенности реализации
1 Классы не из глобального namespace разбираются динамически и превращаются в название модуля, который тут же подключается.
2 Классы из глобальной области проверяются по маппингу "имя класса => имя модуля", для вычисления которого делается подключение всех установленных в системе модулей и производится сбор внутренних данных, которые потом кешируются.
Известные ограничения
При установке нового модуля
Если происходит установка нового модуля, использующего классы в глобальной области, кеш маппинга "имя класса => имя модуля" будет неактуальным. Рекомендуется сбросить его по тегу следующим образом:
$tagCache = \Bitrix\Main\Application::getInstance()->getTaggedCache();
$tagCache->clearByTag(\WebArch\BitrixNeverInclude\BitrixNeverInclude::CACHE_TAG);
После сброса кеша рекомендуется вызвать
\WebArch\BitrixNeverInclude\BitrixNeverInclude::getClassMapping();
, чтобы при следующем хите уже существовал маппинг "имя класса => имя модуля".
Функции в модулях
В некоторых модулях объявляются функции, которые недоступны без подключения модуля. Например, функция
SaleFormatCurrency недоступна без
подключения модуля sale. Из-за того, что в php нет механизма
автозагрузки функций, эта проблема не может быть решена автоматически. Следует вручную подключать соответствующий модуль
перед вызовом функции, объявленной в этом модуле.
Несовместимость с некоторыми модулями
Если архитектура модуля Битрикс сделана таким образом, что в include.php происходит регистрация своего автозагрузчика
классов, то очень вероятна несовместимость такого модуля с данным пакетом. Следует исключить этот модуль из
обработки(см. выше) и подключать его по необходимости вручную.
统计信息
- 总下载量: 15.04k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 11
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 1
其他信息
- 授权协议: MIT
- 更新时间: 2017-04-22