/****************************************************************************** * Product: Adempiere ERP & CRM Smart Business Solution * * Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify it * * under the terms version 2 of the GNU General Public License as published * * by the Free Software Foundation. This program is distributed in the hope * * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * * with this program; if not, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * * For the text or an alternative of this public license, you may reach us * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * or via info@compiere.org or http://www.compiere.org/license.html * *****************************************************************************/ package org.compiere.util; /** * Key Name Pair (Integer key and string name) * * @author Jorg Janke * @version $Id: KeyNamePair.java,v 1.2 2006/07/30 00:52:23 jjanke Exp $ */ public final class KeyNamePair extends NamePair { /** * generated serial id */ private static final long serialVersionUID = 6347385376010388473L; public static final KeyNamePair EMPTY = new KeyNamePair(-1, ""); /** * Constructor KeyNamePair Pair - * @param key Key (-1 is considered as null) * @param name string representation */ public KeyNamePair(int key, String name) { super(name); m_key = key; } // KeyNamePair /** The Key */ private int m_key = 0; /** * Get Key * @return key */ public int getKey() { return m_key; } // getKey /** * Get ID (convert key to string) * * @return String value of key or null if key value is -1 */ @Override public String getID() { if (m_key == -1) return null; return String.valueOf(m_key); } // getID /** * Equals * @param obj object * @return true if equal */ @Override public boolean equals(Object obj) { if (obj instanceof KeyNamePair) { KeyNamePair pp = (KeyNamePair)obj; if (pp.getKey() == m_key && pp.getName() != null && pp.getName().equals(getName())) return true; return false; } return false; } // equals /** * Return key as hash code of object * @return key value */ @Override public int hashCode() { return m_key; } // hashCode } // KeyNamePair