diff options
| author | Bdale Garbee <bdale@gag.com> | 2018-02-12 16:38:57 -0700 | 
|---|---|---|
| committer | Bdale Garbee <bdale@gag.com> | 2018-02-12 16:38:57 -0700 | 
| commit | ee79a205e118ea8730a02cc327d8fb79cc5f74ff (patch) | |
| tree | be0b0c9fbccaa84acadb1d18688aae9b8db3e048 /src/scheme/ao_scheme_int.c | |
| parent | 365eee3ebfe73204033089b363687228f97e5d98 (diff) | |
| parent | 78a90fc760b88ab66c5c238289afc38356e29d8a (diff) | |
Merge branch 'master' of ssh://git.gag.com/scm/git/fw/altos
Diffstat (limited to 'src/scheme/ao_scheme_int.c')
| -rw-r--r-- | src/scheme/ao_scheme_int.c | 87 | 
1 files changed, 0 insertions, 87 deletions
| diff --git a/src/scheme/ao_scheme_int.c b/src/scheme/ao_scheme_int.c deleted file mode 100644 index 01b571c0..00000000 --- a/src/scheme/ao_scheme_int.c +++ /dev/null @@ -1,87 +0,0 @@ -/* - * Copyright © 2016 Keith Packard <keithp@keithp.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, but - * WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU - * General Public License for more details. - */ - -#include "ao_scheme.h" - -void -ao_scheme_int_write(ao_poly p, bool write) -{ -	int i = ao_scheme_poly_int(p); -	(void) write; -	printf("%d", i); -} - -#ifdef AO_SCHEME_FEATURE_BIGINT - -int32_t -ao_scheme_poly_integer(ao_poly p, bool *fail) -{ -	if (fail) -		*fail = false; -	switch (ao_scheme_poly_base_type(p)) { -	case AO_SCHEME_INT: -		return ao_scheme_poly_int(p); -	case AO_SCHEME_BIGINT: -		return ao_scheme_poly_bigint(p)->value; -	} -	if (fail) -		*fail = true; -	return 0; -} - -ao_poly -ao_scheme_integer_poly(int32_t p) -{ -	struct ao_scheme_bigint	*bi; - -	if (AO_SCHEME_MIN_INT <= p && p <= AO_SCHEME_MAX_INT) -		return ao_scheme_int_poly(p); -	bi = ao_scheme_alloc(sizeof (struct ao_scheme_bigint)); -	bi->value = p; -	return ao_scheme_bigint_poly(bi); -} - -static void bigint_mark(void *addr) -{ -	(void) addr; -} - -static int bigint_size(void *addr) -{ -	if (!addr) -		return 0; -	return sizeof (struct ao_scheme_bigint); -} - -static void bigint_move(void *addr) -{ -	(void) addr; -} - -const struct ao_scheme_type ao_scheme_bigint_type = { -	.mark = bigint_mark, -	.size = bigint_size, -	.move = bigint_move, -	.name = "bigint", -}; - -void -ao_scheme_bigint_write(ao_poly p, bool write) -{ -	struct ao_scheme_bigint	*bi = ao_scheme_poly_bigint(p); - -	(void) write; -	printf("%d", bi->value); -} -#endif /* AO_SCHEME_FEATURE_BIGINT */ | 
