From 78e573ed73f42c6628d3d3eca0aab3ec4a1744fb Mon Sep 17 00:00:00 2001 From: badumbatish Date: Sun, 21 Jul 2024 15:41:21 -0700 Subject: [PATCH] Change assertion of constructor Change the assert of (expr != nullptr) to (this->expr != nullptr) because we assigned (std::move(expr)) to this->expr, no need to assert expr gcc/rust/ChangeLog: * ast/rust-expr.h (struct AnonConst): Change assertion of constructor (struct InlineAsmOperand): Change assertion of constructor --- gcc/rust/ast/rust-expr.h | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/gcc/rust/ast/rust-expr.h b/gcc/rust/ast/rust-expr.h index 25afe235e4e8..9477bf06d6c0 100644 --- a/gcc/rust/ast/rust-expr.h +++ b/gcc/rust/ast/rust-expr.h @@ -4723,18 +4723,21 @@ struct AnonConst { NodeId id; std::unique_ptr expr; + AnonConst (NodeId id, std::unique_ptr expr) + : id (id), expr (std::move (expr)) + { + rust_assert (this->expr != nullptr); + } AnonConst (const AnonConst &other) { id = other.id; - if (other.expr) - expr = other.expr->clone_expr (); + expr = other.expr->clone_expr (); } AnonConst operator= (const AnonConst &other) { id = other.id; - if (other.expr) - expr = other.expr->clone_expr (); + expr = other.expr->clone_expr (); return *this; } }; @@ -4787,7 +4790,7 @@ struct InlineAsmOperand std::unique_ptr expr) : reg (reg), expr (std::move (expr)) { - rust_assert (expr != nullptr); + rust_assert (this->expr != nullptr); } In (const struct In &other) @@ -4816,7 +4819,7 @@ struct InlineAsmOperand std::unique_ptr expr) : reg (reg), late (late), expr (std::move (expr)) { - rust_assert (expr != nullptr); + rust_assert (this->expr != nullptr); } Out (const struct Out &other) @@ -4845,7 +4848,7 @@ struct InlineAsmOperand std::unique_ptr expr) : reg (reg), late (late), expr (std::move (expr)) { - rust_assert (expr != nullptr); + rust_assert (this->expr != nullptr); } InOut (const struct InOut &other) @@ -4877,8 +4880,8 @@ struct InlineAsmOperand : reg (reg), late (late), in_expr (std::move (in_expr)), out_expr (std::move (out_expr)) { - rust_assert (in_expr != nullptr); - rust_assert (out_expr != nullptr); + rust_assert (this->in_expr != nullptr); + rust_assert (this->out_expr != nullptr); } SplitInOut (const struct SplitInOut &other) @@ -4911,7 +4914,7 @@ struct InlineAsmOperand Sym (std::unique_ptr expr) : expr (std::move (expr)) { - rust_assert (expr != nullptr); + rust_assert (this->expr != nullptr); } Sym (const struct Sym &other) { @@ -4933,7 +4936,7 @@ struct InlineAsmOperand Label (tl::optional label_name, std::unique_ptr expr) : expr (std::move (expr)) { - rust_assert (expr != nullptr); + rust_assert (this->expr != nullptr); if (label_name.has_value ()) this->label_name = label_name.value (); }