MuseScore/libmscore/xml.h

164 lines
5.2 KiB
C
Raw Normal View History

2012-05-26 14:26:10 +02:00
//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2004-2011 Werner Schweer
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2
// as published by the Free Software Foundation and appearing in
// the file LICENCE.GPL
//=============================================================================
#ifndef __XML_H__
#define __XML_H__
#include "mscore.h"
#include "spatium.h"
#include "fraction.h"
#include "property.h"
2013-05-13 18:49:17 +02:00
namespace Ms {
2013-01-21 20:21:41 +01:00
class Spanner;
class Beam;
class Tuplet;
2013-01-24 09:46:28 +01:00
class ClefList;
2013-01-21 20:21:41 +01:00
2013-10-13 13:06:32 +02:00
//---------------------------------------------------------
// SpannerValues
//---------------------------------------------------------
struct SpannerValues {
int spannerId;
int tick2;
int track2;
};
2013-01-11 18:10:18 +01:00
//---------------------------------------------------------
// XmlReader
//---------------------------------------------------------
2013-06-26 10:04:41 +02:00
class XmlReader : public QXmlStreamReader {
2013-01-11 18:10:18 +01:00
QString docName; // used for error reporting
2013-01-21 20:21:41 +01:00
// Score read context (for read optimizations):
int _tick;
int _track;
QList<Beam*> _beams;
QList<Tuplet*> _tuplets;
2013-10-13 13:06:32 +02:00
QList<SpannerValues> _spannerValues;
2013-01-21 20:21:41 +01:00
2013-01-11 18:10:18 +01:00
public:
XmlReader(QFile*);
2013-09-25 14:36:11 +02:00
XmlReader(const QByteArray& d, const QString& s = QString());
XmlReader(QIODevice* d, const QString& s = QString());
XmlReader(const QString& d, const QString& s = QString());
2013-01-11 18:10:18 +01:00
void unknown() const;
// attribute helper routines:
QString attribute(const char* s) const { return attributes().value(s).toString(); }
QString attribute(const char* s, const QString&) const;
int intAttribute(const char* s) const;
int intAttribute(const char* s, int _default) const;
double doubleAttribute(const char* s) const;
double doubleAttribute(const char* s, double _default) const;
bool hasAttribute(const char* s) const;
// helper routines based on readElementText():
int readInt() { return readElementText().toInt(); }
int readInt(bool* ok) { return readElementText().toInt(ok); }
double readDouble() { return readElementText().toDouble(); }
QPointF readPoint();
QSizeF readSize();
QRectF readRect();
QColor readColor();
Fraction readFraction();
void setDocName(const QString& s) { docName = s; }
2013-01-21 20:21:41 +01:00
int tick() const { return _tick; }
2013-06-04 18:29:14 +02:00
int& rtick() { return _tick; }
2013-01-21 20:21:41 +01:00
void setTick(int val) { _tick = val; }
int track() const { return _track; }
void setTrack(int val) { _track = val; }
2013-01-24 09:31:41 +01:00
void addTuplet(Tuplet* s);
2013-01-21 20:21:41 +01:00
void addBeam(Beam* s) { _beams.append(s); }
Beam* findBeam(int) const;
Tuplet* findTuplet(int) const;
2013-10-13 13:06:32 +02:00
QList<Tuplet*>& tuplets() { return _tuplets; }
QList<Beam*>& beams() { return _beams; }
void addSpannerValues(const SpannerValues& sv) { _spannerValues.append(sv); }
const SpannerValues* spannerValues(int id);
2013-01-11 18:10:18 +01:00
};
2012-05-26 14:26:10 +02:00
//---------------------------------------------------------
// Xml
//---------------------------------------------------------
class Xml : public QTextStream {
static const int BS = 2048;
QList<QString> stack;
void putLevel();
2013-01-21 20:21:41 +01:00
QList<Spanner*> _spanner;
2012-05-26 14:26:10 +02:00
public:
int curTick; // used to optimize output
int curTrack;
int tickDiff;
int trackDiff; // saved track is curTrack-trackDiff
bool clipboardmode; // used to modify write() behaviour
bool excerptmode; // true when writing a part
bool writeOmr; // false if writing into *.msc file
int tupletId;
int beamId;
int spannerId;
2013-01-21 20:21:41 +01:00
QList<Spanner*>& spanner() { return _spanner; }
void addSpanner(Spanner* s) { _spanner.append(s); }
2012-05-26 14:26:10 +02:00
Xml(QIODevice* dev);
Xml();
void sTag(const char* name, Spatium sp) { Xml::tag(name, QVariant(sp.val())); }
void pTag(const char* name, PlaceText);
2012-05-26 14:26:10 +02:00
void fTag(const char* name, const Fraction&);
void header();
void stag(const QString&);
void etag();
void tagE(const QString&);
void tagE(const char* format, ...);
void ntag(const char* name);
void netag(const char* name);
void tag(P_ID id, void* data, void* defaultVal);
void tag(P_ID id, QVariant data, QVariant defaultData = QVariant());
void tag(const char* name, QVariant data, QVariant defaultData = QVariant());
void tag(const QString&, QVariant data);
void tag(const char* name, const char* s) { tag(name, QVariant(s)); }
void tag(const char* name, const QString& s) { tag(name, QVariant(s)); }
void tag(const char* name, const QWidget*);
2013-06-26 14:29:00 +02:00
void writeHtml(QString s);
2012-05-26 14:26:10 +02:00
void dump(int len, const unsigned char* p);
static QString xmlString(const QString&);
2013-01-11 18:10:18 +01:00
static void htmlToString(XmlReader&, int level, QString*);
static QString htmlToString(XmlReader&);
2012-05-26 14:26:10 +02:00
};
2013-01-11 18:10:18 +01:00
extern PlaceText readPlacement(XmlReader&);
2012-05-26 14:26:10 +02:00
extern QString docName;
2013-05-13 18:49:17 +02:00
} // namespace Ms
2012-05-26 14:26:10 +02:00
#endif