summaryrefslogblamecommitdiff
path: root/zap/source/any/mem/utf8enc.c
blob: 04febb27183c57bab12a038ea37ff3077e18985d (plain) (tree)















































                                                                                                                     
/*
	Copyright 2022-2023 Gabriel Jensen.
	This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
	If a copy of the MPL was not distributed with this file, You can obtain one at <https://mozilla.org/MPL/2.0>.
*/

#include <zap/mem.h>

void zap_utf8enc(zap_chr8 * const _dest,zap_chr02 const * const _src) {
	zap_chr8 *        dest;
	zap_chr02 const * src;
	for (dest = _dest,src = _src;;++src) {
		zap_chr02 const chr = *src;
		if (chr > 0xFFFFu) { /* Four octets. */
			*dest = 0xF0u + (chr >> 0x12u);
			++dest;
			*dest = 0x80u + (chr >> 0xCu & 0x3Fu);
			++dest;
			*dest = 0x80u + (chr >> 0x6u & 0x3Fu);
			++dest;
			*dest = 0x80u + (chr & 0x3Fu);
			++dest;
			continue;
		}
		if (chr >= 0x7FFu) { /* Three octets. */
			*dest = 0xE0u + (zap_chr8)(chr >> 0xCu);
			++dest;
			*dest = 0x80u + (zap_chr8)(chr >> 0x6u & 0x3Fu);
			++dest;
			*dest = 0x80u + (zap_chr8)(chr & 0x3Fu);
			++dest;
			continue;
		}
		if (chr >= 0x7Fu) { /* Two octets. */
			*dest = 0xC0u + (zap_chr8)(chr >> 0x6u);
			++dest;
			*dest = 0x80u + (zap_chr8)(chr & 0x3Fu);
			++dest;
			continue;
		}
		/* One octet. */
		*dest = chr;
		++dest;
		if (chr == 0x0u) {
			break;
		}
	}
}