. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; use Fisharebest\Webtrees\Individual; /** * Children take their mother’s surname. */ class MatrilinealSurnameTradition extends DefaultSurnameTradition { /** * What name is given to a new child * * @param Individual|null $father * @param Individual|null $mother * @param string $sex * * @return array */ public function newChildNames(?Individual $father, ?Individual $mother, string $sex): array { if (preg_match(self::REGEX_SPFX_SURN, $this->extractName($mother), $match)) { $name = $match['NAME']; $spfx = $match['SPFX']; $surn = $match['SURN']; return [ $this->buildName($name, ['TYPE' => 'birth', 'SPFX' => $spfx, 'SURN' => $surn]), ]; } return parent::newChildNames($father, $mother, $sex); } /** * What name is given to a new parent * * @param Individual $child * @param string $sex * * @return array */ public function newParentNames(Individual $child, string $sex): array { if ($sex === 'F' && preg_match(self::REGEX_SPFX_SURN, $this->extractName($child), $match)) { $name = $match['NAME']; $spfx = $match['SPFX']; $surn = $match['SURN']; return [ $this->buildName($name, ['TYPE' => 'birth', 'SPFX' => $spfx, 'SURN' => $surn]), ]; } return parent::newParentNames($child, $sex); } }