Merge "Check whether the scene-graph RenderTask object is valid" into devel/master
[platform/core/uifw/dali-core.git] / dali / devel-api / common / hash.cpp
1 /*
2  * Copyright (c) 2022 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 inline void HashBuffer(const std::vector<std::uint8_t>& buffer, std::size_t& hash)
47 {
48   for(const auto& c : buffer)
49   {
50     hash = hash * 33 + c;
51   }
52 }
53
54 inline void HashBuffer(const Dali::Vector<std::uint8_t>& buffer, std::size_t& hash)
55 {
56   for(const auto& c : buffer)
57   {
58     hash = hash * 33 + c;
59   }
60 }
61
62 } // unnamed namespace
63
64 std::size_t CalculateHash(const std::string& toHash)
65 {
66   std::size_t hash(INITIAL_HASH_VALUE);
67
68   HashString(toHash.c_str(), hash);
69
70   return hash;
71 }
72
73 std::size_t CalculateHash(const std::string& toHash, char terminator)
74 {
75   std::size_t hash(INITIAL_HASH_VALUE);
76
77   HashString(toHash.c_str(), hash, terminator);
78
79   return hash;
80 }
81
82 std::size_t CalculateHash(const std::string& string1, const std::string& string2)
83 {
84   std::size_t hash(INITIAL_HASH_VALUE);
85
86   HashString(string1.c_str(), hash);
87   HashString(string2.c_str(), hash);
88
89   return hash;
90 }
91
92 std::size_t CalculateHash(const std::vector<std::uint8_t>& toHash)
93 {
94   std::size_t hash(INITIAL_HASH_VALUE);
95
96   HashBuffer(toHash, hash);
97
98   return hash;
99 }
100
101 std::size_t CalculateHash(const Dali::Vector<std::uint8_t>& toHash)
102 {
103   std::size_t hash(INITIAL_HASH_VALUE);
104
105   HashBuffer(toHash, hash);
106
107   return hash;
108 }
109
110 } // namespace Dali