X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Ftag.cpp;h=3586507a5f8ba17c35a560b55fdbfb6990290672;hp=8e29bee1f3eba6f97665bc9abd0e3fb60dd24d99;hb=b617c5d7b5283ad260a77f01e42e6170cabbc03d;hpb=19583522999f9ca2cddb178691633bc20f714b01 diff --git a/source/tag.cpp b/source/tag.cpp index 8e29bee1..3586507a 100644 --- a/source/tag.cpp +++ b/source/tag.cpp @@ -1,28 +1,35 @@ /* $Id$ This file is part of libmspgl -Copyright © 2007 Mikko Rasa, Mikkosoft Productions +Copyright © 2007, 2010 Mikko Rasa, Mikkosoft Productions Distributed under the LGPL */ #include "tag.h" +namespace { + +template +inline unsigned hash(T begin, T end) +{ + unsigned result = 0; + for(T i=begin; (i!=end && *i); ++i) + result = ((result>>29)|(result<<5))^static_cast(*i); + return result; +} + +} + namespace Msp { namespace GL { Tag::Tag(const char *s): - id(0) -{ - for(const char *i=s; *i; ++i) - id=id*id+*i; -} + id(s ? hash(s, 0) : 0) +{ } Tag::Tag(const std::string &s): - id(0) -{ - for(std::string::const_iterator i=s.begin(); i!=s.end(); ++i) - id=id*id+*i; -} + id(hash(s.begin(), s.end())) +{ } } // namespace GL } // namespace Msp