1
0
mirror of https://github.com/golang/go synced 2024-10-04 11:11:21 -06:00
go/src/runtime/array.c

176 lines
3.2 KiB
C
Raw Normal View History

2008-08-27 18:28:30 -06:00
// 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.
#include "runtime.h"
static int32 debug = 0;
2008-12-18 21:06:28 -07:00
// newarray(nel int, cap int, width int) (ary []any);
2008-08-27 18:28:30 -06:00
void
2008-12-18 21:06:28 -07:00
sys·newarray(uint32 nel, uint32 cap, uint32 width, Array ret)
2008-08-27 18:28:30 -06:00
{
uint64 size;
if(cap < nel)
cap = nel;
size = cap*width;
2008-12-18 21:06:28 -07:00
ret.nel = nel;
ret.cap = cap;
ret.array = mal(size);
2008-08-27 18:28:30 -06:00
FLUSH(&ret);
2008-08-27 18:28:30 -06:00
if(debug) {
prints("newarray: nel=");
sys·printint(nel);
prints("; cap=");
sys·printint(cap);
prints("; width=");
sys·printint(width);
prints("; ret=");
2008-12-18 23:17:05 -07:00
sys·printarray(ret);
2008-08-27 18:28:30 -06:00
prints("\n");
}
}
static void
throwslice(uint32 lb, uint32 hb, uint32 n)
{
prints("slice[");
sys·printint(lb);
prints(":");
sys·printint(hb);
prints("] of [");
sys·printint(n);
prints("] array\n");
throw("array slice");
}
2008-12-18 21:06:28 -07:00
// arraysliced(old []any, lb int, hb int, width int) (ary []any);
2008-08-27 18:28:30 -06:00
void
2008-12-18 21:06:28 -07:00
sys·arraysliced(Array old, uint32 lb, uint32 hb, uint32 width, Array ret)
2008-08-27 18:28:30 -06:00
{
2008-12-18 21:06:28 -07:00
if(hb > old.cap || lb > hb) {
2008-08-27 18:28:30 -06:00
if(debug) {
2008-12-18 21:06:28 -07:00
prints("sys·arraysliced: old=");
2008-12-18 23:17:05 -07:00
sys·printarray(old);
2008-08-27 18:28:30 -06:00
prints("; lb=");
sys·printint(lb);
prints("; hb=");
sys·printint(hb);
prints("; width=");
sys·printint(width);
prints("\n");
prints("oldarray: nel=");
2008-12-18 21:06:28 -07:00
sys·printint(old.nel);
2008-08-27 18:28:30 -06:00
prints("; cap=");
2008-12-18 21:06:28 -07:00
sys·printint(old.cap);
2008-08-27 18:28:30 -06:00
prints("\n");
}
2008-12-18 21:06:28 -07:00
throwslice(lb, hb, old.cap);
2008-08-27 18:28:30 -06:00
}
// new array is inside old array
2008-12-18 21:06:28 -07:00
ret.nel = hb-lb;
ret.cap = old.cap - lb;
ret.array = old.array + lb*width;
2008-08-27 18:28:30 -06:00
FLUSH(&ret);
2008-08-27 18:28:30 -06:00
if(debug) {
2008-12-18 21:06:28 -07:00
prints("sys·arraysliced: old=");
2008-12-18 23:17:05 -07:00
sys·printarray(old);
2008-08-27 18:28:30 -06:00
prints("; lb=");
sys·printint(lb);
prints("; hb=");
sys·printint(hb);
prints("; width=");
sys·printint(width);
prints("; ret=");
2008-12-18 23:17:05 -07:00
sys·printarray(ret);
2008-08-27 18:28:30 -06:00
prints("\n");
}
}
2008-12-18 21:06:28 -07:00
// arrayslices(old *any, nel int, lb int, hb int, width int) (ary []any);
2008-08-27 18:28:30 -06:00
void
2008-12-18 21:06:28 -07:00
sys·arrayslices(byte* old, uint32 nel, uint32 lb, uint32 hb, uint32 width, Array ret)
2008-08-27 18:28:30 -06:00
{
if(hb > nel || lb > hb) {
if(debug) {
prints("sys·arrayslices: old=");
sys·printpointer(old);
prints("; nel=");
sys·printint(nel);
prints("; lb=");
sys·printint(lb);
prints("; hb=");
sys·printint(hb);
prints("; width=");
sys·printint(width);
prints("\n");
}
throwslice(lb, hb, nel);
2008-08-27 18:28:30 -06:00
}
// new array is inside old array
2008-12-18 21:06:28 -07:00
ret.nel = hb-lb;
ret.cap = nel-lb;
ret.array = old + lb*width;
2008-08-27 18:28:30 -06:00
FLUSH(&ret);
2008-08-27 18:28:30 -06:00
if(debug) {
prints("sys·arrayslices: old=");
sys·printpointer(old);
prints("; nel=");
sys·printint(nel);
prints("; lb=");
sys·printint(lb);
prints("; hb=");
sys·printint(hb);
prints("; width=");
sys·printint(width);
prints("; ret=");
2008-12-18 23:17:05 -07:00
sys·printarray(ret);
2008-08-27 18:28:30 -06:00
prints("\n");
}
}
2008-12-18 21:06:28 -07:00
// arrays2d(old *any, nel int) (ary []any)
2008-08-27 18:28:30 -06:00
void
2008-12-18 21:06:28 -07:00
sys·arrays2d(byte* old, uint32 nel, Array ret)
2008-08-27 18:28:30 -06:00
{
// new dope to old array
2008-12-18 21:06:28 -07:00
ret.nel = nel;
ret.cap = nel;
ret.array = old;
2008-08-27 18:28:30 -06:00
FLUSH(&ret);
2008-08-27 18:28:30 -06:00
if(debug) {
prints("sys·arrays2d: old=");
sys·printpointer(old);
prints("; ret=");
2008-12-18 23:17:05 -07:00
sys·printarray(ret);
2008-08-27 18:28:30 -06:00
prints("\n");
}
}
void
2008-12-18 23:17:05 -07:00
sys·printarray(Array a)
{
prints("[");
2008-12-18 23:17:05 -07:00
sys·printint(a.nel);
2008-12-18 21:06:28 -07:00
prints("/");
2008-12-18 23:17:05 -07:00
sys·printint(a.cap);
prints("]");
2008-12-18 23:17:05 -07:00
sys·printpointer(a.array);
}