codezero/composer-preload-files 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

codezero/composer-preload-files

最新稳定版本:1.0.2

Composer 安装命令:

composer require codezero/composer-preload-files

包简介

Composer plugin to autoload files before vendor files.

README 文档

README

GitHub release License Total Downloads

Autoload Your Files Before Vendor Files

This Composer plugin enables you to autoload files that you specify before any vendor files.

This package is based on the original funkjedi/composer-include-files by @funkjedi and its fork hopeseekr-contribs/composer-include-files by @hopeseekr. Because maintenance of these packages appears to be stalled, I decided to attempt and remake the package from scratch and fix any reported bugs in the process.

✅ Requirements

  • PHP >= 7.0
  • Composer ^2.3

📦 Install

Install this package with Composer:

composer require codezero/composer-preload-files

📘 Usage

Add the preload-files to your project's composer.json under the extra section:

"extra": {
    "preload-files": [
        "app/helpers.php"
    ]
},

The preload-files in the extra section will be loaded before the files in a standard autoload or autoload-dev section. This is true for your project, but also for any vendor package. Your project's preload files will always be loaded first.

🔌 Example Use Case

The best example use case is when you need to override a global helper function in a Laravel project. Those helper functions are declared in helper files that are loaded in the files array in the autoload section of composer.json:

"autoload": {
    "files": [
        "src/Illuminate/Collections/helpers.php",
        "src/Illuminate/Events/functions.php",
        "src/Illuminate/Foundation/helpers.php",
        "src/Illuminate/Support/helpers.php"
    ]
},

These functions are declared like this:

// helpers.php
if ( ! function_exists('route')) {
    function route($name, $parameters = [], $absolute = true)
    {
        return app('url')->route($name, $parameters, $absolute);
    }
}

If you add your own helper file to your project's autoload section to override such function, you will notice that Laravel's function is already loaded, and you can not redeclare it.

One way to solve this, is to manually require the helper file before Composer's autoload.php file. For Laravel, this means you need to require the file in your project's public/index.php file:

require __DIR__.'/../app/helpers.php';
require __DIR__.'/../vendor/autoload.php';

This works, but it is difficult, if not impossible to test (I did not find a way yet). If you are developing a package, it's also an extra step that users need take to install it.

Another solution is a package like this.

☕ Credits

🔒 Security

If you discover any security related issues, please e-mail me instead of using the issue tracker.

📑 Changelog

A complete list of all notable changes to this package can be found on the releases page.

📜 License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 389.37k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 1
  • 依赖项目数: 5
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-04-02