xref: /webtrees/app/Encodings/EncodingInterface.php (revision d11be7027e34e3121be11cc025421873364403f9)
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