1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1996, Vrije Universiteit Amsterdam.
5
// Author: Frank Dehne (frank@cs.vu.nl).
7
// TCM is free software; you can redistribute it and/or modify
8
// it under the terms of the GNU General Public License as published by
9
// the Free Software Foundation; either version 2 of the License, or
10
// (at your option) any later version.
12
// TCM is distributed in the hope that it will be useful,
13
// but WITHOUT ANY WARRANTY; without even the implied warranty of
14
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
// GNU General Public License for more details.
17
// You should have received a copy of the GNU General Public License
18
// along with TCM; if not, write to the Free Software
19
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21
////////////////////////////////////////////////////////////////////////////////
22
#include "datastore.h"
23
#include "inputfile.h"
24
#include "outputfile.h"
27
DataStore::DataStore(DFGraph *g): DFStore(g) {
28
atomicSubjects = new List<string *>;
31
DataStore::DataStore(const DataStore &dt): DFStore(dt) {
32
atomicSubjects = new List<string *>;
33
for (dt.atomicSubjects->first(); !dt.atomicSubjects->done(); dt.atomicSubjects->next()) {
34
string *a = dt.atomicSubjects->cur();
35
string *b = new string(*a);
36
atomicSubjects->add(b);
40
DataStore::~DataStore() {
41
atomicSubjects->clear();
42
delete atomicSubjects;
45
void DataStore::WriteMembers(OutputFile *ofile) {
46
DFStore::WriteMembers(ofile);
47
(*ofile) << "\t{ AtomicSubjects " << atomicSubjects->count() << " }\n";
48
for(atomicSubjects->first(); !atomicSubjects->done(); atomicSubjects->next()) {
49
string *s = atomicSubjects->cur();
50
(*ofile) << "\t{ AtomicSubject " << '"' << *s << '"' << " }\n";
54
bool DataStore::ReadMembers(InputFile *ifile, double format) {
55
if (!DFStore::ReadMembers(ifile, format))
59
if (!ifile->ReadAttribute("AtomicSubjects", &val))
61
unsigned numItems = val.toint();
62
for (unsigned i=0; i<numItems; i++) {
63
string *s = new string;
64
if (!ifile->ReadStringAttribute("AtomicSubject", s)) {
68
atomicSubjects->add(s);