-
-
Notifications
You must be signed in to change notification settings - Fork 925
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #4955 from jruby/use_ruby_weakref
Revert to using weakref.rb, since it's based on a proper weak map.
- 9.4.12.0
- 9.4.11.0
- 9.4.10.0
- 9.4.9.0
- 9.4.8.0
- 9.4.7.0
- 9.4.6.0
- 9.4.5.0
- 9.4.4.0
- 9.4.3.0
- 9.4.2.0
- 9.4.1.0
- 9.4.0.0
- 9.3.15.0
- 9.3.14.0
- 9.3.13.0
- 9.3.12.0
- 9.3.11.0
- 9.3.10.0
- 9.3.9.0
- 9.3.8.0
- 9.3.7.0
- 9.3.6.0
- 9.3.5.0
- 9.3.4.0
- 9.3.3.0
- 9.3.2.0
- 9.3.1.0
- 9.3.0.0
- 9.2.21.0
- 9.2.20.1
- 9.2.20.0
- 9.2.19.0
- 9.2.18.0
- 9.2.17.0
- 9.2.16.0
- 9.2.15.0
- 9.2.14.0
- 9.2.13.0
- 9.2.12.0
- 9.2.11.1
- 9.2.11.0
- 9.2.10.0
- 9.2.9.0
- 9.2.8.0
- 9.2.7.0
- 9.2.6.0
- 9.2.5.0
- 9.2.4.1
- 9.2.4.0
- 9.2.3.0
- 9.2.2.0
- 9.2.1.0
- 9.2.0.0
- 9.1.17.0
- 9.1.16.0
Showing
6 changed files
with
113 additions
and
159 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
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 was deleted.
Oops, something went wrong.
46 changes: 0 additions & 46 deletions
46
core/src/main/java/org/jruby/ext/weakref/WeakRefLibrary.java
This file was deleted.
Oops, something went wrong.
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,107 @@ | ||
# frozen_string_literal: false | ||
require "delegate" | ||
|
||
# Weak Reference class that allows a referenced object to be | ||
# garbage-collected. | ||
# | ||
# A WeakRef may be used exactly like the object it references. | ||
# | ||
# Usage: | ||
# | ||
# foo = Object.new # create a new object instance | ||
# p foo.to_s # original's class | ||
# foo = WeakRef.new(foo) # reassign foo with WeakRef instance | ||
# p foo.to_s # should be same class | ||
# GC.start # start the garbage collector | ||
# p foo.to_s # should raise exception (recycled) | ||
# | ||
# == Example | ||
# | ||
# With help from WeakRef, we can implement our own rudimentary WeakHash class. | ||
# | ||
# We will call it WeakHash, since it's really just a Hash except all of it's | ||
# keys and values can be garbage collected. | ||
# | ||
# require 'weakref' | ||
# | ||
# class WeakHash < Hash | ||
# def []= key, obj | ||
# super WeakRef.new(key), WeakRef.new(obj) | ||
# end | ||
# end | ||
# | ||
# This is just a simple implementation, we've opened the Hash class and changed | ||
# Hash#store to create a new WeakRef object with +key+ and +obj+ parameters | ||
# before passing them as our key-value pair to the hash. | ||
# | ||
# With this you will have to limit your self to String keys, otherwise you | ||
# will get an ArgumentError because WeakRef cannot create a finalizer for a | ||
# Symbol. Symbols are immutable and cannot be garbage collected. | ||
# | ||
# Let's see it in action: | ||
# | ||
# omg = "lol" | ||
# c = WeakHash.new | ||
# c['foo'] = "bar" | ||
# c['baz'] = Object.new | ||
# c['qux'] = omg | ||
# puts c.inspect | ||
# #=> {"foo"=>"bar", "baz"=>#<Object:0x007f4ddfc6cb48>, "qux"=>"lol"} | ||
# | ||
# # Now run the garbage collector | ||
# GC.start | ||
# c['foo'] #=> nil | ||
# c['baz'] #=> nil | ||
# c['qux'] #=> nil | ||
# omg #=> "lol" | ||
# | ||
# puts c.inspect | ||
# #=> WeakRef::RefError: Invalid Reference - probably recycled | ||
# | ||
# You can see the local variable +omg+ stayed, although its reference in our | ||
# hash object was garbage collected, along with the rest of the keys and | ||
# values. Also, when we tried to inspect our hash, we got a WeakRef::RefError. | ||
# This is because these objects were also garbage collected. | ||
|
||
class WeakRef < Delegator | ||
|
||
## | ||
# RefError is raised when a referenced object has been recycled by the | ||
# garbage collector | ||
|
||
class RefError < StandardError | ||
end | ||
|
||
@@__map = ::ObjectSpace::WeakMap.new | ||
|
||
## | ||
# Creates a weak reference to +orig+ | ||
# | ||
# Raises an ArgumentError if the given +orig+ is immutable, such as Symbol, | ||
# Fixnum, or Float. | ||
|
||
def initialize(orig) | ||
case orig | ||
when true, false, nil | ||
@delegate_sd_obj = orig | ||
else | ||
@@__map[self] = orig | ||
end | ||
super | ||
end | ||
|
||
def __getobj__ # :nodoc: | ||
@@__map[self] or defined?(@delegate_sd_obj) ? @delegate_sd_obj : | ||
Kernel::raise(RefError, "Invalid Reference - probably recycled", Kernel::caller(2)) | ||
end | ||
|
||
def __setobj__(obj) # :nodoc: | ||
end | ||
|
||
## | ||
# Returns true if the referenced object is still alive. | ||
|
||
def weakref_alive? | ||
@@__map.key?(self) or defined?(@delegate_sd_obj) | ||
end | ||
end |
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 |
---|---|---|
|
@@ -66,6 +66,7 @@ | |
unicode_normalize.rb | ||
uri | ||
uri.rb | ||
weakref.rb | ||
webrick | ||
webrick.rb | ||
xmlrpc | ||
|