Mercurial Hosting > luan
diff src/luan/interp/Closure.java @ 78:7c08b611125d
better deep cloning
git-svn-id: https://luan-java.googlecode.com/svn/trunk@79 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Fri, 15 Feb 2013 22:29:16 +0000 |
parents | 4bf3d0c0b6b9 |
children | 6db8f286fa6c |
line wrap: on
line diff
--- a/src/luan/interp/Closure.java Fri Feb 15 09:55:17 2013 +0000 +++ b/src/luan/interp/Closure.java Fri Feb 15 22:29:16 2013 +0000 @@ -10,7 +10,7 @@ final class Closure extends LuanFunction implements DeepCloneable<Closure> { private final Chunk chunk; - final UpValue[] upValues; + private UpValue[] upValues; private final static UpValue[] NO_UP_VALUES = new UpValue[0]; Closure(LuanStateImpl luan,Chunk chunk) { @@ -28,7 +28,6 @@ private Closure(Closure c) { this.chunk = c.chunk; - this.upValues = c.upValues==NO_UP_VALUES ? NO_UP_VALUES : c.upValues.clone(); } @Override public Closure shallowClone() { @@ -36,7 +35,11 @@ } @Override public void deepenClone(Closure clone,DeepCloner cloner) { - cloner.deepenClone(clone.upValues); + clone.upValues = cloner.deepClone(upValues); + } + + UpValue[] upValues() { + return upValues; } public Object[] call(LuanState luan,Object[] args) throws LuanException {