mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
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:
parent
fd778c2c76
commit
959172a112
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user