Description
About
PHP-Spellchecker is a spellchecker abstraction library for PHP. By providing a unified interface for many different spellcheckers, youβre able to swap out spellcheckers without extensive rewrites.
Using PHP-Spellchecker can eliminate vendor lock-in, reduce technical debt, and improve the testability of your code.
Features
π§ Supports many popular spellcheckers out of the box: Aspell, Hunspell, Ispell, PHP Pspell, LanguageTools and MultiSpellchecker (add yours!)
page_facing_up Supports different text sources: file system file/directory, string, and multi-source (add yours!)
hammer_and_wrench Supports text processors: MarkdownRemover (add yours!)
repeat Supports misspelling handlers: EchoHandler (add yours!)
curly_loop Makes use of generators to reduce memory footprint
β Flexible and straightforward design
bulb Makes it a breeze to implement your own spellcheckers, text processors and misspellings handlers
muscle Runs tests against real spellcheckers to ensure full compatibility
PHP-Spellchecker alternatives and similar libraries
Based on the "Frameworks" category.
Alternatively, view PHP-Spellchecker alternatives based on common mentions on social networks and blogs.
-
Laravel 5
Laravel is a web application framework with expressive, elegant syntax. Weβve already laid the foundation for your next big idea β freeing you to create without sweating the small things. -
Slim Framework
Slim is a PHP micro framework that helps you quickly write simple yet powerful web applications and APIs. -
FuelPHP
Fuel PHP Framework v1.x is a simple, flexible, community driven PHP 5.3+ framework, based on the best ideas of other frameworks, with a fresh start! FuelPHP is now fully PHP 8.0 compatible. -
PHP-GLFW
πͺA fully-featured OpenGL and GLFW extension for PHP. πBatteries included (Math Functions, Texture Loaders, etc..) -
OpenAPI PSR-7 Message (HTTP Request/Response) Validator
It validates PSR-7 messages (HTTP request/response) against OpenAPI specifications
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of PHP-Spellchecker or a related project?
README
PHP-Spellchecker
Check misspellings from any text source with the most popular PHP spellchecker.
About
PHP-Spellchecker is a spellchecker abstraction library for PHP. By providing a unified interface for many different spellcheckers, youβre able to swap out spellcheckers without extensive rewrites.
Using PHP-Spellchecker can eliminate vendor lock-in, reduce technical debt, and improve the testability of your code.
Features
- π§ Supports many popular spellcheckers out of the box: Aspell, Hunspell, Ispell, PHP Pspell, LanguageTools, JamSpell and MultiSpellchecker (add yours!)
- π Supports different text sources: file system file/directory, string, and multi-source (add yours!)
- π Supports text processors: MarkdownRemover (add yours!)
- π Supports misspelling handlers: EchoHandler (add yours!)
- β° Makes use of generators to reduce memory footprint
- β Flexible and straightforward design
- π‘ Makes it a breeze to implement your own spellcheckers, text processors and misspellings handlers
- πͺ Runs tests against real spellcheckers to ensure full compatibility
PHP-Spellchecker is a welcoming project for new contributors.
Want to make your first open source contribution? Check the roadmap, pick one task, open an issue and we'll help you go through it π€π
Install
Via Composer
$ composer require tigitz/php-spellchecker
Usage
Check out the documentation and examples
Using the spellchecker directly
You can check misspellings directly from a PhpSpellcheck\Spellchecker
class and process them on your own.
<?php
// if you made the default aspell installation on your local machine
$aspell = Aspell::create();
// or if you want to use binaries from Docker
$aspell = new Aspell(new CommandLine(['docker','run','--rm', '-i', 'starefossen/aspell']));
$misspellings = $aspell->check('mispell', ['en_US'], ['from_example']);
foreach ($misspellings as $misspelling) {
$misspelling->getWord(); // 'mispell'
$misspelling->getLineNumber(); // '1'
$misspelling->getOffset(); // '0'
$misspelling->getSuggestions(); // ['misspell', ...]
$misspelling->getContext(); // ['from_example']
}
Using the MisspellingFinder
orchestrator
You can also use an opinionated MisspellingFinder
class to orchestrate your spellchecking flow:
Following the well-known Unix philosophy:
Write programs that do one thing and do it well. Write programs to work together. Write programs to handle text streams, because that is a universal interface.
<?php
// My custom text processor that replaces "_" by " "
$customTextProcessor = new class implements TextProcessorInterface
{
public function process(TextInterface $text): TextInterface
{
$contentProcessed = str_replace('_', ' ', $text->getContent());
return $text->replaceContent($contentProcessed);
}
};
$misspellingFinder = new MisspellingFinder(
Aspell::create(), // Creates aspell spellchecker pointing to "aspell" as it's binary path
new EchoHandler(), // Handles all the misspellings found by echoing their information
$customTextProcessor
);
// using a string
$misspellingFinder->find('It\'s_a_mispelling', ['en_US']);
// word: mispelling | line: 1 | offset: 7 | suggestions: mi spelling,mi-spelling,misspelling | context: []
// using a TextSource
$inMemoryTextProvider = new class implements SourceInterface
{
public function toTexts(array $context): iterable
{
yield new Text('my_mispell', ['from_source_interface']);
// t() is a shortcut for new Text()
yield t('my_other_mispell', ['from_named_constructor']);
}
};
$misspellingFinder->find($inMemoryTextProvider, ['en_US']);
//word: mispell | line: 1 | offset: 3 | suggestions: mi spell,mi-spell,misspell,... | context: ["from_source_interface"]
//word: mispell | line: 1 | offset: 9 | suggestions: mi spell,mi-spell,misspell,... | context: ["from_named_constructor"]
Roadmap
The project is still in its initial phase, requiring more real-life usage to stabilize its final 1.0.0 API.
Global
- [ ] Add a CLI that could do something like
vendor/bin/php-spellchecker "misspell" Languagetools EchoHandler --lang=en_US
- [ ] Add asynchronous mechanism to spellcheckers.
- [ ] Make some computed misspelling properties optional to improve performance for certain use cases (e.g., lines and offset in
LanguageTools
). - [ ] Add a language mapper to manage different representations across spellcheckers.
- [ ] Evaluate
strtok
instead ofexplode
to parse lines of text, for performance. - [ ] Evaluate
MutableMisspelling
for performance comparison. - [ ] Wrap
Webmozart/Assert
library exceptions to throw PHP-Spellchecker custom exceptions instead. - [ ] Improve the
Makefile
.
Sources
- [ ] Make a
SourceInterface
class that's able to have an effect on the used spellchecker configuration. - [ ]
League/Flysystem
source. - [ ]
Symfony/Finder
source.
Text processors
- [ ] Markdown - Find a way to keep the original offset and line of words after stripping.
- [ ] Add PHPDoc processor.
- [ ] Add HTML Processor (inspiration).
- [ ] Add XLIFF Processor (inspiration).
Spell checkers
- [ ] Cache suggestions of already spellchecked words (PSR-6/PSR-16?).
- [ ] Pspell - Find way to compute word offset.
- [ ] LanguageTools - Evaluate HTTPlug library to make API requests.
- [x] Pspell - find way to list available dictionaries.
- [x] Add JamSpell spellchecker.
- [ ] Add NuSpell spellchecker.
- [ ] Add SymSpell spellchecker.
- [ ] Add Yandex.Speller API spellchecker.
- [ ] Add Bing Spell Check API spellchecker.
Handlers
- [ ] MonologHandler
- [ ] ChainedHandler
- [ ] HTMLReportHandler
- [ ] XmlReportHandler
- [ ] JSONReportHandler
- [ ] ConsoleTableHandler
Tests
- [ ] Add or improve tests with different text encoding.
- [ ] Refactor duplicate Dockerfile content between PHP images.
Versioning
We follow SemVer v2.0.0.
There still are many design decisions that should be confronted with real-world usage before thinking about a v1.0.0 stable release:
- Are
TextInterface
andMisspellingInterface
really useful? - Is using generators the right way to go?
- Should all the contributed spellcheckers be maintained by the package itself?
- How to design an intuitive CLI given the needed flexibility of usage?
- Is the "context" array passed through all the layers the right design to handle data sharing?
Testing
Spell checkers come in many different forms, from HTTP API to command line tools. PHP-Spellchecker wants to ensure real-world usage is OK, so it contains integration tests. To run these, spellcheckers need to all be available during tests execution.
The most convenient way to do it is by using Docker and avoid polluting your local machine.
Docker
Requires docker
and docker-compose
to be installed (tested on Linux).
$ make build # build container images
$ make setup # start spellcheckers container
$ make tests-dox
You can also specify PHP version, dependency version target and if you want coverage. Coverage is only supported on PHP 8.0 for now.
$ PHP_VERSION=8.0 DEPS=LOWEST WITH_COVERAGE="true" make tests-dox
Run make help
to list all available tasks.
Locally
Todo
Environment variables
If spellcheckers execution paths are different than their default values (e.g., docker exec -ti myispell
instead of ispell
) you can override the path used in tests by redefining environment variables in the PHPUnit config file.
Contributing
Please see CONTRIBUTING.
Credits
- Inspired by php-speller, monolog and flysystem
- Philippe Segatori
- [All Contributors][link-contributors]
License
The MIT License (MIT). Please see license file for more information.
Logo: Elements taken for the final rendering are Designed by rawpixel.com / Freepik.
*Note that all licence references and agreements mentioned in the PHP-Spellchecker README section above
are relevant to that project's source code only.