Arquivos
hhvm/hphp/runtime/vm/fixed_string_map.cpp
T
Drew Paroski 9edc07112b Merge ObjectData and Instance together, part 1
When object support was first added to HHVM, a class named "Instance"
was introduced (deriving from ObjectData) to represent instances of user
defined classes. Since then, things have evolved and HPHPc and HPHPi have
been retired, and now there really is no needed to have ObjectData and
Instance be separate classes anymore.

As a first step towards merging ObjectData and Instance together, this diff
puts their definitions in the same .h file and puts their implementations
in the same .cpp file. A few small changes were necessary to fix issues
with cyclical includes: (1) Repo/emitter related parts of class.cpp and
class.h were moved to class-emit.cpp and class-emit.h; (2) the contents of
"vm/core_types.h" was moved to "base/types.h"; and (3) a few functions that
didn't appear to be hot were moved from .h files and the corresponding .cpp
files.
2013-07-06 11:12:29 -07:00

105 linhas
3.5 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#include "hphp/runtime/vm/fixed_string_map.h"
#include "hphp/runtime/base/complex_types.h"
#include "hphp/runtime/base/macros.h"
namespace HPHP {
TRACE_SET_MOD(runtime);
///////////////////////////////////////////////////////////////////////////////
class Func;
static const StringData* null_key;
inline bool strEqual(bool case_sensitive,
const StringData* sd1, const StringData* sd2) {
if (sd1 == sd2) return true;
if (sd1->size() != sd2->size()) return false;
return case_sensitive ?
(0 == memcmp(sd1->data(), sd2->data(), sd1->size())) :
bstrcaseeq(sd1->data(), sd2->data(), sd1->size());
}
template <typename V, bool case_sensitive>
FixedStringMap<V, case_sensitive>::~FixedStringMap() {
if (m_table != (Elm*)&null_key) {
free(m_table);
}
}
template <typename V, bool case_sensitive>
void FixedStringMap<V, case_sensitive>::init(int num) {
if (!num) {
m_table = (Elm*)&null_key;
m_mask = 0;
return;
}
static const double kLoadFactor = 0.80;
int capac = 1;
while (num >= kLoadFactor * capac) {
capac *= 2;
}
TRACE(1, "FixedStringMap::init: %d -> %d\n", num, capac);
assert(!m_table);
m_table = (Elm*)calloc(capac * sizeof(Elm), 1);
assert(m_table);
m_mask = capac - 1;
}
template <typename V, bool case_sensitive>
void FixedStringMap<V, case_sensitive>::add(const StringData* sd, const V& v) {
assert(sd->isStatic());
Elm* elm = &m_table[sd->hash() & m_mask];
UNUSED unsigned numProbes = 0;
while (elm->sd) {
assert(numProbes++ < m_mask + 1);
// Semantics for multiple insertion: new value wins.
if (strEqual(case_sensitive, elm->sd, sd)) break;
if (UNLIKELY(++elm == &m_table[m_mask + 1])) elm = m_table;
}
elm->sd = sd;
elm->data = v;
}
template <typename V, bool case_sensitive>
V* FixedStringMap<V, case_sensitive>::find(const StringData* sd) const {
Elm* elm = &m_table[sd->hash() & m_mask];
UNUSED unsigned numProbes = 0;
for(;;) {
assert(numProbes++ < m_mask + 1);
if (UNLIKELY(nullptr == elm->sd)) return nullptr;
if (strEqual(case_sensitive, elm->sd, sd)) return &elm->data;
if (UNLIKELY(++elm == &m_table[m_mask + 1])) elm = m_table;
}
}
template class FixedStringMap<Slot, false>;
template class FixedStringMap<Slot, true>;
template class FixedStringMap<Id, false>;
template class FixedStringMap<Id, true>;
template class FixedStringMap<Func*, false>;
template class FixedStringMap<unsigned char* /* TCA */, true>;
///////////////////////////////////////////////////////////////////////////////
}