00001 // Copyright (C) 2001, Compaq Computer Corporation 00002 // 00003 // This file is part of Vesta. 00004 // 00005 // Vesta is free software; you can redistribute it and/or 00006 // modify it under the terms of the GNU Lesser General Public 00007 // License as published by the Free Software Foundation; either 00008 // version 2.1 of the License, or (at your option) any later version. 00009 // 00010 // Vesta is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00013 // Lesser General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU Lesser General Public 00016 // License along with Vesta; if not, write to the Free Software 00017 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00018 00019 // 00020 // ArcTable.C 00021 // Last modified on Tue Jul 20 15:15:02 EDT 2004 by ken@xorian.net 00022 // modified on Thu Jul 19 15:29:00 PDT 2001 by mann 00023 // 00024 // Temporary hash table of arcs. Representation is a pointer to the 00025 // non-null-terminated characters (not a copy!), plus a copy of the length. 00026 // 00027 00028 #include "ArcTable.H" 00029 00030 Word 00031 ArcKey::Hash() const throw () 00032 { 00033 Word v = 0, i; 00034 for (i = 0; i < slen; i++) 00035 v += (s[i] & 0xff) << ((i * 8) % (sizeof(Word) * 8 - 1)); 00036 return v; 00037 } 00038 00039 bool 00040 operator==(const ArcKey& k1, const ArcKey& k2) throw () 00041 { 00042 return k1.slen == k2.slen && memcmp(k1.s, k2.s, k1.slen) == 0; 00043 } 00044