|
@@ -69,7 +69,7 @@ general_stuff :: proc() {
|
|
|
Foo :: struct {
|
|
|
x: int,
|
|
|
b: bool,
|
|
|
- }
|
|
|
+ };
|
|
|
f := Foo{137, true};
|
|
|
x, b := expand_to_tuple(f);
|
|
|
fmt.println(f);
|
|
@@ -228,18 +228,18 @@ union_type :: proc() {
|
|
|
orientation: Quaternion,
|
|
|
|
|
|
derived: any,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
Frog :: struct {
|
|
|
using entity: Entity,
|
|
|
jump_height: f32,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
Monster :: struct {
|
|
|
using entity: Entity,
|
|
|
is_robot: bool,
|
|
|
is_zombie: bool,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
// See `parametric_polymorphism` procedure for details
|
|
|
new_entity :: proc($T: typeid) -> ^Entity {
|
|
@@ -273,18 +273,18 @@ union_type :: proc() {
|
|
|
orientation: Quaternion,
|
|
|
|
|
|
derived: union {Frog, Monster},
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
Frog :: struct {
|
|
|
using entity: ^Entity,
|
|
|
jump_height: f32,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
Monster :: struct {
|
|
|
using entity: ^Entity,
|
|
|
is_robot: bool,
|
|
|
is_zombie: bool,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
// See `parametric_polymorphism` procedure for details
|
|
|
new_entity :: proc($T: typeid) -> ^Entity {
|
|
@@ -402,13 +402,13 @@ parametric_polymorphism :: proc() {
|
|
|
hash: u32,
|
|
|
key: Key,
|
|
|
value: Value,
|
|
|
- }
|
|
|
+ };
|
|
|
TABLE_SIZE_MIN :: 32;
|
|
|
Table :: struct(Key, Value: typeid) {
|
|
|
count: int,
|
|
|
allocator: mem.Allocator,
|
|
|
slots: []Table_Slot(Key, Value),
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
// Only allow types that are specializations of a (polymorphic) slice
|
|
|
make_slice :: proc($T: typeid/[]$E, len: int) -> T {
|
|
@@ -532,7 +532,7 @@ parametric_polymorphism :: proc() {
|
|
|
Foo1,
|
|
|
Foo2,
|
|
|
Foo3,
|
|
|
- }
|
|
|
+ };
|
|
|
Para_Union :: union(T: typeid) {T, Error};
|
|
|
r: Para_Union(int);
|
|
|
fmt.println(typeid_of(type_of(r)));
|
|
@@ -728,19 +728,19 @@ map_type :: proc() {
|
|
|
Enum_u8 :: enum u8 {
|
|
|
A = 0,
|
|
|
B = 1 << 8 - 1,
|
|
|
- }
|
|
|
+ };
|
|
|
Enum_u64 :: enum u64 {
|
|
|
A = 0,
|
|
|
B = 1 << 64 - 1,
|
|
|
- }
|
|
|
+ };
|
|
|
Enum_i8 :: enum i8 {
|
|
|
A = 0,
|
|
|
B = -(1 << 7),
|
|
|
- }
|
|
|
+ };
|
|
|
Enum_i64 :: enum i64 {
|
|
|
A = 0,
|
|
|
B = -(1 << 63),
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
map_u8: map[Enum_u8]u8;
|
|
|
map_u8[Enum_u8.A] = u8(Enum_u8.B);
|
|
@@ -764,7 +764,7 @@ map_type :: proc() {
|
|
|
|
|
|
demo_struct :: struct {
|
|
|
member: Enum_i64,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
map_string: map[string]demo_struct;
|
|
|
map_string["Hellope!"] = demo_struct{Enum_i64.B};
|
|
@@ -846,7 +846,7 @@ complete_switch :: proc() {
|
|
|
B,
|
|
|
C,
|
|
|
D,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
b := Foo.B;
|
|
|
f := Foo.A;
|
|
@@ -916,7 +916,7 @@ bit_set_type :: proc() {
|
|
|
Thursday,
|
|
|
Friday,
|
|
|
Saturday,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
Days :: distinct bit_set[Day];
|
|
|
WEEKEND :: Days{Sunday, Saturday};
|
|
@@ -1003,7 +1003,7 @@ reflection :: proc() {
|
|
|
x: int `tag1`,
|
|
|
y: string `json:"y_field"`,
|
|
|
z: bool, // no tag
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
id := typeid_of(Foo);
|
|
|
names := reflect.struct_field_names(id);
|
|
@@ -1105,7 +1105,7 @@ inline_for_statement :: proc() {
|
|
|
B,
|
|
|
C = 6,
|
|
|
D,
|
|
|
- }
|
|
|
+ };
|
|
|
fmt.println("Enum types");
|
|
|
inline for elem, idx in Foo_Enum {
|
|
|
fmt.println(elem, idx);
|
|
@@ -1180,7 +1180,7 @@ where_clauses :: proc() {
|
|
|
N > 2 {
|
|
|
x: [N]T,
|
|
|
y: [N-2]T,
|
|
|
- }
|
|
|
+ };
|
|
|
|
|
|
T :: i32;
|
|
|
N :: 5;
|