From 6d891490b20dfd68b27c2b5d2a9c5ba08c43bd4d Mon Sep 17 00:00:00 2001 From: "Bowen S. Zhu" Date: Sun, 11 Aug 2024 19:15:54 -0700 Subject: [PATCH] Fix missing metadata fro `+` `*` with args containing metadata --- src/types.jl | 4 ++-- test/basics.jl | 14 ++++++++++++++ 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/types.jl b/src/types.jl index 7acff620f..a7b095570 100644 --- a/src/types.jl +++ b/src/types.jl @@ -588,13 +588,13 @@ function basicsymbolic(f, args, stype, metadata) elseif all(x->symtype(x) <: Number, args) if f === (+) res = +(args...) - if isadd(res) + if isadd(res) || isterm(res) @set! res.metadata = metadata end res elseif f == (*) res = *(args...) - if ismul(res) + if ismul(res) || isterm(res) @set! res.metadata = metadata end res diff --git a/test/basics.jl b/test/basics.jl index 20d772804..7d3457ae2 100644 --- a/test/basics.jl +++ b/test/basics.jl @@ -227,6 +227,20 @@ end # test that maketerm sets metadata correctly metadata = Base.ImmutableDict{DataType, Any}(Ctx1, "meta_1") + metadata2 = Base.ImmutableDict{DataType, Any}(Ctx2, "meta_2") + + @set! c.metadata = metadata2 + + s = SymbolicUtils.maketerm(typeof(a + b), +, [a * b, c], metadata) + @test isterm(s) + @test hasmetadata(s, Ctx1) + @test getmetadata(s, Ctx1) == "meta_1" + + s = SymbolicUtils.maketerm(typeof(a * b), *, [a * b, c], metadata) + @test isterm(s) + @test hasmetadata(s, Ctx1) + @test getmetadata(s, Ctx1) == "meta_1" + s = SymbolicUtils.maketerm(typeof(a^b), ^, [a * b, 3], metadata) @test !hasmetadata(s, Ctx1)