aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeroen van Rijn <Kelimion@users.noreply.github.com>2025-10-09 15:28:00 +0200
committerJeroen van Rijn <Kelimion@users.noreply.github.com>2025-10-09 15:28:00 +0200
commitd5a763e7d0eeb49aeb4dbd359046af4e95c8c7f9 (patch)
treed8f82c2455cbe396fdd057c4f37cf0a5c51646c5
parentaec7d6480be79bb32c9937ff06ec38baff89e344 (diff)
parentc0fd19da182e56fa49352a19f8a683eeeb758987 (diff)
Merge branch 'master' of github.com:odin-lang/Odin
-rw-r--r--core/odin/ast/ast.odin120
1 files changed, 60 insertions, 60 deletions
diff --git a/core/odin/ast/ast.odin b/core/odin/ast/ast.odin
index 3b8998b31..dbb7f5e52 100644
--- a/core/odin/ast/ast.odin
+++ b/core/odin/ast/ast.odin
@@ -70,7 +70,7 @@ File :: struct {
src: string,
tags: [dynamic]tokenizer.Token,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
pkg_decl: ^Package_Decl,
pkg_token: tokenizer.Token,
@@ -137,26 +137,26 @@ Basic_Directive :: struct {
Ellipsis :: struct {
using node: Expr,
tok: tokenizer.Token_Kind,
- expr: ^Expr,
+ expr: ^Expr, // possibly nil
}
Proc_Lit :: struct {
using node: Expr,
- type: ^Proc_Type,
- body: ^Stmt,
- tags: Proc_Tags,
- inlining: Proc_Inlining,
- where_token: tokenizer.Token,
+ type: ^Proc_Type,
+ body: ^Stmt, // nil when it represents a foreign procedure
+ tags: Proc_Tags,
+ inlining: Proc_Inlining,
+ where_token: tokenizer.Token,
where_clauses: []^Expr,
}
Comp_Lit :: struct {
using node: Expr,
- type: ^Expr,
- open: tokenizer.Pos,
+ type: ^Expr, // nil when type is inferred
+ open: tokenizer.Pos,
elems: []^Expr,
close: tokenizer.Pos,
- tag: ^Expr,
+ tag: ^Expr, // possibly nil
}
@@ -170,7 +170,7 @@ Tag_Expr :: struct {
Unary_Expr :: struct {
using node: Expr,
op: tokenizer.Token,
- expr: ^Expr,
+ expr: ^Expr, // nil in the case of `[?]T` or `x.?`
}
Binary_Expr :: struct {
@@ -224,9 +224,9 @@ Slice_Expr :: struct {
using node: Expr,
expr: ^Expr,
open: tokenizer.Pos,
- low: ^Expr,
+ low: ^Expr, // possibly nil
interval: tokenizer.Token,
- high: ^Expr,
+ high: ^Expr, // possibly nil
close: tokenizer.Pos,
}
@@ -291,7 +291,7 @@ Or_Branch_Expr :: struct {
using node: Expr,
expr: ^Expr,
token: tokenizer.Token,
- label: ^Expr,
+ label: ^Expr, // possibly nil when not used
}
Type_Assertion :: struct {
@@ -384,13 +384,13 @@ Block_Stmt :: struct {
If_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
if_pos: tokenizer.Pos,
- init: ^Stmt,
+ init: ^Stmt, // possibly nil
cond: ^Expr,
body: ^Stmt,
else_pos: tokenizer.Pos,
- else_stmt: ^Stmt,
+ else_stmt: ^Stmt, // possibly nil
}
When_Stmt :: struct {
@@ -398,7 +398,7 @@ When_Stmt :: struct {
when_pos: tokenizer.Pos,
cond: ^Expr,
body: ^Stmt,
- else_stmt: ^Stmt,
+ else_stmt: ^Stmt, // possibly nil
}
Return_Stmt :: struct {
@@ -413,17 +413,17 @@ Defer_Stmt :: struct {
For_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
for_pos: tokenizer.Pos,
- init: ^Stmt,
- cond: ^Expr,
- post: ^Stmt,
+ init: ^Stmt, // possibly nil
+ cond: ^Expr, // possibly nil
+ post: ^Stmt, // possibly nil
body: ^Stmt,
}
Range_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
for_pos: tokenizer.Pos,
vals: []^Expr,
in_pos: tokenizer.Pos,
@@ -436,12 +436,12 @@ Inline_Range_Stmt :: Unroll_Range_Stmt
Unroll_Range_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
unroll_pos: tokenizer.Pos,
args: []^Expr,
for_pos: tokenizer.Pos,
val0: ^Expr,
- val1: ^Expr,
+ val1: ^Expr, // possibly nil
in_pos: tokenizer.Pos,
expr: ^Expr,
body: ^Stmt,
@@ -460,9 +460,9 @@ Case_Clause :: struct {
Switch_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
switch_pos: tokenizer.Pos,
- init: ^Stmt,
+ init: ^Stmt, // possibly nil
cond: ^Expr,
body: ^Stmt,
partial: bool,
@@ -470,7 +470,7 @@ Switch_Stmt :: struct {
Type_Switch_Stmt :: struct {
using node: Stmt,
- label: ^Expr,
+ label: ^Expr, // possibly nil
switch_pos: tokenizer.Pos,
tag: ^Stmt,
expr: ^Expr,
@@ -481,7 +481,7 @@ Type_Switch_Stmt :: struct {
Branch_Stmt :: struct {
using node: Stmt,
tok: tokenizer.Token,
- label: ^Ident,
+ label: ^Ident, // possibly nil
}
Using_Stmt :: struct {
@@ -498,55 +498,55 @@ Bad_Decl :: struct {
Value_Decl :: struct {
using node: Decl,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
attributes: [dynamic]^Attribute, // dynamic as parsing will add to them lazily
names: []^Expr,
- type: ^Expr,
+ type: ^Expr, // possibly nil
values: []^Expr,
- comment: ^Comment_Group,
+ comment: ^Comment_Group, // possibly nil
is_using: bool,
is_mutable: bool,
}
Package_Decl :: struct {
using node: Decl,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
token: tokenizer.Token,
name: string,
- comment: ^Comment_Group,
+ comment: ^Comment_Group, // possibly nil
}
Import_Decl :: struct {
using node: Decl,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
attributes: [dynamic]^Attribute, // dynamic as parsing will add to them lazily
is_using: bool,
import_tok: tokenizer.Token,
name: tokenizer.Token,
relpath: tokenizer.Token,
fullpath: string,
- comment: ^Comment_Group,
+ comment: ^Comment_Group, // possibly nil
}
Foreign_Block_Decl :: struct {
using node: Decl,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
attributes: [dynamic]^Attribute, // dynamic as parsing will add to them lazily
tok: tokenizer.Token,
- foreign_library: ^Expr,
- body: ^Stmt,
+ foreign_library: ^Expr, // possibly nil
+ body: ^Stmt, // possibly nil
}
Foreign_Import_Decl :: struct {
using node: Decl,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
attributes: [dynamic]^Attribute, // dynamic as parsing will add to them lazily
foreign_tok: tokenizer.Token,
import_tok: tokenizer.Token,
- name: ^Ident,
+ name: ^Ident, // possibly nil
collection_name: string,
fullpaths: []^Expr,
- comment: ^Comment_Group,
+ comment: ^Comment_Group, // possibly nil
}
@@ -689,13 +689,13 @@ Attribute :: struct {
Field :: struct {
using node: Node,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
names: []^Expr, // Could be polymorphic
type: ^Expr,
- default_value: ^Expr,
+ default_value: ^Expr, // possibly nil
tag: tokenizer.Token,
flags: Field_Flags,
- comment: ^Comment_Group,
+ comment: ^Comment_Group, // possibly nil
}
Field_List :: struct {
@@ -710,7 +710,7 @@ Field_List :: struct {
Typeid_Type :: struct {
using node: Expr,
tok: tokenizer.Token_Kind,
- specialization: ^Expr,
+ specialization: ^Expr, // possibly nil
}
Helper_Type :: struct {
@@ -729,7 +729,7 @@ Poly_Type :: struct {
using node: Expr,
dollar: tokenizer.Pos,
type: ^Ident,
- specialization: ^Expr,
+ specialization: ^Expr, // possibly nil
}
Proc_Type :: struct {
@@ -746,7 +746,7 @@ Proc_Type :: struct {
Pointer_Type :: struct {
using node: Expr,
- tag: ^Expr,
+ tag: ^Expr, // possibly nil
pointer: tokenizer.Pos,
elem: ^Expr,
}
@@ -762,7 +762,7 @@ Multi_Pointer_Type :: struct {
Array_Type :: struct {
using node: Expr,
open: tokenizer.Pos,
- tag: ^Expr,
+ tag: ^Expr, // possibly nil
len: ^Expr, // Unary_Expr node for [?]T array types, nil for slice types
close: tokenizer.Pos,
elem: ^Expr,
@@ -770,7 +770,7 @@ Array_Type :: struct {
Dynamic_Array_Type :: struct {
using node: Expr,
- tag: ^Expr,
+ tag: ^Expr, // possibly nil
open: tokenizer.Pos,
dynamic_pos: tokenizer.Pos,
close: tokenizer.Pos,
@@ -780,10 +780,10 @@ Dynamic_Array_Type :: struct {
Struct_Type :: struct {
using node: Expr,
tok_pos: tokenizer.Pos,
- poly_params: ^Field_List,
- align: ^Expr,
- min_field_align: ^Expr,
- max_field_align: ^Expr,
+ poly_params: ^Field_List, // possibly nil
+ align: ^Expr, // possibly nil
+ min_field_align: ^Expr, // possibly nil
+ max_field_align: ^Expr, // possibly nil
where_token: tokenizer.Token,
where_clauses: []^Expr,
is_packed: bool,
@@ -803,8 +803,8 @@ Union_Type_Kind :: enum u8 {
Union_Type :: struct {
using node: Expr,
tok_pos: tokenizer.Pos,
- poly_params: ^Field_List,
- align: ^Expr,
+ poly_params: ^Field_List, // possibly nil
+ align: ^Expr, // possibly nil
kind: Union_Type_Kind,
where_token: tokenizer.Token,
where_clauses: []^Expr,
@@ -814,7 +814,7 @@ Union_Type :: struct {
Enum_Type :: struct {
using node: Expr,
tok_pos: tokenizer.Pos,
- base_type: ^Expr,
+ base_type: ^Expr, // possibly nil
open: tokenizer.Pos,
fields: []^Expr,
close: tokenizer.Pos,
@@ -827,7 +827,7 @@ Bit_Set_Type :: struct {
tok_pos: tokenizer.Pos,
open: tokenizer.Pos,
elem: ^Expr,
- underlying: ^Expr,
+ underlying: ^Expr, // possibly nil
close: tokenizer.Pos,
}
@@ -864,12 +864,12 @@ Bit_Field_Type :: struct {
Bit_Field_Field :: struct {
using node: Node,
- docs: ^Comment_Group,
+ docs: ^Comment_Group, // possibly nil
name: ^Expr,
type: ^Expr,
bit_size: ^Expr,
tag: tokenizer.Token,
- comments: ^Comment_Group,
+ comments: ^Comment_Group, // possibly nil
}
Any_Node :: union {