mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 12:34:17 +00:00
Fix bug in timer clean up
Summary: One of the impacts of this bug is that Java is firing timer completion events into JavaScript for timers that should have been deleted. JavaScript filters these out so it doesn't impact the app developer. However, Java is completing more timers than necessary. When cleaning up a timer, we were accidentally deleting the whole set of timers for that context. Instead, we should just delete that timer from its context. Adam Comella Microsoft Corp. Closes https://github.com/facebook/react-native/pull/9361 Differential Revision: D3797573 fbshipit-source-id: c30ed600af741601f2babdfc61da9aac549cbadb
This commit is contained in:
parent
69c889815e
commit
06e52f8e8c
@ -104,10 +104,16 @@ public final class Timing extends ReactContextBaseJavaModule implements Lifecycl
|
|||||||
timer.mTargetTime = frameTimeMillis + timer.mInterval;
|
timer.mTargetTime = frameTimeMillis + timer.mInterval;
|
||||||
mTimers.add(timer);
|
mTimers.add(timer);
|
||||||
} else {
|
} else {
|
||||||
|
SparseArray<Timer> timers = mTimerIdsToTimers.get(timer.mExecutorToken);
|
||||||
|
if (timers != null) {
|
||||||
|
timers.remove(timer.mCallbackID);
|
||||||
|
if (timers.size() == 0) {
|
||||||
mTimerIdsToTimers.remove(timer.mExecutorToken);
|
mTimerIdsToTimers.remove(timer.mExecutorToken);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (Map.Entry<ExecutorToken, WritableArray> entry : mTimersToCall.entrySet()) {
|
for (Map.Entry<ExecutorToken, WritableArray> entry : mTimersToCall.entrySet()) {
|
||||||
getReactApplicationContext().getJSModule(entry.getKey(), JSTimersExecution.class)
|
getReactApplicationContext().getJSModule(entry.getKey(), JSTimersExecution.class)
|
||||||
@ -385,7 +391,10 @@ public final class Timing extends ReactContextBaseJavaModule implements Lifecycl
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// We may have already called/removed it
|
// We may have already called/removed it
|
||||||
|
timersForContext.remove(timerId);
|
||||||
|
if (timersForContext.size() == 0) {
|
||||||
mTimerIdsToTimers.remove(executorToken);
|
mTimerIdsToTimers.remove(executorToken);
|
||||||
|
}
|
||||||
mTimers.remove(timer);
|
mTimers.remove(timer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user