Composer.json#
composer.json
is a JSON file placed in the root folder of PHP project. Its purpose is to specify a common project properties, meta data and dependencies, and it is a part of vast array of existing projects. In most ways, it is a counterpart to .NET project file. At least, the information from the composer.json
file can be represented by standard .NET project properties and items (not the other way around).
Metadata#
By default, the composer.json
file is processed during build time. As a result, certain composer metadata is mapped to the corresponding project properties, thanks to which the created NuGet packages are automatically annotated.
Following table lists composer meta and corresponding project properties being automatically set:
Meta | MsBuild Property | Nuspec Value |
---|---|---|
"name" | PackageId | Id |
"description" | PackageDescription | Description |
"version" | Version, PackageVersion /1/ | Version |
"license" | PackageLicenseExpression | license |
"homepage" | PackageProjectUrl | ProjectUrl |
"authors" | Authors | Authors |
/1/ Version respects specified $(VersionSuffix)
property. In case project has non-empty VersionSuffix
, the resulting Version
will have the suffix specified even composer's version
meta does not have it.
MSBuild Properties#
$(ComposerJsonPath)#
The ComposerJsonPath
property controls path to the composer.json
file. If the property is empty, the file is being located next to the project file implicitly.
<ComposerJsonPath>false</ComposerJsonPath>
Set ComposerJsonPath
to false
in order to disable processing of composer.json meta data during build.
$(ComposerAutoload)#
Setting ComposerAutoload
to true
or false
controls whether autoload rules are processed.
$(VersionSuffix)#
Explicitly setting VersionSuffix
allows to override suffix portion of version
meta data from composer file. If VersionSuffix
is non-empty string, the resulting version will respect the suffix.
Project file:
<VersionSuffix>dev</VersionSuffix>
composer.json
{
"version": "1.2.3"
}
The setup above results in PackageVersion
property set to 1.2.3-dev
.
Composer Dependencies#
Sections "require", "require-dev" and "suggest" are not processed (yet).
Composer Autoload#
Available since
0.9.980
See Composer & Compile-Time Autoloading blog post.
Composer autoloading provides a standard approach in defining what classes will be loaded automatically when needed. Also, it allows to specify what files will be included by the runtime at the very beginning of request or the program start. When the compiler processes the "autoload"
section, it remembers the autoloading rules and stores the information in metadata. It does not use the information to compile any additional files - all the files meant to be compiled have to be listed within the <Compile>
MSBuild item group explicitly.
- Rules from
composer.json
will be stored within the assembly metadata; hence the originalcomposer.json
file is not required to be bundled with the compiled application. - Files listed in
"autoload"
are not automatically added to the compilation. Files needed to be compiled have to be listed within the<Compile>
item group explicitly. - A syntax error in the json file will cause the compilation to stop with a corresponding error message. A wrong value in the
composer.json
causes a compile-time warning and the compilation will continue.
Sample "composer.json":
{
"autoload": {
"psr-4": {
"Vendor\\Namespace\\": "src/",
"": "src/",
},
"psr-0": {
"Vendor\\Namespace\\": "src/",
"Vendor_Namespace_": "src/"
},
"classmap": ["src/", "lib/", "Something.php"],
"exclude-from-classmap": ["/src/Tests/", "/lib/tests/"],
"files": [],
}
}
During the compilation, this information is used in order to avoid autoloading process in the first place. Classes, interfaces and traits fulfiling the specified rules are declared implicitly without need of invoking autoloaders during run time. (We can say, the autoloading will performed only once during compilation when it's safe to.) In case a source file contains more than just the class itself, autoloading cannot be fully optimized. In such case, containing source file has to be looked up and invoked during run time causing an unnecesary overhead.
This behavior differs from standard PHP where the map above is used to generate autoloaders which are invoked every time when an unknown class, interface or trait is being used in every new web request.