File: importmxmlnotepitch.h

package info (click to toggle)
musescore2 2.3.2%2Bdfsg4-15
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 168,212 kB
  • sloc: cpp: 262,317; xml: 176,707; sh: 3,377; ansic: 1,384; python: 356; makefile: 227; perl: 82; pascal: 78
file content (62 lines) | stat: -rw-r--r-- 2,131 bytes parent folder | download | duplicates (9)
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
//=============================================================================
//  MuseScore
//  Music Composition & Notation
//
//  Copyright (C) 2018 Werner Schweer and others
//
//  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 __IMPORTMXMLNOTEPITCH_H__
#define __IMPORTMXMLNOTEPITCH_H__

#include "libmscore/accidental.h"

namespace Ms {

class MxmlLogger;
class Score;

//---------------------------------------------------------
//   mxmlNotePitch
//---------------------------------------------------------

/**
 Parse the note pitch related part of the /score-partwise/part/measure/note node.
 */

class mxmlNotePitch
      {
public:
      mxmlNotePitch(MxmlLogger* logger) : _logger(logger) { /* nothing so far */ }
      void pitch(QXmlStreamReader& e);
      bool readProperties(QXmlStreamReader& e, Score* score);
      Accidental* acc() const { return _acc; }
      AccidentalType accType() const { return _accType; }
      int alter() const { return _alter; }
      int displayOctave() const { return _displayOctave; }
      int displayStep() const { return _displayStep; }
      void displayStepOctave(QXmlStreamReader& e);
      int octave() const { return _octave; }
      int step() const { return _step; }
      bool unpitched() const { return _unpitched; }

private:
      Accidental* _acc = 0;                                 // created based on accidental element
      AccidentalType _accType = AccidentalType::NONE;       // set by pitch() based on alter value (can be microtonal)
      int _alter = 0;
      int _displayStep = -1;                                // invalid
      int _displayOctave = -1;                              // invalid
      int _octave = -1;
      int _step = 0;
      bool _unpitched = false;
      MxmlLogger* _logger;                                  ///< Error logger
      };


} // namespace Ms

#endif