OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "platform/assert.h" | 5 #include "platform/assert.h" |
6 #include "vm/bootstrap_natives.h" | 6 #include "vm/bootstrap_natives.h" |
7 #include "vm/class_finalizer.h" | 7 #include "vm/class_finalizer.h" |
8 #include "vm/dart.h" | 8 #include "vm/dart.h" |
9 #include "vm/dart_api_impl.h" | 9 #include "vm/dart_api_impl.h" |
10 #include "vm/dart_entry.h" | 10 #include "vm/dart_entry.h" |
(...skipping 150 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
161 return retval; | 161 return retval; |
162 } | 162 } |
163 | 163 |
164 | 164 |
165 static bool CreateIsolate(Isolate* parent_isolate, | 165 static bool CreateIsolate(Isolate* parent_isolate, |
166 IsolateSpawnState* state, | 166 IsolateSpawnState* state, |
167 char** error) { | 167 char** error) { |
168 Dart_IsolateCreateCallback callback = Isolate::CreateCallback(); | 168 Dart_IsolateCreateCallback callback = Isolate::CreateCallback(); |
169 if (callback == NULL) { | 169 if (callback == NULL) { |
170 *error = strdup("Null callback specified for isolate creation\n"); | 170 *error = strdup("Null callback specified for isolate creation\n"); |
171 Isolate::SetCurrent(parent_isolate); | |
172 return false; | 171 return false; |
173 } | 172 } |
174 | 173 |
175 void* init_data = parent_isolate->init_callback_data(); | 174 void* init_data = parent_isolate->init_callback_data(); |
176 Isolate* child_isolate = reinterpret_cast<Isolate*>( | 175 Isolate* child_isolate = reinterpret_cast<Isolate*>( |
177 (callback)(state->script_url(), | 176 (callback)(state->script_url(), |
178 state->function_name(), | 177 state->function_name(), |
179 state->package_root(), | 178 state->package_root(), |
180 init_data, | 179 init_data, |
181 error)); | 180 error)); |
182 if (child_isolate == NULL) { | 181 if (child_isolate == NULL) { |
183 Isolate::SetCurrent(parent_isolate); | |
184 return false; | 182 return false; |
185 } | 183 } |
186 if (!state->is_spawn_uri()) { | 184 if (!state->is_spawn_uri()) { |
187 // For isolates spawned using the spawnFunction semantics we set | 185 // For isolates spawned using the spawnFunction semantics we set |
188 // the origin_id to the origin_id of the parent isolate. | 186 // the origin_id to the origin_id of the parent isolate. |
189 child_isolate->set_origin_id(parent_isolate->origin_id()); | 187 child_isolate->set_origin_id(parent_isolate->origin_id()); |
190 } | 188 } |
191 state->set_isolate(reinterpret_cast<Isolate*>(child_isolate)); | 189 state->set_isolate(reinterpret_cast<Isolate*>(child_isolate)); |
192 | |
193 Isolate::SetCurrent(parent_isolate); | |
194 return true; | 190 return true; |
195 } | 191 } |
196 | 192 |
197 | 193 |
198 static void Spawn(Isolate* parent_isolate, IsolateSpawnState* state) { | 194 static void Spawn(Isolate* parent_isolate, IsolateSpawnState* state) { |
| 195 Thread::ExitIsolate(); |
199 // Create a new isolate. | 196 // Create a new isolate. |
200 char* error = NULL; | 197 char* error = NULL; |
201 if (!CreateIsolate(parent_isolate, state, &error)) { | 198 if (!CreateIsolate(parent_isolate, state, &error)) { |
| 199 Thread::EnterIsolate(parent_isolate); |
202 delete state; | 200 delete state; |
203 const String& msg = String::Handle(String::New(error)); | 201 const String& msg = String::Handle(String::New(error)); |
204 free(error); | 202 free(error); |
205 ThrowIsolateSpawnException(msg); | 203 ThrowIsolateSpawnException(msg); |
206 } | 204 } |
207 | 205 Thread::EnterIsolate(parent_isolate); |
208 // Start the new isolate if it is already marked as runnable. | 206 // Start the new isolate if it is already marked as runnable. |
209 Isolate* spawned_isolate = state->isolate(); | 207 Isolate* spawned_isolate = state->isolate(); |
210 MutexLocker ml(spawned_isolate->mutex()); | 208 MutexLocker ml(spawned_isolate->mutex()); |
211 spawned_isolate->set_spawn_state(state); | 209 spawned_isolate->set_spawn_state(state); |
212 if (spawned_isolate->is_runnable()) { | 210 if (spawned_isolate->is_runnable()) { |
213 spawned_isolate->Run(); | 211 spawned_isolate->Run(); |
214 } | 212 } |
215 } | 213 } |
216 | 214 |
217 | 215 |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
302 MessageWriter writer(&data, &allocator, false); | 300 MessageWriter writer(&data, &allocator, false); |
303 writer.WriteMessage(msg); | 301 writer.WriteMessage(msg); |
304 | 302 |
305 PortMap::PostMessage(new Message(port.Id(), | 303 PortMap::PostMessage(new Message(port.Id(), |
306 data, writer.BytesWritten(), | 304 data, writer.BytesWritten(), |
307 Message::kOOBPriority)); | 305 Message::kOOBPriority)); |
308 return Object::null(); | 306 return Object::null(); |
309 } | 307 } |
310 | 308 |
311 } // namespace dart | 309 } // namespace dart |
OLD | NEW |