blob: 492451cf1aa0a1d78c517f4854f1f4ad9aff9f38 [file] [log] [blame]
Thomas Vachuska7d693f52014-10-21 19:17:57 -07001/*
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07002 * Copyright 2014 Open Networking Laboratory
Thomas Vachuska7d693f52014-10-21 19:17:57 -07003 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07004 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
Thomas Vachuska7d693f52014-10-21 19:17:57 -07007 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07008 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
Thomas Vachuska7d693f52014-10-21 19:17:57 -070015 */
tom13cb4852014-09-11 12:44:17 -070016package org.onlab.onos.cli.net;
17
18import org.apache.karaf.shell.console.Completer;
19import org.apache.karaf.shell.console.completer.StringsCompleter;
20import org.onlab.onos.cli.AbstractShellCommand;
21import org.onlab.onos.net.topology.Topology;
22import org.onlab.onos.net.topology.TopologyCluster;
23import org.onlab.onos.net.topology.TopologyService;
24
25import java.util.List;
26import java.util.SortedSet;
27
28/**
29 * Cluster ID completer.
30 */
31public class ClusterIdCompleter implements Completer {
32 @Override
33 public int complete(String buffer, int cursor, List<String> candidates) {
34 // Delegate string completer
35 StringsCompleter delegate = new StringsCompleter();
36
37 // Fetch our service and feed it's offerings to the string completer
38 TopologyService service = AbstractShellCommand.get(TopologyService.class);
39 Topology topology = service.currentTopology();
40
41 SortedSet<String> strings = delegate.getStrings();
42 for (TopologyCluster cluster : service.getClusters(topology)) {
43 strings.add(Integer.toString(cluster.id().index()));
44 }
45
46 // Now let the completer do the work for figuring out what to offer.
47 return delegate.complete(buffer, cursor, candidates);
48 }
49
50}