madeitbelgium / spintax
Generate multiple artikels based on one text.
Fund package maintenance!
madeitbelgium
Installs: 2 062
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 3
Forks: 9
Open Issues: 1
Requires
- php: >=5.6
- illuminate/support: *
Requires (Dev)
- php-coveralls/php-coveralls: ~2.1
- phpunit/phpunit: 7.*|6.*|8.*|9.*
README
With this (Laravel) package you can create multiple articles based on a single text. A forked and extended version of https://github.com/chilloutdevelopment/ChillDevSpintax
Installation
Require this package in your composer.json
and update composer.
"madeitbelgium/spintax": "~1.0"
Documentation
Usage
Get a random spin
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; Spintax::parse('Your {text|content} here.')->generate();
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; $spintax = Spintax::parse('Schrödinger’s Cat is {dead|alive}.'); $string = $spintax->generate();
Get all possible spins:
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; Spintax::parse('Your {text|content} here.')->getAll();
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; $spintax = Spintax::parse('Schrödinger’s Cat is {dead|alive}.'); $strings = $spintax->getAll();
Other examples
But there is much more that than that in our library. First of all nested structures are supported:
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; $spintax = Spintax::parse('I {love {PHP|Java|C|C++|JavaScript|Python}|hate Ruby}.'); $string = $spintax->generate();
Still not finished! With our brilliant library you can detect the path used to generate given variant and re-use it later:
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; $path = []; $spintax = Spintax::parse('I {love {PHP|Java|C|C++|JavaScript|Python}|hate Ruby}.'); // since $path is empty, random values will be used for missing indices and $path will be filled with them $string = $spintax->generate($path); // from now you can use $path to re-create the same combination // all these calls will keep returning same string value $spintax->generate($path); $spintax->generate($path); $spintax->generate($path); $spintax->generate($path); // this will force generating "I love Java." $path = [0, 1]; $spintax->generate($path);
Paths are counted from 0, each entry is next step.
You can also use partial paths to define just the starting path and all missing parts will be choosen randomly:
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; $path = [0]; $spintax = Spintax::parse('I {love {PHP|Java|C|C++|JavaScript|Python}|hate Ruby}.'); // this will generate one of "I love {}." variants $string = $spintax->generate($path);
For all this there is a shortcut method Parser::replicate()
(you can use comma-separated number in a single string as second argument in this shortcut method):
use MadeITBelgium\Spintax\SpintaxFacade as Spintax; echo Spintax::replicate('I {love {PHP|Java|C|C++|JavaScript|Python}|hate Ruby}.', '0,0');
The complete documentation can be found at: http://www.madeit.be/
Support
Support github or mail: tjebbe.lievens@madeit.be
Contributing
Please try to follow the psr-2 coding style guide. http://www.php-fig.org/psr/psr-2/
License
This package is licensed under LGPL. You are free to use it in personal and commercial projects. The code can be forked and modified, but the original copyright author should always be included!