ruby-core@ruby-lang.org archive (unofficial mirror)
 help / color / mirror / Atom feed
* [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).