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/