1c2ed51d1SGreg Roach<?php 2c2ed51d1SGreg Roach 3c2ed51d1SGreg Roach/** 4c2ed51d1SGreg Roach * webtrees: online genealogy 5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 6c2ed51d1SGreg Roach * This program is free software: you can redistribute it and/or modify 7c2ed51d1SGreg Roach * it under the terms of the GNU General Public License as published by 8c2ed51d1SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9c2ed51d1SGreg Roach * (at your option) any later version. 10c2ed51d1SGreg Roach * This program is distributed in the hope that it will be useful, 11c2ed51d1SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12c2ed51d1SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13c2ed51d1SGreg Roach * GNU General Public License for more details. 14c2ed51d1SGreg Roach * You should have received a copy of the GNU General Public License 15c2ed51d1SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16c2ed51d1SGreg Roach */ 17c2ed51d1SGreg Roach 18c2ed51d1SGreg Roachdeclare(strict_types=1); 19c2ed51d1SGreg Roach 20c2ed51d1SGreg Roachnamespace Fisharebest\Webtrees\Elements; 21c2ed51d1SGreg Roach 22c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree; 23c2ed51d1SGreg Roach 24c2ed51d1SGreg Roachuse function strtoupper; 25c2ed51d1SGreg Roach 26c2ed51d1SGreg Roach/** 27c2ed51d1SGreg Roach * CHARACTER_SET := {Size=1:8} 28c2ed51d1SGreg Roach * [ ANSEL |UTF-8 | UNICODE | ASCII ] 29c2ed51d1SGreg Roach * A code value that represents the character set to be used to interpret this 30c2ed51d1SGreg Roach * data. Currently, the preferred character set is ANSEL, which includes ASCII 31c2ed51d1SGreg Roach * as a subset. UNICODE is not widely supported by most operating systems; 32c2ed51d1SGreg Roach * therefore, GEDCOM produced using the UNICODE character set will be limited 33c2ed51d1SGreg Roach * in its interchangeability for a while but should eventually provide the 34c2ed51d1SGreg Roach * international flexibility that is desired. See Chapter 3, starting on page 35c2ed51d1SGreg Roach * 77. 36c2ed51d1SGreg Roach * Note:The IBMPC character set is not allowed. This character set cannot be 37c2ed51d1SGreg Roach * interpreted properly without knowing which code page the sender was using. 38c2ed51d1SGreg Roach */ 39c2ed51d1SGreg Roachclass CharacterSet extends AbstractElement 40c2ed51d1SGreg Roach{ 41c2ed51d1SGreg Roach /** 42c2ed51d1SGreg Roach * Convert a value to a canonical form. 43c2ed51d1SGreg Roach * 44c2ed51d1SGreg Roach * @param string $value 45c2ed51d1SGreg Roach * 46c2ed51d1SGreg Roach * @return string 47c2ed51d1SGreg Roach */ 48c2ed51d1SGreg Roach public function canonical(string $value): string 49c2ed51d1SGreg Roach { 50c2ed51d1SGreg Roach return strtoupper(parent::canonical($value)); 51c2ed51d1SGreg Roach } 52c2ed51d1SGreg Roach 53c2ed51d1SGreg Roach /** 54c2ed51d1SGreg Roach * Create a default value for this element. 55c2ed51d1SGreg Roach * 56c2ed51d1SGreg Roach * @param Tree $tree 57c2ed51d1SGreg Roach * 58c2ed51d1SGreg Roach * @return string 59c2ed51d1SGreg Roach */ 60c2ed51d1SGreg Roach public function default(Tree $tree): string 61c2ed51d1SGreg Roach { 62c2ed51d1SGreg Roach return 'UTF-8'; 63c2ed51d1SGreg Roach } 64c2ed51d1SGreg Roach 65c2ed51d1SGreg Roach /** 66c2ed51d1SGreg Roach * A list of controlled values for this element 67c2ed51d1SGreg Roach * 68c2ed51d1SGreg Roach * @return array<int|string,string> 69c2ed51d1SGreg Roach */ 70c2ed51d1SGreg Roach public function values(): array 71c2ed51d1SGreg Roach { 72c2ed51d1SGreg Roach return [ 73c2ed51d1SGreg Roach 'UTF-8' => 'UTF-8', 74c2ed51d1SGreg Roach 'UNICODE' => 'UNICODE', 75c2ed51d1SGreg Roach 'ANSEL' => 'ANSEL', 76c2ed51d1SGreg Roach 'ASCII' => 'ASCII', 77c2ed51d1SGreg Roach ]; 78c2ed51d1SGreg Roach } 79c2ed51d1SGreg Roach} 80