mirror of
https://github.com/odin-lang/Odin.git
synced 2025-12-29 17:34:34 +00:00
Update demo.odin
This commit is contained in:
@@ -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;
|
||||
|
||||
Reference in New Issue
Block a user