File: DatafilesSet.cpp

package info (click to toggle)
bornagain 23.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 103,936 kB
  • sloc: cpp: 423,131; python: 40,997; javascript: 11,167; awk: 630; sh: 318; ruby: 173; xml: 130; makefile: 51; ansic: 24
file content (86 lines) | stat: -rw-r--r-- 2,489 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
//  ************************************************************************************************
//
//  BornAgain: simulate and fit reflection and scattering
//
//! @file      GUI/Model/File/DatafilesSet.cpp
//! @brief     Implements class DatafilesSet.
//!
//! @homepage  http://www.bornagainproject.org
//! @license   GNU General Public License v3 or higher (see COPYING)
//! @copyright Forschungszentrum Jülich GmbH 2018
//! @authors   Scientific Computing Group at MLZ (see CITATION, AUTHORS)
//
//  ************************************************************************************************

#include "GUI/Model/File/DatafilesSet.h"
#include "Base/Util/Assert.h"
#include "GUI/Model/Util/UtilXML.h"

namespace {
namespace Tag {

const QString RealData("RealData");
const QString CurrentIndex("CurrentIndex");

} // namespace Tag
} // namespace

DatafilesSet::DatafilesSet() = default;
DatafilesSet::~DatafilesSet() = default;

void DatafilesSet::writeTo(QXmlStreamWriter* w) const
{
    // real items
    for (auto* dfi : *this) {
        w->writeStartElement(Tag::RealData);
        XML::writeAttribute(w, XML::Attrib::name, dfi->name());
        dfi->writeTo(w);
        w->writeEndElement();
    }
    XML::writeTaggedValue(w, Tag::CurrentIndex, (int)currentIndex());
}

void DatafilesSet::readFrom(QXmlStreamReader* r)
{
    clear();
    while (r->readNextStartElement()) {
        QString tag = r->name().toString();
        if (tag == Tag::RealData) {
            auto* item = new DatafileItem;
            item->readFrom(r);
            add_item(item);
            XML::gotoEndElementOfTag(r, tag);
        } else if (tag == Tag::CurrentIndex)
            setCurrentIndex(XML::readTaggedInt(r, tag));
        else
            r->skipCurrentElement();
    }

    if (r->hasError())
        throw std::runtime_error(r->errorString().toStdString());
}

void DatafilesSet::writeDatafiles(const QString& projectDir) const
{
    for (const auto* dfi : *this)
        dfi->saveDatafield(projectDir);

    dataFilesCleaner.cleanOldFiles(projectDir, dataItems());
}

void DatafilesSet::readDatafiles(const QString& projectDir)
{
    for (auto* dfi : *this)
        dfi->loadDatafield(projectDir);

    dataFilesCleaner.recollectDataNames(dataItems());
}

QVector<DataItem*> DatafilesSet::dataItems() const
{
    QVector<DataItem*> result;
    for (auto* dfi : *this)
        if (auto* data_item = dfi->dataItem())
            result.push_back(data_item);
    return result;
}