hiroshinishio / julia

The Julia Programming Language
https://julialang.org/
MIT License
0 stars 0 forks source link

GitAuto: Core.println repr wrong for Core.IntrinsicFunction type #19

Open gitauto-for-dev[bot] opened 3 months ago

gitauto-for-dev[bot] commented 3 months ago

Original issue: #9

Why the bug occurs

The bug occurs because the jl_static_show function in rtutils.c is not correctly handling the special case of Core.IntrinsicFunction types. The Symbol name in the MethodTable of jl_intrinsic_type is causing confusion, leading to incorrect representation.

How to reproduce

  1. Execute which(Core.Compiler.is_pure_intrinsic_infer, (Core.IntrinsicFunction,)).sig in a Julia REPL to get the correct signature.
  2. Pipe the result to Core.println to observe the incorrect representation.
  3. Check the name and method table name of Core.IntrinsicFunction to see the inconsistency.

How to fix

  1. Modify the jl_static_show function in rtutils.c to utilize the jl_intrinsic_name function for Core.IntrinsicFunction types. This will ensure the correct identifier is printed.
  2. Update the is_globname_binding function to take an additional argument indicating whether v is a value or type. This will allow branching based on this information instead of using the || operator, which is currently leading to incorrect behavior.

Test these changes locally

git checkout -b gitauto-wes/issue-#9-89d74fbe-29fb-4235-ab69-179e348d16b1
git pull origin gitauto-wes/issue-#9-89d74fbe-29fb-4235-ab69-179e348d16b1