451 lines
12 KiB
PHP
451 lines
12 KiB
PHP
<?php
|
|
|
|
namespace Safe;
|
|
|
|
use Safe\Exceptions\PspellException;
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param string $word The added word.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_add_to_personal(int $dictionary_link, string $word): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_add_to_personal($dictionary_link, $word);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param string $word The added word.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_add_to_session(int $dictionary_link, string $word): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_add_to_session($dictionary_link, $word);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_clear_session(int $dictionary_link): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_clear_session($dictionary_link);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Create a config used to open a dictionary.
|
|
*
|
|
* pspell_config_create has a very similar syntax to
|
|
* pspell_new. In fact, using
|
|
* pspell_config_create immediately followed by
|
|
* pspell_new_config will produce the exact same result.
|
|
* However, after creating a new config, you can also use
|
|
* pspell_config_* functions before calling
|
|
* pspell_new_config to take advantage of some
|
|
* advanced functionality.
|
|
*
|
|
* For more information and examples, check out inline manual pspell
|
|
* website:http://aspell.net/.
|
|
*
|
|
* @param string $language The language parameter is the language code which consists of the
|
|
* two letter ISO 639 language code and an optional two letter ISO
|
|
* 3166 country code after a dash or underscore.
|
|
* @param string $spelling The spelling parameter is the requested spelling for languages
|
|
* with more than one spelling such as English. Known values are
|
|
* 'american', 'british', and 'canadian'.
|
|
* @param string $jargon The jargon parameter contains extra information to distinguish
|
|
* two different words lists that have the same language and
|
|
* spelling parameters.
|
|
* @param string $encoding The encoding parameter is the encoding that words are expected to
|
|
* be in. Valid values are 'utf-8', 'iso8859-*', 'koi8-r',
|
|
* 'viscii', 'cp1252', 'machine unsigned 16', 'machine unsigned
|
|
* 32'. This parameter is largely untested, so be careful when
|
|
* using.
|
|
* @return int Returns a pspell config identifier.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_create(string $language, string $spelling = null, string $jargon = null, string $encoding = null): int
|
|
{
|
|
error_clear_last();
|
|
if ($encoding !== null) {
|
|
$result = \pspell_config_create($language, $spelling, $jargon, $encoding);
|
|
} elseif ($jargon !== null) {
|
|
$result = \pspell_config_create($language, $spelling, $jargon);
|
|
} elseif ($spelling !== null) {
|
|
$result = \pspell_config_create($language, $spelling);
|
|
} else {
|
|
$result = \pspell_config_create($language);
|
|
}
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
|
|
/**
|
|
* This function is
|
|
* currently not documented; only its argument list is available.
|
|
*
|
|
*
|
|
* @param int $conf
|
|
* @param string $directory
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_data_dir(int $conf, string $directory): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_data_dir($conf, $directory);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* This function is
|
|
* currently not documented; only its argument list is available.
|
|
*
|
|
*
|
|
* @param int $conf
|
|
* @param string $directory
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_dict_dir(int $conf, string $directory): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_dict_dir($conf, $directory);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param int $n Words less than n characters will be skipped.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_ignore(int $dictionary_link, int $n): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_ignore($dictionary_link, $n);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param int $mode The mode parameter is the mode in which spellchecker will work.
|
|
* There are several modes available:
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_FAST - Fast mode (least number of
|
|
* suggestions)
|
|
*
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_NORMAL - Normal mode (more suggestions)
|
|
*
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_BAD_SPELLERS - Slow mode (a lot of
|
|
* suggestions)
|
|
*
|
|
*
|
|
*
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_mode(int $dictionary_link, int $mode): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_mode($dictionary_link, $mode);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Set a file that contains personal wordlist. The personal wordlist will be
|
|
* loaded and used in addition to the standard one after you call
|
|
* pspell_new_config. The file is also the file where
|
|
* pspell_save_wordlist will save personal wordlist to.
|
|
*
|
|
* pspell_config_personal should be used on a config
|
|
* before calling pspell_new_config.
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param string $file The personal wordlist. If the file does not exist, it will be created.
|
|
* The file should be writable by whoever PHP runs as (e.g. nobody).
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_personal(int $dictionary_link, string $file): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_personal($dictionary_link, $file);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Set a file that contains replacement pairs.
|
|
*
|
|
* The replacement pairs improve the quality of the spellchecker. When a word
|
|
* is misspelled, and a proper suggestion was not found in the list,
|
|
* pspell_store_replacement can be used to store a
|
|
* replacement pair and then pspell_save_wordlist to
|
|
* save the wordlist along with the replacement pairs.
|
|
*
|
|
* pspell_config_repl should be used on a config
|
|
* before calling pspell_new_config.
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param string $file The file should be writable by whoever PHP runs as (e.g. nobody).
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_repl(int $dictionary_link, string $file): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_repl($dictionary_link, $file);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* This function determines whether run-together words will be treated as
|
|
* legal compounds. That is, "thecat" will be a legal compound, although
|
|
* there should be a space between the two words. Changing this setting only
|
|
* affects the results returned by pspell_check;
|
|
* pspell_suggest will still return suggestions.
|
|
*
|
|
* pspell_config_runtogether should be used on a config
|
|
* before calling pspell_new_config.
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param bool $flag TRUE if run-together words should be treated as legal compounds,
|
|
* FALSE otherwise.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_runtogether(int $dictionary_link, bool $flag): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_runtogether($dictionary_link, $flag);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* pspell_config_save_repl determines whether
|
|
* pspell_save_wordlist will save the replacement pairs
|
|
* along with the wordlist. Usually there is no need to use this function
|
|
* because if pspell_config_repl is used, the
|
|
* replacement pairs will be saved by
|
|
* pspell_save_wordlist anyway, and if it is not,
|
|
* the replacement pairs will not be saved.
|
|
*
|
|
* pspell_config_save_repl should be used on a config
|
|
* before calling pspell_new_config.
|
|
*
|
|
* @param int $dictionary_link
|
|
* @param bool $flag TRUE if replacement pairs should be saved, FALSE otherwise.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_config_save_repl(int $dictionary_link, bool $flag): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_config_save_repl($dictionary_link, $flag);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $config The config parameter is the one returned by
|
|
* pspell_config_create when the config was created.
|
|
* @return int Returns a dictionary link identifier on success.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_new_config(int $config): int
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_new_config($config);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
|
|
/**
|
|
* pspell_new opens up a new dictionary and
|
|
* returns the dictionary link identifier for use in other pspell
|
|
* functions.
|
|
*
|
|
* For more information and examples, check out inline manual pspell
|
|
* website:http://aspell.net/.
|
|
*
|
|
* @param string $language The language parameter is the language code which consists of the
|
|
* two letter ISO 639 language code and an optional two letter ISO
|
|
* 3166 country code after a dash or underscore.
|
|
* @param string $spelling The spelling parameter is the requested spelling for languages
|
|
* with more than one spelling such as English. Known values are
|
|
* 'american', 'british', and 'canadian'.
|
|
* @param string $jargon The jargon parameter contains extra information to distinguish
|
|
* two different words lists that have the same language and
|
|
* spelling parameters.
|
|
* @param string $encoding The encoding parameter is the encoding that words are expected to
|
|
* be in. Valid values are 'utf-8', 'iso8859-*', 'koi8-r',
|
|
* 'viscii', 'cp1252', 'machine unsigned 16', 'machine unsigned
|
|
* 32'. This parameter is largely untested, so be careful when
|
|
* using.
|
|
* @param int $mode The mode parameter is the mode in which spellchecker will work.
|
|
* There are several modes available:
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_FAST - Fast mode (least number of
|
|
* suggestions)
|
|
*
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_NORMAL - Normal mode (more suggestions)
|
|
*
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_BAD_SPELLERS - Slow mode (a lot of
|
|
* suggestions)
|
|
*
|
|
*
|
|
*
|
|
*
|
|
* PSPELL_RUN_TOGETHER - Consider run-together words
|
|
* as legal compounds. That is, "thecat" will be a legal compound,
|
|
* although there should be a space between the two words. Changing this
|
|
* setting only affects the results returned by
|
|
* pspell_check; pspell_suggest
|
|
* will still return suggestions.
|
|
*
|
|
*
|
|
*
|
|
* Mode is a bitmask constructed from different constants listed above.
|
|
* However, PSPELL_FAST,
|
|
* PSPELL_NORMAL and
|
|
* PSPELL_BAD_SPELLERS are mutually exclusive, so you
|
|
* should select only one of them.
|
|
* @return int Returns the dictionary link identifier on success.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_new(string $language, string $spelling = null, string $jargon = null, string $encoding = null, int $mode = 0): int
|
|
{
|
|
error_clear_last();
|
|
if ($mode !== 0) {
|
|
$result = \pspell_new($language, $spelling, $jargon, $encoding, $mode);
|
|
} elseif ($encoding !== null) {
|
|
$result = \pspell_new($language, $spelling, $jargon, $encoding);
|
|
} elseif ($jargon !== null) {
|
|
$result = \pspell_new($language, $spelling, $jargon);
|
|
} elseif ($spelling !== null) {
|
|
$result = \pspell_new($language, $spelling);
|
|
} else {
|
|
$result = \pspell_new($language);
|
|
}
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link A dictionary link identifier opened with
|
|
* pspell_new_personal.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_save_wordlist(int $dictionary_link): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_save_wordlist($dictionary_link);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
*
|
|
* @param int $dictionary_link A dictionary link identifier, opened with
|
|
* pspell_new_personal
|
|
* @param string $misspelled The misspelled word.
|
|
* @param string $correct The fixed spelling for the misspelled word.
|
|
* @throws PspellException
|
|
*
|
|
*/
|
|
function pspell_store_replacement(int $dictionary_link, string $misspelled, string $correct): void
|
|
{
|
|
error_clear_last();
|
|
$result = \pspell_store_replacement($dictionary_link, $misspelled, $correct);
|
|
if ($result === false) {
|
|
throw PspellException::createFromPhpError();
|
|
}
|
|
}
|