Mercurial Hosting > luan
diff src/luan/interp/Closure.java @ 77:4bf3d0c0b6b9
make LuanState cloneable
git-svn-id: https://luan-java.googlecode.com/svn/trunk@78 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Fri, 15 Feb 2013 09:55:17 +0000 |
parents | 8ede219cd111 |
children | 7c08b611125d |
line wrap: on
line diff
--- a/src/luan/interp/Closure.java Fri Feb 15 04:52:16 2013 +0000 +++ b/src/luan/interp/Closure.java Fri Feb 15 09:55:17 2013 +0000 @@ -4,9 +4,11 @@ import luan.LuanState; import luan.LuanElement; import luan.LuanException; +import luan.DeepCloner; +import luan.DeepCloneable; -final class Closure extends LuanFunction { +final class Closure extends LuanFunction implements DeepCloneable<Closure> { private final Chunk chunk; final UpValue[] upValues; private final static UpValue[] NO_UP_VALUES = new UpValue[0]; @@ -24,6 +26,19 @@ } } + 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() { + return new Closure(this); + } + + @Override public void deepenClone(Closure clone,DeepCloner cloner) { + cloner.deepenClone(clone.upValues); + } + public Object[] call(LuanState luan,Object[] args) throws LuanException { return call(this,(LuanStateImpl)luan,args); }