forked from musescore/MuseScore
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgroups.h
89 lines (69 loc) · 2.53 KB
/
groups.h
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
87
88
//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2013 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 __GROUPS__
#define __GROUPS__
#include "fraction.h"
#include "mscore.h"
#include "durationtype.h"
#include "beam.h"
namespace Ms {
class ChordRest;
class XmlWriter;
class XmlReader;
//---------------------------------------------------------
// GroupNode
//---------------------------------------------------------
struct GroupNode {
int pos; // tick position, division 32nd
int action; // bits: cccc bbbb aaaa
// cc - 1/64 bb - 1/32 aa - 1/16
// bit pattern xxxx:
// 1 - start new beam
// 2 - start new 1/32 subbeam
// 3 - start new 1/64 subbeam
bool operator==(const GroupNode& g) const { return g.pos == pos && g.action == action; }
};
//---------------------------------------------------------
// @@ Groups
/// GroupNodes must be sorted by tick
//---------------------------------------------------------
class Groups : public std::vector<GroupNode> {
public:
Groups() {}
Groups(const std::vector<GroupNode>& l) : std::vector<GroupNode>(l) {}
void write(XmlWriter&) const;
void read(XmlReader&);
Beam::Mode beamMode(int tick, TDuration::DurationType d) const;
void addStop(int pos, TDuration::DurationType d, Beam::Mode bm);
bool operator==(const Groups& g) const {
if (g.size() != size())
return false;
for (unsigned i = 0; i < size(); ++i) {
if (!(g[i] == (*this)[i]))
return false;
}
return true;
}
void dump(const char*) const;
static const Groups& endings(const Fraction& f);
static Beam::Mode endBeam(ChordRest* cr, ChordRest* prev = 0);
};
//---------------------------------------------------------
// NoteGroup
//---------------------------------------------------------
struct NoteGroup {
Fraction timeSig;
Groups endings;
};
} // namespace Ms
Q_DECLARE_METATYPE(Ms::Groups);
#endif