From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: AS4713 221.184.0.0/13 X-Spam-Status: No, score=-4.1 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS shortcircuit=no autolearn=ham autolearn_force=no version=3.4.2 Received: from neon.ruby-lang.org (neon.ruby-lang.org [221.186.184.75]) by dcvr.yhbt.net (Postfix) with ESMTP id E17B81F463 for ; Mon, 9 Sep 2019 21:16:34 +0000 (UTC) Received: from neon.ruby-lang.org (localhost [IPv6:::1]) by neon.ruby-lang.org (Postfix) with ESMTP id 73890120AC7; Tue, 10 Sep 2019 06:16:25 +0900 (JST) Received: from o1678948x4.outbound-mail.sendgrid.net (o1678948x4.outbound-mail.sendgrid.net [167.89.48.4]) by neon.ruby-lang.org (Postfix) with ESMTPS id 690C5120AB7 for ; Tue, 10 Sep 2019 06:16:23 +0900 (JST) Received: by filter0088p3iad2.sendgrid.net with SMTP id filter0088p3iad2-32122-5D76C128-4D 2019-09-09 21:16:24.755029587 +0000 UTC m=+15963.305463212 Received: from herokuapp.com (unknown [54.210.152.167]) by ismtpd0024p1mdw1.sendgrid.net (SG) with ESMTP id Zufk4wolQzOgEP8dnlFxUw for ; Mon, 09 Sep 2019 21:16:24.694 +0000 (UTC) Date: Mon, 09 Sep 2019 21:16:24 +0000 (UTC) From: matthew@kerwin.net.au Message-ID: References: Mime-Version: 1.0 X-Redmine-MailingListIntegration-Message-Ids: 70428 X-Redmine-Project: ruby-trunk X-Redmine-Issue-Id: 16155 X-Redmine-Issue-Author: connorshea X-Redmine-Sender: phluid61 X-Mailer: Redmine X-Redmine-Host: bugs.ruby-lang.org X-Redmine-Site: Ruby Issue Tracking System X-Auto-Response-Suppress: All Auto-Submitted: auto-generated X-SG-EID: =?us-ascii?Q?dc6bl8=2FRfjZl6IUFmz6hrXGqzg+6U4v9dH0u7=2FcQTE=2FiaV1pVKFk4g3mCiK0Ft?= =?us-ascii?Q?1e6KFlswBr3+HjleD4NNsoAV02HDExQm=2FDv1dl3?= =?us-ascii?Q?hcbRB3Xw9tYxMa0uQYYxaSgXhWdQdb15DcxBohY?= =?us-ascii?Q?Ho6RyYQdh=2F+XUQRQpCfWkFA0LqV6AEIbEE1LkUJ?= =?us-ascii?Q?UT6ebTNQfGJupR2CrqeUULSiQAYf5VJFvDg=3D=3D?= To: ruby-core@ruby-lang.org X-ML-Name: ruby-core X-Mail-Count: 94874 Subject: [ruby-core:94874] [Ruby master Feature#16155] Add an Array#intersection method X-BeenThere: ruby-core@ruby-lang.org X-Mailman-Version: 2.1.15 Precedence: list Reply-To: Ruby developers List-Id: Ruby developers List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: ruby-core-bounces@ruby-lang.org Sender: "ruby-core" Issue #16155 has been updated by phluid61 (Matthew Kerwin). connorshea (Connor Shea) wrote: > shevegen (Robert A. Heiler) wrote: > > Should we keep `intersection` as a simple alias for `&` or have it allow multiple arrays, to match the `difference` and `union` methods? The question should be: is it needed? ---------------------------------------- Feature #16155: Add an Array#intersection method https://bugs.ruby-lang.org/issues/16155#change-81490 * Author: connorshea (Connor Shea) * Status: Open * Priority: Normal * Assignee: * Target version: ---------------------------------------- `Array#union` and `Array#difference` were added in Ruby 2.6 ([see this bug](https://bugs.ruby-lang.org/issues/14097)), but an equivalent for `&` (intersection) was not. I'd like to propose `Array#intersection`. This would essentially just be a more readable alias for `Array#&`, in the same way that `Array#|` and `Array#-` have `Array#union` and `Array#difference`. I think it'd make sense for Ruby to have a more readable name for this method :) Current syntax: ``` ruby [ 1, 1, 3, 5 ] & [ 3, 2, 1 ] #=> [ 1, 3 ] [ 'a', 'b', 'b', 'z' ] & [ 'a', 'b', 'c' ] #=> [ 'a', 'b' ] ``` What I'd like to see added: ```ruby [ 1, 1, 3, 5 ].intersection([ 3, 2, 1 ]) #=> [ 1, 3 ] [ 'a', 'b', 'b', 'z' ].intersection([ 'a', 'b', 'c' ]) #=> [ 'a', 'b' ] ``` mame asks about `intersection` [in this comment](https://bugs.ruby-lang.org/issues/14097#note-26) on the `union`/`difference` bug, but as far as I can tell it was never addressed. [`Set#intersection`](http://ruby-doc.org/stdlib-2.6.2/libdoc/set/rdoc/Set.html#method-i-intersection) already exists and is an alias for `Set#&`, so there's precedent for such a method to exist. Thanks for Ruby, I enjoy using it a lot! :) Related links: - [PR for `union`](https://github.com/ruby/ruby/pull/1747) - [PR for `difference`](https://github.com/ruby/ruby/pull/1758) - [Bug for adding `union` and `difference` methods](https://bugs.ruby-lang.org/issues/14097) -- https://bugs.ruby-lang.org/