A PHP library providing various sorting algorithms and utilities for arrays and objects.
Install the package via Composer:
composer require valksor/php-functions-sortPHP 8.4 or higher
There are two ways to use this package: via the Functions class or by directly using the traits.
The Functions class provides various sorting algorithms and utilities for arrays and objects.
use Valksor\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, CharlieAlternatively, you can use the traits directly in your own classes:
use Valksor\Functions\Sort\Traits\_BubbleSort;
use Valksor\Functions\Sort\Traits\_MergeSort;
use Valksor\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.
For a complete list of all functions available in this package, see Features.
Contributions are welcome! Please read our Contributing Guidelines for details on:
- Code style requirements (PSR-12)
- Testing requirements for PRs
- One feature per pull request
- Development setup instructions
To contribute to Sort functions:
- Fork the repository
- Create a feature branch (git checkout -b feature/new-sort-function)
- Implement your function following existing patterns
- Add comprehensive tests
- Ensure all tests pass and code style is correct
- Submit a pull request
If you discover any security-related issues, please email us at security@valksor.dev instead of using the issue tracker.
For security policy and vulnerability reporting guidelines, please see our Security Policy.
- Documentation: Full documentation
- Issues: GitHub Issues for bug reports and feature requests
- Discussions: GitHub Discussions for questions and community support
- Stack Overflow: Use tag valksor-php-functions-sort
- Original Author - Creator and maintainer
- All Contributors - Thank you to all who contributed
- Algorithms Community - Sorting algorithm inspiration and research
- Valksor Project - Part of the larger Valksor PHP ecosystem
This package is licensed under the BSD-3-Clause License.
This package is part of the valksor/php-valksor 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
- Symfony bundle for easy configuration
- And much more
If you find this Sort component useful, you might want to check out the full Valksor project for additional tools and utilities that can enhance your Symfony application development.
To install the complete package:
composer require valksor/php-valksor