shithub: rgbds

ref: e3d355d9762b5f50697274b25b685a0e3c16981a
dir: /src/asm/util.c/

View raw version
/*
 * This file is part of RGBDS.
 *
 * Copyright (c) 1997-2019, Carsten Sorensen and RGBDS contributors.
 *
 * SPDX-License-Identifier: MIT
 */

#include <ctype.h>
#include <stdint.h>

#include "asm/main.h"
#include "asm/util.h"
#include "asm/warning.h"

#include "extern/utf8decoder.h"

/*
 * Calculate the hash value for a string.
 * Uses the djb2 algorithm (xor version).
 * http://www.cse.yorku.ca/~oz/hash.html
 */
uint32_t calchash(const char *s)
{
	uint32_t hash = 5381;

	while (*s != 0)
		hash = (hash * 33) ^ (*s++);

	return hash;
}

char const *print(int c)
{
	static char buf[5]; /* '\xNN' + '\0' */

	if (c == EOF)
		return "EOF";

	if (isprint(c)) {
		buf[0] = c;
		buf[1] = '\0';
		return buf;
	}

	buf[0] = '\\';
	switch (c) {
	case '\n':
		buf[1] = 'n';
		break;
	case '\r':
		buf[1] = 'r';
		break;
	case '\t':
		buf[1] = 't';
		break;

	default: /* Print as hex */
		buf[1] = 'x';
		sprintf(&buf[2], "%02hhx", c);
		return buf;
	}
	buf[2] = '\0';
	return buf;
}

size_t readUTF8Char(uint8_t *dest, char const *src)
{
	uint32_t state = 0;
	uint32_t codep;
	size_t i = 0;

	for (;;) {
		if (decode(&state, &codep, src[i]) == 1)
			return 0;

		dest[i] = src[i];
		i++;

		if (state == 0)
			return i;
	}
}