vairogs / functions-sort
A PHP library providing various sorting algorithms and utilities for arrays and objects
Requires
- php: >=8.4
- vairogs/functions-iteration: dev-master
- vairogs/functions-php: dev-master
This package is auto-updated.
Last update: 2025-04-15 09:01:31 UTC
README
A PHP library providing various sorting algorithms and utilities for arrays and objects.
Installation
Install the package via Composer:
composer require vairogs/functions-sort
Requirements
PHP 8.4 or higher
Usage
There are two ways to use this package: via the Functions class or by directly using the traits.
Using the Functions Class
The Functions class provides various sorting algorithms and utilities for arrays and objects.
use Vairogs\Functions\Sort\Functions; // Create a new Functions instance $sort = new Functions(); // Use bubble sort $array = [3, 1, 4, 1, 5, 9, 2, 6, 5]; $sort->bubbleSort($array); // $array is now sorted: [1, 1, 2, 3, 4, 5, 5, 6, 9] // Use merge sort $array = [3, 1, 4, 1, 5, 9, 2, 6, 5]; $sortedArray = $sort->mergeSort($array); // $sortedArray is now [1, 1, 2, 3, 4, 5, 5, 6, 9] // Sort an array of objects by a specific parameter $objects = [ ['id' => 3, 'name' => 'Charlie'], ['id' => 1, 'name' => 'Alice'], ['id' => 2, 'name' => 'Bob'], ]; $sortedObjects = $sort->sortByParameter($objects, 'name'); // $sortedObjects is now sorted by name: Alice, Bob, Charlie
Using Traits Directly
Alternatively, you can use the traits directly in your own classes:
use Vairogs\Functions\Sort\Traits\_BubbleSort; use Vairogs\Functions\Sort\Traits\_MergeSort; use Vairogs\Functions\Sort\Traits\_SortByParameter; class MyClass { // Import the traits you need use _BubbleSort; use _MergeSort; use _SortByParameter; public function doSomething(): void { // Use bubble sort $array = [3, 1, 4, 1, 5, 9, 2, 6, 5]; $this->bubbleSort($array); // Use merge sort $array = [3, 1, 4, 1, 5, 9, 2, 6, 5]; $sortedArray = $this->mergeSort($array); // Sort by parameter $objects = [ ['id' => 3, 'name' => 'Charlie'], ['id' => 1, 'name' => 'Alice'], ['id' => 2, 'name' => 'Bob'], ]; $sortedObjects = $this->sortByParameter($objects, 'name'); } }
Note that some traits may depend on other helper traits. For example, the _SortByParameter
trait uses _Usort
and _IsSortable
internally. The Functions class handles these dependencies for you, but if you use the traits directly, you may need to include these helper traits as well.
Features
For a complete list of all functions available in this package, see Features.
License
This package is licensed under the BSD-3-Clause License.
About Vairogs
This package is part of the vairogs/vairogs project - a comprehensive PHP library and Symfony bundle that provides a collection of utilities, components, and integrations for Symfony applications.
The main project includes:
- Various utility functions and components
- Doctrine ORM tools and extensions
- API Platform integrations
- Symfony bundle for easy configuration
- And much more
If you find this Sort component useful, you might want to check out the full Vairogs project for additional tools and utilities that can enhance your Symfony application development.
To install the complete package:
composer require vairogs/vairogs