diff options
author | Florian Frank <flori@ping.de> | 2011-07-04 18:04:14 +0200 |
---|---|---|
committer | Florian Frank <flori@ping.de> | 2011-07-04 18:04:14 +0200 |
commit | 58a54defa3344f94b211b1d3b5e1a6e24e4054b0 (patch) | |
tree | e8d11a478a55f6d317b80b135eefaf3d090d883b /java/src/json/ext/ParserService.java | |
parent | 738a65c873f7ecc82352fbd516aadfec67063fc8 (diff) | |
parent | 1a9725371131300e3230b4b9c14e669d334f4152 (diff) | |
download | json-58a54defa3344f94b211b1d3b5e1a6e24e4054b0.tar.gz |
Merge branch 'fix_memory_leak' of https://github.com/bigfix/json into development
Diffstat (limited to 'java/src/json/ext/ParserService.java')
-rw-r--r-- | java/src/json/ext/ParserService.java | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/java/src/json/ext/ParserService.java b/java/src/json/ext/ParserService.java index e0805a7..f2ecae1 100644 --- a/java/src/json/ext/ParserService.java +++ b/java/src/json/ext/ParserService.java @@ -7,6 +7,7 @@ package json.ext; import java.io.IOException; +import java.lang.ref.WeakReference; import org.jruby.Ruby; import org.jruby.RubyClass; @@ -23,8 +24,8 @@ public class ParserService implements BasicLibraryService { runtime.getLoadService().require("json/common"); RuntimeInfo info = RuntimeInfo.initRuntime(runtime); - info.jsonModule = runtime.defineModule("JSON"); - RubyModule jsonExtModule = info.jsonModule.defineModuleUnder("Ext"); + info.jsonModule = new WeakReference<RubyModule>(runtime.defineModule("JSON")); + RubyModule jsonExtModule = info.jsonModule.get().defineModuleUnder("Ext"); RubyClass parserClass = jsonExtModule.defineClassUnder("Parser", runtime.getObject(), Parser.ALLOCATOR); |