3 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
5 * This program and the accompanying materials are made available under the
6 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
7 * and is available at http://www.eclipse.org/legal/epl-v10.html
10 package org.opendaylight.controller.sal.action;
12 import java.util.Arrays;
14 import javax.xml.bind.annotation.XmlAccessType;
15 import javax.xml.bind.annotation.XmlAccessorType;
16 import javax.xml.bind.annotation.XmlElement;
17 import javax.xml.bind.annotation.XmlRootElement;
19 import org.opendaylight.controller.sal.utils.HexEncode;
22 * Set destination datalayer address action
26 @XmlAccessorType(XmlAccessType.NONE)
28 public class SetDlDst extends Action {
29 private byte[] address;
31 /* Dummy constructor for JAXB */
35 public SetDlDst(byte[] dlAddress) {
36 type = ActionType.SET_DL_DST;
37 this.address = dlAddress.clone();
41 * Returns the datalayer address that this action will set
45 public byte[] getDlAddress() {
46 return address.clone();
49 @XmlElement(name = "address")
50 public String getDlAddressString() {
51 return HexEncode.bytesToHexString(address);
55 public boolean equals(Object obj) {
58 if (!super.equals(obj))
60 if (getClass() != obj.getClass())
62 SetDlDst other = (SetDlDst) obj;
63 if (!Arrays.equals(address, other.address))
69 public int hashCode() {
71 int result = super.hashCode();
72 result = prime * result + Arrays.hashCode(address);
77 public String toString() {
78 return type + "[address = " + HexEncode.bytesToHexString(address) + "]";