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

Side by Side Diff: mojo/public/js/bindings/connector.js

Issue 708563002: Move mojo/public/js/bindings/ moves to mojo/public/js/ (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Sync again Created 6 years, 1 month 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
« no previous file with comments | « mojo/public/js/bindings/connection.js ('k') | mojo/public/js/bindings/constants.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 define("mojo/public/js/bindings/connector", [
6 "mojo/public/js/bindings/buffer",
7 "mojo/public/js/bindings/codec",
8 "mojo/public/js/bindings/core",
9 "mojo/public/js/bindings/support",
10 ], function(buffer, codec, core, support) {
11
12 function Connector(handle) {
13 this.handle_ = handle;
14 this.dropWrites_ = false;
15 this.error_ = false;
16 this.incomingReceiver_ = null;
17 this.readWaitCookie_ = null;
18 this.errorHandler_ = null;
19
20 this.waitToReadMore_();
21 }
22
23 Connector.prototype.close = function() {
24 if (this.readWaitCookie_) {
25 support.cancelWait(this.readWaitCookie_);
26 this.readWaitCookie_ = null;
27 }
28 if (this.handle_ != null) {
29 core.close(this.handle_);
30 this.handle_ = null;
31 }
32 };
33
34 Connector.prototype.accept = function(message) {
35 if (this.error_)
36 return false;
37
38 if (this.dropWrites_)
39 return true;
40
41 var result = core.writeMessage(this.handle_,
42 new Uint8Array(message.buffer.arrayBuffer),
43 message.handles,
44 core.WRITE_MESSAGE_FLAG_NONE);
45 switch (result) {
46 case core.RESULT_OK:
47 // The handles were successfully transferred, so we don't own them
48 // anymore.
49 message.handles = [];
50 break;
51 case core.RESULT_FAILED_PRECONDITION:
52 // There's no point in continuing to write to this pipe since the other
53 // end is gone. Avoid writing any future messages. Hide write failures
54 // from the caller since we'd like them to continue consuming any
55 // backlog of incoming messages before regarding the message pipe as
56 // closed.
57 this.dropWrites_ = true;
58 break;
59 default:
60 // This particular write was rejected, presumably because of bad input.
61 // The pipe is not necessarily in a bad state.
62 return false;
63 }
64 return true;
65 };
66
67 Connector.prototype.setIncomingReceiver = function(receiver) {
68 this.incomingReceiver_ = receiver;
69 };
70
71 Connector.prototype.setErrorHandler = function(handler) {
72 this.errorHandler_ = handler;
73 };
74
75 Connector.prototype.encounteredError = function() {
76 return this.error_;
77 };
78
79 Connector.prototype.waitToReadMore_ = function() {
80 this.readWaitCookie_ = support.asyncWait(this.handle_,
81 core.HANDLE_SIGNAL_READABLE,
82 this.readMore_.bind(this));
83 };
84
85 Connector.prototype.readMore_ = function(result) {
86 for (;;) {
87 var read = core.readMessage(this.handle_,
88 core.READ_MESSAGE_FLAG_NONE);
89 if (this.handle_ == null) // The connector has been closed.
90 return;
91 if (read.result == core.RESULT_SHOULD_WAIT) {
92 this.waitToReadMore_();
93 return;
94 }
95 if (read.result != core.RESULT_OK) {
96 this.error_ = true;
97 if (this.errorHandler_)
98 this.errorHandler_.onError(read.result);
99 return;
100 }
101 var messageBuffer = new buffer.Buffer(read.buffer);
102 var message = new codec.Message(messageBuffer, read.handles);
103 if (this.incomingReceiver_) {
104 this.incomingReceiver_.accept(message);
105 }
106 }
107 };
108
109 // The TestConnector subclass is only intended to be used in unit tests. It
110 // enables delivering a message to the pipe's handle without an async wait.
111
112 function TestConnector(handle) {
113 Connector.call(this, handle);
114 }
115
116 TestConnector.prototype = Object.create(Connector.prototype);
117
118 TestConnector.prototype.waitToReadMore_ = function() {
119 };
120
121 TestConnector.prototype.deliverMessage = function() {
122 this.readMore_(core.RESULT_OK);
123 }
124
125 var exports = {};
126 exports.Connector = Connector;
127 exports.TestConnector = TestConnector;
128 return exports;
129 });
OLDNEW
« no previous file with comments | « mojo/public/js/bindings/connection.js ('k') | mojo/public/js/bindings/constants.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698