blob: de18fc05b828b05b5073600f813183055f0494e5 [file] [log] [blame]
Sho SHIMIZUfe129db2014-11-11 14:24:51 -08001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
4 * 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
7 *
8 * 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.
15 */
16package org.onlab.onos.net;
17
18/**
19 * Collection of keys for annotation.
20 * Definitions of annotation keys needs to be here to avoid scattering.
21 */
22public final class AnnotationKeys {
23
24 // Prohibit instantiation
25 private AnnotationKeys() {}
26
27 /**
Thomas Vachuska57126fe2014-11-11 17:13:24 -080028 * Annotation key for durable links.
29 */
30 public static final String DURABLE = "durable";
31
32 /**
33 * Annotation key for active/inactive links. Links are implicitly
34 * considered active unless explicitly marked otherwise.
35 */
36 public static final String INACTIVE = "inactive";
37
38 /**
Sho SHIMIZUfe129db2014-11-11 14:24:51 -080039 * Annotation key for latency.
40 */
41 public static final String LATENCY = "latency";
Sho SHIMIZU97a64cd2014-11-11 16:31:21 -080042
43 /**
Toshio Koide4b6562b2014-11-13 17:20:47 -080044 * Annotation key for bandwidth.
45 */
46 public static final String BANDWIDTH = "bandwidth";
47
48 /**
49 * Annotation key for the number of optical waves.
50 */
51 public static final String OPTICAL_WAVES = "optical.waves";
52
53 /**
Sho SHIMIZU97a64cd2014-11-11 16:31:21 -080054 * Returns the value annotated object for the specified annotation key.
55 * The annotated value is expected to be String that can be parsed as double.
56 * If parsing fails, the returned value will be 1.0.
57 *
58 * @param annotated annotated object whose annotated value is obtained
59 * @param key key of annotation
60 * @return double value of annotated object for the specified key
61 */
62 public static double getAnnotatedValue(Annotated annotated, String key) {
63 double value;
64 try {
65 value = Double.parseDouble(annotated.annotations().value(key));
66 } catch (NumberFormatException e) {
67 value = 1.0;
68 }
69 return value;
70 }
Sho SHIMIZUfe129db2014-11-11 14:24:51 -080071}