return naturally from function in Continuations.shift rather than via the continuation

Since the function in question is the only one on the call stack above
the reset method, there's no need to invoke the captured continuation
-- we get the same effect by just returning normally, and it's more
efficient that way.
This commit is contained in:
Joel Dice 2014-03-24 09:50:09 -06:00
parent fd778c2c76
commit 959172a112

View File

@ -187,7 +187,7 @@ public class Continuations {
final Reset reset = new Reset(latestReset.get()); final Reset reset = new Reset(latestReset.get());
latestReset.set(reset); latestReset.set(reset);
try { try {
C result = (C) callWithCurrentContinuation Object result = callWithCurrentContinuation
(new Function<Callback<Object>,Object>() { (new Function<Callback<Object>,Object>() {
public Object call(Callback continuation) throws Exception { public Object call(Callback continuation) throws Exception {
reset.continuation = continuation; reset.continuation = continuation;
@ -195,13 +195,15 @@ public class Continuations {
} }
}); });
Cell<Callback> shift = reset.shifts; while (true) {
if (shift != null) { Cell<Function> shift = reset.shifts;
reset.shifts = shift.next; if (shift != null) {
shift.value.handleResult(result); reset.shifts = shift.next;
result = shift.value.call(result);
} else {
return (C) result;
}
} }
return result;
} finally { } finally {
latestReset.set(reset.next); latestReset.set(reset.next);
} }
@ -215,32 +217,36 @@ public class Continuations {
(new Function<Callback<Object>,Object>() { (new Function<Callback<Object>,Object>() {
public Object call(final Callback continuation) { public Object call(final Callback continuation) {
final Reset reset = latestReset.get(); final Reset reset = latestReset.get();
reset.shifts = new Cell(new Callback() { reset.shifts = new Cell(new Function() {
public void handleResult(Object ignored) { public Object call(Object ignored) throws Exception {
try { return receiver.call
reset.continuation.handleResult (new Function() {
(receiver.call public Object call(final Object argument)
(new Function() { throws Exception
public Object call(final Object argument) {
throws Exception return callWithCurrentContinuation
{ (new Function<Callback<Object>,Object>() {
return callWithCurrentContinuation public Object call
(new Function<Callback<Object>,Object>() { (final Callback shiftContinuation)
public Object call(Callback shiftContinuation) throws Exception
throws Exception {
{ reset.shifts = new Cell
reset.shifts = new Cell (new Function() {
(shiftContinuation, reset.shifts); public Object call(Object result)
throws Exception
{
shiftContinuation.handleResult(result);
throw new AssertionError();
}
},
reset.shifts);
continuation.handleResult(argument); continuation.handleResult(argument);
throw new AssertionError(); throw new AssertionError();
} }
}); });
} }
})); });
} catch (Exception e) {
reset.continuation.handleException(e);
}
} }
public void handleException(Throwable exception) { public void handleException(Throwable exception) {
@ -312,7 +318,7 @@ public class Continuations {
private static class Reset { private static class Reset {
public Callback continuation; public Callback continuation;
public final Reset next; public final Reset next;
public Cell<Callback> shifts; public Cell<Function> shifts;
public Reset(Reset next) { public Reset(Reset next) {
this.next = next; this.next = next;