comparison data/model/WaveFileModel.h @ 936:0c1d6de8f44b

Merge from branch warnfix_no_size_t
author Chris Cannam
date Wed, 18 Jun 2014 13:51:16 +0100
parents 59e7fe1b1003
children 6d2ece0fe356
comparison
equal deleted inserted replaced
917:49618f39ff09 936:0c1d6de8f44b
32 class WaveFileModel : public RangeSummarisableTimeValueModel 32 class WaveFileModel : public RangeSummarisableTimeValueModel
33 { 33 {
34 Q_OBJECT 34 Q_OBJECT
35 35
36 public: 36 public:
37 WaveFileModel(FileSource source, size_t targetRate = 0); 37 WaveFileModel(FileSource source, int targetRate = 0);
38 WaveFileModel(FileSource source, AudioFileReader *reader); 38 WaveFileModel(FileSource source, AudioFileReader *reader);
39 ~WaveFileModel(); 39 ~WaveFileModel();
40 40
41 bool isOK() const; 41 bool isOK() const;
42 bool isReady(int *) const; 42 bool isReady(int *) const;
43 43
44 const ZoomConstraint *getZoomConstraint() const { return &m_zoomConstraint; } 44 const ZoomConstraint *getZoomConstraint() const { return &m_zoomConstraint; }
45 45
46 size_t getFrameCount() const; 46 int getFrameCount() const;
47 size_t getChannelCount() const; 47 int getChannelCount() const;
48 size_t getSampleRate() const; 48 int getSampleRate() const;
49 size_t getNativeRate() const; 49 int getNativeRate() const;
50 50
51 QString getTitle() const; 51 QString getTitle() const;
52 QString getMaker() const; 52 QString getMaker() const;
53 QString getLocation() const; 53 QString getLocation() const;
54 54
55 virtual Model *clone() const; 55 virtual Model *clone() const;
56 56
57 float getValueMinimum() const { return -1.0f; } 57 float getValueMinimum() const { return -1.0f; }
58 float getValueMaximum() const { return 1.0f; } 58 float getValueMaximum() const { return 1.0f; }
59 59
60 virtual size_t getStartFrame() const { return m_startFrame; } 60 virtual int getStartFrame() const { return m_startFrame; }
61 virtual size_t getEndFrame() const { return m_startFrame + getFrameCount(); } 61 virtual int getEndFrame() const { return m_startFrame + getFrameCount(); }
62 62
63 void setStartFrame(size_t startFrame) { m_startFrame = startFrame; } 63 void setStartFrame(int startFrame) { m_startFrame = startFrame; }
64 64
65 virtual size_t getData(int channel, size_t start, size_t count, 65 virtual int getData(int channel, int start, int count,
66 float *buffer) const; 66 float *buffer) const;
67 67
68 virtual size_t getData(int channel, size_t start, size_t count, 68 virtual int getData(int channel, int start, int count,
69 double *buffer) const; 69 double *buffer) const;
70 70
71 virtual size_t getData(size_t fromchannel, size_t tochannel, 71 virtual int getData(int fromchannel, int tochannel,
72 size_t start, size_t count, 72 int start, int count,
73 float **buffers) const; 73 float **buffers) const;
74 74
75 virtual size_t getSummaryBlockSize(size_t desired) const; 75 virtual int getSummaryBlockSize(int desired) const;
76 76
77 virtual void getSummaries(size_t channel, size_t start, size_t count, 77 virtual void getSummaries(int channel, int start, int count,
78 RangeBlock &ranges, 78 RangeBlock &ranges,
79 size_t &blockSize) const; 79 int &blockSize) const;
80 80
81 virtual Range getSummary(size_t channel, size_t start, size_t count) const; 81 virtual Range getSummary(int channel, int start, int count) const;
82 82
83 QString getTypeName() const { return tr("Wave File"); } 83 QString getTypeName() const { return tr("Wave File"); }
84 84
85 virtual void toXml(QTextStream &out, 85 virtual void toXml(QTextStream &out,
86 QString indent = "", 86 QString indent = "",
98 public: 98 public:
99 RangeCacheFillThread(WaveFileModel &model) : 99 RangeCacheFillThread(WaveFileModel &model) :
100 m_model(model), m_fillExtent(0), 100 m_model(model), m_fillExtent(0),
101 m_frameCount(model.getFrameCount()) { } 101 m_frameCount(model.getFrameCount()) { }
102 102
103 size_t getFillExtent() const { return m_fillExtent; } 103 int getFillExtent() const { return m_fillExtent; }
104 virtual void run(); 104 virtual void run();
105 105
106 protected: 106 protected:
107 WaveFileModel &m_model; 107 WaveFileModel &m_model;
108 size_t m_fillExtent; 108 int m_fillExtent;
109 size_t m_frameCount; 109 int m_frameCount;
110 }; 110 };
111 111
112 void fillCache(); 112 void fillCache();
113 113
114 FileSource m_source; 114 FileSource m_source;
115 QString m_path; 115 QString m_path;
116 AudioFileReader *m_reader; 116 AudioFileReader *m_reader;
117 bool m_myReader; 117 bool m_myReader;
118 118
119 size_t m_startFrame; 119 int m_startFrame;
120 120
121 RangeBlock m_cache[2]; // interleaved at two base resolutions 121 RangeBlock m_cache[2]; // interleaved at two base resolutions
122 mutable QMutex m_mutex; 122 mutable QMutex m_mutex;
123 RangeCacheFillThread *m_fillThread; 123 RangeCacheFillThread *m_fillThread;
124 QTimer *m_updateTimer; 124 QTimer *m_updateTimer;
125 size_t m_lastFillExtent; 125 int m_lastFillExtent;
126 bool m_exiting; 126 bool m_exiting;
127 static PowerOfSqrtTwoZoomConstraint m_zoomConstraint; 127 static PowerOfSqrtTwoZoomConstraint m_zoomConstraint;
128 128
129 mutable SampleBlock m_directRead; 129 mutable SampleBlock m_directRead;
130 mutable size_t m_lastDirectReadStart; 130 mutable int m_lastDirectReadStart;
131 mutable size_t m_lastDirectReadCount; 131 mutable int m_lastDirectReadCount;
132 mutable QMutex m_directReadMutex; 132 mutable QMutex m_directReadMutex;
133 }; 133 };
134 134
135 #endif 135 #endif