[#101174] [Ruby master Bug#17359] Ractor copy mode is not Ractor-safe — marcandre-ruby-core@...

Issue #17359 has been reported by marcandre (Marc-Andre Lafortune).

17 messages 2020/12/01

[#101217] [Ruby master Feature#17363] Timeouts — marcandre-ruby-core@...

Issue #17363 has been reported by marcandre (Marc-Andre Lafortune).

19 messages 2020/12/03

[#101250] [Ruby master Bug#17369] Introduce non-blocking `Process.wait`, `Kernel.system` and related methods. — samuel@...

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

12 messages 2020/12/05

[#101276] [Ruby master Bug#17373] Ruby 3.0 is slower at Discourse bench than Ruby 2.7 — sam.saffron@...

Issue #17373 has been reported by sam.saffron (Sam Saffron).

11 messages 2020/12/07

[#101278] [Ruby master Bug#17374] Refined methods aren't visible from a refinementRefinements that include/prepend module — marcandre-ruby-core@...

Issue #17374 has been reported by marcandre (Marc-Andre Lafortune).

17 messages 2020/12/07

[#101317] [Ruby master Feature#17378] Ractor#receive with filtering like other actor langauge — ko1@...

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

9 messages 2020/12/08

[#101343] [Ruby master Bug#17382] Segfault in String#inspect — lionel.perrin@...

Issue #17382 has been reported by lionelperrin (Lionel Perrin).

10 messages 2020/12/09

[#101381] [Ruby master Bug#17385] Test failures on gcc 11 — jaruga@...

Issue #17385 has been reported by jaruga (Jun Aruga).

18 messages 2020/12/10

[#101458] [Ruby master Bug#17394] TCPServer is not thread safe on win32 — aladjev.andrew@...

Issue #17394 has been reported by puchuu (Andrew Aladjev).

9 messages 2020/12/14

[#101472] [Ruby master Feature#17397] shareable_literal_constant should check at runtime, not at parse time — marcandre-ruby-core@...

Issue #17397 has been reported by marcandre (Marc-Andre Lafortune).

10 messages 2020/12/16

[#101475] [Ruby master Bug#17398] SyntaxError in endless method — zverok.offline@...

Issue #17398 has been reported by zverok (Victor Shepelev).

15 messages 2020/12/16

[#101477] [Ruby master Misc#17399] Are endless methods experimental? — zverok.offline@...

Issue #17399 has been reported by zverok (Victor Shepelev).

13 messages 2020/12/16

[#101480] [Ruby master Bug#17400] Incorrect character downcase for Greek Sigma — xfalcox@...

SXNzdWUgIzE3NDAwIGhhcyBiZWVuIHJlcG9ydGVkIGJ5IHhmYWxjb3ggKFJhZmFlbCBTaWx2YSku

10 messages 2020/12/16

[#101513] [Ruby master Bug#17405] irb ---nomultiline gets exception when output contains some non-ascii characters — rsharman@...

SXNzdWUgIzE3NDA1IGhhcyBiZWVuIHJlcG9ydGVkIGJ5IHJzaGFybWFuIChSaWNoYXJkIFNoYXJt

8 messages 2020/12/18

[#101534] [Ruby master Bug#17409] Endless range of dates stuck on include? when miss — sergey.gnuskov@...

Issue #17409 has been reported by gsmetal (Sergey G).

9 messages 2020/12/19

[#101546] [Ruby master Bug#17411] Syntax error with . in pattern — zverok.offline@...

Issue #17411 has been reported by zverok (Victor Shepelev).

10 messages 2020/12/19

[#101598] [Ruby master Bug#17420] Unsafe mutation of $" when doing non-RubyGems require in Ractor — eregontp@...

Issue #17420 has been reported by Eregon (Benoit Daloze).

12 messages 2020/12/21

[#101635] [Ruby master Bug#17428] Method#inspect bad output for class methods — marcandre-ruby-core@...

Issue #17428 has been reported by marcandre (Marc-Andre Lafortune).

13 messages 2020/12/23

[#101639] [Ruby master Bug#17429] Prohibit include/prepend in refinement modules — shugo@...

Issue #17429 has been reported by shugo (Shugo Maeda).

32 messages 2020/12/23

[#101707] [Ruby master Feature#17472] HashWithIndifferentAccess like Hash extension — naruse@...

Issue #17472 has been reported by naruse (Yui NARUSE).

31 messages 2020/12/26

[#101710] [Ruby master Feature#17473] Make Pathname to embedded class of Ruby — hsbt@...

Issue #17473 has been reported by hsbt (Hiroshi SHIBATA).

28 messages 2020/12/26

[#101719] [Ruby master Feature#17474] Interpreting constants at compile time — jzakiya@...

Issue #17474 has been reported by jzakiya (Jabari Zakiya).

23 messages 2020/12/26

[#101735] [Ruby master Misc#17480] DevelopersMeeting20210113Japan — mame@...

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

12 messages 2020/12/27

[#101790] [Ruby master Bug#17486] Build fails on darwin due to libtool being removed — dark.panda@...

Issue #17486 has been reported by dark.panda (J Smith).

11 messages 2020/12/28

[#101794] [Ruby master Bug#17488] Regression in Ruby 3: Hash#key? is non-deterministic when argument uses DelegateClass — myron.marston@...

Issue #17488 has been reported by myronmarston (Myron Marston).

11 messages 2020/12/28

[#101809] [Ruby master Feature#17490] Rename RubyVM::MJIT to RubyVM::JIT — takashikkbn@...

Issue #17490 has been reported by k0kubun (Takashi Kokubun).

15 messages 2020/12/30

[#101838] [Ruby master Feature#17496] Add constant Math::TAU — jzakiya@...

Issue #17496 has been reported by jzakiya (Jabari Zakiya).

32 messages 2020/12/31

[#101840] [Ruby master Bug#17497] Ractor performance issue — marcandre-ruby-core@...

SXNzdWUgIzE3NDk3IGhhcyBiZWVuIHJlcG9ydGVkIGJ5IG1hcmNhbmRyZSAoTWFyYy1BbmRyZSBM

21 messages 2020/12/31

[ruby-core:101351] Re: [Ruby master Feature#17333] Enumerable#many?

From: Austin Ziegler <halostatue@...>
Date: 2020-12-10 02:35:41 UTC
List: ruby-core #101351
I started with the opinion that this wasn=E2=80=99t necessary, but the simp=
lest
Ruby implementation I could come up with is this:

  def many?
    reduce(false) { |f, v|
      vp =3D block_given? ? yield v : v
      break true if f && vp
      vp
    }
  end

It=E2=80=99s probably a little less efficient than the ActiveSupport extens=
ion
(which uses two different branches for `block_given?` or not). Something
similar was recently suggested to the Elixir core list, and what was
decided there is I think a little more generalizable, `count_until` (
https://github.com/elixir-lang/elixir/pull/10532).

Here=E2=80=99s a Ruby implementation of what could be Enumerable#count_unti=
l?

  def count_until(limit, match =3D nil, &block)
    cnt =3D 0

    if match
      warn 'warning: given block not used' if block
      block =3D ->(v) { v =3D=3D match }
    elsif !block
      return [limit, count].min if respond_to?(:size)
      block =3D ->(_) { true }
    end

    stop_at =3D limit - 1

    reduce(0) { |c, v|
      c +=3D 1 if block.(v)

      break limit if c =3D=3D stop_at

      c
    }
  end

  # (1..20).count_until(5) # =3D> 5
  # (1..20).count_until(50) # =3D> 20
  # (1..10).count_until(10) =3D=3D 10 # =3D> true # At least 10
  # (1..11).count_until(10) =3D=3D 10 # =3D> true # At least 10
  # (1..11).count_until(10 + 1) > 10 # =3D> true # More than 10
  # (1..5).count_until(10) < 10 # =3D> true # Less than 10
  # (1..10).count_until(10 + 1) =3D=3D 10 # =3D> true # Exactly ten

-a

On Wed, Dec 9, 2020 at 8:56 AM <masafumi.o1988@gmail.com> wrote:

> Issue #17333 has been updated by okuramasafumi (Masafumi OKURA).
>
>
> Here are a usecase where we could use `many?` over `count` for better
> performance.
>
>
> https://github.com/Homebrew/brew/blob/master/Library/Homebrew/cask/audit.=
rb#L188
>
> This code, `cask.artifacts.count { |k| k.is_a?(Artifact::Uninstall) } > 1=
`
> calls block as many times as the size of `cask.artifact`. In contrast,
> `cask.artifacts.many? { |k| k.is_a?(Artifact::Uninstall) }` calls blocks
> only before finding second matching artifact, which could improve
> performance.
> Like this case where we cannot expect the size of collection, using
> `count` could cost a lot and introducing `many?` could help.
>
> ----------------------------------------
> Feature #17333: Enumerable#many?
> https://bugs.ruby-lang.org/issues/17333#change-89042
>
> * Author: okuramasafumi (Masafumi OKURA)
> * Status: Open
> * Priority: Normal
> ----------------------------------------
> `Enumerable#many?` method is implemented in ActiveSupport.
> https://api.rubyonrails.org/classes/Enumerable.html#method-i-many-3F
> However, it's slightly different from Ruby's core methods such as `one?`
> or `all?`, where they take pattern argument.
> I believe these methods should behave the same so that it's easier to
> guess and learn.
>
> We already have `none?`, `one?`, `any?` and `all?`, which translate into
> `=3D=3D 0`, `=3D=3D 1`, `> 0` and `=3D=3D self.size`.
> `many?` method translates into `> 1`, which is reasonable to exist.
> Currently we need to write something this:
>
> ```ruby
> [1, 2, 3].count(&:odd?) > 1
> ```
>
> With `many?`, we can make it simpler:
>
> ```ruby
> [1, 2, 3].many?(&:odd?)
> ```
>
> Pull Request on GitHub is available at
> https://github.com/ruby/ruby/pull/3785
>
>
>
> --
> https://bugs.ruby-lang.org/
>
> Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=3Dunsubscrib=
e>
> <http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>
>


--=20
Austin Ziegler =E2=80=A2 halostatue@gmail.com =E2=80=A2 austin@halostatue.c=
a
http://www.halostatue.ca/ =E2=80=A2 http://twitter.com/halostatue

Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>

In This Thread