OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "tonic/dart_timer_heap.h" | 5 #include "tonic/dart_timer_heap.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
9 #include "base/time/time.h" | 9 #include "base/time/time.h" |
10 #include "tonic/dart_api_scope.h" | 10 #include "tonic/dart_api_scope.h" |
11 #include "tonic/dart_invoke.h" | 11 #include "tonic/dart_invoke.h" |
12 #include "tonic/dart_isolate_scope.h" | 12 #include "tonic/dart_isolate_scope.h" |
13 #include "tonic/dart_state.h" | 13 #include "tonic/dart_state.h" |
14 | 14 |
15 namespace blink { | 15 namespace tonic { |
16 | 16 |
17 DartTimerHeap::DartTimerHeap() : next_timer_id_(1), weak_factory_(this) { | 17 DartTimerHeap::DartTimerHeap() : next_timer_id_(1), weak_factory_(this) { |
18 } | 18 } |
19 | 19 |
20 DartTimerHeap::~DartTimerHeap() { | 20 DartTimerHeap::~DartTimerHeap() { |
21 } | 21 } |
22 | 22 |
23 int DartTimerHeap::Add(std::unique_ptr<Task> task) { | 23 int DartTimerHeap::Add(std::unique_ptr<Task> task) { |
24 int id = next_timer_id_++; | 24 int id = next_timer_id_++; |
25 Schedule(id, std::move(task)); | 25 Schedule(id, std::move(task)); |
(...skipping 20 matching lines...) Expand all Loading... |
46 if (!task->closure.dart_state()) | 46 if (!task->closure.dart_state()) |
47 return; | 47 return; |
48 DartIsolateScope scope(task->closure.dart_state()->isolate()); | 48 DartIsolateScope scope(task->closure.dart_state()->isolate()); |
49 DartApiScope api_scope; | 49 DartApiScope api_scope; |
50 DartInvokeAppClosure(task->closure.value(), 0, nullptr); | 50 DartInvokeAppClosure(task->closure.value(), 0, nullptr); |
51 if (task->repeating) | 51 if (task->repeating) |
52 Schedule(id, std::move(task)); | 52 Schedule(id, std::move(task)); |
53 } | 53 } |
54 | 54 |
55 } | 55 } |
OLD | NEW |