11c6adce8SGreg Roach<?php 21c6adce8SGreg Roach 31c6adce8SGreg Roach/** 41c6adce8SGreg Roach * webtrees: online genealogy 5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 61c6adce8SGreg Roach * This program is free software: you can redistribute it and/or modify 71c6adce8SGreg Roach * it under the terms of the GNU General Public License as published by 81c6adce8SGreg Roach * the Free Software Foundation, either version 3 of the License, or 91c6adce8SGreg Roach * (at your option) any later version. 101c6adce8SGreg Roach * This program is distributed in the hope that it will be useful, 111c6adce8SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 121c6adce8SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 131c6adce8SGreg Roach * GNU General Public License for more details. 141c6adce8SGreg Roach * You should have received a copy of the GNU General Public License 151c6adce8SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 161c6adce8SGreg Roach */ 171c6adce8SGreg Roach 181c6adce8SGreg Roachdeclare(strict_types=1); 191c6adce8SGreg Roach 201c6adce8SGreg Roachnamespace Fisharebest\Webtrees\Encodings; 211c6adce8SGreg Roach 221c6adce8SGreg Roach/** 231c6adce8SGreg Roach * Convert between UTF-8 and another encoding. 241c6adce8SGreg Roach */ 251c6adce8SGreg Roachinterface EncodingInterface 261c6adce8SGreg Roach{ 271c6adce8SGreg Roach // Concrete classes should re-define this. Use the ICONV name, where possible. 281c6adce8SGreg Roach //public const NAME = '????'; 291c6adce8SGreg Roach 301c6adce8SGreg Roach /** 311c6adce8SGreg Roach * Convert a string from UTF-8 encoding to another encoding. 321c6adce8SGreg Roach * 331c6adce8SGreg Roach * @param string $text 341c6adce8SGreg Roach * 351c6adce8SGreg Roach * @return string 361c6adce8SGreg Roach */ 371c6adce8SGreg Roach public function fromUtf8(string $text): string; 381c6adce8SGreg Roach 391c6adce8SGreg Roach /** 401c6adce8SGreg Roach * Convert a string from another encoding to UTF-8 encoding. 411c6adce8SGreg Roach * 421c6adce8SGreg Roach * @param string $text 431c6adce8SGreg Roach * 441c6adce8SGreg Roach * @return string 451c6adce8SGreg Roach */ 461c6adce8SGreg Roach public function toUtf8(string $text): string; 471c6adce8SGreg Roach 481c6adce8SGreg Roach /** 491c6adce8SGreg Roach * When reading multi-byte encodings using a stream, we must avoid incomplete characters. 501c6adce8SGreg Roach * 511c6adce8SGreg Roach * @param string $text 521c6adce8SGreg Roach * 531c6adce8SGreg Roach * @return int 541c6adce8SGreg Roach */ 551c6adce8SGreg Roach public function convertibleBytes(string $text): int; 561c6adce8SGreg Roach} 57