. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; /** * Children take their father’s surname. Wives take their husband’s surname. Surnames are inflected to indicate an individual’s sex. */ class PolishSurnameTradition extends PaternalSurnameTradition { // Inflect a surname for females private const INFLECT_FEMALE = [ 'cki\b' => 'cka', 'dzki\b' => 'dzka', 'ski\b' => 'ska', 'żki\b' => 'żka', ]; // Inflect a surname for males private const INFLECT_MALE = [ 'cka\b' => 'cki', 'dzka\b' => 'dzki', 'ska\b' => 'ski', 'żka\b' => 'żki', ]; /** * What names are given to a new child * * @param string $father_name A GEDCOM NAME * @param string $mother_name A GEDCOM NAME * @param string $child_sex M, F or U * * @return array Associative array of GEDCOM name parts (SURN, _MARNM, etc.) */ public function newChildNames(string $father_name, string $mother_name, string $child_sex): array { if (preg_match(self::REGEX_SURN, $father_name, $match)) { if ($child_sex === 'F') { return array_filter([ 'NAME' => $this->inflect($match['NAME'], self::INFLECT_FEMALE), 'SURN' => $this->inflect($match['SURN'], self::INFLECT_MALE), ]); } return array_filter([ 'NAME' => $this->inflect($match['NAME'], self::INFLECT_MALE), 'SURN' => $this->inflect($match['SURN'], self::INFLECT_MALE), ]); } return [ 'NAME' => '//', ]; } /** * What names are given to a new parent * * @param string $child_name A GEDCOM NAME * @param string $parent_sex M, F or U * * @return array Associative array of GEDCOM name parts (SURN, _MARNM, etc.) */ public function newParentNames(string $child_name, string $parent_sex): array { if ($parent_sex === 'M' && preg_match(self::REGEX_SURN, $child_name, $match)) { return array_filter([ 'NAME' => $this->inflect($match['NAME'], self::INFLECT_MALE), 'SURN' => $this->inflect($match['SURN'], self::INFLECT_MALE), ]); } return [ 'NAME' => '//', ]; } /** * What names are given to a new spouse * * @param string $spouse_name A GEDCOM NAME * @param string $spouse_sex M, F or U * * @return array Associative array of GEDCOM name parts (SURN, _MARNM, etc.) */ public function newSpouseNames(string $spouse_name, string $spouse_sex): array { if ($spouse_sex === 'F' && preg_match(self::REGEX_SURN, $spouse_name, $match)) { return [ 'NAME' => '//', '_MARNM' => $this->inflect($match['NAME'], self::INFLECT_FEMALE), ]; } return [ 'NAME' => '//', ]; } }