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

Side by Side Diff: mojo/dart/apptests/test_apps/echo/lib/main.dart

Issue 1983453002: Dart: Refactor Stubs (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Merge Created 4 years, 7 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 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
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 }
OLDNEW
« no previous file with comments | « benchmarks/mojo_rtt_benchmark/lib/echo_server.dart ('k') | mojo/dart/apptests/test_apps/pingpong/lib/main.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698