void KstPlugin::save(QTextStream &ts) { if (_plugin.data() != 0L) { ts << " <plugin>" << endl; ts << " <tag>" << tagName() << "</tag>" << endl; ts << " <name>" << _plugin->data()._name << "</name>" << endl; for (KstVectorMap::Iterator i = _inputVectors.begin(); i != _inputVectors.end(); ++i) { ts << " <ivector name=\"" << i.key() << "\">" << i.data()->tagName() << "</ivector>" << endl; } for (KstScalarMap::Iterator i = _inputScalars.begin(); i != _inputScalars.end(); ++i) { ts << " <iscalar name=\"" << i.key() << "\">" << i.data()->tagName() << "</iscalar>" << endl; } for (KstVectorMap::Iterator i = _outputVectors.begin(); i != _outputVectors.end(); ++i) { ts << " <ovector name=\"" << i.key() << "\">" << i.data()->tagName() << "</ovector>" << endl; } for (KstScalarMap::Iterator i = _outputScalars.begin(); i != _outputScalars.end(); ++i) { ts << " <oscalar name=\"" << i.key() << "\">" << i.data()->tagName() << "</oscalar>" << endl; } ts << " </plugin>" << endl; } }
void KstCPlugin::save(QTextStream &ts, const QString& indent) { if (!_plugin) { return; } QString l2 = indent + " "; ts << indent << "<plugin>" << endl; ts << l2 << "<tag>" << QStyleSheet::escape(tagName()) << "</tag>" << endl; ts << l2 << "<name>" << QStyleSheet::escape(_plugin->data()._name) << "</name>" << endl; for (KstVectorMap::Iterator i = _inputVectors.begin(); i != _inputVectors.end(); ++i) { ts << l2 << "<ivector name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tag().tagString()) << "</ivector>" << endl; } for (KstScalarMap::Iterator i = _inputScalars.begin(); i != _inputScalars.end(); ++i) { ts << l2 << "<iscalar name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tag().tagString()) << "</iscalar>" << endl; } for (KstStringMap::Iterator i = _inputStrings.begin(); i != _inputStrings.end(); ++i) { ts << l2 << "<istring name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tag().tagString()) << "</istring>" << endl; } for (KstVectorMap::Iterator i = _outputVectors.begin(); i != _outputVectors.end(); ++i) { ts << l2 << "<ovector name=\"" << QStyleSheet::escape(i.key()); if (i.data()->isScalarList()) { ts << "\" scalarList=\"1"; } ts << "\">" << QStyleSheet::escape(i.data()->tag().tag()) << "</ovector>" << endl; } for (KstScalarMap::Iterator i = _outputScalars.begin(); i != _outputScalars.end(); ++i) { ts << l2 << "<oscalar name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tag().tag()) << "</oscalar>" << endl; } for (KstStringMap::Iterator i = _outputStrings.begin(); i != _outputStrings.end(); ++i) { ts << l2 << "<ostring name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tag().tag()) << "</ostring>" << endl; } ts << indent << "</plugin>" << endl; }
void CrossPowerSpectrum::save(QTextStream& ts, const QString& indent) { QString l2 = indent + " "; ts << indent << "<plugin name=\"Cross Power Spectrum\">" << endl; ts << l2 << "<tag>" << QStyleSheet::escape(tagName()) << "</tag>" << endl; for (KstVectorMap::Iterator i = _inputVectors.begin(); i != _inputVectors.end(); ++i) { ts << l2 << "<ivector name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</ivector>" << endl; } for (KstScalarMap::Iterator i = _inputScalars.begin(); i != _inputScalars.end(); ++i) { ts << l2 << "<iscalar name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</iscalar>" << endl; } for (KstStringMap::Iterator i = _inputStrings.begin(); i != _inputStrings.end(); ++i) { ts << l2 << "<istring name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</istring>" << endl; } for (KstVectorMap::Iterator i = _outputVectors.begin(); i != _outputVectors.end(); ++i) { ts << l2 << "<ovector name=\"" << QStyleSheet::escape(i.key()); if (i.data()->isScalarList()) { ts << "\" scalarList=\"1"; } ts << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</ovector>" << endl; } for (KstScalarMap::Iterator i = _outputScalars.begin(); i != _outputScalars.end(); ++i) { ts << l2 << "<oscalar name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</oscalar>" << endl; } for (KstStringMap::Iterator i = _outputStrings.begin(); i != _outputStrings.end(); ++i) { ts << l2 << "<ostring name=\"" << QStyleSheet::escape(i.key()) << "\">" << QStyleSheet::escape(i.data()->tagName()) << "</ostring>" << endl; } ts << indent << "</plugin>" << endl; }
void KstEquation::replaceDependency(KstDataObjectPtr oldObject, KstDataObjectPtr newObject) { QString newExp = _equation; // replace all occurences of outputVectors, outputScalars from oldObject for (KstVectorMap::Iterator j = oldObject->outputVectors().begin(); j != oldObject->outputVectors().end(); ++j) { QString oldTag = j.data()->tagName(); QString newTag = ((newObject->outputVectors())[j.key()])->tagName(); newExp = newExp.replace("[" + oldTag + "]", "[" + newTag + "]"); } for (KstScalarMap::Iterator j = oldObject->outputScalars().begin(); j != oldObject->outputScalars().end(); ++j) { QString oldTag = j.data()->tagName(); QString newTag = ((newObject->outputScalars())[j.key()])->tagName(); newExp = newExp.replace("[" + oldTag + "]", "[" + newTag + "]"); } // and dependencies on matrix stats (there won't be matrices themselves in the expression) for (KstMatrixMap::Iterator j = oldObject->outputMatrices().begin(); j != oldObject->outputMatrices().end(); ++j) { QDictIterator<KstScalar> scalarDictIter(j.data()->scalars()); for (; scalarDictIter.current(); ++scalarDictIter) { QString oldTag = scalarDictIter.current()->tagName(); QString newTag = ((((newObject->outputMatrices())[j.key()])->scalars())[scalarDictIter.currentKey()])->tagName(); newExp = newExp.replace("[" + oldTag + "]", "[" + newTag + "]"); } } // only replace _inputVectors for (KstVectorMap::Iterator j = oldObject->outputVectors().begin(); j != oldObject->outputVectors().end(); ++j) { for (KstVectorMap::Iterator k = _inputVectors.begin(); k != _inputVectors.end(); ++k) { if (j.data().data() == k.data().data()) { // replace input with the output from newObject _inputVectors[k.key()] = (newObject->outputVectors())[j.key()]; } } // and dependencies on vector stats QDictIterator<KstScalar> scalarDictIter(j.data()->scalars()); for (; scalarDictIter.current(); ++scalarDictIter) { QString oldTag = scalarDictIter.current()->tagName(); QString newTag = ((((newObject->outputVectors())[j.key()])->scalars())[scalarDictIter.currentKey()])->tagName(); newExp = newExp.replace("[" + oldTag + "]", "[" + newTag + "]"); } } setEquation(newExp); }
void KstCPlugin::setTagName(const QString &in_tag) { KstObjectTag newTag(in_tag, tag().context()); if (newTag == tag()) { return; } KstObject::setTagName(newTag); for (KstVectorMap::Iterator iter = outputVectors().begin(); iter != outputVectors().end(); ++iter) { (*iter)->setTagName(KstObjectTag(iter.data()->tag().tag(), tag())); } for (KstScalarMap::Iterator iter = outputScalars().begin(); iter != outputScalars().end(); ++iter) { (*iter)->setTagName(KstObjectTag(iter.data()->tag().tag(), tag())); } for (KstStringMap::Iterator iter = outputStrings().begin(); iter != outputStrings().end(); ++iter) { (*iter)->setTagName(KstObjectTag(iter.data()->tag().tag(), tag())); } }