blob: 70279ab860dc34d4fbe2367dbcb4f5a7fadb31e9 [file] [log] [blame]
Carmelo Cascone7b821702017-06-19 11:26:08 +09001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2017-present Open Networking Foundation
Carmelo Cascone7b821702017-06-19 11:26:08 +09003 *
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 */
16
17package org.onosproject.net.pi.runtime;
18
19import com.google.common.annotations.Beta;
20import org.onlab.util.Identifier;
21
22import static com.google.common.base.Preconditions.checkArgument;
23import static com.google.common.base.Preconditions.checkNotNull;
24
25/**
26 * Identifier of an action's runtime parameter in a match+action table of a protocol-independent pipeline.
27 */
28@Beta
29public final class PiActionParamId extends Identifier<String> {
30
31 private final String name;
32
33 // TODO: if needed, we might add here support for positional parameters.
34 // E.g. add a second constructor that takes the "position" of a parameter, vs. its name.
35
36 private PiActionParamId(String name) {
37 super(name);
38 this.name = name;
39 }
40
41 /**
42 * Returns the name of this parameter.
43 *
44 * @return parameter name
45 */
46 public String name() {
47 return name;
48 }
49
50 /**
51 * Returns a parameter identifier with the given name.
52 *
53 * @param name parameter name
54 * @return parameter identifier
55 */
56 public static PiActionParamId of(String name) {
57 checkNotNull(name);
58 checkArgument(!name.isEmpty(), "Name can't be empty");
59 return new PiActionParamId(name);
60 }
61}