natvis: add support for more ast types, and improve existing
Bug: tint:1331
Change-Id: I3195cf3d16ed66875f4bac5cac4922af802e4087
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/83202
Kokoro: Kokoro <noreply+kokoro@google.com>
Reviewed-by: Ben Clayton <bclayton@google.com>
Commit-Queue: Antonio Maiorano <amaiorano@google.com>
diff --git a/src/tint/tint.natvis b/src/tint/tint.natvis
index 4490ee9..2687196 100644
--- a/src/tint/tint.natvis
+++ b/src/tint/tint.natvis
@@ -23,13 +23,45 @@
<Type Name="tint::ast::AssignmentStatement">
<DisplayString>{*lhs} = {*rhs};</DisplayString>
- <DisplayString>{AstNodeToString(this)}</DisplayString>
<Expand>
<Item Name="lhs">*lhs</Item>
<Item Name="rhs">*rhs</Item>
</Expand>
</Type>
+ <Type Name="tint::ast::IfStatement">
+ <DisplayString Condition="else_statements.size() == 0">if ({*condition}) {*body}</DisplayString>
+ <DisplayString Condition="else_statements.size() == 1">if ({*condition}) {*body} {*else_statements[0]} </DisplayString>
+ <DisplayString Condition="else_statements.size() == 2">if ({*condition}) {*body} {*else_statements[0]} {*else_statements[1]} </DisplayString>
+ <DisplayString Condition="else_statements.size() == 3">if ({*condition}) {*body} {*else_statements[0]} {*else_statements[1]} {*else_statements[2]}</DisplayString>
+ <DisplayString Condition="else_statements.size() > 3">if ({*condition}) {*body} {*else_statements[0]} {*else_statements[1]} {*else_statements[2]} else {else_statements.size()-3} more...</DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::ElseStatement">
+ <DisplayString Condition="!condition">else {*body}</DisplayString>
+ <DisplayString Condition="!!condition">else if ({*condition}) {*body}</DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::BlockStatement">
+ <DisplayString Condition="statements.size() == 1">{{ {*statements[0]} }} </DisplayString>
+ <DisplayString Condition="statements.size() == 2">{{ {*statements[0]} {*statements[1]} }} </DisplayString>
+ <DisplayString Condition="statements.size() == 3">{{ {*statements[0]} {*statements[1]} {*statements[2]} }} </DisplayString>
+ <DisplayString Condition="statements.size() > 3">{{ {*statements[0]} {*statements[1]} {*statements[2]} {statements.size()-3} more... }} </DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::ReturnStatement">
+ <DisplayString Condition="!value">return;</DisplayString>
+ <DisplayString Condition="!!value">return {*value};</DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::Function">
+ <DisplayString Condition="params.size() == 0">fn {symbol}() -> {*return_type} {*body}</DisplayString>
+ <DisplayString Condition="params.size() == 1">fn {symbol}({*params[0]}) -> {*return_type} {*body}</DisplayString>
+ <DisplayString Condition="params.size() == 2">fn {symbol}({*params[0]} {*params[1]}) -> {*return_type} {*body}</DisplayString>
+ <DisplayString Condition="params.size() == 3">fn {symbol}({*params[0]} {*params[1]} {*params[2]}) -> {*return_type} {*body}</DisplayString>
+ <DisplayString Condition="params.size() > 3">fn {symbol}({*params[0]} {*params[1]} {*params[2]} {params.size()-3} more...) -> {*return_type} {*body}</DisplayString>
+ </Type>
+
<Type Name="tint::ast::IdentifierExpression">
<!--the ",sb" specifier removes the double quotes on the displayed string -->
<DisplayString>{symbol}</DisplayString>
@@ -55,11 +87,14 @@
</Type>
<Type Name="tint::ast::Variable">
- <DisplayString Condition="is_const & !!type">let {symbol} : {*type} = {*constructor}</DisplayString>
- <DisplayString Condition="is_const & !type">let {symbol} = {*constructor}</DisplayString>
- <DisplayString Condition="!is_const & !type">var {symbol} = {*constructor}</DisplayString>
- <DisplayString Condition="!is_const & !!type & !constructor">var {symbol} : {*type}</DisplayString>
+ <!-- Hack: we can deduce that this variable is a parameter if it's const with a type but no constructor, which is illegal for a let -->
+ <DisplayString Condition=" is_const & !!type & !constructor">{symbol} : {*type}</DisplayString>
+
+ <DisplayString Condition=" is_const & !!type & !!constructor">let {symbol} : {*type} = {*constructor}</DisplayString>
+ <DisplayString Condition=" is_const & !type & !constructor">let {symbol} = {*constructor}</DisplayString>
<DisplayString Condition="!is_const & !!type & !!constructor">var {symbol} : {*type} = {*constructor}</DisplayString>
+ <DisplayString Condition="!is_const & !type & !!constructor">var {symbol} = {*constructor}</DisplayString>
+ <DisplayString Condition="!is_const & !!type & !constructor">var {symbol}</DisplayString>
</Type>
<Type Name="tint::ast::VariableDeclStatement">
@@ -74,8 +109,42 @@
<DisplayString>{value}</DisplayString>
</Type>
+ <Type Name="tint::ast::BoolLiteralExpression">
+ <DisplayString>{value}</DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::Void">
+ <DisplayString>void</DisplayString>
+ </Type>
+
+ <Type Name="tint::ast::UnaryOpExpression">
+ <DisplayString Condition="op==tint::ast::UnaryOp::kAddressOf">&({expr})</DisplayString>
+ <DisplayString Condition="op==tint::ast::UnaryOp::kComplement">~({expr})</DisplayString>
+ <DisplayString Condition="op==tint::ast::UnaryOp::kIndirection">*({expr})</DisplayString>
+ <DisplayString Condition="op==tint::ast::UnaryOp::kNegation">-({expr})</DisplayString>
+ <DisplayString Condition="op==tint::ast::UnaryOp::kNot">!({expr})</DisplayString>
+ </Type>
+
<Type Name="tint::ast::BinaryExpression">
- <DisplayString>({*lhs} {op,en} {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kNone">({*lhs} NONE {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kAnd">({*lhs} & {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kOr">({*lhs} | {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kXor">({*lhs} ^ {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kLogicalAnd">({*lhs} && {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kLogicalOr">({*lhs} || {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kEqual">({*lhs} == {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kNotEqual">({*lhs} != {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kLessThan">({*lhs} < {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kGreaterThan">({*lhs} > {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kLessThanEqual">({*lhs} <= {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kGreaterThanEqual">({*lhs} >= {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kShiftLeft">({*lhs} << {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kShiftRight">({*lhs} >> {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kAdd">({*lhs} + {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kSubtract">({*lhs} - {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kMultiply">({*lhs} * {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kDivide">({*lhs} / {*rhs})</DisplayString>
+ <DisplayString Condition="op==tint::ast::BinaryOp::kModulo">({*lhs} % {*rhs})</DisplayString>
</Type>
<Type Name="tint::ast::CallExpression">
@@ -83,7 +152,7 @@
<DisplayString Condition="args.size() == 1">{target}({*args[0]})</DisplayString>
<DisplayString Condition="args.size() == 2">{target}({*args[0]}, {*args[1]})</DisplayString>
<DisplayString Condition="args.size() == 3">{target}({*args[0]}, {*args[1]}, {*args[2]})</DisplayString>
- <DisplayString Condition="args.size() > 3">{target}({*args[0]}, {*args[1]}, {*args[2]}, ...)</DisplayString>
+ <DisplayString Condition="args.size() > 3">{target}({*args[0]}, {*args[1]}, {*args[2]}, {args.size()-3} more...)</DisplayString>
<!-- TODO: add more overloads -->
</Type>