mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-29 19:30:36 +02:00
* libguile/bitvectors.c: * libguile/bitvectors.h: * libguile/bytevectors.c: * libguile/bytevectors.h: * libguile/chars.c: * libguile/continuations.c: * libguile/control.c: * libguile/conv-integer.i.c: * libguile/conv-uinteger.i.c: * libguile/dynstack.c: * libguile/dynstack.h: * libguile/foreign.c: * libguile/frames.c: * libguile/frames.h: * libguile/gc-inline.h: * libguile/gc.h: * libguile/gsubr.c: * libguile/gsubr.h: * libguile/hash.c: * libguile/i18n.c: * libguile/instructions.c: * libguile/intrinsics.c: * libguile/intrinsics.h: * libguile/loader.c: * libguile/loader.h: * libguile/numbers.c: * libguile/numbers.h: * libguile/pairs.c: * libguile/ports-internal.h: * libguile/ports.c: * libguile/ports.h: * libguile/posix.c: * libguile/print.c: * libguile/print.h: * libguile/programs.c: * libguile/programs.h: * libguile/r6rs-ports.c: * libguile/random.c: * libguile/random.h: * libguile/scm.h: * libguile/socket.c: * libguile/srfi-4.c: * libguile/srfi-4.h: * libguile/stacks.c: * libguile/stime.c: * libguile/strings.c: * libguile/struct.c: * libguile/struct.h: * libguile/symbols.c: * libguile/threads.c: * libguile/threads.h: * libguile/uniform.c: * libguile/vm-engine.c: * libguile/vm.c: * libguile/vm.h: * libguile/vports.c: * test-suite/standalone/test-conversion.c: * test-suite/standalone/test-ffi-lib.c: * test-suite/standalone/test-scm-take-u8vector.c: * test-suite/standalone/test-srfi-4.c: Replace e.g. scm_t_uint8 with uint8_t.
91 lines
2.2 KiB
C
91 lines
2.2 KiB
C
/* Copyright 2014,2018
|
|
Free Software Foundation, Inc.
|
|
|
|
This file is part of Guile.
|
|
|
|
Guile is free software: you can redistribute it and/or modify it
|
|
under the terms of the GNU Lesser General Public License as published
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Guile 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 Lesser General Public
|
|
License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with Guile. If not, see
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
# include <config.h>
|
|
#endif
|
|
|
|
/* Make sure the assertions are tested. */
|
|
#undef NDEBUG
|
|
|
|
#include <libguile.h>
|
|
|
|
#include <stdio.h>
|
|
#include <assert.h>
|
|
|
|
static void
|
|
test_writable_elements ()
|
|
{
|
|
SCM elts = scm_list_4 (scm_from_int (1), scm_from_int (2),
|
|
scm_from_int (3), scm_from_int (4));
|
|
|
|
{
|
|
SCM v = scm_u32vector (elts);
|
|
size_t len;
|
|
ssize_t inc;
|
|
scm_t_array_handle h;
|
|
uint32_t *elts = scm_u32vector_writable_elements (v, &h, &len, &inc);
|
|
assert (len == 4);
|
|
assert (inc == 1);
|
|
assert (elts[0] == 1);
|
|
assert (elts[3] == 4);
|
|
scm_array_handle_release (&h);
|
|
}
|
|
|
|
{
|
|
SCM v = scm_f32vector (elts);
|
|
size_t len;
|
|
ssize_t inc;
|
|
scm_t_array_handle h;
|
|
float *elts = scm_f32vector_writable_elements (v, &h, &len, &inc);
|
|
assert (len == 4);
|
|
assert (inc == 1);
|
|
assert (elts[0] == 1.0);
|
|
assert (elts[3] == 4.0);
|
|
scm_array_handle_release (&h);
|
|
}
|
|
|
|
{
|
|
SCM v = scm_c32vector (elts);
|
|
size_t len;
|
|
ssize_t inc;
|
|
scm_t_array_handle h;
|
|
float *elts = scm_c32vector_writable_elements (v, &h, &len, &inc);
|
|
assert (len == 4);
|
|
assert (inc == 1);
|
|
assert (elts[0] == 1.0);
|
|
assert (elts[1] == 0.0);
|
|
assert (elts[6] == 4.0);
|
|
assert (elts[7] == 0.0);
|
|
scm_array_handle_release (&h);
|
|
}
|
|
}
|
|
|
|
static void
|
|
tests (void *data, int argc, char **argv)
|
|
{
|
|
test_writable_elements ();
|
|
}
|
|
|
|
int
|
|
main (int argc, char *argv[])
|
|
{
|
|
scm_boot_guile (argc, argv, tests, NULL);
|
|
return 0;
|
|
}
|