2011-06-28 11:51:03 +03:00
|
|
|
|
<?php
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* @license Dual licensed under the MIT or GPL Version 2 licenses.
|
|
|
|
|
* @package NameCaseLib
|
|
|
|
|
*/
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*/
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if (!defined('NCL_DIR'))
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 16:01:19 +03:00
|
|
|
|
define('NCL_DIR', dirname(__FILE__));
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-05 16:01:19 +03:00
|
|
|
|
require_once NCL_DIR . '/NCL.php';
|
|
|
|
|
require_once NCL_DIR . '/NCLStr.php';
|
|
|
|
|
require_once NCL_DIR . '/NCLNameCaseWord.php';
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* <b>NCL NameCase Core</b>
|
|
|
|
|
*
|
|
|
|
|
* Набор основных функций, который позволяют сделать интерфейс слонения русского и украниского языка
|
|
|
|
|
* абсолютно одинаковым. Содержит все функции для внешнего взаимодействия с библиотекой.
|
|
|
|
|
*
|
|
|
|
|
* @author Андрей Чайка <bymer3@gmail.com>
|
2011-07-11 20:56:11 +03:00
|
|
|
|
* @version 0.4.1
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* @package NameCaseLib
|
|
|
|
|
*/
|
2011-07-05 16:01:19 +03:00
|
|
|
|
class NCLNameCaseCore extends NCL
|
|
|
|
|
{
|
2011-07-10 15:21:23 +03:00
|
|
|
|
/**
|
|
|
|
|
* Версия библиотеки
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
2011-07-11 20:56:11 +03:00
|
|
|
|
protected $version = '0.4.1';
|
2011-07-10 15:21:23 +03:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Версия языкового файла
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
|
|
|
|
protected $languageBuild = '0';
|
|
|
|
|
|
2011-07-05 16:01:19 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Готовность системы:
|
|
|
|
|
* - Все слова идентифицированы (известо к какой части ФИО относится слово)
|
|
|
|
|
* - У всех слов определен пол
|
|
|
|
|
* Если все сделано стоит флаг true, при добавлении нового слова флаг сбрасывается на false
|
2011-07-05 20:22:03 +03:00
|
|
|
|
* @var bool
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
private $ready = false;
|
2011-07-05 20:22:03 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если все текущие слова было просклонены и в каждом слове уже есть результат склонения,
|
|
|
|
|
* тогда true. Если было добавлено новое слово флаг збрасывается на false
|
2011-07-05 20:22:03 +03:00
|
|
|
|
* @var bool
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
private $finished = false;
|
2011-07-05 20:22:03 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Массив содержит елементы типа NCLNameCaseWord. Это все слова которые нужно обработать и просклонять
|
2011-07-05 20:22:03 +03:00
|
|
|
|
* @var array
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
private $words = array();
|
|
|
|
|
/**
|
|
|
|
|
* Переменная, в которую заносится слово с которым сейчас идет работа
|
2011-07-05 14:32:28 +03:00
|
|
|
|
* @var string
|
|
|
|
|
*/
|
|
|
|
|
protected $workingWord = '';
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод Last() вырезает подстроки разной длины. Посколько одинаковых вызовов бывает несколько,
|
|
|
|
|
* то все результаты выполнения кешируются в этом массиве.
|
2011-07-05 14:32:28 +03:00
|
|
|
|
* @var array
|
|
|
|
|
*/
|
|
|
|
|
protected $workindLastCache = array();
|
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Номер последнего использованого правила, устанавливается методом Rule()
|
2011-07-05 14:32:28 +03:00
|
|
|
|
* @var int
|
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
private $lastRule = 0;
|
2011-07-05 14:32:28 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Массив содержит результат склонения слова - слово во всех падежах
|
2011-07-05 14:32:28 +03:00
|
|
|
|
* @var array
|
|
|
|
|
*/
|
|
|
|
|
protected $lastResult = array();
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Массив содержит информацию о том какие слова из массива <var>$this->words</var> относятся к
|
|
|
|
|
* фамилии, какие к отчеству а какие к имени. Массив нужен потому, что при добавлении слов мы не
|
|
|
|
|
* всегда знаем какая часть ФИО сейчас, поэтому после идентификации всех слов генерируется массив
|
|
|
|
|
* индексов для быстрого поиска в дальнейшем.
|
|
|
|
|
* @var array
|
|
|
|
|
*/
|
|
|
|
|
private $index = array();
|
2011-07-05 14:32:28 +03:00
|
|
|
|
|
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Метод очищает результаты последнего склонения слова. Нужен при склонении нескольких слов.
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
private function reset()
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
|
|
|
|
$this->lastRule = 0;
|
|
|
|
|
$this->lastResult = array();
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Сбрасывает все информацию на начальную. Очищает все слова добавленые в систему.
|
|
|
|
|
* После выполнения система готова работать с начала.
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-07-06 14:08:04 +03:00
|
|
|
|
*/
|
|
|
|
|
public function fullReset()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
$this->words = array();
|
|
|
|
|
$this->index = array('N' => array(), 'F' => array(), 'S' => array());
|
|
|
|
|
$this->reset();
|
|
|
|
|
$this->notReady();
|
2011-07-08 20:06:07 +03:00
|
|
|
|
return $this;
|
2011-07-05 20:22:03 +03:00
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Устанавливает флаги о том, что система не готово и слова еще не были просклонены
|
|
|
|
|
*/
|
|
|
|
|
private function notReady()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
$this->ready = false;
|
|
|
|
|
$this->finished = false;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-05 14:32:28 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Устанавливает номер последнего правила
|
|
|
|
|
* @param int $index номер правила которое нужно установить
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function Rule($index)
|
|
|
|
|
{
|
|
|
|
|
$this->lastRule = $index;
|
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Устанавливает слово текущим для работы системы. Очищает кеш слова.
|
|
|
|
|
* @param string $word слово, которое нужно установить
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function setWorkingWord($word)
|
|
|
|
|
{
|
|
|
|
|
//Сбрасываем настройки
|
|
|
|
|
$this->reset();
|
|
|
|
|
//Ставим слово
|
|
|
|
|
$this->workingWord = $word;
|
|
|
|
|
//Чистим кеш
|
|
|
|
|
$this->workindLastCache = array();
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Если <var>$stopAfter</var> = 0, тогда вырезает $length последних букв с текущего слова (<var>$this->workingWord</var>)
|
|
|
|
|
* Если нет, тогда вырезает <var>$stopAfter</var> букв начиная от <var>$length</var> с конца
|
|
|
|
|
* @param int $length количество букв с конца
|
|
|
|
|
* @param int $stopAfter количество букв которые нужно вырезать (0 - все)
|
|
|
|
|
* @return string требуемая подстрока
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function Last($length=1, $stopAfter=0)
|
|
|
|
|
{
|
|
|
|
|
//Сколько букв нужно вырезать все или только часть
|
|
|
|
|
if (!$stopAfter)
|
|
|
|
|
{
|
|
|
|
|
$cut = $length;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$cut = $stopAfter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Проверяем кеш
|
|
|
|
|
if (!isset($this->workindLastCache[$length][$stopAfter]))
|
|
|
|
|
{
|
2011-07-05 16:01:19 +03:00
|
|
|
|
$this->workindLastCache[$length][$stopAfter] = NCLStr::substr($this->workingWord, -$length, $cut);
|
2011-07-05 14:32:28 +03:00
|
|
|
|
}
|
|
|
|
|
return $this->workindLastCache[$length][$stopAfter];
|
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
2011-07-05 14:32:28 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Над текущим словом (<var>$this->workingWord</var>) выполняются правила в порядке указаном в <var>$rulesArray</var>.
|
|
|
|
|
* <var>$gender</var> служит для указания какие правила использовать мужские ('man') или женские ('woman')
|
|
|
|
|
* @param string $gender - префикс мужских/женских правил
|
|
|
|
|
* @param array $rulesArray - массив, порядок выполнения правил
|
|
|
|
|
* @return boolean если правило было задествовано, тогда true, если нет - тогда false
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function RulesChain($gender, $rulesArray)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
foreach ($rulesArray as $ruleID)
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$ruleMethod = $gender . 'Rule' . $ruleID;
|
|
|
|
|
if ($this->$ruleMethod())
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Если <var>$string</var> строка, тогда проверяется входит ли буква <var>$letter</var> в строку <var>$string</var>
|
|
|
|
|
* Если <var>$string</var> массив, тогда проверяется входит ли строка <var>$letter</var> в массив <var>$string</var>
|
|
|
|
|
* @param string $letter буква или строка, которую нужно искать
|
|
|
|
|
* @param mixed $string строка или массив, в котором нужно искать
|
|
|
|
|
* @return bool true если искомое значение найдено
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function in($letter, $string)
|
|
|
|
|
{
|
2011-07-05 14:32:28 +03:00
|
|
|
|
//Если второй параметр массив
|
|
|
|
|
if (is_array($string))
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 14:32:28 +03:00
|
|
|
|
return in_array($letter, $string);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-07-05 16:01:19 +03:00
|
|
|
|
if (!$letter or NCLStr::strpos($string, $letter) === false)
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-05 14:32:28 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Функция проверяет, входит ли имя <var>$nameNeedle</var> в перечень имен <var>$names</var>.
|
|
|
|
|
* @param string $nameNeedle - имя которое нужно найти
|
|
|
|
|
* @param array $names - перечень имен в котором нужно найти имя
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function inNames($nameNeedle, $names)
|
|
|
|
|
{
|
|
|
|
|
if (!is_array($names))
|
|
|
|
|
{
|
|
|
|
|
$names = array($names);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach ($names as $name)
|
|
|
|
|
{
|
2011-07-05 16:01:19 +03:00
|
|
|
|
if (NCLStr::strtolower($nameNeedle) == NCLStr::strtolower($name))
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет слово <var>$word</var>, удаляя из него <var>$replaceLast</var> последних букв
|
|
|
|
|
* и добавляя в каждый падеж окончание из массива <var>$endings</var>.
|
|
|
|
|
* @param string $word слово, к которому нужно добавить окончания
|
|
|
|
|
* @param array $endings массив окончаний
|
|
|
|
|
* @param int $replaceLast сколько последних букв нужно убрать с начального слова
|
2011-07-05 14:32:28 +03:00
|
|
|
|
*/
|
|
|
|
|
protected function wordForms($word, $endings, $replaceLast=0)
|
|
|
|
|
{
|
|
|
|
|
//Создаем массив с именительный падежом
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$result = array($this->workingWord);
|
2011-07-05 14:32:28 +03:00
|
|
|
|
//Убираем в окончание лишние буквы
|
2011-07-05 16:01:19 +03:00
|
|
|
|
$word = NCLStr::substr($word, 0, NCLStr::strlen($word) - $replaceLast);
|
2011-07-05 14:32:28 +03:00
|
|
|
|
|
|
|
|
|
//Добавляем окончания
|
|
|
|
|
for ($padegIndex = 1; $padegIndex < $this->CaseCount; $padegIndex++)
|
|
|
|
|
{
|
|
|
|
|
$result[$padegIndex] = $word . $endings[$padegIndex - 1];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$this->lastResult = $result;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$firstname</var> и пометкой, что это имя
|
|
|
|
|
* @param string $firstname имя
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setFirstName($firstname="")
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if ($firstname)
|
|
|
|
|
{
|
|
|
|
|
$index = count($this->words);
|
|
|
|
|
$this->words[$index] = new NCLNameCaseWord($firstname);
|
|
|
|
|
$this->words[$index]->setNamePart('N');
|
|
|
|
|
$this->notReady();
|
|
|
|
|
}
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$secondname</var> и пометкой, что это фамилия
|
|
|
|
|
* @param string $secondname фамилия
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setSecondName($secondname="")
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if ($secondname)
|
|
|
|
|
{
|
|
|
|
|
$index = count($this->words);
|
|
|
|
|
$this->words[$index] = new NCLNameCaseWord($secondname);
|
|
|
|
|
$this->words[$index]->setNamePart('S');
|
|
|
|
|
$this->notReady();
|
|
|
|
|
}
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$fathername</var> и пометкой, что это отчество
|
|
|
|
|
* @param string $fathername отчество
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setFatherName($fathername="")
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if ($fathername)
|
|
|
|
|
{
|
|
|
|
|
$index = count($this->words);
|
|
|
|
|
$this->words[$index] = new NCLNameCaseWord($fathername);
|
|
|
|
|
$this->words[$index]->setNamePart('F');
|
|
|
|
|
$this->notReady();
|
|
|
|
|
}
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Всем словам устанавливается пол, который может иметь следующие значения
|
2011-07-05 16:01:19 +03:00
|
|
|
|
* - 0 - не определено
|
2011-06-28 11:51:03 +03:00
|
|
|
|
* - NCL::$MAN - мужчина
|
|
|
|
|
* - NCL::$WOMAN - женщина
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* @param int $gender пол, который нужно установить
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setGender($gender=0)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
foreach ($this->words as $word)
|
|
|
|
|
{
|
|
|
|
|
$word->setTrueGender($gender);
|
|
|
|
|
}
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В система заносится сразу фамилия, имя, отчество
|
|
|
|
|
* @param string $secondName фамилия
|
|
|
|
|
* @param string $firstName имя
|
|
|
|
|
* @param string $fatherName отчество
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setFullName($secondName="", $firstName="", $fatherName="")
|
|
|
|
|
{
|
|
|
|
|
$this->setFirstName($firstName);
|
|
|
|
|
$this->setSecondName($secondName);
|
|
|
|
|
$this->setFatherName($fatherName);
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$firstname</var> и пометкой, что это имя
|
|
|
|
|
* @param string $firstname имя
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setName($firstname="")
|
|
|
|
|
{
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this->setFirstName($firstname);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$secondname</var> и пометкой, что это фамилия
|
|
|
|
|
* @param string $secondname фамилия
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function setLastName($secondname="")
|
|
|
|
|
{
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this->setSecondName($secondname);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* В массив <var>$this->words</var> добавляется новый об’єкт класса NCLNameCaseWord
|
|
|
|
|
* со словом <var>$secondname</var> и пометкой, что это фамилия
|
|
|
|
|
* @param string $secondname фамилия
|
2011-07-08 20:55:22 +03:00
|
|
|
|
* @return NCLNameCaseCore
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-06 14:08:04 +03:00
|
|
|
|
public function setSirName($secondname="")
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-08 20:04:44 +03:00
|
|
|
|
return $this->setSecondName($secondname);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Если слово <var>$word</var> не идентифицировано, тогда определяется это имя, фамилия или отчество
|
|
|
|
|
* @param NCLNameCaseWord $word слово которое нужно идентифицировать
|
|
|
|
|
*/
|
|
|
|
|
private function prepareNamePart(NCLNameCaseWord $word)
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
if (!$word->getNamePart())
|
|
|
|
|
{
|
|
|
|
|
$this->detectNamePart($word);
|
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Проверяет все ли слова идентифицированы, если нет тогда для каждого определяется это имя, фамилия или отчество
|
|
|
|
|
*/
|
|
|
|
|
private function prepareAllNameParts()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
foreach ($this->words as $word)
|
|
|
|
|
{
|
|
|
|
|
$this->prepareNamePart($word);
|
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Определяет пол для слова <var>$word</var>
|
|
|
|
|
* @param NCLNameCaseWord $word слово для которого нужно определить пол
|
|
|
|
|
*/
|
|
|
|
|
private function prepareGender(NCLNameCaseWord $word)
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
if (!$word->isGenderSolved())
|
|
|
|
|
{
|
|
|
|
|
$namePart = $word->getNamePart();
|
|
|
|
|
switch ($namePart)
|
|
|
|
|
{
|
|
|
|
|
case 'N': $this->GenderByFirstName($word);
|
|
|
|
|
break;
|
|
|
|
|
case 'F': $this->GenderByFatherName($word);
|
|
|
|
|
break;
|
|
|
|
|
case 'S': $this->GenderBySecondName($word);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Для всех слов проверяет определен ли пол, если нет - определяет его
|
|
|
|
|
* После этого расчитывает пол для всех слов и устанавливает такой пол всем словам
|
|
|
|
|
* @return bool был ли определен пол
|
|
|
|
|
*/
|
|
|
|
|
private function solveGender()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
//Ищем, может гдето пол уже установлен
|
|
|
|
|
foreach ($this->words as $word)
|
|
|
|
|
{
|
|
|
|
|
if ($word->isGenderSolved())
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($word->gender());
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Если нет тогда определяем у каждого слова и потом сумируем
|
|
|
|
|
$man = 0;
|
|
|
|
|
$woman = 0;
|
|
|
|
|
|
|
|
|
|
foreach ($this->words as $word)
|
|
|
|
|
{
|
|
|
|
|
$this->prepareGender($word);
|
|
|
|
|
$gender = $word->getGender();
|
|
|
|
|
$man+=$gender[NCL::$MAN];
|
|
|
|
|
$woman+=$gender[NCL::$WOMAN];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($man > $woman)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender(NCL::$MAN);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$this->setGender(NCL::$WOMAN);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Генерируется массив, который содержит информацию о том какие слова из массива <var>$this->words</var> относятся к
|
|
|
|
|
* фамилии, какие к отчеству а какие к имени. Массив нужен потому, что при добавлении слов мы не
|
|
|
|
|
* всегда знаем какая часть ФИО сейчас, поэтому после идентификации всех слов генерируется массив
|
|
|
|
|
* индексов для быстрого поиска в дальнейшем.
|
|
|
|
|
*/
|
|
|
|
|
private function generateIndex()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
$this->index = array('N' => array(), 'S' => array(), 'F' => array());
|
|
|
|
|
foreach ($this->words as $index => $word)
|
|
|
|
|
{
|
|
|
|
|
$namepart = $word->getNamePart();
|
|
|
|
|
$this->index[$namepart][] = $index;
|
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Выполнет все необходимые подготовления для склонения.
|
|
|
|
|
* Все слова идентфицируются. Определяется пол.
|
|
|
|
|
* Обновляется индекс.
|
|
|
|
|
*/
|
|
|
|
|
private function prepareEverything()
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
if (!$this->ready)
|
|
|
|
|
{
|
|
|
|
|
$this->prepareAllNameParts();
|
|
|
|
|
$this->solveGender();
|
|
|
|
|
$this->generateIndex();
|
|
|
|
|
$this->ready = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* По указаным словам определяется пол человека:
|
|
|
|
|
* - 0 - не определено
|
|
|
|
|
* - NCL::$MAN - мужчина
|
|
|
|
|
* - NCL::$WOMAN - женщина
|
|
|
|
|
* @return int текущий пол человека
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function genderAutoDetect()
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->prepareEverything();
|
|
|
|
|
if (isset($this->words[0]))
|
|
|
|
|
{
|
|
|
|
|
return $this->words[0]->gender();
|
|
|
|
|
}
|
|
|
|
|
return false;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Разбивает строку <var>$fullname</var> на слова и возвращает формат в котором записано имя
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param string $fullname строка, для которой необходимо определить формат
|
2011-07-06 14:25:28 +03:00
|
|
|
|
* @return array формат в котором записано имя массив типа <var>$this->words</var>
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-06 14:51:42 +03:00
|
|
|
|
private function splitFullName($fullname)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
$fullname = trim($fullname);
|
|
|
|
|
$list = explode(' ', $fullname);
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
|
|
|
|
foreach ($list as $word)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->words[] = new NCLNameCaseWord($word);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
2011-07-05 14:32:28 +03:00
|
|
|
|
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->prepareEverything();
|
|
|
|
|
$formatArr = array();
|
|
|
|
|
|
|
|
|
|
foreach ($this->words as $word)
|
|
|
|
|
{
|
|
|
|
|
$formatArr[] = $word->getNamePart();
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:25:28 +03:00
|
|
|
|
return $this->words;
|
2011-07-05 20:22:03 +03:00
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:51:42 +03:00
|
|
|
|
/**
|
|
|
|
|
* Разбивает строку <var>$fullname</var> на слова и возвращает формат в котором записано имя
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param string $fullname строка, для которой необходимо определить формат
|
|
|
|
|
* @return string формат в котором записано имя
|
|
|
|
|
*/
|
|
|
|
|
public function getFullNameFormat($fullname)
|
|
|
|
|
{
|
|
|
|
|
$this->fullReset();
|
|
|
|
|
$words = $this->splitFullName($fullname);
|
|
|
|
|
$format = '';
|
|
|
|
|
foreach ($words as $word)
|
|
|
|
|
{
|
|
|
|
|
$format .= $word->getNamePart() . ' ';
|
|
|
|
|
}
|
|
|
|
|
return $format;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет слово <var>$word</var> по нужным правилам в зависимости от пола и типа слова
|
|
|
|
|
* @param NCLNameCaseWord $word слово, которое нужно просклонять
|
|
|
|
|
*/
|
|
|
|
|
private function WordCase(NCLNameCaseWord $word)
|
2011-07-05 20:22:03 +03:00
|
|
|
|
{
|
|
|
|
|
$gender = ($word->gender() == NCL::$MAN ? 'man' : 'woman');
|
|
|
|
|
|
|
|
|
|
$namepart = '';
|
|
|
|
|
|
|
|
|
|
switch ($word->getNamePart())
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-06 14:25:28 +03:00
|
|
|
|
case 'F': $namepart = 'Father';
|
|
|
|
|
break;
|
|
|
|
|
case 'N': $namepart = 'First';
|
|
|
|
|
break;
|
|
|
|
|
case 'S': $namepart = 'Second';
|
|
|
|
|
break;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
|
|
|
|
$method = $gender . $namepart . 'Name';
|
|
|
|
|
|
|
|
|
|
$this->setWorkingWord($word->getWord());
|
|
|
|
|
|
|
|
|
|
if ($this->$method())
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$word->setNameCases($this->lastResult);
|
|
|
|
|
$word->setRule($this->lastRule);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$word->setNameCases(array_fill(0, $this->CaseCount, $word->getWord()));
|
|
|
|
|
$word->setRule(-1);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Производит склонение всех слов, который хранятся в массиве <var>$this->words</var>
|
|
|
|
|
*/
|
|
|
|
|
private function AllWordCases()
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if (!$this->finished)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->prepareEverything();
|
|
|
|
|
|
|
|
|
|
foreach ($this->words as $word)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->WordCase($word);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
|
|
|
|
$this->finished = true;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Если указан номер падежа <var>$number</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param NCLNameCaseWord $word слово для котрого нужно вернуть падеж
|
|
|
|
|
* @param int $number номер падежа, который нужно вернуть
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
|
|
|
|
*/
|
2011-07-05 20:22:03 +03:00
|
|
|
|
private function getWordCase(NCLNameCaseWord $word, $number=null)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$cases = $word->getNameCases();
|
|
|
|
|
if (is_null($number) or $number < 0 or $number > ($this->CaseCount - 1))
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return $cases;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return $cases[$number];
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-05 20:22:03 +03:00
|
|
|
|
/**
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если нужно было просклонять несколько слов, то их необходимо собрать в одну строку.
|
|
|
|
|
* Эта функция собирает все слова указаные в <var>$indexArray</var> в одну строку.
|
|
|
|
|
* @param array $indexArray индексы слов, которые необходимо собрать вместе
|
|
|
|
|
* @param int $number номер падежа
|
|
|
|
|
* @return mixed либо массив со всеми падежами, либо строка с одним падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
2011-07-05 20:22:03 +03:00
|
|
|
|
private function getCasesConnected($indexArray, $number=null)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$readyArr = array();
|
|
|
|
|
foreach ($indexArray as $index)
|
|
|
|
|
{
|
|
|
|
|
$readyArr[] = $this->getWordCase($this->words[$index], $number);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$all = count($readyArr);
|
|
|
|
|
if ($all)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if (is_array($readyArr[0]))
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
//Масив нужно скелить каждый падеж
|
|
|
|
|
$resultArr = array();
|
|
|
|
|
for ($case = 0; $case < $this->CaseCount; $case++)
|
|
|
|
|
{
|
|
|
|
|
$tmp = array();
|
|
|
|
|
for ($i = 0; $i < $all; $i++)
|
|
|
|
|
{
|
|
|
|
|
$tmp[] = $readyArr[$i][$case];
|
|
|
|
|
}
|
|
|
|
|
$resultArr[$case] = implode(' ', $tmp);
|
|
|
|
|
}
|
|
|
|
|
return $resultArr;
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return implode(' ', $readyArr);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return '';
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит имя в нужный падеж.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$number</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param int $number номер падежа
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function getFirstNameCase($number=null)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->AllWordCases();
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return $this->getCasesConnected($this->index['N'], $number);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит фамилию в нужный падеж.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$number</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param int $number номер падежа
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function getSecondNameCase($number=null)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->AllWordCases();
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return $this->getCasesConnected($this->index['S'], $number);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит отчество в нужный падеж.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$number</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param int $number номер падежа
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function getFatherNameCase($number=null)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->AllWordCases();
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
2011-07-05 20:22:03 +03:00
|
|
|
|
return $this->getCasesConnected($this->index['F'], $number);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит имя <var>$firstName</var> в нужный падеж <var>$CaseNumber</var> по правилам пола <var>$gender</var>.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$CaseNumber</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param string $firstName имя, которое нужно просклонять
|
|
|
|
|
* @param int $CaseNumber номер падежа
|
|
|
|
|
* @param int $gender пол, который нужно использовать
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function qFirstName($firstName, $CaseNumber=null, $gender=0)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->fullReset();
|
|
|
|
|
$this->setFirstName($firstName);
|
|
|
|
|
if ($gender)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($gender);
|
|
|
|
|
}
|
2011-06-28 11:51:03 +03:00
|
|
|
|
return $this->getFirstNameCase($CaseNumber);
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит фамилию <var>$secondName</var> в нужный падеж <var>$CaseNumber</var> по правилам пола <var>$gender</var>.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$CaseNumber</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param string $secondName фамилия, которую нужно просклонять
|
|
|
|
|
* @param int $CaseNumber номер падежа
|
|
|
|
|
* @param int $gender пол, который нужно использовать
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function qSecondName($secondName, $CaseNumber=null, $gender=0)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->fullReset();
|
|
|
|
|
$this->setSecondName($secondName);
|
|
|
|
|
if ($gender)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($gender);
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-28 11:51:03 +03:00
|
|
|
|
return $this->getSecondNameCase($CaseNumber);
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Функция ставит отчество <var>$fatherName</var> в нужный падеж <var>$CaseNumber</var> по правилам пола <var>$gender</var>.
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*
|
2011-07-06 14:08:04 +03:00
|
|
|
|
* Если указан номер падежа <var>$CaseNumber</var>, тогда возвращается строка с таким номером падежа,
|
|
|
|
|
* если нет, тогда возвращается массив со всеми падежами текущего слова.
|
|
|
|
|
* @param string $fatherName отчество, которое нужно просклонять
|
|
|
|
|
* @param int $CaseNumber номер падежа
|
|
|
|
|
* @param int $gender пол, который нужно использовать
|
|
|
|
|
* @return mixed массив или строка с нужным падежом
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function qFatherName($fatherName, $CaseNumber=null, $gender=0)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->fullReset();
|
|
|
|
|
$this->setFatherName($fatherName);
|
|
|
|
|
if ($gender)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($gender);
|
|
|
|
|
}
|
2011-06-28 11:51:03 +03:00
|
|
|
|
return $this->getFatherNameCase($CaseNumber);
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет текущие слова во все падежи и форматирует слово по шаблону <var>$format</var>
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param string $format строка формат
|
|
|
|
|
* @return array массив со всеми падежами
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function getFormattedArray($format)
|
|
|
|
|
{
|
|
|
|
|
if (is_array($format))
|
|
|
|
|
{
|
|
|
|
|
return $this->getFormattedArrayHard($format);
|
|
|
|
|
}
|
2011-07-05 20:22:03 +03:00
|
|
|
|
|
|
|
|
|
$length = NCLStr::strlen($format);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
$result = array();
|
|
|
|
|
$cases = array();
|
2011-07-06 14:51:42 +03:00
|
|
|
|
$cases['S'] = $this->getCasesConnected($this->index['S']);
|
|
|
|
|
$cases['N'] = $this->getCasesConnected($this->index['N']);
|
|
|
|
|
$cases['F'] = $this->getCasesConnected($this->index['F']);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
|
|
|
|
for ($curCase = 0; $curCase < $this->CaseCount; $curCase++)
|
|
|
|
|
{
|
|
|
|
|
$line = "";
|
|
|
|
|
for ($i = 0; $i < $length; $i++)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$symbol = NCLStr::substr($format, $i, 1);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
if ($symbol == 'S')
|
|
|
|
|
{
|
|
|
|
|
$line.=$cases['S'][$curCase];
|
|
|
|
|
}
|
|
|
|
|
elseif ($symbol == 'N')
|
|
|
|
|
{
|
|
|
|
|
$line.=$cases['N'][$curCase];
|
|
|
|
|
}
|
|
|
|
|
elseif ($symbol == 'F')
|
|
|
|
|
{
|
|
|
|
|
$line.=$cases['F'][$curCase];
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$line.=$symbol;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$result[] = $line;
|
|
|
|
|
}
|
|
|
|
|
return $result;
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет текущие слова во все падежи и форматирует слово по шаблону <var>$format</var>
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param array $format массив с форматом
|
|
|
|
|
* @return array массив со всеми падежами
|
|
|
|
|
*/
|
2011-06-28 11:51:03 +03:00
|
|
|
|
public function getFormattedArrayHard($format)
|
|
|
|
|
{
|
2011-07-05 14:32:28 +03:00
|
|
|
|
|
2011-06-28 11:51:03 +03:00
|
|
|
|
$result = array();
|
|
|
|
|
$cases = array();
|
2011-07-06 14:25:28 +03:00
|
|
|
|
foreach ($format as $word)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
2011-07-06 14:25:28 +03:00
|
|
|
|
$cases[] = $word->getNameCases();
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for ($curCase = 0; $curCase < $this->CaseCount; $curCase++)
|
|
|
|
|
{
|
|
|
|
|
$line = "";
|
|
|
|
|
foreach ($cases as $value)
|
|
|
|
|
{
|
2011-07-06 14:25:28 +03:00
|
|
|
|
$line.=$value[$curCase] . ' ';
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
$result[] = trim($line);
|
|
|
|
|
}
|
|
|
|
|
return $result;
|
|
|
|
|
}
|
2011-07-06 14:25:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет текущие слова в падеж <var>$caseNum</var> и форматирует слово по шаблону <var>$format</var>
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param array $format массив с форматом
|
|
|
|
|
* @return string строка в нужном падеже
|
|
|
|
|
*/
|
2011-06-28 11:51:03 +03:00
|
|
|
|
public function getFormattedHard($caseNum=0, $format=array())
|
|
|
|
|
{
|
2011-07-05 14:32:28 +03:00
|
|
|
|
$result = "";
|
2011-07-06 14:25:28 +03:00
|
|
|
|
foreach ($format as $word)
|
2011-07-05 14:32:28 +03:00
|
|
|
|
{
|
2011-07-06 14:25:28 +03:00
|
|
|
|
$cases = $word->getNameCases();
|
|
|
|
|
$result.= $cases[$caseNum] . ' ';
|
2011-07-05 14:32:28 +03:00
|
|
|
|
}
|
|
|
|
|
return trim($result);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
2011-07-05 14:32:28 +03:00
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет текущие слова в падеж <var>$caseNum</var> и форматирует слово по шаблону <var>$format</var>
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param string $format строка с форматом
|
|
|
|
|
* @return string строка в нужном падеже
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function getFormatted($caseNum=0, $format="S N F")
|
|
|
|
|
{
|
2011-07-08 20:55:22 +03:00
|
|
|
|
$this->AllWordCases();
|
2011-07-05 20:22:03 +03:00
|
|
|
|
//Если не указан падеж используем другую функцию
|
2011-07-08 20:55:22 +03:00
|
|
|
|
if (is_null($caseNum) or !$caseNum)
|
2011-06-28 11:51:03 +03:00
|
|
|
|
{
|
|
|
|
|
return $this->getFormattedArray($format);
|
|
|
|
|
}
|
|
|
|
|
//Если формат сложный
|
|
|
|
|
elseif (is_array($format))
|
|
|
|
|
{
|
|
|
|
|
return $this->getFormattedHard($caseNum, $format);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$length = NCLStr::strlen($format);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
$result = "";
|
|
|
|
|
for ($i = 0; $i < $length; $i++)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$symbol = NCLStr::substr($format, $i, 1);
|
2011-06-28 11:51:03 +03:00
|
|
|
|
if ($symbol == 'S')
|
|
|
|
|
{
|
|
|
|
|
$result.=$this->getSecondNameCase($caseNum);
|
|
|
|
|
}
|
|
|
|
|
elseif ($symbol == 'N')
|
|
|
|
|
{
|
|
|
|
|
$result.=$this->getFirstNameCase($caseNum);
|
|
|
|
|
}
|
|
|
|
|
elseif ($symbol == 'F')
|
|
|
|
|
{
|
|
|
|
|
$result.=$this->getFatherNameCase($caseNum);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$result.=$symbol;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return $result;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет фамилию <var>$secondName</var>, имя <var>$firstName</var>, отчество <var>$fatherName</var>
|
|
|
|
|
* в падеж <var>$caseNum</var> по правилам пола <var>$gender</var> и форматирует результат по шаблону <var>$format</var>
|
|
|
|
|
* <b>Формат:</b>
|
|
|
|
|
* - S - Фамилия
|
|
|
|
|
* - N - Имя
|
|
|
|
|
* - F - Отчество
|
|
|
|
|
* @param string $secondName фамилия
|
|
|
|
|
* @param string $firstName имя
|
|
|
|
|
* @param string $fatherName отчество
|
|
|
|
|
* @param int $gender пол
|
|
|
|
|
* @param int $caseNum номер падежа
|
|
|
|
|
* @param string $format формат
|
|
|
|
|
* @return mixed либо массив со всеми падежами, либо строка
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function qFullName($secondName="", $firstName="", $fatherName="", $gender=0, $caseNum=0, $format="S N F")
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->fullReset();
|
|
|
|
|
$this->setFirstName($firstName);
|
|
|
|
|
$this->setSecondName($secondName);
|
|
|
|
|
$this->setFatherName($fatherName);
|
|
|
|
|
if ($gender)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($gender);
|
|
|
|
|
}
|
2011-06-28 11:51:03 +03:00
|
|
|
|
|
|
|
|
|
return $this->getFormatted($caseNum, $format);
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-06 14:08:04 +03:00
|
|
|
|
/**
|
|
|
|
|
* Склоняет ФИО <var>$fullname</var> в падеж <var>$caseNum</var> по правилам пола <var>$gender</var>.
|
|
|
|
|
* Возвращает результат в таком же формате, как он и был.
|
|
|
|
|
* @param string $fullname ФИО
|
|
|
|
|
* @param int $caseNum номер падежа
|
|
|
|
|
* @param int $gender пол человека
|
|
|
|
|
* @return mixed либо массив со всеми падежами, либо строка
|
2011-06-28 11:51:03 +03:00
|
|
|
|
*/
|
|
|
|
|
public function q($fullname, $caseNum=null, $gender=null)
|
|
|
|
|
{
|
2011-07-05 20:22:03 +03:00
|
|
|
|
$this->fullReset();
|
2011-06-28 11:51:03 +03:00
|
|
|
|
$format = $this->splitFullName($fullname);
|
2011-07-05 20:22:03 +03:00
|
|
|
|
if ($gender)
|
|
|
|
|
{
|
|
|
|
|
$this->setGender($gender);
|
|
|
|
|
}
|
2011-07-08 20:55:22 +03:00
|
|
|
|
|
2011-06-28 11:51:03 +03:00
|
|
|
|
return $this->getFormatted($caseNum, $format);
|
|
|
|
|
}
|
2011-07-08 15:52:33 +03:00
|
|
|
|
|
2011-07-07 00:01:30 +03:00
|
|
|
|
/**
|
|
|
|
|
* Определяет пол человека по ФИО
|
|
|
|
|
* @param string $fullname ФИО
|
|
|
|
|
* @return int пол человека
|
|
|
|
|
*/
|
|
|
|
|
public function genderDetect($fullname)
|
|
|
|
|
{
|
|
|
|
|
$this->fullReset();
|
|
|
|
|
$this->splitFullName($fullname);
|
|
|
|
|
return $this->genderAutoDetect();
|
|
|
|
|
}
|
2011-07-08 15:52:33 +03:00
|
|
|
|
|
2011-07-08 14:08:48 +03:00
|
|
|
|
/**
|
|
|
|
|
* Возвращает внутренний массив $this->words каждая запись имеет тип NCLNameCaseWord
|
|
|
|
|
* @return array Массив всех слов в системе
|
|
|
|
|
*/
|
|
|
|
|
public function getWordsArray()
|
|
|
|
|
{
|
2011-07-08 15:52:33 +03:00
|
|
|
|
return $this->words;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2011-07-12 18:59:05 +03:00
|
|
|
|
* Функция пытается применить цепочку правил для мужских имен
|
2011-07-08 15:52:33 +03:00
|
|
|
|
* @return boolean true - если было использовано правило из списка, false - если правило не было найденым
|
|
|
|
|
*/
|
|
|
|
|
protected function manFirstName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2011-07-12 18:59:05 +03:00
|
|
|
|
* Функция пытается применить цепочку правил для женских имен
|
2011-07-08 15:52:33 +03:00
|
|
|
|
* @return boolean true - если было использовано правило из списка, false - если правило не было найденым
|
|
|
|
|
*/
|
|
|
|
|
protected function womanFirstName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2011-07-12 18:59:05 +03:00
|
|
|
|
* Функция пытается применить цепочку правил для мужских фамилий
|
2011-07-08 15:52:33 +03:00
|
|
|
|
* @return boolean true - если было использовано правило из списка, false - если правило не было найденым
|
|
|
|
|
*/
|
|
|
|
|
protected function manSecondName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2011-07-12 18:59:05 +03:00
|
|
|
|
* Функция пытается применить цепочку правил для женских фамилий
|
2011-07-08 15:52:33 +03:00
|
|
|
|
* @return boolean true - если было использовано правило из списка, false - если правило не было найденым
|
|
|
|
|
*/
|
|
|
|
|
protected function womanSecondName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Функция склоняет мужский отчества
|
|
|
|
|
* @return boolean true - если слово было успешно изменено, false - если не получилось этого сделать
|
|
|
|
|
*/
|
|
|
|
|
protected function manFatherName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Функция склоняет женские отчества
|
|
|
|
|
* @return boolean true - если слово было успешно изменено, false - если не получилось этого сделать
|
|
|
|
|
*/
|
|
|
|
|
protected function womanFatherName()
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Определение пола по правилам имен
|
|
|
|
|
* @param NCLNameCaseWord $word обьект класса слов, для которого нужно определить пол
|
|
|
|
|
*/
|
|
|
|
|
protected function GenderByFirstName(NCLNameCaseWord $word)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Определение пола по правилам фамилий
|
|
|
|
|
* @param NCLNameCaseWord $word обьект класса слов, для которого нужно определить пол
|
|
|
|
|
*/
|
|
|
|
|
protected function GenderBySecondName(NCLNameCaseWord $word)
|
|
|
|
|
{
|
|
|
|
|
|
2011-07-08 14:08:48 +03:00
|
|
|
|
}
|
2011-07-08 15:52:33 +03:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Определение пола по правилам отчеств
|
|
|
|
|
* @param NCLNameCaseWord $word обьект класса слов, для которого нужно определить пол
|
|
|
|
|
*/
|
|
|
|
|
protected function GenderByFatherName(NCLNameCaseWord $word)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Идетифицирует слово определяе имя это, или фамилия, или отчество
|
|
|
|
|
* - <b>N</b> - имя
|
|
|
|
|
* - <b>S</b> - фамилия
|
|
|
|
|
* - <b>F</b> - отчество
|
|
|
|
|
* @param NCLNameCaseWord $word обьект класса слов, который необходимо идентифицировать
|
|
|
|
|
*/
|
|
|
|
|
protected function detectNamePart(NCLNameCaseWord $word)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
2011-07-10 15:21:23 +03:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает версию библиотеки
|
|
|
|
|
* @return string версия библиотеки
|
|
|
|
|
*/
|
|
|
|
|
public function version()
|
|
|
|
|
{
|
|
|
|
|
return $this->version;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает версию использованого языкового файла
|
|
|
|
|
* @return string версия языкового файла
|
|
|
|
|
*/
|
|
|
|
|
public function languageVersion()
|
|
|
|
|
{
|
|
|
|
|
return $this->languageBuild;
|
|
|
|
|
}
|
2011-07-08 15:52:33 +03:00
|
|
|
|
|
2011-06-28 11:51:03 +03:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-05 16:01:19 +03:00
|
|
|
|
?>
|