barkley/create-phar

PHP packaging and build process

v2.2.6 2024-12-12 18:00 UTC

README

Overview

This project will aid in creating PHP projects that following Barkley's typical development flow, and will allow the creation of versioned PHAR files for projects to be easily distributed to systems that are detached from any code repository.

Barkley's PHP development process is ever-changing, so updates and changes to this project will likely shift around frequently as well. However, backwards-compatibility will always be important as we move forward. We will intend to support the ability to disable any new features that get added.

Setup

Composer

Composer support has been introduced in v2.0.0, and is relatively fresh, so proceed with caution. This will be supported on Linux.

Install

Install the Composer package barkley/create-phar (see Packagist).

composer require barkley/create-phar

Version set to dev-master will pull directly from the master branch, which may include work-in-progress changes. It is suggested to lock your install to a specific version instead.

create-phar needs to be installed in the root of your project, rather than the source directory. The initialization will help structure the project.

Usage

Once installed, the following script, run from the root of your project, will allow access to all create-phar logic.

./vendor/bin/create-phar

Prior to version 2.1.1, you would need to use the following script:

php vendor/barkley/create-phar/build.php

(Anytime instructions below refer to the command create-phar, you will need to use this path instead)

Windows

Add the directory for the create-phar project to your system's PATH variable. If done correctly you should see output when you type create-phar in your system's terminal.

Project Initialization

To initialize a new project, create an empty directory for it, and within it run the command create-phar init.

The project will be named and namespaced based on the current directory. For example, if you run create-phar init in the directory c:\TestProject\, your project will have the name Testproject and be in the namespace rei\TestProject.

Configuration

TO DO

Project Build

To build projects after initialization, simply run the command create-phar within the project directory.

If you want to change the version number for the project, run the command followed by the new version number. For example create-phar 1.2.4.

Run Flags

  • -h - Outputs help commands.
  • -v - Runs in verbose mode, providing more output during the build process.
  • -u - Updates Composer and dependencies. By default, running a build does not update these items.
  • -i - Outputs version information on the current project without doing any build steps.
  • -c - Run a Composer command against the curent project using the Composer from the create-phar build.
  • -fixpsr - Fix PSR adjustments. Should only need to be run if prompted to do so.