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

Side by Side Diff: mojo/edk/js/handle.cc

Issue 1350023003: Add a Mojo EDK for Chrome that uses one OS pipe per message pipe. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: more cleanup Created 5 years, 2 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "third_party/mojo/src/mojo/edk/js/handle.h" 5 #include "mojo/edk/js/handle.h"
6 6
7 #include "third_party/mojo/src/mojo/edk/js/handle_close_observer.h" 7 #include "mojo/edk/js/handle_close_observer.h"
8 8
9 namespace mojo { 9 namespace mojo {
10 namespace js { 10 namespace edk {
11 11
12 gin::WrapperInfo HandleWrapper::kWrapperInfo = { gin::kEmbedderNativeGin }; 12 gin::WrapperInfo HandleWrapper::kWrapperInfo = { gin::kEmbedderNativeGin };
13 13
14 HandleWrapper::HandleWrapper(MojoHandle handle) 14 HandleWrapper::HandleWrapper(MojoHandle handle)
15 : handle_(mojo::Handle(handle)) { 15 : handle_(mojo::Handle(handle)) {
16 } 16 }
17 17
18 HandleWrapper::~HandleWrapper() { 18 HandleWrapper::~HandleWrapper() {
19 NotifyCloseObservers(); 19 NotifyCloseObservers();
20 } 20 }
(...skipping 11 matching lines...) Expand all
32 close_observers_.RemoveObserver(observer); 32 close_observers_.RemoveObserver(observer);
33 } 33 }
34 34
35 void HandleWrapper::NotifyCloseObservers() { 35 void HandleWrapper::NotifyCloseObservers() {
36 if (!handle_.is_valid()) 36 if (!handle_.is_valid())
37 return; 37 return;
38 38
39 FOR_EACH_OBSERVER(HandleCloseObserver, close_observers_, OnWillCloseHandle()); 39 FOR_EACH_OBSERVER(HandleCloseObserver, close_observers_, OnWillCloseHandle());
40 } 40 }
41 41
42 } // namespace js 42 } // namespace edk
43 } // namespace mojo 43 } // namespace mojo
44 44
45 namespace gin { 45 namespace gin {
46 46
47 v8::Handle<v8::Value> Converter<mojo::Handle>::ToV8(v8::Isolate* isolate, 47 v8::Handle<v8::Value> Converter<mojo::Handle>::ToV8(v8::Isolate* isolate,
48 const mojo::Handle& val) { 48 const mojo::Handle& val) {
49 if (!val.is_valid()) 49 if (!val.is_valid())
50 return v8::Null(isolate); 50 return v8::Null(isolate);
51 return mojo::js::HandleWrapper::Create(isolate, val.value()).ToV8(); 51 return mojo::edk::HandleWrapper::Create(isolate, val.value()).ToV8();
52 } 52 }
53 53
54 bool Converter<mojo::Handle>::FromV8(v8::Isolate* isolate, 54 bool Converter<mojo::Handle>::FromV8(v8::Isolate* isolate,
55 v8::Handle<v8::Value> val, 55 v8::Handle<v8::Value> val,
56 mojo::Handle* out) { 56 mojo::Handle* out) {
57 if (val->IsNull()) { 57 if (val->IsNull()) {
58 *out = mojo::Handle(); 58 *out = mojo::Handle();
59 return true; 59 return true;
60 } 60 }
61 61
62 gin::Handle<mojo::js::HandleWrapper> handle; 62 gin::Handle<mojo::edk::HandleWrapper> handle;
63 if (!Converter<gin::Handle<mojo::js::HandleWrapper> >::FromV8( 63 if (!Converter<gin::Handle<mojo::edk::HandleWrapper> >::FromV8(
64 isolate, val, &handle)) 64 isolate, val, &handle))
65 return false; 65 return false;
66 66
67 *out = handle->get(); 67 *out = handle->get();
68 return true; 68 return true;
69 } 69 }
70 70
71 v8::Handle<v8::Value> Converter<mojo::MessagePipeHandle>::ToV8( 71 v8::Handle<v8::Value> Converter<mojo::MessagePipeHandle>::ToV8(
72 v8::Isolate* isolate, mojo::MessagePipeHandle val) { 72 v8::Isolate* isolate, mojo::MessagePipeHandle val) {
73 return Converter<mojo::Handle>::ToV8(isolate, val); 73 return Converter<mojo::Handle>::ToV8(isolate, val);
74 } 74 }
75 75
76 bool Converter<mojo::MessagePipeHandle>::FromV8(v8::Isolate* isolate, 76 bool Converter<mojo::MessagePipeHandle>::FromV8(v8::Isolate* isolate,
77 v8::Handle<v8::Value> val, 77 v8::Handle<v8::Value> val,
78 mojo::MessagePipeHandle* out) { 78 mojo::MessagePipeHandle* out) {
79 return Converter<mojo::Handle>::FromV8(isolate, val, out); 79 return Converter<mojo::Handle>::FromV8(isolate, val, out);
80 } 80 }
81 81
82 82
83 } // namespace gin 83 } // namespace gin
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698