本文整理汇总了C++中ArrayData::iter_begin方法的典型用法代码示例。如果您正苦于以下问题:C++ ArrayData::iter_begin方法的具体用法?C++ ArrayData::iter_begin怎么用?C++ ArrayData::iter_begin使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ArrayData
的用法示例。
在下文中一共展示了ArrayData::iter_begin方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: isHead
bool Globals::isHead(ssize_t pos) const {
if (staticSize() > 0) return pos == 0;
if (pos < -1) {
ArrayData *arr = Array::get();
ASSERT(arr);
return !arr->empty() && wrapIter(pos) == arr->iter_begin();
}
return false;
}
示例2: iter_advance
ssize_t Globals::iter_advance(ssize_t prev) const {
ArrayData *arr = Array::get();
if (prev < -1) {
return wrapIter(arr->iter_advance(wrapIter(prev)));
}
ssize_t next = prev + 1;
if (next == staticSize()) {
if (arr) return wrapIter(arr->iter_begin());
return ArrayData::invalid_index;
}
return next;
}
示例3: Object
ALWAYS_INLINE
typename std::enable_if<
std::is_base_of<BaseMap, TMap>::value, Object>::type
BaseMap::FromArray(const Class*, const Variant& arr) {
if (!arr.isArray()) {
SystemLib::throwInvalidArgumentExceptionObject(
"Parameter arr must be an array");
}
auto map = req::make<TMap>();
ArrayData* ad = arr.getArrayData();
map->reserve(ad->size());
for (ssize_t pos = ad->iter_begin(), limit = ad->iter_end(); pos != limit;
pos = ad->iter_advance(pos)) {
Variant k = ad->getKey(pos);
auto* tv = ad->getValueRef(pos).asCell();
if (k.isInteger()) {
map->setRaw(k.toInt64(), tv);
} else {
assert(k.isString());
map->setRaw(k.getStringData(), tv);
}
}
return Object(std::move(map));
}
示例4: extract_impl
ALWAYS_INLINE static
int64_t extract_impl(VRefParam vref_array,
int extract_type /* = EXTR_OVERWRITE */,
const String& prefix /* = "" */) {
auto arrByRef = false;
auto arr_tv = vref_array.wrapped().asTypedValue();
if (arr_tv->m_type == KindOfRef) {
arr_tv = arr_tv->m_data.pref->tv();
arrByRef = true;
}
if (!isArrayType(arr_tv->m_type)) {
raise_warning("extract() expects parameter 1 to be array");
return 0;
}
bool reference = extract_type & EXTR_REFS;
extract_type &= ~EXTR_REFS;
VMRegAnchor _;
auto const varEnv = g_context->getOrCreateVarEnv();
if (!varEnv) return 0;
auto& carr = tvAsCVarRef(arr_tv).asCArrRef();
if (UNLIKELY(reference)) {
auto extr_refs = [&](Array& arr) {
if (arr.size() > 0) {
// force arr to escalate (if necessary) by getting an lvalue to the
// first element.
ArrayData* ad = arr.get();
auto const& first_key = ad->getKey(ad->iter_begin());
arr.lvalAt(first_key);
}
int count = 0;
for (ArrayIter iter(arr); iter; ++iter) {
auto name = iter.first().toString();
if (!modify_extract_name(varEnv, name, extract_type, prefix)) continue;
// The const_cast is safe because we escalated the array. We can't use
// arr.lvalAt(name), because arr may have been modified as a side
// effect of an earlier iteration.
auto& ref = const_cast<Variant&>(iter.secondRef());
g_context->bindVar(name.get(), ref.asTypedValue());
++count;
}
return count;
};
if (arrByRef) {
return extr_refs(tvAsVariant(vref_array.getRefData()->tv()).asArrRef());
}
Array tmp = carr;
return extr_refs(tmp);
}
int count = 0;
for (ArrayIter iter(carr); iter; ++iter) {
auto name = iter.first().toString();
if (!modify_extract_name(varEnv, name, extract_type, prefix)) continue;
g_context->setVar(name.get(), iter.secondRef().asTypedValue());
++count;
}
return count;
}