array: replace make() with the new init syntax
parent
f23948010a
commit
83552a0d58
|
@ -26,18 +26,6 @@ fn __new_array(mylen int, cap int, elm_size int) array {
|
|||
return arr
|
||||
}
|
||||
|
||||
// TODO
|
||||
pub fn make(len int, cap int, elm_size int) array {
|
||||
return __new_array(len, cap, elm_size)
|
||||
}
|
||||
|
||||
/*
|
||||
struct Foo {
|
||||
a []string
|
||||
b [][]string
|
||||
}
|
||||
*/
|
||||
|
||||
// Private function, used by V (`nums := [1, 2, 3]`)
|
||||
fn new_array_from_c_array(len, cap, elm_size int, c_array voidptr) array {
|
||||
cap_ := if cap == 0 { 1 } else { cap }
|
||||
|
|
|
@ -551,6 +551,7 @@ fn test_array_str() {
|
|||
numbers := [1, 2, 3]
|
||||
assert numbers == [1,2,3]
|
||||
numbers2 := [numbers, [4, 5, 6]] // dup str() bug
|
||||
_=numbers2
|
||||
assert true
|
||||
assert numbers.str() == '[1, 2, 3]'
|
||||
// QTODO
|
||||
|
@ -727,4 +728,7 @@ fn test_array_with_cap() {
|
|||
a4 := []int{cap:10, len:1 }
|
||||
assert a4.len == 1
|
||||
assert a4.cap == 10
|
||||
a5 := []int{len:1, cap:10}
|
||||
assert a5.len == 1
|
||||
assert a5.cap == 10
|
||||
}
|
||||
|
|
|
@ -11,8 +11,7 @@ const (
|
|||
// NOTE: temp until we have []bytes(buff)
|
||||
fn c_array_to_bytes_tmp(len int, buffer voidptr) []byte {
|
||||
|
||||
mut arr := []byte{}
|
||||
arr = make(len, 1, 1)
|
||||
mut arr := []byte{len:len, cap:1}
|
||||
arr.data = buffer
|
||||
/*
|
||||
|
||||
|
|
|
@ -13,7 +13,8 @@ pub mut:
|
|||
|
||||
pub fn new_builder(initial_size int) Builder {
|
||||
return Builder{
|
||||
buf: make(0, initial_size, 1)
|
||||
//buf: make(0, initial_size)
|
||||
buf: []byte{cap: initial_size}
|
||||
initial_size: initial_size
|
||||
}
|
||||
}
|
||||
|
@ -86,7 +87,9 @@ pub fn (b mut Builder) free() {
|
|||
unsafe{
|
||||
free(b.buf.data)
|
||||
}
|
||||
b.buf = make(0, b.initial_size, 1)
|
||||
// QTODO checker bug
|
||||
s := b.initial_size
|
||||
b.buf = []byte{cap: s}
|
||||
b.len = 0
|
||||
}
|
||||
|
||||
|
|
|
@ -361,15 +361,9 @@ pub fn (mut c Checker) infix_expr(infix_expr mut ast.InfixExpr) table.Type {
|
|||
if left.kind == .array {
|
||||
// `array << elm`
|
||||
match infix_expr.left {
|
||||
ast.Ident {
|
||||
|
||||
}
|
||||
ast.SelectorExpr {
|
||||
|
||||
}
|
||||
else {
|
||||
println('typeof: ${typeof(infix_expr.left)}')
|
||||
}
|
||||
ast.Ident {}
|
||||
ast.SelectorExpr {}
|
||||
else { println('typeof: ${typeof(infix_expr.left)}') }
|
||||
}
|
||||
// the expressions have different types (array_x and x)
|
||||
if c.table.check(c.table.value_type(left_type), right_type) {
|
||||
|
@ -1047,6 +1041,16 @@ pub fn (mut c Checker) array_init(array_init mut ast.ArrayInit) table.Type {
|
|||
}
|
||||
// a = []
|
||||
if array_init.exprs.len == 0 {
|
||||
if array_init.has_cap {
|
||||
if c.expr(array_init.cap_expr) != table.int_type {
|
||||
c.error('array cap needs to be an int', array_init.pos)
|
||||
}
|
||||
}
|
||||
if array_init.has_len {
|
||||
if c.expr(array_init.len_expr) != table.int_type {
|
||||
c.error('array len needs to be an int', array_init.pos)
|
||||
}
|
||||
}
|
||||
type_sym := c.table.get_type_symbol(c.expected_type)
|
||||
if type_sym.kind != .array {
|
||||
c.error('array_init: no type specified (maybe: `[]Type` instead of `[]`)', array_init.pos)
|
||||
|
|
|
@ -314,8 +314,7 @@ pub enum Precedence {
|
|||
}
|
||||
|
||||
pub fn build_precedences() []Precedence {
|
||||
mut p := []Precedence{}
|
||||
p = make(100, 100, sizeof(Precedence))
|
||||
mut p := []Precedence{len:100, cap:100}
|
||||
p[Kind.assign] = .assign
|
||||
p[Kind.eq] = .eq
|
||||
p[Kind.ne] = .eq
|
||||
|
|
Loading…
Reference in New Issue