blob: 867cfbf7bc2a343ba2a176151de688f912c49671 [file] [log] [blame]
Sho SHIMIZUf33b8932016-01-25 18:43:32 -08001/*
2 * Copyright 2016 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.onosproject.net.newresource;
17
18import com.google.common.annotations.Beta;
Sho SHIMIZU2a704512016-01-26 14:41:34 -080019import com.google.common.base.MoreObjects;
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080020
21import java.util.Objects;
Sho SHIMIZU2a704512016-01-26 14:41:34 -080022import java.util.Optional;
23
24import static com.google.common.base.Preconditions.checkArgument;
Sho SHIMIZU0e1a4762016-02-11 13:04:41 -080025import static com.google.common.base.Preconditions.checkNotNull;
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080026
27/**
28 * Represents a resource path which specifies a resource which can be measured
29 * as a discrete unit. A VLAN ID and a MPLS label of a link are examples of the resource.
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080030 */
31@Beta
Sho SHIMIZU2a704512016-01-26 14:41:34 -080032public final class DiscreteResource implements Resource {
33 private final DiscreteResourceId id;
34
35 DiscreteResource(DiscreteResourceId id) {
36 this.id = id;
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080037 }
38
Sho SHIMIZUf95b96e2016-01-25 19:35:15 -080039 DiscreteResource() {
Sho SHIMIZU2a704512016-01-26 14:41:34 -080040 this.id = ResourceId.ROOT;
41 }
42
43 @Override
44 public DiscreteResourceId id() {
45 return id;
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080046 }
47
48 /**
49 * The user of this methods must receive the return value as the correct type.
50 * Otherwise, this methods throws an exception.
51 *
52 * @param <T> type of the return value
53 * @return the volume of this resource
54 */
55 @SuppressWarnings("unchecked")
56 @Override
57 // TODO: consider receiving Class<T> as an argument. Which approach is convenient?
58 public <T> T volume() {
59 return (T) last();
60 }
61
62 @Override
Sho SHIMIZUb08d5862016-02-11 12:37:28 -080063 public boolean isSubTypeOf(Class<?> ancestor) {
Sho SHIMIZU0e1a4762016-02-11 13:04:41 -080064 checkNotNull(ancestor);
65
Sho SHIMIZU9c02f3a2016-01-29 15:11:59 -080066 return id.components().stream()
67 .map(Object::getClass)
Sho SHIMIZUb08d5862016-02-11 12:37:28 -080068 .filter(x -> x.equals(ancestor))
Sho SHIMIZU9c02f3a2016-01-29 15:11:59 -080069 .findAny()
70 .isPresent();
Sho SHIMIZU2a704512016-01-26 14:41:34 -080071 }
72
73 @Override
74 public Object last() {
Sho SHIMIZU42ac51f2016-01-27 12:59:31 -080075 if (id.components().isEmpty()) {
Sho SHIMIZU2a704512016-01-26 14:41:34 -080076 return null;
77 }
Sho SHIMIZU42ac51f2016-01-27 12:59:31 -080078 return id.components().get(id.components().size() - 1);
Sho SHIMIZU2a704512016-01-26 14:41:34 -080079 }
80
81 @Override
82 public DiscreteResource child(Object child) {
83 checkArgument(!(child instanceof Class<?>));
84
Sho SHIMIZU460b9722016-01-28 10:48:26 -080085 return Resources.discrete(id.child(child)).resource();
Sho SHIMIZU2a704512016-01-26 14:41:34 -080086 }
87
88 @Override
89 public ContinuousResource child(Class<?> child, double value) {
Sho SHIMIZU460b9722016-01-28 10:48:26 -080090 return Resources.continuous(id.child(child)).resource(value);
Sho SHIMIZU2a704512016-01-26 14:41:34 -080091 }
92
93 @Override
94 public Optional<DiscreteResource> parent() {
Sho SHIMIZU460b9722016-01-28 10:48:26 -080095 return id.parent().map(x -> Resources.discrete(x).resource());
Sho SHIMIZU2a704512016-01-26 14:41:34 -080096 }
97
98 @Override
Sho SHIMIZUf33b8932016-01-25 18:43:32 -080099 public int hashCode() {
100 // the value returing from volume() is excluded due to optimization
Sho SHIMIZU34b55b62016-01-27 12:49:43 -0800101 return id.hashCode();
Sho SHIMIZUf33b8932016-01-25 18:43:32 -0800102 }
103
104 @Override
105 public boolean equals(Object obj) {
106 if (this == obj) {
107 return true;
108 }
109 if (obj == null || getClass() != obj.getClass()) {
110 return false;
111 }
112 final DiscreteResource other = (DiscreteResource) obj;
113 // the value returing from volume() is excluded due to optimization
Sho SHIMIZU34b55b62016-01-27 12:49:43 -0800114 return Objects.equals(this.id, other.id);
Sho SHIMIZUf33b8932016-01-25 18:43:32 -0800115 }
Sho SHIMIZU2a704512016-01-26 14:41:34 -0800116
117 @Override
118 public String toString() {
119 return MoreObjects.toStringHelper(this)
120 .add("id", id)
121 .add("volume", volume())
122 .toString();
123 }
Sho SHIMIZUf33b8932016-01-25 18:43:32 -0800124}