d510013e0048a372fb56c0ceda8817e2a1f8e510
[platform/core/uifw/dali-core.git] / dali / devel-api / common / hash.cpp
1 /*
2  * Copyright (c) 2020 Samsung Electronics Co., Ltd.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 // CLASS HEADER
19 #include <dali/devel-api/common/hash.h>
20
21 namespace Dali
22 {
23 namespace //unnamed namespace
24 {
25 /*
26  * djb2 (http://www.cse.yorku.ca/~oz/hash.html)
27  */
28
29 inline void HashString(const char* string, std::size_t& hash)
30 {
31   while(int c = *string++)
32   {
33     hash = hash * 33 + c;
34   }
35 }
36
37 inline void HashString(const char* string, std::size_t& hash, char terminator)
38 {
39   char c;
40   while((c = *string++) && c != terminator)
41   {
42     hash = hash * 33 + c;
43   }
44 }
45
46 } // unnamed namespace
47
48 std::size_t CalculateHash(const std::string& toHash)
49 {
50   std::size_t hash(INITIAL_HASH_VALUE);
51
52   HashString(toHash.c_str(), hash);
53
54   return hash;
55 }
56
57 std::size_t CalculateHash(const std::string& toHash, char terminator)
58 {
59   std::size_t hash(INITIAL_HASH_VALUE);
60
61   HashString(toHash.c_str(), hash, terminator);
62
63   return hash;
64 }
65
66 std::size_t CalculateHash(const std::string& string1, const std::string& string2)
67 {
68   std::size_t hash(INITIAL_HASH_VALUE);
69
70   HashString(string1.c_str(), hash);
71   HashString(string2.c_str(), hash);
72
73   return hash;
74 }
75
76 } // namespace Dali