hichemtab-tech/namecrement

A smart php utility that generates unique incremental names, preventing naming collisions by automatically appending incremental suffixes.

1.1.0 2025-04-30 23:13 UTC

This package is auto-updated.

Last update: 2025-04-30 23:16:10 UTC


README

Tests License Packagist Version

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.

✨ Features

  • Generate unique names based on existing ones
  • Smart gap detection (fills missing indexes first)
  • Lightweight, dependency-free
  • Perfect for filenames, labels, IDs, and more

📦 Also Available

Looking for a JavaScript version? Check out Namecrement for JavaScript!

📦 Installation

composer require hichemtab-tech/namecrement-php

🚀 Usage

<?php

use HichemTabTech\Namecrement\Namecrement;

$existing = ['file', 'file (1)', 'file (2)'];
$newName = Namecrement::namecrement('file', $existing);

echo $newName; 
// Outputs: "file (3)"

🧠 Advanced Usage

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>'

🛡 Suffix Format Rules

  • The suffixFormat must include %N%, or an InvalidArgumentException will 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_

📚 API

namecrement(string $baseName, array $existingNames): string

Parameter Type Description
baseName string Proposed name to start from
existingNames string[] List of already existing names
suffixFormat string Optional format for suffix (optional)

Returns the next available unique name.

🛠 Examples

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-'

📄 License

This project is open-source and available under the MIT license.

🤝 Contributing

Contributions are welcome!
Please check out the CONTRIBUTING.md for guidelines.