[#115984] [Ruby master Misc#20107] Update required Oracle Solaris Studio version to 12.5 — "kddnewton (Kevin Newton) via ruby-core" <ruby-core@...>

Issue #20107 has been reported by kddnewton (Kevin Newton).

7 messages 2024/01/02

[#115985] [Ruby master Feature#20108] Introduction of Happy Eyeballs Version 2 (RFC8305) in Socket.tcp — "shioimm (Misaki Shioi) via ruby-core" <ruby-core@...>

Issue #20108 has been reported by shioimm (Misaki Shioi).

14 messages 2024/01/02

[#116028] [Ruby master Feature#20152] mkmf / extconf: Add a proper way to not compile the extension — "byroot (Jean Boussier) via ruby-core" <ruby-core@...>

Issue #20152 has been reported by byroot (Jean Boussier).

21 messages 2024/01/05

[#116039] [Ruby master Bug#20154] aarch64: configure overrides `-mbranch-protection` if it was set in CFLAGS via environment — "jprokop (Jarek Prokop) via ruby-core" <ruby-core@...>

Issue #20154 has been reported by jprokop (Jarek Prokop).

11 messages 2024/01/05

[#116041] [Ruby master Bug#20155] Using value of rb_fiber_scheduler_current() crashes Ruby — "paddor (Patrik Wenger) via ruby-core" <ruby-core@...>

Issue #20155 has been reported by paddor (Patrik Wenger).

12 messages 2024/01/05

[#116065] [Ruby master Feature#20160] rescue keyword for case expressions — "lloeki (Loic Nageleisen) via ruby-core" <ruby-core@...>

Issue #20160 has been reported by lloeki (Loic Nageleisen).

9 messages 2024/01/08

[#116083] [Ruby master Feature#20163] Introduce #bit_count method on Integer — "garrison (Garrison Jensen) via ruby-core" <ruby-core@...>

Issue #20163 has been reported by garrison (Garrison Jensen).

25 messages 2024/01/08

[#116114] [Ruby master Bug#20169] `GC.compact` can raises `EFAULT` on IO — "ko1 (Koichi Sasada) via ruby-core" <ruby-core@...>

Issue #20169 has been reported by ko1 (Koichi Sasada).

14 messages 2024/01/09

[#116129] [Ruby master Bug#20172] Socket.addrinfo failing randomly — "mwaldvogel (Michael Waldvogel) via ruby-core" <ruby-core@...>

Issue #20172 has been reported by mwaldvogel (Michael Waldvogel).

9 messages 2024/01/09

[#116182] [Ruby master Bug#20180] Inconsistent evaluation of `**{}` depending on position in array — "ozydingo (Andrew Schwartz) via ruby-core" <ruby-core@...>

Issue #20180 has been reported by ozydingo (Andrew Schwartz).

8 messages 2024/01/12

[#116203] [Ruby master Bug#20185] String#ascii_only? buggy in ruby 3.3 — "chucke (Tiago Cardoso) via ruby-core" <ruby-core@...>

SXNzdWUgIzIwMTg1IGhhcyBiZWVuIHJlcG9ydGVkIGJ5IGNodWNrZSAoVGlhZ28gQ2FyZG9zbyku

7 messages 2024/01/14

[#116223] [Ruby master Bug#20188] `Module#const_source_location` returns wrong information when real constant was defined but autoload is still ongoing — "byroot (Jean Boussier) via ruby-core" <ruby-core@...>

Issue #20188 has been reported by byroot (Jean Boussier).

32 messages 2024/01/16

[#116315] [Ruby master Misc#20193] DevMeeting-2024-02-14 — "mame (Yusuke Endoh) via ruby-core" <ruby-core@...>

Issue #20193 has been reported by mame (Yusuke Endoh).

16 messages 2024/01/19

[#116347] [Ruby master Bug#20197] Postponed job invocations are significantly reduced in Ruby 3.3 — "osyoyu (Daisuke Aritomo) via ruby-core" <ruby-core@...>

Issue #20197 has been reported by osyoyu (Daisuke Aritomo).

8 messages 2024/01/20

[#116370] [Ruby master Bug#20203] `TestEnumerable` test failures with GCC 14 — "vo.x (Vit Ondruch) via ruby-core" <ruby-core@...>

Issue #20203 has been reported by vo.x (Vit Ondruch).

13 messages 2024/01/22

[#116382] [Ruby master Feature#20205] Enable `frozen_string_literal` by default — "byroot (Jean Boussier) via ruby-core" <ruby-core@...>

Issue #20205 has been reported by byroot (Jean Boussier).

77 messages 2024/01/23

[#116395] [Ruby master Bug#20207] Segmentation fault for a regexp containing positive and negative lookaheads — "Sundeep (Sundeep Agarwal) via ruby-core" <ruby-core@...>

Issue #20207 has been reported by Sundeep (Sundeep Agarwal).

7 messages 2024/01/24

[#116399] [Ruby master Bug#20208] Net::HTTP errors with Errno::EAFNOSUPPORT when setting local_host with Addrinfo — "jprokop (Jarek Prokop) via ruby-core" <ruby-core@...>

Issue #20208 has been reported by jprokop (Jarek Prokop).

9 messages 2024/01/24

[#116435] [Ruby master Misc#20210] Invalid source encoding raises ArgumentError, not SyntaxError — "kddnewton (Kevin Newton) via ruby-core" <ruby-core@...>

Issue #20210 has been reported by kddnewton (Kevin Newton).

8 messages 2024/01/25

[#116456] [Ruby master Feature#20215] Introduce `IO#readable?` — "ioquatix (Samuel Williams) via ruby-core" <ruby-core@...>

Issue #20215 has been reported by ioquatix (Samuel Williams).

17 messages 2024/01/26

[#116460] [Ruby master Bug#20218] aset/masgn/op_asgn with keyword arguments — "jeremyevans0 (Jeremy Evans) via ruby-core" <ruby-core@...>

Issue #20218 has been reported by jeremyevans0 (Jeremy Evans).

18 messages 2024/01/27

[#116491] [Ruby master Bug#20225] Inconsistent behavior of regex matching for a regex has a null loop — "make_now_just (Hiroya Fujinami) via ruby-core" <ruby-core@...>

Issue #20225 has been reported by make_now_just (Hiroya Fujinami).

10 messages 2024/01/30

[#116493] [Ruby master Bug#20226] Inconsistent Sort results on 3.3.0 compared to previous versions — "omerby (Omer Ben Yosef) via ruby-core" <ruby-core@...>

Issue #20226 has been reported by omerby (Omer Ben Yosef).

14 messages 2024/01/30

[ruby-core:116404] [Ruby master Feature#20205] Enable `frozen_string_literal` by default

From: duerst via ruby-core <ruby-core@...>
Date: 2024-01-24 11:11:27 UTC
List: ruby-core #116404
Issue #20205 has been updated by duerst (Martin D=FCrst).





`frozen_string_literal` can lead to more efficient code, but it's also part=
 of a programming style (usually called functional programming). Functional=
 programming often leads to cleaner code, but it may require some additiona=
l programming effort. There's also a fundamental conflict between object-or=
iented programming (objects are generally mutable) and functional programmi=
ng, although Ruby is pretty good at integrating these concepts.



My main issue with this proposal is that I think it's probably the right th=
ing for most big code bases, but it may not be the right thing for quick-an=
d-dirty small scripts. And Ruby is used, and should continue to be usable, =
for both kinds of code.



Maybe what could help is a declaration on a higher level, e.g. per gem or s=
o rather than per source file. (That's just an idea, with many open questio=
ns: Where would the setting go? How would the interpreter pick it up? How w=
ould people become aware of it? ...)



----------------------------------------

Feature #20205: Enable `frozen_string_literal` by default

https://bugs.ruby-lang.org/issues/20205#change-106425



* Author: byroot (Jean Boussier)

* Status: Open

* Priority: Normal

----------------------------------------

### Context



The `frozen_string_literal: true` pragma was introduced in Ruby 2.3, and as=
 far as I'm aware the plan was initially to make it the default for Ruby 3.=
0, but this plan was abandoned because it would be too much of a breaking c=
hange without any real further notice.



According to Matz, he still wishes to enable `frozen_string_literal` by def=
ault in the future, but a reasonable migration plan is required.=20



The main issue is backward compatibility, flipping the switch immediately w=
ould break a lot of code, so there must be some deprecation period.



The usual the path forward for this kind of change is to emit deprecation w=
arnings one of multiple versions in advance.



One example of that was the Ruby 2.7 keyword argument deprecation. It was q=
uite verbose, and some users were initially annoyed, but I think the commun=
ity pulled through it and I don't seem to hear much about it anymore.



So for frozen string literals, the first step would be to start warning whe=
n a string that would be frozen in the future is mutated.



### Deprecation Warning Implementation



I implemented a quick proof of concept with @etienne in https://github.com/=
Shopify/ruby/pull/549



In short:



- Files with `# frozen_string_literal: true` or `# frozen_string_literal: f=
alse` don't change in behavior at all.

- Files with no `# frozen_string_literal` comment are compiled to use `putc=
hilledstring` opcode instead of regular `putstring`.

- This opcode mark the string with a user flag, when these strings are muta=
ted, a warning is issued.



Currently the proof of concept issue the warning at the mutation location, =
which in some case can make locating where the string was allocated a bit h=
ard.



But it is possible to improve it so the message also include the location a=
t which the literal string was allocated, and learning from the keyword arg=
ument warning experience,

we can record which warnings were already issued to avoid spamming users wi=
th duplicated warnings.



As currently implemented, there is almost no overhead. If we modify the imp=
lementation to record the literal location,

we'd incur a small memory overhead for each literal string in a file withou=
t an explicit `frozen_string_literal` pragma.



But I believe we could do it in a way that has no overhead if `Warning[:dep=
recated] =3D false`.



### Timeline



The migration would happen in 3 steps, each step can potentially last multi=
ple releases. e.g. `R0` could be `3.4`, `R1` be `3.7` and `R2` be `4.0`.

I don't have a strong opinion on the pace.



- Release `R0`: introduce the deprecation warning (only if deprecation warn=
ings enabled).

- Release `R1`: make the deprecation warning show up regardless of verbosit=
y level.

- Release `R2`: make string literals frozen by default.



### Impact



Given that `rubocop` is quite popular in the community and it has enforced =
the usage of `# frozen_string_literal: true` for years now,

I suspect a large part of the actively maintained codebases in the wild wou=
ldn't see any warnings.



And with recent versions of `minitest` enabling deprecation warnings by def=
ault (and [potentially RSpec too](https://github.com/rspec/rspec-core/issue=
s/2867)),

the few that didn't migrate will likely be made compatible quickly.



The real problem of course are the less actively developed libraries and ap=
plications. For such cases, any codebase can remain compatible by setting `=
RUBYOPT=3D"--disable=3Dfrozen_string_literal"`,

and so even after `R2` release. The flag would never be removed any legacy =
codebase can continue upgrading Ruby without changing a single line of cod =
by just flipping this flag.



### Workflow for library maintainers



As a library maintainer, fixing the deprecation warnings can be as simple a=
s prepending `# frozen_string_literal: false` at the top of all their sourc=
e files, and this will keep working forever.



Alternatively they can of course make their code compatible with frozen str=
ing literals.



Code that is frozen string literal compatible doesn't need to explicitly de=
clare it. Only code that need it turned of need to do so.



### Workflow for application owners



For application owners, the workflow is the same than for libraries.



However if they depend on a gem that hasn't updated, or that they can't upg=
rade it, they can run their application with `RUBYOPT=3D"--disable=3Dfrozen=
_string_literal"` and it will keep working forever.



Any user running into an incompatibility issue can set `RUBYOPT=3D"--disabl=
e=3Dfrozen_string_literal"` forever, even in `4.x`, the only thing changing=
 is the default value.



And any application for which all dependencies have been made fully frozen =
string literal compatible can set `RUBYOPT=3D"--enable=3Dfrozen_string_lite=
ral"` and start immediately removing magic comment from their codebase.









--=20

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/postorius/lists/ruby-c=
ore.ml.ruby-lang.org/

In This Thread