Fix documentation of `make-bytevector'.
[bpt/guile.git] / libguile / bytevectors.h
CommitLineData
1ee2c72e
LC
1#ifndef SCM_BYTEVECTORS_H
2#define SCM_BYTEVECTORS_H
3
4/* Copyright (C) 2009 Free Software Foundation, Inc.
5 *
6 * This library is free software; you can redistribute it and/or
53befeb7
NJ
7 * modify it under the terms of the GNU Lesser General Public License
8 * as published by the Free Software Foundation; either version 3 of
9 * the License, or (at your option) any later version.
1ee2c72e 10 *
53befeb7
NJ
11 * This library is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
1ee2c72e
LC
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
53befeb7
NJ
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 * 02110-1301 USA
1ee2c72e
LC
20 */
21
22\f
23
24#include "libguile/__scm.h"
25
26
27/* R6RS bytevectors. */
28
29#define SCM_BYTEVECTOR_LENGTH(_bv) \
30 ((unsigned) SCM_SMOB_DATA (_bv))
31#define SCM_BYTEVECTOR_CONTENTS(_bv) \
32 (SCM_BYTEVECTOR_INLINE_P (_bv) \
33 ? (signed char *) SCM_SMOB_OBJECT_2_LOC (_bv) \
34 : (signed char *) SCM_SMOB_DATA_2 (_bv))
35
36
37SCM_API SCM scm_endianness_big;
38SCM_API SCM scm_endianness_little;
39
40SCM_API SCM scm_make_bytevector (SCM, SCM);
41SCM_API SCM scm_c_make_bytevector (unsigned);
42SCM_API SCM scm_native_endianness (void);
43SCM_API SCM scm_bytevector_p (SCM);
44SCM_API SCM scm_bytevector_length (SCM);
45SCM_API SCM scm_bytevector_eq_p (SCM, SCM);
46SCM_API SCM scm_bytevector_fill_x (SCM, SCM);
47SCM_API SCM scm_bytevector_copy_x (SCM, SCM, SCM, SCM, SCM);
48SCM_API SCM scm_bytevector_copy (SCM);
49
782a82ee
AW
50SCM_API SCM scm_uniform_array_to_bytevector (SCM);
51
1ee2c72e
LC
52SCM_API SCM scm_bytevector_to_u8_list (SCM);
53SCM_API SCM scm_u8_list_to_bytevector (SCM);
54SCM_API SCM scm_uint_list_to_bytevector (SCM, SCM, SCM);
55SCM_API SCM scm_bytevector_to_uint_list (SCM, SCM, SCM);
56SCM_API SCM scm_sint_list_to_bytevector (SCM, SCM, SCM);
57SCM_API SCM scm_bytevector_to_sint_list (SCM, SCM, SCM);
58
59SCM_API SCM scm_bytevector_u16_native_ref (SCM, SCM);
60SCM_API SCM scm_bytevector_s16_native_ref (SCM, SCM);
61SCM_API SCM scm_bytevector_u32_native_ref (SCM, SCM);
62SCM_API SCM scm_bytevector_s32_native_ref (SCM, SCM);
63SCM_API SCM scm_bytevector_u64_native_ref (SCM, SCM);
64SCM_API SCM scm_bytevector_s64_native_ref (SCM, SCM);
65SCM_API SCM scm_bytevector_u8_ref (SCM, SCM);
66SCM_API SCM scm_bytevector_s8_ref (SCM, SCM);
67SCM_API SCM scm_bytevector_uint_ref (SCM, SCM, SCM, SCM);
68SCM_API SCM scm_bytevector_sint_ref (SCM, SCM, SCM, SCM);
69SCM_API SCM scm_bytevector_u16_ref (SCM, SCM, SCM);
70SCM_API SCM scm_bytevector_s16_ref (SCM, SCM, SCM);
71SCM_API SCM scm_bytevector_u32_ref (SCM, SCM, SCM);
72SCM_API SCM scm_bytevector_s32_ref (SCM, SCM, SCM);
73SCM_API SCM scm_bytevector_u64_ref (SCM, SCM, SCM);
74SCM_API SCM scm_bytevector_s64_ref (SCM, SCM, SCM);
75SCM_API SCM scm_bytevector_u16_native_set_x (SCM, SCM, SCM);
76SCM_API SCM scm_bytevector_s16_native_set_x (SCM, SCM, SCM);
77SCM_API SCM scm_bytevector_u32_native_set_x (SCM, SCM, SCM);
78SCM_API SCM scm_bytevector_s32_native_set_x (SCM, SCM, SCM);
79SCM_API SCM scm_bytevector_u64_native_set_x (SCM, SCM, SCM);
80SCM_API SCM scm_bytevector_s64_native_set_x (SCM, SCM, SCM);
81SCM_API SCM scm_bytevector_u8_set_x (SCM, SCM, SCM);
82SCM_API SCM scm_bytevector_s8_set_x (SCM, SCM, SCM);
83SCM_API SCM scm_bytevector_uint_set_x (SCM, SCM, SCM, SCM, SCM);
84SCM_API SCM scm_bytevector_sint_set_x (SCM, SCM, SCM, SCM, SCM);
85SCM_API SCM scm_bytevector_u16_set_x (SCM, SCM, SCM, SCM);
86SCM_API SCM scm_bytevector_s16_set_x (SCM, SCM, SCM, SCM);
87SCM_API SCM scm_bytevector_u32_set_x (SCM, SCM, SCM, SCM);
88SCM_API SCM scm_bytevector_s32_set_x (SCM, SCM, SCM, SCM);
89SCM_API SCM scm_bytevector_u64_set_x (SCM, SCM, SCM, SCM);
90SCM_API SCM scm_bytevector_s64_set_x (SCM, SCM, SCM, SCM);
91SCM_API SCM scm_bytevector_ieee_single_ref (SCM, SCM, SCM);
92SCM_API SCM scm_bytevector_ieee_single_native_ref (SCM, SCM);
93SCM_API SCM scm_bytevector_ieee_single_set_x (SCM, SCM, SCM, SCM);
94SCM_API SCM scm_bytevector_ieee_single_native_set_x (SCM, SCM, SCM);
95SCM_API SCM scm_bytevector_ieee_double_ref (SCM, SCM, SCM);
96SCM_API SCM scm_bytevector_ieee_double_native_ref (SCM, SCM);
97SCM_API SCM scm_bytevector_ieee_double_set_x (SCM, SCM, SCM, SCM);
98SCM_API SCM scm_bytevector_ieee_double_native_set_x (SCM, SCM, SCM);
99SCM_API SCM scm_string_to_utf8 (SCM);
100SCM_API SCM scm_string_to_utf16 (SCM, SCM);
101SCM_API SCM scm_string_to_utf32 (SCM, SCM);
102SCM_API SCM scm_utf8_to_string (SCM);
103SCM_API SCM scm_utf16_to_string (SCM, SCM);
104SCM_API SCM scm_utf32_to_string (SCM, SCM);
105
106
107\f
108/* Internal API. */
109
110/* The threshold (in octets) under which bytevectors are stored "in-line",
111 i.e., without allocating memory beside the SMOB itself (a double cell).
112 This optimization is necessary since small bytevectors are expected to be
113 common. */
114#define SCM_BYTEVECTOR_INLINE_THRESHOLD (2 * sizeof (SCM))
115#define SCM_BYTEVECTOR_INLINEABLE_SIZE_P(_size) \
116 ((_size) <= SCM_BYTEVECTOR_INLINE_THRESHOLD)
117#define SCM_BYTEVECTOR_INLINE_P(_bv) \
118 (SCM_BYTEVECTOR_INLINEABLE_SIZE_P (SCM_BYTEVECTOR_LENGTH (_bv)))
119
120/* Hint that is passed to `scm_gc_malloc ()' and friends. */
121#define SCM_GC_BYTEVECTOR "bytevector"
122
123SCM_API void scm_init_bytevectors (void);
124
125SCM_INTERNAL scm_t_bits scm_tc16_bytevector;
126SCM_INTERNAL SCM scm_c_take_bytevector (signed char *, unsigned);
127
128#define scm_c_shrink_bytevector(_bv, _len) \
129 (SCM_BYTEVECTOR_INLINE_P (_bv) \
130 ? (_bv) \
131 : scm_i_shrink_bytevector ((_bv), (_len)))
132
133SCM_INTERNAL SCM scm_i_shrink_bytevector (SCM, unsigned);
134SCM_INTERNAL SCM scm_null_bytevector;
135
136#endif /* SCM_BYTEVECTORS_H */