* [ruby-core:119137] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals
@ 2024-09-12 13:30 luke-gru (Luke Gruber) via ruby-core
2024-09-15 19:15 ` [ruby-core:119204] " osyo (manga osyo) via ruby-core
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: luke-gru (Luke Gruber) via ruby-core @ 2024-09-12 13:30 UTC (permalink / raw)
To: ruby-core; +Cc: luke-gru (Luke Gruber)
Issue #20726 has been reported by luke-gru (Luke Gruber).
----------------------------------------
Bug #20726: Issue with hash without braces when assigned to constant with ractor literals
https://bugs.ruby-lang.org/issues/20726
* Author: luke-gru (Luke Gruber)
* Status: Open
* ruby -v: 3.4.0dev
* Backport: 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN
----------------------------------------
```ruby
a = 'hi'
A = ['hello' => a]
p A
```
gives:
```
./ruby -I../ruby/lib -I. -I.ext/x86_64-linux -I.ext/common -r./x86_64-linux-fake ../ruby/test.rb
-- raw disasm--------
trace: 1
0000 putchilledstring "hi" ( 3)
0002 setlocal_WC_0 3 ( 3)
trace: 1
0004 newarray 1 ( 4)
0006 putspecialobject 3 ( 4)
* 0008 setconstant :A ( 4)
trace: 1
0010 putself ( 5)
0011 opt_getconstant_path [:A] ( 5)
0013 opt_send_without_block <calldata:p, 1> ( 5)
0015 leave ( 5)
---------------------
../ruby/test.rb:4: argument stack underflow (-1)
../ruby/test.rb: compile error (SyntaxError)
```
This is due to a line in `compile.c`, function `compile_shareable_literal_constant`:
```c
if (!RNODE_HASH(node)->nd_brace) { }
```
I'm not sure why this condition is there so I'm not confident in making a fix. Also, my git-fu isn't the best so I can't track down the right commit where it was added.
--
https://bugs.ruby-lang.org/
______________________________________________
ruby-core mailing list -- ruby-core@ml.ruby-lang.org
To unsubscribe send an email to ruby-core-leave@ml.ruby-lang.org
ruby-core info -- https://ml.ruby-lang.org/mailman3/lists/ruby-core.ml.ruby-lang.org/
^ permalink raw reply [flat|nested] 4+ messages in thread
* [ruby-core:119204] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals
2024-09-12 13:30 [ruby-core:119137] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals luke-gru (Luke Gruber) via ruby-core
@ 2024-09-15 19:15 ` osyo (manga osyo) via ruby-core
2024-09-30 5:10 ` [ruby-core:119345] " mame (Yusuke Endoh) via ruby-core
2025-05-14 14:26 ` [ruby-core:122099] [Ruby " byroot (Jean Boussier) via ruby-core
2 siblings, 0 replies; 4+ messages in thread
From: osyo (manga osyo) via ruby-core @ 2024-09-15 19:15 UTC (permalink / raw)
To: ruby-core; +Cc: osyo (manga osyo)
Issue #20726 has been updated by osyo (manga osyo).
This problem was not reproduced with `--parser=prism`, but with `--parser=parse.y`.
```ruby
# shareable_constant_value: literal
# test.rb
puts RUBY_DESCRIPTION
A = [a: 1]
p A
```
```shell
$ ruby --parser=prism test.rb
ruby 3.4.0dev (2024-09-15T01:06:11Z master 532af89e3b) +PRISM [x86_64-linux]
test.rb:5:in 'ensure_shareable': cannot assign unshareable object to A (Ractor::IsolationError)
from test.rb:5:in '<main>'
$ ruby --parser=parse.y test.rb
-- raw disasm--------
trace: 1
0000 putself ( 3)
0001 opt_getconstant_path [:RUBY_DESCRIPTION] ( 3)
0003 opt_send_without_block <calldata:puts, 1> ( 3)
0005 pop ( 3)
trace: 1
0006 newarray 1 ( 5)
0008 putspecialobject 3 ( 5)
* 0010 setconstant :A ( 5)
trace: 1
0012 putself ( 6)
0013 opt_getconstant_path [:A] ( 6)
0015 opt_send_without_block <calldata:p, 1> ( 6)
0017 leave ( 6)
---------------------
test.rb:5: argument stack underflow (-1)
test.rb: compile error (SyntaxError)
```
----------------------------------------
Bug #20726: Issue with hash without braces when assigned to constant with ractor literals
https://bugs.ruby-lang.org/issues/20726#change-109786
* Author: luke-gru (Luke Gruber)
* Status: Open
* ruby -v: 3.4.0dev
* Backport: 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN
----------------------------------------
```ruby
# shareable_constant_value: literal
a = 'hi'
A = ['hello' => a]
p A
```
gives:
```
./ruby -I../ruby/lib -I. -I.ext/x86_64-linux -I.ext/common -r./x86_64-linux-fake ../ruby/test.rb
-- raw disasm--------
trace: 1
0000 putchilledstring "hi" ( 3)
0002 setlocal_WC_0 3 ( 3)
trace: 1
0004 newarray 1 ( 4)
0006 putspecialobject 3 ( 4)
* 0008 setconstant :A ( 4)
trace: 1
0010 putself ( 5)
0011 opt_getconstant_path [:A] ( 5)
0013 opt_send_without_block <calldata:p, 1> ( 5)
0015 leave ( 5)
---------------------
../ruby/test.rb:4: argument stack underflow (-1)
../ruby/test.rb: compile error (SyntaxError)
```
This is due to a line in `compile.c`, function `compile_shareable_literal_constant`:
```c
if (!RNODE_HASH(node)->nd_brace) { }
```
I'm not sure why this condition is there so I'm not confident in making a fix. Also, my git-fu isn't the best so I can't track down the right commit where it was added.
Expected:
It works just the same as when pragma `shareable_constant_value: literal` is not given. Which is to say, `[{'hello' => 'hi'}]` is is the value of `A`.
--
https://bugs.ruby-lang.org/
______________________________________________
ruby-core mailing list -- ruby-core@ml.ruby-lang.org
To unsubscribe send an email to ruby-core-leave@ml.ruby-lang.org
ruby-core info -- https://ml.ruby-lang.org/mailman3/lists/ruby-core.ml.ruby-lang.org/
^ permalink raw reply [flat|nested] 4+ messages in thread
* [ruby-core:119345] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals
2024-09-12 13:30 [ruby-core:119137] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals luke-gru (Luke Gruber) via ruby-core
2024-09-15 19:15 ` [ruby-core:119204] " osyo (manga osyo) via ruby-core
@ 2024-09-30 5:10 ` mame (Yusuke Endoh) via ruby-core
2025-05-14 14:26 ` [ruby-core:122099] [Ruby " byroot (Jean Boussier) via ruby-core
2 siblings, 0 replies; 4+ messages in thread
From: mame (Yusuke Endoh) via ruby-core @ 2024-09-30 5:10 UTC (permalink / raw)
To: ruby-core; +Cc: mame (Yusuke Endoh)
Issue #20726 has been updated by mame (Yusuke Endoh).
Assignee set to ko1 (Koichi Sasada)
----------------------------------------
Bug #20726: Issue with hash without braces when assigned to constant with ractor literals
https://bugs.ruby-lang.org/issues/20726#change-109956
* Author: luke-gru (Luke Gruber)
* Status: Open
* Assignee: ko1 (Koichi Sasada)
* ruby -v: 3.4.0dev
* Backport: 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN
----------------------------------------
```ruby
# shareable_constant_value: literal
a = 'hi'
A = ['hello' => a]
p A
```
gives:
```
./ruby -I../ruby/lib -I. -I.ext/x86_64-linux -I.ext/common -r./x86_64-linux-fake ../ruby/test.rb
-- raw disasm--------
trace: 1
0000 putchilledstring "hi" ( 3)
0002 setlocal_WC_0 3 ( 3)
trace: 1
0004 newarray 1 ( 4)
0006 putspecialobject 3 ( 4)
* 0008 setconstant :A ( 4)
trace: 1
0010 putself ( 5)
0011 opt_getconstant_path [:A] ( 5)
0013 opt_send_without_block <calldata:p, 1> ( 5)
0015 leave ( 5)
---------------------
../ruby/test.rb:4: argument stack underflow (-1)
../ruby/test.rb: compile error (SyntaxError)
```
This is due to a line in `compile.c`, function `compile_shareable_literal_constant`:
```c
if (!RNODE_HASH(node)->nd_brace) { }
```
I'm not sure why this condition is there so I'm not confident in making a fix. Also, my git-fu isn't the best so I can't track down the right commit where it was added.
Expected:
It works just the same as when pragma `shareable_constant_value: literal` is not given. Which is to say, `[{'hello' => 'hi'}]` is is the value of `A`.
--
https://bugs.ruby-lang.org/
______________________________________________
ruby-core mailing list -- ruby-core@ml.ruby-lang.org
To unsubscribe send an email to ruby-core-leave@ml.ruby-lang.org
ruby-core info -- https://ml.ruby-lang.org/mailman3/lists/ruby-core.ml.ruby-lang.org/
^ permalink raw reply [flat|nested] 4+ messages in thread
* [ruby-core:122099] [Ruby Bug#20726] Issue with hash without braces when assigned to constant with ractor literals
2024-09-12 13:30 [ruby-core:119137] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals luke-gru (Luke Gruber) via ruby-core
2024-09-15 19:15 ` [ruby-core:119204] " osyo (manga osyo) via ruby-core
2024-09-30 5:10 ` [ruby-core:119345] " mame (Yusuke Endoh) via ruby-core
@ 2025-05-14 14:26 ` byroot (Jean Boussier) via ruby-core
2 siblings, 0 replies; 4+ messages in thread
From: byroot (Jean Boussier) via ruby-core @ 2025-05-14 14:26 UTC (permalink / raw)
To: ruby-core; +Cc: byroot (Jean Boussier)
Issue #20726 has been updated by byroot (Jean Boussier).
Status changed from Assigned to Closed
This no longer reproduce with either parser, so I'm going to assume it was fixed.
----------------------------------------
Bug #20726: Issue with hash without braces when assigned to constant with ractor literals
https://bugs.ruby-lang.org/issues/20726#change-113252
* Author: luke-gru (Luke Gruber)
* Status: Closed
* Assignee: ractor
* ruby -v: 3.4.0dev
* Backport: 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN
----------------------------------------
```ruby
# shareable_constant_value: literal
a = 'hi'
A = ['hello' => a]
p A
```
gives:
```
./ruby -I../ruby/lib -I. -I.ext/x86_64-linux -I.ext/common -r./x86_64-linux-fake ../ruby/test.rb
-- raw disasm--------
trace: 1
0000 putchilledstring "hi" ( 3)
0002 setlocal_WC_0 3 ( 3)
trace: 1
0004 newarray 1 ( 4)
0006 putspecialobject 3 ( 4)
* 0008 setconstant :A ( 4)
trace: 1
0010 putself ( 5)
0011 opt_getconstant_path [:A] ( 5)
0013 opt_send_without_block <calldata:p, 1> ( 5)
0015 leave ( 5)
---------------------
../ruby/test.rb:4: argument stack underflow (-1)
../ruby/test.rb: compile error (SyntaxError)
```
This is due to a line in `compile.c`, function `compile_shareable_literal_constant`:
```c
if (!RNODE_HASH(node)->nd_brace) { }
```
I'm not sure why this condition is there so I'm not confident in making a fix. Also, my git-fu isn't the best so I can't track down the right commit where it was added.
Expected:
It works just the same as when pragma `shareable_constant_value: literal` is not given. Which is to say, `[{'hello' => 'hi'}]` is is the value of `A`.
--
https://bugs.ruby-lang.org/
______________________________________________
ruby-core mailing list -- ruby-core@ml.ruby-lang.org
To unsubscribe send an email to ruby-core-leave@ml.ruby-lang.org
ruby-core info -- https://ml.ruby-lang.org/mailman3/lists/ruby-core.ml.ruby-lang.org/
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2025-05-14 14:26 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-09-12 13:30 [ruby-core:119137] [Ruby master Bug#20726] Issue with hash without braces when assigned to constant with ractor literals luke-gru (Luke Gruber) via ruby-core
2024-09-15 19:15 ` [ruby-core:119204] " osyo (manga osyo) via ruby-core
2024-09-30 5:10 ` [ruby-core:119345] " mame (Yusuke Endoh) via ruby-core
2025-05-14 14:26 ` [ruby-core:122099] [Ruby " byroot (Jean Boussier) via ruby-core
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).