2019-07-02 00:00:27 +02:00
|
|
|
struct A{
|
2019-09-28 13:13:09 +02:00
|
|
|
mut:
|
|
|
|
val int
|
|
|
|
nums []int
|
|
|
|
}
|
2019-07-02 00:00:27 +02:00
|
|
|
|
|
|
|
struct B{
|
2019-09-28 13:13:09 +02:00
|
|
|
mut:
|
|
|
|
a A
|
|
|
|
}
|
2019-07-03 23:53:48 +02:00
|
|
|
|
2019-07-02 00:00:27 +02:00
|
|
|
struct C {
|
2019-09-28 13:13:09 +02:00
|
|
|
mut:
|
|
|
|
b B
|
|
|
|
nums []int
|
|
|
|
aarr []A
|
|
|
|
num int
|
|
|
|
}
|
2019-07-03 23:53:48 +02:00
|
|
|
|
|
|
|
struct User {
|
|
|
|
name string
|
2019-09-28 13:13:09 +02:00
|
|
|
age int
|
|
|
|
}
|
2019-07-24 02:22:34 +02:00
|
|
|
|
|
|
|
struct Foo {
|
2019-09-28 13:13:09 +02:00
|
|
|
@type string
|
|
|
|
}
|
|
|
|
|
|
|
|
//We need to make sure that this compiles with all the reserved names.
|
|
|
|
struct ReservedKeywords {
|
|
|
|
delete int
|
|
|
|
exit int
|
|
|
|
unix int
|
|
|
|
error int
|
|
|
|
malloc int
|
|
|
|
calloc int
|
|
|
|
free int
|
|
|
|
panic int
|
|
|
|
auto int
|
|
|
|
char int
|
|
|
|
do int
|
|
|
|
double int
|
|
|
|
extern int
|
|
|
|
float int
|
|
|
|
inline int
|
|
|
|
long int
|
|
|
|
register int
|
|
|
|
restrict int
|
|
|
|
short int
|
|
|
|
signed int
|
|
|
|
typedef int
|
|
|
|
unsigned int
|
|
|
|
void int
|
|
|
|
volatile int
|
|
|
|
while int
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_struct_levels() {
|
|
|
|
mut c := C{}
|
|
|
|
assert c.nums.len == 0
|
|
|
|
c.nums << 3
|
|
|
|
assert c.nums.len == 1
|
|
|
|
assert c.nums[0] == 3
|
|
|
|
c.nums[0] = 4
|
|
|
|
assert c.nums[0] == 4
|
|
|
|
c.b.a.val = 34
|
|
|
|
assert c.b.a.val == 34
|
2019-09-15 11:26:05 +02:00
|
|
|
c.b.a.nums = [0].repeat(0)
|
2019-09-28 13:13:09 +02:00
|
|
|
c.b.a.nums << 0
|
|
|
|
c.b.a.nums << 2
|
|
|
|
assert c.b.a.nums.len == 2
|
|
|
|
assert c.b.a.nums[0] == 0
|
|
|
|
assert c.b.a.nums[1] == 2
|
|
|
|
c.b.a.nums [0] = 7
|
|
|
|
assert c.b.a.nums[0] == 7
|
|
|
|
c.aarr << A{val:8}
|
|
|
|
assert c.aarr.len == 1
|
|
|
|
assert c.aarr[0].val == 8
|
|
|
|
c.num = 20
|
|
|
|
assert c.num == 20
|
|
|
|
c.aarr[0].val = 10
|
|
|
|
assert c.aarr[0].val == 10
|
|
|
|
}
|
2019-07-03 23:53:48 +02:00
|
|
|
|
|
|
|
fn test_struct_str() {
|
2019-09-28 13:13:09 +02:00
|
|
|
u := User{'Bob', 30}
|
|
|
|
println(u) // make sure the struct is printable
|
|
|
|
// assert u.str() == '{name:"Bob", age:30}' // TODO
|
|
|
|
}
|
2019-07-24 02:22:34 +02:00
|
|
|
|
|
|
|
fn test_at() {
|
2019-09-28 13:13:09 +02:00
|
|
|
foo := Foo{ @type: 'test' }
|
|
|
|
println(foo.@type)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_reserved_keywords() {
|
|
|
|
//Make sure we can initialize them correctly using full syntax.
|
|
|
|
rk_holder := ReservedKeywords{0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3}
|
|
|
|
//Test a few as it'll take too long to test all. If it's initialized
|
|
|
|
//correctly, other fields are also probably valid.
|
|
|
|
assert rk_holder.unix == 5
|
|
|
|
assert rk_holder.while == 3
|
|
|
|
|
|
|
|
rk_holder2 := ReservedKeywords{inline: 9, volatile: 11}
|
|
|
|
//Make sure partial initialization works too.
|
|
|
|
assert rk_holder2.inline == 9
|
|
|
|
assert rk_holder2.volatile == 11
|
|
|
|
assert rk_holder2.while == 0 //Zero value as not specified.
|
|
|
|
}
|
2019-10-13 00:50:15 +02:00
|
|
|
|
|
|
|
struct User2 {
|
|
|
|
mut:
|
|
|
|
name string
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_mutable_fields() {
|
|
|
|
mut u := User2{}
|
|
|
|
u.name = 'Peter'
|
|
|
|
assert u.name == 'Peter'
|
|
|
|
}
|
2019-11-24 13:56:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
struct Def {
|
|
|
|
a int
|
|
|
|
b int = 7
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_default_vals() {
|
|
|
|
d := Def{}
|
|
|
|
assert d.a == 0
|
|
|
|
assert d.b == 7
|
|
|
|
d2 := Def{10, 20}
|
|
|
|
assert d2.a == 10
|
|
|
|
assert d2.b == 20
|
|
|
|
}
|
|
|
|
|