2010-12-03 05:34:57 +01:00
|
|
|
/* array.h -- the open array type for Go.
|
|
|
|
|
|
|
|
Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
Use of this source code is governed by a BSD-style
|
|
|
|
license that can be found in the LICENSE file. */
|
|
|
|
|
|
|
|
#ifndef LIBGO_ARRAY_H
|
|
|
|
#define LIBGO_ARRAY_H
|
|
|
|
|
|
|
|
/* An open array is an instance of this structure. */
|
|
|
|
|
|
|
|
struct __go_open_array
|
|
|
|
{
|
|
|
|
/* The elements of the array. In use in the compiler this is a
|
|
|
|
pointer to the element type. */
|
|
|
|
void* __values;
|
|
|
|
/* The number of elements in the array. Note that this is "int",
|
|
|
|
not "size_t". The language definition says that "int" is large
|
|
|
|
enough to hold the size of any allocated object. Using "int"
|
|
|
|
saves 8 bytes per slice header on a 64-bit system with 32-bit
|
|
|
|
ints. */
|
2012-11-01 04:02:13 +01:00
|
|
|
intgo __count;
|
2010-12-03 05:34:57 +01:00
|
|
|
/* The capacity of the array--the number of elements that can fit in
|
|
|
|
the __VALUES field. */
|
2012-11-01 04:02:13 +01:00
|
|
|
intgo __capacity;
|
2010-12-03 05:34:57 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* !defined(LIBGO_ARRAY_H) */
|