OLD | NEW |
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 import 'dart:async'; | 5 import 'dart:async'; |
6 | 6 |
7 import 'package:mojo/application.dart'; | 7 import 'package:mojo/application.dart'; |
8 import 'package:mojo/bindings.dart'; | 8 import 'package:mojo/bindings.dart'; |
9 import 'package:mojo/core.dart'; | 9 import 'package:mojo/core.dart'; |
10 import 'package:_mojo_for_test_only/test/echo_service.mojom.dart'; | 10 import 'package:_mojo_for_test_only/test/echo_service.mojom.dart'; |
(...skipping 27 matching lines...) Expand all Loading... |
38 } | 38 } |
39 | 39 |
40 void quit() {} | 40 void quit() {} |
41 | 41 |
42 static void _swapImpls(EchoServiceImpl impl) { | 42 static void _swapImpls(EchoServiceImpl impl) { |
43 final stub = impl._stub; | 43 final stub = impl._stub; |
44 final app = impl._application; | 44 final app = impl._application; |
45 // It is not allowed to do an unbind in the midst of handling an event, so | 45 // It is not allowed to do an unbind in the midst of handling an event, so |
46 // it is delayed until popping back out to the event loop. | 46 // it is delayed until popping back out to the event loop. |
47 Timer.run(() { | 47 Timer.run(() { |
48 final endpoint = stub.unbind(); | 48 final endpoint = stub.ctrl.unbind(); |
49 new EchoServiceImpl(app, endpoint); | 49 new EchoServiceImpl(app, endpoint); |
50 }); | 50 }); |
51 } | 51 } |
52 } | 52 } |
53 | 53 |
54 class EchoApplication extends Application { | 54 class EchoApplication extends Application { |
55 EchoApplication.fromHandle(MojoHandle handle) : super.fromHandle(handle); | 55 EchoApplication.fromHandle(MojoHandle handle) : super.fromHandle(handle); |
56 | 56 |
57 @override | 57 @override |
58 void acceptConnection(String requestorUrl, String resolvedUrl, | 58 void acceptConnection(String requestorUrl, String resolvedUrl, |
59 ApplicationConnection connection) { | 59 ApplicationConnection connection) { |
60 connection.provideService(EchoService.serviceName, | 60 connection.provideService(EchoService.serviceName, |
61 (endpoint) => new EchoServiceImpl(this, endpoint)); | 61 (endpoint) => new EchoServiceImpl(this, endpoint)); |
62 } | 62 } |
63 } | 63 } |
64 | 64 |
65 main(List args, Object handleToken) { | 65 main(List args, Object handleToken) { |
66 MojoHandle appHandle = new MojoHandle(handleToken); | 66 MojoHandle appHandle = new MojoHandle(handleToken); |
67 new EchoApplication.fromHandle(appHandle) | 67 new EchoApplication.fromHandle(appHandle) |
68 ..onError = ((_) { | 68 ..onError = ((_) { |
69 MojoHandle.reportLeakedHandles(); | 69 MojoHandle.reportLeakedHandles(); |
70 }); | 70 }); |
71 } | 71 } |
OLD | NEW |