[前][次][番号順一覧][スレッド一覧]

ruby-changes:71906

From: Jean <ko1@a...>
Date: Sat, 21 May 2022 03:32:13 +0900 (JST)
Subject: [ruby-changes:71906] 65122d09d5 (master): [Feature #18595] Alias String#-@ as String#dedup

https://git.ruby-lang.org/ruby.git/commit/?id=65122d09d5

From 65122d09d515c9183e643d5f7f31d24251b149ed Mon Sep 17 00:00:00 2001
From: Jean Boussier <jean.boussier@g...>
Date: Mon, 21 Feb 2022 12:17:02 +0100
Subject: [Feature #18595] Alias String#-@ as String#dedup

---
 spec/ruby/core/string/dedup_spec.rb   |  8 ++++++
 spec/ruby/core/string/shared/dedup.rb | 47 +++++++++++++++++++++++++++++++++++
 spec/ruby/core/string/uminus_spec.rb  | 47 ++---------------------------------
 string.c                              |  5 +++-
 4 files changed, 61 insertions(+), 46 deletions(-)
 create mode 100644 spec/ruby/core/string/dedup_spec.rb
 create mode 100644 spec/ruby/core/string/shared/dedup.rb

diff --git a/spec/ruby/core/string/dedup_spec.rb b/spec/ruby/core/string/dedup_spec.rb
new file mode 100644
index 0000000000..919d440c51
--- /dev/null
+++ b/spec/ruby/core/string/dedup_spec.rb
@@ -0,0 +1,8 @@ https://github.com/ruby/ruby/blob/trunk/spec/ruby/core/string/dedup_spec.rb#L1
+require_relative '../../spec_helper'
+require_relative 'shared/dedup'
+
+describe 'String#dedup' do
+  ruby_version_is '3.2'do
+    it_behaves_like :string_dedup, :dedup
+  end
+end
diff --git a/spec/ruby/core/string/shared/dedup.rb b/spec/ruby/core/string/shared/dedup.rb
new file mode 100644
index 0000000000..345e874583
--- /dev/null
+++ b/spec/ruby/core/string/shared/dedup.rb
@@ -0,0 +1,47 @@ https://github.com/ruby/ruby/blob/trunk/spec/ruby/core/string/shared/dedup.rb#L1
+describe :string_dedup, shared: true do
+  it 'returns self if the String is frozen' do
+    input  = 'foo'.freeze
+    output = input.send(@method)
+
+    output.should equal(input)
+    output.should.frozen?
+  end
+
+  it 'returns a frozen copy if the String is not frozen' do
+    input  = 'foo'
+    output = input.send(@method)
+
+    output.should.frozen?
+    output.should_not equal(input)
+    output.should == 'foo'
+  end
+
+  it "returns the same object for equal unfrozen strings" do
+    origin = "this is a string"
+    dynamic = %w(this is a string).join(' ')
+
+    origin.should_not equal(dynamic)
+    origin.send(@method).should equal(dynamic.send(@method))
+  end
+
+  it "returns the same object when it's called on the same String literal" do
+    "unfrozen string".send(@method).should equal("unfrozen string".send(@method))
+    "unfrozen string".send(@method).should_not equal("another unfrozen string".send(@method))
+  end
+
+  it "deduplicates frozen strings" do
+    dynamic = %w(this string is frozen).join(' ').freeze
+
+    dynamic.should_not equal("this string is frozen".freeze)
+
+    dynamic.send(@method).should equal("this string is frozen".freeze)
+    dynamic.send(@method).should equal("this string is frozen".send(@method).freeze)
+  end
+
+  ruby_version_is "3.0" do
+    it "interns the provided string if it is frozen" do
+      dynamic = "this string is unique and frozen #{rand}".freeze
+      dynamic.send(@method).should equal(dynamic)
+    end
+  end
+end
diff --git a/spec/ruby/core/string/uminus_spec.rb b/spec/ruby/core/string/uminus_spec.rb
index 800dca5044..46d88f6704 100644
--- a/spec/ruby/core/string/uminus_spec.rb
+++ b/spec/ruby/core/string/uminus_spec.rb
@@ -1,49 +1,6 @@ https://github.com/ruby/ruby/blob/trunk/spec/ruby/core/string/uminus_spec.rb#L1
 require_relative '../../spec_helper'
+require_relative 'shared/dedup'
 
 describe 'String#-@' do
-  it 'returns self if the String is frozen' do
-    input  = 'foo'.freeze
-    output = -input
-
-    output.should equal(input)
-    output.should.frozen?
-  end
-
-  it 'returns a frozen copy if the String is not frozen' do
-    input  = 'foo'
-    output = -input
-
-    output.should.frozen?
-    output.should_not equal(input)
-    output.should == 'foo'
-  end
-
-  it "returns the same object for equal unfrozen strings" do
-    origin = "this is a string"
-    dynamic = %w(this is a string).join(' ')
-
-    origin.should_not equal(dynamic)
-    (-origin).should equal(-dynamic)
-  end
-
-  it "returns the same object when it's called on the same String literal" do
-    (-"unfrozen string").should equal(-"unfrozen string")
-    (-"unfrozen string").should_not equal(-"another unfrozen string")
-  end
-
-  it "deduplicates frozen strings" do
-    dynamic = %w(this string is frozen).join(' ').freeze
-
-    dynamic.should_not equal("this string is frozen".freeze)
-
-    (-dynamic).should equal("this string is frozen".freeze)
-    (-dynamic).should equal(-"this string is frozen".freeze)
-  end
-
-  ruby_version_is "3.0" do
-    it "interns the provided string if it is frozen" do
-      dynamic = "this string is unique and frozen #{rand}".freeze
-      (-dynamic).should equal(dynamic)
-    end
-  end
+  it_behaves_like :string_dedup, :-@
 end
diff --git a/string.c b/string.c
index 02044821bc..83d90ff3a9 100644
--- a/string.c
+++ b/string.c
@@ -2933,7 +2933,9 @@ str_uplus(VALUE str) https://github.com/ruby/ruby/blob/trunk/string.c#L2933
  * Returns a frozen, possibly pre-existing copy of the string.
  *
  * The returned \String will be deduplicated as long as it does not have
- * any instance variables set on it.
+ * any instance variables set on it and is not a String subclass.
+ *
+ * String#dedup is an alias for String#-@.
  */
 static VALUE
 str_uminus(VALUE str)
@@ -11879,6 +11881,7 @@ Init_String(void) https://github.com/ruby/ruby/blob/trunk/string.c#L11881
     rb_define_method(rb_cString, "freeze", rb_str_freeze, 0);
     rb_define_method(rb_cString, "+@", str_uplus, 0);
     rb_define_method(rb_cString, "-@", str_uminus, 0);
+    rb_define_alias(rb_cString, "dedup", "-@");
 
     rb_define_method(rb_cString, "to_i", rb_str_to_i, -1);
     rb_define_method(rb_cString, "to_f", rb_str_to_f, 0);
-- 
cgit v1.2.1


--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]