PHPackages                             vairogs/functions-sort - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. vairogs/functions-sort

Abandoned → [valksor/php-functions-sort](/?search=valksor%2Fphp-functions-sort)Library[Utility &amp; Helpers](/categories/utility)

vairogs/functions-sort
======================

A PHP library providing various sorting algorithms and utilities for arrays and objects

00PHP

Since Apr 16Pushed 11mo agoCompare

[ Source](https://github.com/vairogs/functions-sort)[ Packagist](https://packagist.org/packages/vairogs/functions-sort)[ RSS](/packages/vairogs-functions-sort/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (1)Used By (0)

Vairogs Functions: Sort
=======================

[](#vairogs-functions-sort)

A PHP library providing various sorting algorithms and utilities for arrays and objects.

Installation
------------

[](#installation)

Install the package via Composer:

```
composer require vairogs/functions-sort
```

Requirements
------------

[](#requirements)

PHP 8.4 or higher

Usage
-----

[](#usage)

There are two ways to use this package: via the Functions class or by directly using the traits.

### Using the Functions Class

[](#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

[](#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
--------

[](#features)

For a complete list of all functions available in this package, see [Features](docs/features.md).

License
-------

[](#license)

This package is licensed under the [BSD-3-Clause License](LICENSE).

About Vairogs
-------------

[](#about-vairogs)

This package is part of the [vairogs/vairogs](https://github.com/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
```

###  Health Score

15

—

LowBetter than 3% of packages

Maintenance37

Infrequent updates — may be unmaintained

Popularity0

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity15

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/c4db85e32518c5a6caa2fd625032a2b016ef42d60cf8a101c165cc5c0048b221?d=identicon)[k0d3r1s](/maintainers/k0d3r1s)

---

Top Contributors

[![k0d3r1s](https://avatars.githubusercontent.com/u/38725938?v=4)](https://github.com/k0d3r1s "k0d3r1s (2 commits)")

### Embed Badge

![Health badge](/badges/vairogs-functions-sort/health.svg)

```
[![Health](https://phpackages.com/badges/vairogs-functions-sort/health.svg)](https://phpackages.com/packages/vairogs-functions-sort)
```

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
