Smart unique name generator for PHP
Automatically generates a unique name by incrementing it if needed — just like "file" → "file (1)" → "file (2)" and so on.
- Generate unique names based on existing ones
- Smart gap detection (fills missing indexes first)
- Lightweight, dependency-free
- Perfect for filenames, labels, IDs, and more
- JavaScript: Namecrement
- Python: Namecrement-py
composer require hichemtab-tech/namecrement-php<?php
use HichemTabTech\Namecrement\Namecrement;
$existing = ['file', 'file (1)', 'file (2)'];
$newName = Namecrement::namecrement('file', $existing);
echo $newName;
// Outputs: "file (3)"You can customize the suffix format using the %N% placeholder to define how the number is added:
Namecrement::namecrement('file', ['file', 'file -1-', 'file -2-'], ' -%N%-');
// ➔ 'file -3-'
Namecrement::namecrement('version', ['version', 'version<v1>'], '<v%N%>');
// ➔ 'version<v2>'- The
suffixFormatmust include%N%, or anInvalidArgumentExceptionwill be thrown. %N%will be replaced by the next available number.- Default format is
" (%N%)".
| Format Example | Result |
|---|---|
" (%N%)" |
file (1) |
-%N% |
file-1 |
_<v%N%> |
file_<v1> |
_%N%_ |
file_1_ |
| Parameter | Type | Description |
|---|---|---|
baseName |
string | Proposed name to start from |
existingNames |
string[] | List of already existing names |
suffixFormat |
string | Optional format for suffix (optional) |
startingNumber |
int | null |
The starting number for incrementing (default: null) |
Returns the next available unique name.
Namecrement::namecrement('report', ['report', 'report (1)']);
// ➔ 'report (2)'
Namecrement::namecrement('image', ['photo', 'image', 'image (1)', 'image (2)']);
// ➔ 'image (3)'
Namecrement::namecrement('new', []);
// ➔ 'new'
Namecrement::namecrement('file', ['file', 'file (1)', 'file (2)'], ' -%N%-');
// ➔ 'file -1-'
Namecrement::namecrement('file', [], startingNumber: 5);
// → 'file (5)'This project is open-source and available under the MIT license.
Contributions are welcome!
Please check out the CONTRIBUTING.md for guidelines.