2017 © Pedro Peláez
 

composer-plugin composer-exclude-files

Exclude files from autoload_files.php

image

mcaskill/composer-exclude-files

Exclude files from autoload_files.php

  • Sunday, January 7, 2018
  • by mcaskill
  • Repository
  • 1 Watchers
  • 3 Stars
  • 377 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 2 Versions
  • 45 % Grown

The README.md

Exclude PHP files from Composer

![Build Status][github-badge] Latest Release License, (*1)

A Composer plugin for excluding files required by packages using the files autoloading mechanism., (*2)

This is useful for ignoring files required for bootstrapping a package or that provide PHP functions, for example., (*3)

Resolves composer/composer#5029, (*4)

Installation

The plugin can be installed locally or globally., (*5)

composer require mcaskill/composer-exclude-files

As of Composer 2.2.0, for additional security, you should declare the allow-plugins config to allow Composer to run the plugin., (*6)

composer config allow-plugins.mcaskill/composer-exclude-files true

Usage

You can only ignore files from the root composer.json. File exclusions of dependencies' composer.json are ignored., (*7)

From the root composer.json, add the exclude-from-files property to the extra section. The list of paths must be relative to this Composer manifest's vendor directory: <vendor-name>/<project-name>/<file-path>., (*8)

This plugin supports a subset of special characters used by the glob() function to match exclude paths matching a pattern:, (*9)

  • * — Matches zero or more characters.
  • ? — Matches exactly one character (any character).

This plugin is invoked before the autoloader is dumped, such as with the commands install, update, and dump-autoload., (*10)

Example 1: Excluding one file from illuminate/support
{
    "require": {
        "illuminate/support": "^9.6"
    },
    "extra": {
        "exclude-from-files": [
            "illuminate/support/helpers.php"
        ]
    },
    "config": {
        "allow-plugins": {
            "mcaskill/composer-exclude-files": true
        }
    }
}
Example 2: Excluding many files from laravel/framework
{
    "require": {
        "laravel/framework": "^9.6"
    },
    "extra": {
        "exclude-from-files": [
            "laravel/framework/src/*/helpers.php"
        ]
    },
    "config": {…}
}
Example 3: Excluding all files
{
    "require": {…},
    "extra": {
        "exclude-from-files": [
            "*"
        ]
    },
    "config": {…}
}

The plugin will traverse each package and remove all files in the paths configured above from the prepared autoload map. The vendor files themselves are not removed. The root package is ignored., (*11)

The resulting effect is the specified files are never included in vendor/composer/autoload_files.php., (*12)

License

This is licensed under MIT., (*13)

The Versions

07/01 2018

dev-master

9999999-dev

Exclude files from autoload_files.php

  Sources   Download

MIT

The Requires

  • composer-plugin-api ^1.0

 

The Development Requires

07/01 2018

v1.0.0

1.0.0.0

Exclude files from autoload_files.php

  Sources   Download

MIT

The Requires

  • composer-plugin-api ^1.0

 

The Development Requires