This publication describes a standard filesystem skeleton suitable for all PHP packages.
Please see https://github.com/php-pds/skeleton_research for background information.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this publication are to be interpreted as described in RFC 2119.
A package MUST use the following names for the following kinds of directories and files:
bin/ # command-line executables
config/ # configuration files
docs/ # documentation and examples
public/ # web server files
resources/ # other resource files
src/ # PHP source code
tests/ # test code
vendor/ # reserved for package managers
CHANGELOG(.*) # a log of changes between releases
CONTRIBUTING(.*) # guidelines for contributors
LICENSE(.*) # licensing information
README(.*) # information about the package itself
If the package provides a root-level directory for command-line executable files, it MUST
be named bin/
.
This publication does not otherwise define the structure and contents of the directory.
If the package provides a root-level directory for configuration files, it MUST be named
config/
.
This publication does not otherwise define the structure and contents of the directory.
If the package provides a root-level directory for documentation files, it MUST be named
docs/
.
This publication does not otherwise define the structure and contents of the directory.
If the package provides a root-level directory for web server files, it MUST be named
public/
.
This publication does not otherwise define the structure and contents of the directory.
N.b.: This directory MAY be intended as a web server document root. Alternatively, it MAY be that the files will be served dynamically via other code, copied or symlinked to the "real" document root, or otherwise managed so that they become publicly available on the web.
If the package provides a root-level directory for other resource files, it MUST be named
resources/
.
This publication does not otherwise define the structure and contents of the directory.
If the package provides a root-level directory for PHP source code files, it MUST be named
src/
.
This publication does not otherwise define the structure and contents of the directory.
If the package provides a root-level directory for test files, it MUST be named tests/
.
This publication does not otherwise define the structure and contents of the directory.
The vendor/
directory MUST be reserved for use by package managers (e.g.:
Composer).
It MUST be ignored by revision control tools (e.g.: Git, Mercurial, Subversion, etc.).
It MUST NOT be committed to revision control repositories.
This publication does not otherwise define the structure and contents of the directory.
The package MAY contain other root-level directories for purposes not described by this publication.
This publication does not define the structure and contents of other root-level directories.
If the package provides a root-level file with a list of changes since the last release or
version, it MUST be named CHANGELOG
.
It MAY have a lowercase filename extension indicating the file format.
This publication does not otherwise define the structure and contents of the file.
If the package provides a root-level file that describes how to contribute to the package,
it MUST be named CONTRIBUTING
.
It MAY have a lowercase filename extension indicating the file format.
This publication does not otherwise define the structure and contents of the file.
Whereas package consumers might be in violation of copyright law when copying unlicensed intellectual property, the package SHOULD include a root-level file indicating the licensing and copyright terms of the package contents.
If the package provides a root-level file indicating the licensing and copyright
terms of the package contents, it MUST be named LICENSE
.
It MAY have a lowercase filename extension indicating the file format.
This publication does not otherwise define the structure and contents of the file.
If the package provides a root-level file with information about the package itself, it
MUST be named README
.
It MAY have a lowercase filename extension indicating the file format.
This publication does not otherwise define the structure and contents of the file.
The package MAY contain other root-level files for purposes not described in this publication.
This publication does not otherwise define the structure and contents of the other root-level files.