-
-
Notifications
You must be signed in to change notification settings - Fork 921
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Truffle] Hash#merge! works except for an ordering issue.
- Loading branch information
1 parent
3e334e0
commit 68a6a35
Showing
9 changed files
with
101 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,4 @@ | ||
fails:Hash#merge returns a new hash by combining self with the contents of other | ||
fails:Hash#merge sets any duplicate key to the value of block if passed a block | ||
fails:Hash#merge tries to convert the passed argument to a hash using #to_hash | ||
fails:Hash#merge does not call to_hash on hash subclasses | ||
fails:Hash#merge returns subclass instance for subclasses | ||
fails:Hash#merge processes entries with same order as each() | ||
fails:Hash#merge! adds the entries from other, overwriting duplicate keys. Returns self | ||
fails:Hash#merge! sets any duplicate key to the value of block if passed a block | ||
fails:Hash#merge! tries to convert the passed argument to a hash using #to_hash | ||
fails:Hash#merge! does not call to_hash on hash subclasses | ||
fails:Hash#merge! processes entries with same order as merge() | ||
fails:Hash#merge! raises a RuntimeError on a frozen instance that is modified | ||
fails:Hash#merge! checks frozen status before coercing an object with #to_hash | ||
fails:Hash#merge! raises a RuntimeError on a frozen instance that would not be modified | ||
fails:Hash#merge! does not raise an exception if changing the value of an existing key during iteration |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
# Copyright (c) 2007-2014, Evan Phoenix and contributors | ||
# All rights reserved. | ||
# | ||
# Redistribution and use in source and binary forms, with or without | ||
# modification, are permitted provided that the following conditions are met: | ||
# | ||
# * Redistributions of source code must retain the above copyright notice, this | ||
# list of conditions and the following disclaimer. | ||
# * Redistributions in binary form must reproduce the above copyright notice | ||
# this list of conditions and the following disclaimer in the documentation | ||
# and/or other materials provided with the distribution. | ||
# * Neither the name of Rubinius nor the names of its contributors | ||
# may be used to endorse or promote products derived from this software | ||
# without specific prior written permission. | ||
# | ||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE | ||
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
|
||
# Only part of Rubinius' hash.rb | ||
|
||
class Hash | ||
|
||
alias_method :store, :[]= | ||
|
||
# Used internally to get around subclasses redefining #[]= | ||
alias_method :__store__, :[]= | ||
|
||
def merge!(other) | ||
Rubinius.check_frozen | ||
|
||
other = Rubinius::Type.coerce_to other, Hash, :to_hash | ||
|
||
if block_given? | ||
other.each_item do |item| | ||
key = item.key | ||
if key? key | ||
__store__ key, yield(key, self[key], item.value) | ||
else | ||
__store__ key, item.value | ||
end | ||
end | ||
else | ||
other.each_item do |item| | ||
__store__ item.key, item.value | ||
end | ||
end | ||
self | ||
end | ||
|
||
alias_method :update, :merge! | ||
|
||
end |