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

Side by Side Diff: sdk/lib/vmservice/named_lookup.dart

Issue 2980733003: Introduced support for external services registration in the ServiceProtocol (Closed)
Patch Set: Fix checked mode exceptions Created 3 years, 5 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
(Empty)
1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file.
4
5 part of dart._vmservice;
6
7 class NamedLookup<E> extends Object with IterableMixin<E> {
8 final IdGenerator _generator;
9 final Map<String, E> _elements = new Map<String, E>();
10 final Map<E, String> _ids = new Map<E, String>();
11
12 NamedLookup({String prologue = ''})
13 : super(),
14 _generator = new IdGenerator(prologue: prologue);
15
16 void add(E e) {
17 final id = _generator.newId();
18 _elements[id] = e;
19 _ids[e] = id;
20 }
21
22 void remove(E e) {
23 final id = _ids.remove(e);
24 _elements.remove(id);
25 _generator.release(id);
26 }
27
28 E operator [](String id) => _elements[id];
29 String keyOf(E e) => _ids[e];
30
31 Iterator<E> get iterator => _ids.keys.iterator;
32 }
33
34 class IdGenerator {
35 final String prologue;
36 final Set<String> _used = new Set<String>();
37 final Set<String> _free = new Set<String>();
38 int _next = 0;
39
40 IdGenerator({this.prologue = ''});
41
42 String newId() {
43 var id;
44 if (_free.isEmpty) {
45 id = prologue + (_next++).toString();
46 } else {
47 id = _free.first;
48 }
49 _free.remove(id);
50 _used.add(id);
51 return id;
52 }
53
54 void release(String id) {
55 if (_used.remove(id)) {
56 _free.add(id);
57 }
58 }
59 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698