[#100689] [Ruby master Feature#17303] Make webrick to bundled gems or remove from stdlib — hsbt@...
Issue #17303 has been reported by hsbt (Hiroshi SHIBATA).
11 messages
2020/11/02
[#100852] [Ruby master Feature#17326] Add Kernel#must! to the standard library — zimmerman.jake@...
SXNzdWUgIzE3MzI2IGhhcyBiZWVuIHJlcG9ydGVkIGJ5IGpleiAoSmFrZSBaaW1tZXJtYW4pLg0K
24 messages
2020/11/14
[#100930] [Ruby master Feature#17333] Enumerable#many? — masafumi.o1988@...
Issue #17333 has been reported by okuramasafumi (Masafumi OKURA).
10 messages
2020/11/18
[#101071] [Ruby master Feature#17342] Hash#fetch_set — hunter_spawn@...
Issue #17342 has been reported by MaxLap (Maxime Lapointe).
26 messages
2020/11/25
[ruby-core:100777] [Ruby master Feature#17316] On memoization
From:
sawadatsuyoshi@...
Date:
2020-11-11 10:22:03 UTC
List:
ruby-core #100777
Issue #17316 has been reported by sawa (Tsuyoshi Sawada).
----------------------------------------
Feature #17316: On memoization
https://bugs.ruby-lang.org/issues/17316
* Author: sawa (Tsuyoshi Sawada)
* Status: Open
* Priority: Normal
----------------------------------------
I have seem so many attempts to memoize a value in the form:
```ruby
@foo ||= some_heavy_calculation(...)
```
improperly, i.e., even when the value can potentially be falsy. This practice is wide spread, and since in most cases memoization is about efficiency and it would not be critical if it does not work correctly, people do not seem to care so much about correcting the wrong usage.
In such case, the correct form would be:
```ruby
unless instance_variable_defined?(:foo)
@foo = some_heavy_calculation(...)
end
```
but this looks too long, and perhaps that is keeping people away from using it.
What about allowing `Kernel#instance_variable_set` to take a block instead of the second argument, in which case the assignment should be done only when the instance variable in not defined?
```ruby
instance_variable_set(:foo){some_heavy_calculation(...)}
```
Or, if that does not look right or seems to depart from the original usage of `instance_variable_set`, then what about having a new method?
```ruby
memoize(:foo){some_heavy_calculation(...)}
```
--
https://bugs.ruby-lang.org/
Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>