本文整理汇总了C++中dynamiccontext::Ptr类的典型用法代码示例。如果您正苦于以下问题:C++ Ptr类的具体用法?C++ Ptr怎么用?C++ Ptr使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Ptr类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: evaluateToSequenceReceiver
void DocumentConstructor::evaluateToSequenceReceiver(const DynamicContext::Ptr &context) const
{
QAbstractXmlReceiver *const receiver = context->outputReceiver();
DocumentContentValidator validator(receiver, context, ConstPtr(this));
const DynamicContext::Ptr receiverContext(context->createReceiverContext(&validator));
validator.startDocument();
m_operand->evaluateToSequenceReceiver(receiverContext);
validator.endDocument();
}
示例2: source
Item::Iterator::Ptr AxisStep::evaluateSequence(const DynamicContext::Ptr &context) const
{
/* If we don't have a focus, it's either a bug or our parent isn't a Path
* that have advanced the focus iterator. Hence, attempt to advance the focus on our own. */
if(!context->contextItem())
context->focusIterator()->next();
Q_ASSERT(context->contextItem());
const QXmlNodeModelIndex::Iterator::Ptr source(context->contextItem().asNode().iterate(m_axis));
return makeItemMappingIterator<Item>(ConstPtr(this), source, context);
}
示例3: evaluateSingleton
Item PrefixFromQNameFN::evaluateSingleton(const DynamicContext::Ptr &context) const
{
const QNameValue::Ptr arg(m_operands.first()->evaluateSingleton(context).as<QNameValue>());
if(!arg)
return Item();
const QString prefix(context->namePool()->stringForPrefix(arg->qName().prefix()));
if(prefix.isEmpty())
return Item();
else
return AtomicString::fromValue(context->namePool()->stringForPrefix(arg->qName().prefix()));
}
示例4: topFocusContext
Item EvaluationCache<IsForGlobal>::evaluateSingleton(const DynamicContext::Ptr &context) const
{
ItemCacheCell &cell = IsForGlobal ? context->globalItemCacheCell(m_varSlot) : context->itemCacheCell(m_varSlot);
if(cell.cacheState == ItemCacheCell::Full)
return cell.cachedItem;
else
{
Q_ASSERT(cell.cacheState == ItemCacheCell::Empty);
cell.cachedItem = m_operand->evaluateSingleton(IsForGlobal ? topFocusContext(context) : context);
cell.cacheState = ItemCacheCell::Full;
return cell.cachedItem;
}
}
示例5: checkTargetNode
void ContextNodeChecker::checkTargetNode(const QXmlNodeModelIndex &node,
const DynamicContext::Ptr &context,
const ReportContext::ErrorCode code) const
{
if(node.root().kind() != QXmlNodeModelIndex::Document)
{
context->error(QtXmlPatterns::tr("The root node of the second argument "
"to function %1 must be a document "
"node. %2 is not a document node.")
.arg(formatFunction(context->namePool(), signature()),
formatData(node)),
code, this);
}
}
示例6: evaluateSingleton
Item AttributeConstructor::evaluateSingleton(const DynamicContext::Ptr &context) const
{
const Item nameItem(m_operand1->evaluateSingleton(context));
const Item content(m_operand2->evaluateSingleton(context));
const QXmlName name(nameItem.as<QNameValue>()->qName());
const QString value(processValue(name, content ? content.stringValue() : QString()));
const NodeBuilder::Ptr nodeBuilder(context->nodeBuilder(QUrl()));
nodeBuilder->attribute(name, QStringRef(&value));
const QAbstractXmlNodeModel::Ptr nm(nodeBuilder->builtDocument());
context->addNodeModel(nm);
return nm->root(QXmlNodeModelIndex());
}
示例7: next
Item::Iterator::Ptr CardinalityVerifier::evaluateSequence(const DynamicContext::Ptr &context) const
{
const Item::Iterator::Ptr it(m_operand->evaluateSequence(context));
const Item next(it->next());
if(next)
{
const Item next2(it->next());
if(next2)
{
if(m_reqCard.allowsMany())
{
Item::List start;
start.append(next);
start.append(next2);
return Item::Iterator::Ptr(new InsertionIterator(it, 1, makeListIterator(start)));
}
else
{
context->error(wrongCardinality(m_reqCard, Cardinality::twoOrMore()), m_errorCode, this);
return CommonValues::emptyIterator;
}
}
else
{
/* We might be instantiated for the empty sequence. */
if(m_reqCard.isEmpty())
{
context->error(wrongCardinality(m_reqCard, Cardinality::twoOrMore()), m_errorCode, this);
return CommonValues::emptyIterator;
}
else
return makeSingletonIterator(next);
}
}
else
{
if(m_reqCard.allowsEmpty())
return CommonValues::emptyIterator;
else
{
context->error(wrongCardinality(m_reqCard, Cardinality::twoOrMore()), m_errorCode, this);
return CommonValues::emptyIterator;
}
}
}
示例8: next
Item::Iterator::Ptr Path::evaluateSequence(const DynamicContext::Ptr &context) const
{
/* Note, we use the old context for m_operand1. */
const Item::Iterator::Ptr source(m_operand1->evaluateSequence(context));
const DynamicContext::Ptr focus(context->createFocus());
focus->setFocusIterator(source);
const Item::Iterator::Ptr result(makeSequenceMappingIterator<Item>(ConstPtr(this), source, focus));
if(m_checkXPTY0018)
{
/* This is an expensive code path, but it should happen very rarely. */
enum FoundItem
{
FoundNone,
FoundNode,
FoundAtomicValue
} hasFound = FoundNone;
Item::List whenChecked;
Item next(result->next());
while(next)
{
const FoundItem found = next.isAtomicValue() ? FoundAtomicValue : FoundNode;
if(hasFound != FoundNone && hasFound != found)
{
/* It's an atomic value and we've already found a node. Mixed content. */
context->error(QtXmlPatterns::tr("The last step in a path must contain either nodes "
"or atomic values. It cannot be a mixture between the two."),
ReportContext::XPTY0018, this);
}
else
hasFound = found;
whenChecked.append(next);
next = result->next();
}
return makeListIterator(whenChecked);
}
else
return result;
}
示例9: evaluateSingleton
Item DocumentConstructor::evaluateSingleton(const DynamicContext::Ptr &context) const
{
NodeBuilder::Ptr nodeBuilder(context->nodeBuilder(m_staticBaseURI));
DocumentContentValidator validator(nodeBuilder.data(), context, ConstPtr(this));
const DynamicContext::Ptr receiverContext(context->createReceiverContext(&validator));
validator.startDocument();
m_operand->evaluateToSequenceReceiver(receiverContext);
validator.endDocument();
const QAbstractXmlNodeModel::Ptr nm(nodeBuilder->builtDocument());
context->addNodeModel(nm);
return nm->root(QXmlNodeModelIndex());
}
示例10: evaluateToSequenceReceiver
void CommentConstructor::evaluateToSequenceReceiver(const DynamicContext::Ptr &context) const
{
const QString content(evaluateContent(context));
QAbstractXmlReceiver *const receiver = context->outputReceiver();
receiver->comment(content);
}
示例11: mapToItem
/**
* Performs the actual tracing.
*/
Item mapToItem(const Item &item,
const DynamicContext::Ptr &context)
{
QTextStream out(stderr);
++m_position;
if(m_position == 1)
{
if(item)
{
out << qPrintable(m_msg)
<< " : "
<< qPrintable(item.stringValue());
}
else
{
out << qPrintable(m_msg)
<< " : ("
<< qPrintable(formatType(context->namePool(), CommonSequenceTypes::Empty))
<< ")\n";
return Item();
}
}
else
{
out << qPrintable(item.stringValue())
<< '['
<< m_position
<< "]\n";
}
return item;
}
示例12: evaluateToSequenceReceiver
void ElementConstructor::evaluateToSequenceReceiver(const DynamicContext::Ptr &context) const
{
/* We create an OutputValidator here too. If we're serializing(a common case, unfortunately)
* the receiver is already validating in order to catch cases where a computed attribute
* constructor is followed by an element constructor, but in the cases where we're not serializing
* it's necessary that we validate in this step. */
const Item name(m_operand1->evaluateSingleton(context));
QAbstractXmlReceiver *const receiver = context->outputReceiver();
OutputValidator validator(receiver, context, this);
const DynamicContext::Ptr receiverContext(context->createReceiverContext(&validator));
receiver->startElement(name.as<QNameValue>()->qName());
m_operand2->evaluateToSequenceReceiver(receiverContext);
receiver->endElement();
}
示例13: evaluateSingleton
Item CastAs::evaluateSingleton(const DynamicContext::Ptr &context) const
{
Q_ASSERT(context);
const Item val(m_operand->evaluateSingleton(context));
if(val)
return cast(val, context);
else
{
/* No item supplied, let's handle the cardinality part. */
if(m_targetType->cardinality().allowsEmpty())
return Item();
else
{
Q_ASSERT(context);
context->error(QtXmlPatterns::tr("Type error in cast, expected %1, "
"received %2.")
.arg(formatType(Cardinality::exactlyOne()))
.arg(formatType(Cardinality::empty())),
ReportContext::XPTY0004, this);
return Item();
}
}
}
示例14: determineNormalizationForm
int NormalizeUnicodeFN::determineNormalizationForm(const DynamicContext::Ptr &context) const
{
const QString strRepr(m_operands.last()->evaluateSingleton(context).stringValue().trimmed().toUpper());
/* TODO. Put these values in a QHash for faster lookup. Keep thread safety in mind. */
if(strRepr.isEmpty())
return -1;
else if(strRepr == QLatin1String("NFC"))
return QString::NormalizationForm_C;
else if(strRepr == QLatin1String("NFD"))
return QString::NormalizationForm_D;
else if(strRepr == QLatin1String("NFKC"))
return QString::NormalizationForm_KC;
else if(strRepr == QLatin1String("NFKD"))
return QString::NormalizationForm_KD;
else
{
/* What form is FULLY_NORMALIZED? Is a code path available for that somewhere? */
context->error(QtXmlPatterns::tr("The normalization form %1 is "
"unsupported. The supported forms are "
"%2, %3, %4, and %5, and none, i.e. "
"the empty string (no normalization).")
.arg(formatKeyword(strRepr))
.arg(formatKeyword("NFC"))
.arg(formatKeyword("NFD"))
.arg(formatKeyword("NFKC"))
.arg(formatKeyword("NFKD")),
ReportContext::FOCH0003,
this);
return QString::NormalizationForm_C; /* Silence compiler warning. */
}
}
示例15: evaluateSingleton
Item TextNodeConstructor::evaluateSingleton(const DynamicContext::Ptr &context) const
{
const Item chars(m_operand->evaluateSingleton(context));
if(!chars)
return Item();
const NodeBuilder::Ptr nodeBuilder(context->nodeBuilder(QUrl()));
const QString &v = chars.stringValue();
nodeBuilder->characters(QStringRef(&v));
const QAbstractXmlNodeModel::Ptr nm(nodeBuilder->builtDocument());
context->addNodeModel(nm);
return nm->root(QXmlNodeModelIndex());
}