-
Notifications
You must be signed in to change notification settings - Fork 180
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[WIP][RFC] improve plugin loading with symfony1-plugin
typed composer packages
#342
Comments
Good idea. Another idea without composer dependency. It avoids plugin duplication
If a plugin is installed with composer, it is also autoloaded. class ProjectConfiguration extends sfProjectConfiguration
{
public function setup()
{
$this->enablePlugins([
\Some\Vendor\SomePluginConfiguration::class,
]);
}
} where public function getPluginPaths()
{
if (!isset($this->pluginPaths[''])) {
$pluginPaths = $this->getAllPluginPaths();
$this->pluginPaths[''] = [];
foreach ($this->getPlugins() as $plugin) {
if (isset($pluginPaths[$plugin])) {
$this->pluginPaths[''][] = $pluginPaths[$plugin];
} else {
// START new code
try {
$pluginConfigurationClass = $plugin;
$pluginReflection = new ReflectionClass($pluginConfigurationClass);
$classFile = $pluginReflection->getFileName();
// to be compatible with loadPlugins()
// require_once '${pluginPath}/config/${pluginName}Configuration.class.php'; be noop
$pluginName = $this->extractBaseClassWithoutConfigurationSuffix($pluginConfigurationClass);
$pluginPath = $this->extractPluginDirectory($classFile);
$this->pluginPaths[''][] = $pluginPath;
$this->setPluginPath($pluginName, $pluginPath);
} catch (ReflectionException) {
throw new InvalidArgumentException(sprintf('The plugin "%s" does not exist.', $plugin));
}
// END new code
}
}
}
return $this->pluginPaths[''];
} |
I have nothing against relying heavily on the composer. It has become a quasi-industry standard. Currently, the code relies heavily on an outdated package management system (pear). This code won't live to see composer become obsolete, so integrating it won't be a problem. |
For Issue #341, I looked into what is needed to put
sfDoctrinePlugin
in a separate package and not have it shipped with the base framework (e.g. propel orm doesn't need this plugin). I don't really like the solution of the other fos1 plugin packages. What happens there is thatcomposer-installer
1.0 knows aboutsymfony1-plugin
and copies the installed package into the appropriate plugins directory. This is not very practical to do in the composer era. Let's take a look at what to do:sfProjectConfiguration::getAllPluginPaths
method should return all packages that are of typesymfony1-plugin
:composer/installers
1.0 to be in the dependencies, because this will duplicate the pluginsThis change would get rid of package codes (which don't work anyway: https://github.com/orgs/FriendsOfSymfony1/discussions/333#discussion-6326793 ), pear codes, and should be default the composer installation way of the framework and the plugins.
What other improvements could be considered?
bundle.php
).Files to remove
Deprecated commands/tasks
Deprecated methods
The text was updated successfully, but these errors were encountered: