. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; /** * All family members keep their original surname */ class DefaultSurnameTradition implements SurnameTraditionInterface { /** Extract a GIVN from a NAME */ protected const REGEX_GIVN = '~^(?[^/ ]+)~'; /** Extract a SPFX and SURN from a NAME */ protected const REGEX_SPFX_SURN = '~(?/(?[a-z’\']{0,4}(?: [a-z’\']{1,4})*) ?(?[^/]*)/)~'; /** Extract a simple SURN from a NAME */ protected const REGEX_SURN = '~(?/(?[^/]+)/)~'; /** Extract two Spanish/Portuguese SURNs from a NAME */ protected const REGEX_SURNS = '~/(?[^ /]+)(?: | y |/ /|/ y /)(?[^ /]+)/~'; /** * Does this surname tradition change surname at marriage? * * @return bool */ public function hasMarriedNames(): bool { return false; } /** * Does this surname tradition use surnames? * * @return bool */ public function hasSurnames(): bool { return true; } /** * 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 { 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 { 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 { return [ 'NAME' => '//', ]; } }