777f1cef8320d4f22ddba1b3b27c66cf5ea9d5af
[hc2vpp.git] /
1 /*
2  * Copyright (c) 2017 Cisco and/or its affiliates.
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  */
16
17 package org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.lisp.address.types.rev151105;
18
19
20 import static com.google.common.base.Preconditions.checkNotNull;
21
22 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.IpAddress;
23 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4Address;
24 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv6Address;
25 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.MacAddress;
26
27 /**
28  * The purpose of generated class in src/main/java for Union types is to create new instances of unions from a string
29  * representation. In some cases it is very difficult to automate it since there can be unions such as (uint32 -
30  * uint16), or (string - uint32).
31  * <p/>
32  * The reason behind putting it under src/main/java is: This class is generated in form of a stub and needs to be
33  * finished by the user. This class is generated only once to prevent loss of user code.
34  */
35 public final class SimpleAddressBuilder {
36
37     public static SimpleAddress getDefaultInstance(String defaultValue) {
38         checkNotNull(defaultValue, "Cannot convert null address");
39
40         if (Ipv4Matcher.matches(defaultValue)) {
41             return new SimpleAddress(new IpAddress(new Ipv4Address(defaultValue)));
42         } else if (Ipv6Matcher.matches(defaultValue)) {
43             return new SimpleAddress(new IpAddress(new Ipv6Address(defaultValue)));
44         } else if (MacMatcher.matches(defaultValue)) {
45             return new SimpleAddress(new MacAddress(defaultValue));
46         } else {
47             throw new IllegalArgumentException("Unknown type");
48         }
49     }
50
51 }