1*ec779b8eSAndroid Build Coastguard Worker /* 2*ec779b8eSAndroid Build Coastguard Worker * Copyright (C) 2010 The Android Open Source Project 3*ec779b8eSAndroid Build Coastguard Worker * 4*ec779b8eSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*ec779b8eSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*ec779b8eSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*ec779b8eSAndroid Build Coastguard Worker * 8*ec779b8eSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*ec779b8eSAndroid Build Coastguard Worker * 10*ec779b8eSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*ec779b8eSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*ec779b8eSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*ec779b8eSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*ec779b8eSAndroid Build Coastguard Worker * limitations under the License. 15*ec779b8eSAndroid Build Coastguard Worker */ 16*ec779b8eSAndroid Build Coastguard Worker 17*ec779b8eSAndroid Build Coastguard Worker #include <sys/types.h> 18*ec779b8eSAndroid Build Coastguard Worker 19*ec779b8eSAndroid Build Coastguard Worker #include "AAtomizer.h" 20*ec779b8eSAndroid Build Coastguard Worker 21*ec779b8eSAndroid Build Coastguard Worker namespace android { 22*ec779b8eSAndroid Build Coastguard Worker 23*ec779b8eSAndroid Build Coastguard Worker // static 24*ec779b8eSAndroid Build Coastguard Worker AAtomizer AAtomizer::gAtomizer; 25*ec779b8eSAndroid Build Coastguard Worker 26*ec779b8eSAndroid Build Coastguard Worker // static Atomize(const char * name)27*ec779b8eSAndroid Build Coastguard Workerconst char *AAtomizer::Atomize(const char *name) { 28*ec779b8eSAndroid Build Coastguard Worker return gAtomizer.atomize(name); 29*ec779b8eSAndroid Build Coastguard Worker } 30*ec779b8eSAndroid Build Coastguard Worker AAtomizer()31*ec779b8eSAndroid Build Coastguard WorkerAAtomizer::AAtomizer() { 32*ec779b8eSAndroid Build Coastguard Worker for (size_t i = 0; i < 128; ++i) { 33*ec779b8eSAndroid Build Coastguard Worker mAtoms.push(List<AString>()); 34*ec779b8eSAndroid Build Coastguard Worker } 35*ec779b8eSAndroid Build Coastguard Worker } 36*ec779b8eSAndroid Build Coastguard Worker atomize(const char * name)37*ec779b8eSAndroid Build Coastguard Workerconst char *AAtomizer::atomize(const char *name) { 38*ec779b8eSAndroid Build Coastguard Worker Mutex::Autolock autoLock(mLock); 39*ec779b8eSAndroid Build Coastguard Worker 40*ec779b8eSAndroid Build Coastguard Worker const size_t n = mAtoms.size(); 41*ec779b8eSAndroid Build Coastguard Worker size_t index = AAtomizer::Hash(name) % n; 42*ec779b8eSAndroid Build Coastguard Worker List<AString> &entry = mAtoms.editItemAt(index); 43*ec779b8eSAndroid Build Coastguard Worker List<AString>::iterator it = entry.begin(); 44*ec779b8eSAndroid Build Coastguard Worker while (it != entry.end()) { 45*ec779b8eSAndroid Build Coastguard Worker if ((*it) == name) { 46*ec779b8eSAndroid Build Coastguard Worker return (*it).c_str(); 47*ec779b8eSAndroid Build Coastguard Worker } 48*ec779b8eSAndroid Build Coastguard Worker ++it; 49*ec779b8eSAndroid Build Coastguard Worker } 50*ec779b8eSAndroid Build Coastguard Worker 51*ec779b8eSAndroid Build Coastguard Worker entry.push_back(AString(name)); 52*ec779b8eSAndroid Build Coastguard Worker 53*ec779b8eSAndroid Build Coastguard Worker return (*--entry.end()).c_str(); 54*ec779b8eSAndroid Build Coastguard Worker } 55*ec779b8eSAndroid Build Coastguard Worker 56*ec779b8eSAndroid Build Coastguard Worker // static Hash(const char * s)57*ec779b8eSAndroid Build Coastguard Workeruint32_t AAtomizer::Hash(const char *s) { 58*ec779b8eSAndroid Build Coastguard Worker uint32_t sum = 0; 59*ec779b8eSAndroid Build Coastguard Worker while (*s != '\0') { 60*ec779b8eSAndroid Build Coastguard Worker sum = (sum * 31) + *s; 61*ec779b8eSAndroid Build Coastguard Worker ++s; 62*ec779b8eSAndroid Build Coastguard Worker } 63*ec779b8eSAndroid Build Coastguard Worker 64*ec779b8eSAndroid Build Coastguard Worker return sum; 65*ec779b8eSAndroid Build Coastguard Worker } 66*ec779b8eSAndroid Build Coastguard Worker 67*ec779b8eSAndroid Build Coastguard Worker } // namespace android 68