Main Page | Namespace List | Class Hierarchy | Class List | Directories | File List | Namespace Members | Class Members | File Members

ArcTable.C

Go to the documentation of this file.
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 

Generated on Mon May 8 00:48:43 2006 for Vesta by  doxygen 1.4.2