. */ namespace Fisharebest\Webtrees\Module\BatchUpdate; use Fisharebest\Webtrees\Filter; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Module\BatchUpdateModule; /** * Class BatchUpdateMarriedNamesPlugin Batch Update plugin: add missing 2 _MARNM records */ class BatchUpdateMarriedNamesPlugin extends BatchUpdateBasePlugin { /** @var string User option: add or replace husband’s surname */ private $surname; /** * User-friendly name for this plugin. * * @return string */ public function getName() { return I18N::translate('Add missing married names'); } /** * Description / help-text for this plugin. * * @return string */ public function getDescription() { return I18N::translate('You can make it easier to search for married women by recording their married name. However not all women take their husband’s surname, so beware of introducing incorrect information into your database.'); } /** * Does this record need updating? * * @param string $xref * @param string $gedrec * * @return bool */ public function doesRecordNeedUpdate($xref, $gedrec) { return preg_match('/^1 SEX F/m', $gedrec) && preg_match('/^1 NAME /m', $gedrec) && self::surnamesToAdd($xref, $gedrec); } /** * Apply any updates to this record * * @param string $xref * @param string $gedrec * * @return string */ public function updateRecord($xref, $gedrec) { global $WT_TREE; $SURNAME_TRADITION = $WT_TREE->getPreference('SURNAME_TRADITION'); preg_match('/^1 NAME (.*)/m', $gedrec, $match); $wife_name = $match[1]; $married_names = array(); foreach (self::surnamesToAdd($xref, $gedrec) as $surname) { switch ($this->surname) { case 'add': $married_names[] = "\n2 _MARNM " . str_replace('/', '', $wife_name) . ' /' . $surname . '/'; break; case 'replace': if ($SURNAME_TRADITION === 'polish') { $surname = preg_replace(array('/ski$/', '/cki$/', '/dzki$/'), array('ska', 'cka', 'dzka'), $surname); } $married_names[] = "\n2 _MARNM " . preg_replace('!/.*/!', '/' . $surname . '/', $wife_name); break; } } return preg_replace('/(^1 NAME .*([\r\n]+[2-9].*)*)/m', '\\1' . implode('', $married_names), $gedrec, 1); } /** * Generate a list of married surnames that are not already present. * * @param string $xref * @param string $gedrec * * @return string[] */ private function surnamesToAdd($xref, $gedrec) { $wife_surnames = self::surnames($xref, $gedrec); $husb_surnames = array(); $missing_surnames = array(); preg_match_all('/^1 FAMS @(.+)@/m', $gedrec, $fmatch); foreach ($fmatch[1] as $famid) { $famrec = BatchUpdateModule::getLatestRecord($famid, 'FAM'); if (preg_match('/^1 MARR/m', $famrec) && preg_match('/^1 HUSB @(.+)@/m', $famrec, $hmatch)) { $husbrec = BatchUpdateModule::getLatestRecord($hmatch[1], 'INDI'); $husb_surnames = array_unique(array_merge($husb_surnames, self::surnames($hmatch[1], $husbrec))); } } foreach ($husb_surnames as $husb_surname) { if (!in_array($husb_surname, $wife_surnames)) { $missing_surnames[] = $husb_surname; } } return $missing_surnames; } /** * Extract a list of surnames from a GEDCOM record. * * @param string $xref * @param string $gedrec * * @return string[] */ private function surnames($xref, $gedrec) { if (preg_match_all('/^(?:1 NAME|2 _MARNM) .*\/(.+)\//m', $gedrec, $match)) { return $match[1]; } else { return array(); } } /** * Process the user-supplied options. */ public function getOptions() { parent::getOptions(); $this->surname = Filter::get('surname', 'add|replace', 'replace'); } /** * Generate a form to ask the user for options. * * @return string */ public function getOptionsForm() { return '
' . '' . '
' . '' . '
' . parent::getOptionsForm(); } }