From 067084bc8bf39891abbb135fd8bbf7243d019fc7 Mon Sep 17 00:00:00 2001 From: David Pashley Date: Thu, 6 Jun 2024 10:41:57 +0200 Subject: [PATCH] Build improvements This adds a `build` and `clean` commands to `composer.json` to enable easier discovery of the build process for new developers. Due to the `clean` deleting the raw directory. I've moved the gitignore into the top level `.gitignore`. The available commands are added to the README.md --- .gitignore | 2 ++ README.md | 17 +++++++++++++++++ composer.json | 14 +++++++++++++- resources/models/raw/.gitignore | 2 -- 4 files changed, 32 insertions(+), 3 deletions(-) delete mode 100644 resources/models/raw/.gitignore diff --git a/.gitignore b/.gitignore index 7514b392c..29ca1fec2 100644 --- a/.gitignore +++ b/.gitignore @@ -19,3 +19,5 @@ composer.lock # OS X **/.DS_Store + +resources/models/raw diff --git a/README.md b/README.md index 9b22c30c6..eb9cd75bb 100644 --- a/README.md +++ b/README.md @@ -67,6 +67,7 @@ This README is divided into several sections: * [Naming conventions](#naming-conventions) * [API versions](#api-versions) * [Working with DTOs](#working-with-dtos) +* [Contributing](#contributing) ## Getting Started @@ -540,3 +541,19 @@ $response = $ordersApi->confirmShipment( confirmShipmentRequest: $confirmShipmentRequest, ) ``` + +## Contributing + +To regenerate the library, you can run + + # composer clean + # composer build + +Composer has a number of pre-configured scripts in `composer.json`: + +* `build`: Run all the stages to regenerate the PHP files +* `clean`: Delete all the generated PHP and JSON files +* `lint`: Run PHP-CS-Fixer +* `schema:download`: Download the schemas from Amazon +* `schema:generate`: Generate the PHP files from the schemas +* `schema:refactor`: Make local modifications to the schemas before generation \ No newline at end of file diff --git a/composer.json b/composer.json index dcbbdc300..54ec9c713 100644 --- a/composer.json +++ b/composer.json @@ -23,8 +23,10 @@ "require": { "php": ">=8.1", "ext-curl": "*", + "ext-dom": "*", "ext-json": "*", "ext-mbstring": "*", + "ext-simplexml": "*", "guzzlehttp/guzzle": "^6.0|^7.0", "saloonphp/saloon": "^3.4", "openspout/openspout": "^4.23", @@ -54,6 +56,13 @@ } }, "scripts": { + "build": [ + "@schema:download", + "@schema:refactor", + "@schema:generate", + "@lint" + ], + "clean": "rm -rf src/Vendor src/Seller resources/models/seller resources/models/vendor resources/models/raw", "lint": [ "@pint", "@php-compatibility-check" @@ -61,7 +70,10 @@ "pint": "php vendor/bin/pint", "php-compatibility-check": "./vendor/bin/phpcs -p ./src ./bin --standard=PHPCompatibility --runtime-set testVersion 8.1-", "post-install-cmd": "\"vendor/bin/phpcs\" --config-set installed_paths vendor/phpcompatibility/php-compatibility", - "post-update-cmd": "\"vendor/bin/phpcs\" --config-set installed_paths vendor/phpcompatibility/php-compatibility" + "post-update-cmd": "\"vendor/bin/phpcs\" --config-set installed_paths vendor/phpcompatibility/php-compatibility", + "schema:download": "@php bin/console schema:download", + "schema:generate": "@php bin/console schema:generate", + "schema:refactor": "@php bin/console schema:refactor" }, "config": { "allow-plugins": { diff --git a/resources/models/raw/.gitignore b/resources/models/raw/.gitignore deleted file mode 100644 index d6b7ef32c..000000000 --- a/resources/models/raw/.gitignore +++ /dev/null @@ -1,2 +0,0 @@ -* -!.gitignore