Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(112)

Unified Diff: runtime/lib/mirrors.cc

Issue 9420038: Heartbeat implementation of dart:mirrors. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/lib/isolate.cc ('k') | runtime/lib/mirrors_impl.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/lib/mirrors.cc
===================================================================
--- runtime/lib/mirrors.cc (revision 0)
+++ runtime/lib/mirrors.cc (revision 0)
@@ -0,0 +1,80 @@
+// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+#include "vm/bootstrap_natives.h"
+
+#include "vm/dart_entry.h"
+#include "vm/exceptions.h"
+#include "vm/message.h"
+#include "vm/port.h"
+
+namespace dart {
+
+static uint8_t* allocator(uint8_t* ptr, intptr_t old_size, intptr_t new_size) {
+ void* new_ptr = realloc(reinterpret_cast<void*>(ptr), new_size);
+ return reinterpret_cast<uint8_t*>(new_ptr);
+}
+
+
+DEFINE_NATIVE_ENTRY(Mirrors_send, 3) {
+ GET_NATIVE_ARGUMENT(Instance, port, arguments->At(0));
+ GET_NATIVE_ARGUMENT(Instance, message, arguments->At(1));
+ GET_NATIVE_ARGUMENT(Instance, replyTo, arguments->At(2));
+
+ // Get the send port id.
+ Object& result = Object::Handle();
+ result = DartLibraryCalls::PortGetId(port);
+ if (result.IsError()) {
+ Exceptions::PropagateError(result);
+ }
+
+ Integer& value = Integer::Handle();
+ value ^= result.raw();
+ int64_t send_port_id = value.AsInt64Value();
+
+ // Get the reply port id.
+ result = DartLibraryCalls::PortGetId(replyTo);
+ if (result.IsError()) {
+ Exceptions::PropagateError(result);
+ }
+ value ^= result.raw();
+ int64_t reply_port_id = value.AsInt64Value();
+
+ // Construct the message.
+ uint8_t* data = NULL;
+ SnapshotWriter writer(Snapshot::kMessage, &data, &allocator);
+ writer.WriteObject(message.raw());
+ writer.FinalizeBuffer();
+
+ // Post the message.
+ bool retval = PortMap::PostMessage(new Message(
+ send_port_id, reply_port_id, data, Message::kOOBPriority));
+ const Bool& retval_obj = Bool::Handle(Bool::Get(retval));
+ arguments->SetReturn(retval_obj);
+}
+
+
+DEFINE_NATIVE_ENTRY(IsolateMirrorImpl_buildResponse, 1) {
+ GET_NATIVE_ARGUMENT(Instance, map, arguments->At(0));
+ String& key = String::Handle();
+ Instance& value = Instance::Handle();
+ Object& result = Object::Handle();
+
+ key = String::New("debugName");
+ value = String::New(isolate->name());
+ result = DartLibraryCalls::MapSetAt(map, key, value);
+ if (result.IsError()) {
+ // TODO(turnidge): Prevent mirror operations from crashing other isolates?
+ Exceptions::PropagateError(result);
+ }
+
+ key = String::New("ok");
+ value = Bool::True();
+ result = DartLibraryCalls::MapSetAt(map, key, value);
+ if (result.IsError()) {
+ Exceptions::PropagateError(result);
+ }
+}
+
+} // namespace dart
« no previous file with comments | « runtime/lib/isolate.cc ('k') | runtime/lib/mirrors_impl.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698