. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; /** * Children take their father’s surname. */ class PatrilinealSurnameTradition extends DefaultSurnameTradition { /** * 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 string[] 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_SPFX_SURN, $father_name, $match)) { return array_filter([ 'NAME' => $match['NAME'], 'SPFX' => $match['SPFX'], 'SURN' => $match['SURN'], ]); } 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 string[] 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_SPFX_SURN, $child_name, $match)) { return array_filter([ 'NAME' => $match['NAME'], 'SPFX' => $match['SPFX'], 'SURN' => $match['SURN'], ]); } return [ 'NAME' => '//', ]; } /** * @param string $name A name * @param string[] $inflections A list of inflections * * @return string An inflected name */ protected function inflect($name, $inflections): string { foreach ($inflections as $from => $to) { $name = preg_replace('~' . $from . '~u', $to, $name); } return $name; } }