| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 #ifndef VM_HANDLES_H_ | 5 #ifndef VM_HANDLES_H_ |
| 6 #define VM_HANDLES_H_ | 6 #define VM_HANDLES_H_ |
| 7 | 7 |
| 8 #include "vm/allocation.h" | 8 #include "vm/allocation.h" |
| 9 #include "vm/flags.h" | 9 #include "vm/flags.h" |
| 10 #include "vm/os.h" | 10 #include "vm/os.h" |
| (...skipping 274 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 285 static int ZoneHandleCount(); | 285 static int ZoneHandleCount(); |
| 286 | 286 |
| 287 friend class ApiZone; | 287 friend class ApiZone; |
| 288 friend class ApiNativeScope; | 288 friend class ApiNativeScope; |
| 289 }; | 289 }; |
| 290 | 290 |
| 291 | 291 |
| 292 // The class HandleScope is used to start a new handles scope in the code. | 292 // The class HandleScope is used to start a new handles scope in the code. |
| 293 // It is used as follows: | 293 // It is used as follows: |
| 294 // { | 294 // { |
| 295 // HANDLESCOPE(isolate); | 295 // HANDLESCOPE(thread); |
| 296 // .... | 296 // .... |
| 297 // ..... | 297 // ..... |
| 298 // code that creates some scoped handles. | 298 // code that creates some scoped handles. |
| 299 // .... | 299 // .... |
| 300 // } | 300 // } |
| 301 class HandleScope : public StackResource { | 301 class HandleScope : public StackResource { |
| 302 public: | 302 public: |
| 303 explicit HandleScope(Thread* thread); |
| 304 // DEPRECATED: Use Thread version. |
| 303 explicit HandleScope(Isolate* isolate); | 305 explicit HandleScope(Isolate* isolate); |
| 304 ~HandleScope(); | 306 ~HandleScope(); |
| 305 | 307 |
| 306 private: | 308 private: |
| 309 void Initialize(); |
| 310 |
| 307 VMHandles::HandlesBlock* saved_handle_block_; // Handle block at prev scope. | 311 VMHandles::HandlesBlock* saved_handle_block_; // Handle block at prev scope. |
| 308 uword saved_handle_slot_; // Next available handle slot at previous scope. | 312 uword saved_handle_slot_; // Next available handle slot at previous scope. |
| 309 #if defined(DEBUG) | 313 #if defined(DEBUG) |
| 310 HandleScope* link_; // Link to previous scope. | 314 HandleScope* link_; // Link to previous scope. |
| 311 #endif | 315 #endif |
| 312 DISALLOW_IMPLICIT_CONSTRUCTORS(HandleScope); | 316 DISALLOW_IMPLICIT_CONSTRUCTORS(HandleScope); |
| 313 }; | 317 }; |
| 314 | 318 |
| 315 // Macro to start a new Handle scope. | 319 // Macro to start a new Handle scope. |
| 316 #define HANDLESCOPE(isolate) \ | 320 #define HANDLESCOPE(isolate_or_thread) \ |
| 317 dart::HandleScope vm_internal_handles_scope_(isolate); | 321 dart::HandleScope vm_internal_handles_scope_(isolate_or_thread); |
| 318 | 322 |
| 319 | 323 |
| 320 // The class NoHandleScope is used in critical regions of the virtual machine | 324 // The class NoHandleScope is used in critical regions of the virtual machine |
| 321 // code where raw dart object pointers are directly manipulated. | 325 // code where raw dart object pointers are directly manipulated. |
| 322 // This class asserts that we do not add code that will allocate new handles | 326 // This class asserts that we do not add code that will allocate new handles |
| 323 // during this critical area. | 327 // during this critical area. |
| 324 // It is used as follows: | 328 // It is used as follows: |
| 325 // { | 329 // { |
| 326 // NOHANDLESCOPE(isolate); | 330 // NOHANDLESCOPE(thread); |
| 327 // .... | 331 // .... |
| 328 // ..... | 332 // ..... |
| 329 // critical code that manipulates dart objects directly. | 333 // critical code that manipulates dart objects directly. |
| 330 // .... | 334 // .... |
| 331 // } | 335 // } |
| 332 #if defined(DEBUG) | 336 #if defined(DEBUG) |
| 333 class NoHandleScope : public StackResource { | 337 class NoHandleScope : public StackResource { |
| 334 public: | 338 public: |
| 339 explicit NoHandleScope(Thread* thread); |
| 340 // DEPRECATED: Use Thread version. |
| 335 explicit NoHandleScope(Isolate* isolate); | 341 explicit NoHandleScope(Isolate* isolate); |
| 336 NoHandleScope(); | 342 NoHandleScope(); |
| 337 ~NoHandleScope(); | 343 ~NoHandleScope(); |
| 338 | 344 |
| 339 private: | 345 private: |
| 340 DISALLOW_COPY_AND_ASSIGN(NoHandleScope); | 346 DISALLOW_COPY_AND_ASSIGN(NoHandleScope); |
| 341 }; | 347 }; |
| 342 #else // defined(DEBUG) | 348 #else // defined(DEBUG) |
| 343 class NoHandleScope : public ValueObject { | 349 class NoHandleScope : public ValueObject { |
| 344 public: | 350 public: |
| 351 explicit NoHandleScope(Thread* thread) { } |
| 345 explicit NoHandleScope(Isolate* isolate) { } | 352 explicit NoHandleScope(Isolate* isolate) { } |
| 346 NoHandleScope() { } | 353 NoHandleScope() { } |
| 347 ~NoHandleScope() { } | 354 ~NoHandleScope() { } |
| 348 | 355 |
| 349 private: | 356 private: |
| 350 DISALLOW_COPY_AND_ASSIGN(NoHandleScope); | 357 DISALLOW_COPY_AND_ASSIGN(NoHandleScope); |
| 351 }; | 358 }; |
| 352 #endif // defined(DEBUG) | 359 #endif // defined(DEBUG) |
| 353 | 360 |
| 354 // Macro to start a no handles scope in the code. | 361 // Macro to start a no handles scope in the code. |
| 355 #define NOHANDLESCOPE(isolate) \ | 362 #define NOHANDLESCOPE(isolate_or_thread) \ |
| 356 dart::NoHandleScope no_vm_internal_handles_scope_(isolate); | 363 dart::NoHandleScope no_vm_internal_handles_scope_(isolate_or_thread); |
| 357 | 364 |
| 358 } // namespace dart | 365 } // namespace dart |
| 359 | 366 |
| 360 #endif // VM_HANDLES_H_ | 367 #endif // VM_HANDLES_H_ |
| OLD | NEW |