blob: 747129b95b751225e90cbbb03dc88d45782f90a7 (
plain)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
|
/*
*
* $Id: k3bmixedjob.h 619556 2007-01-03 17:38:12Z trueg $
* Copyright (C) 2003 Sebastian Trueg <trueg@k3b.org>
*
* This file is part of the K3b project.
* Copyright (C) 1998-2007 Sebastian Trueg <trueg@k3b.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* See the file "COPYING" for the exact licensing terms.
*/
#ifndef K3BMIXEDJOB_H
#define K3BMIXEDJOB_H
#include <k3bjob.h>
class K3bMixedDoc;
class K3bIsoImager;
class K3bAudioImager;
class TQFile;
class TQDataStream;
class K3bAbstractWriter;
class K3bWaveFileWriter;
class KTempFile;
class K3bCdrecordWriter;
class K3bMsInfoFetcher;
class K3bAudioNormalizeJob;
class K3bAudioJobTempData;
namespace K3bDevice {
class Device;
}
/**
*@author Sebastian Trueg
*/
class K3bMixedJob : public K3bBurnJob
{
TQ_OBJECT
public:
K3bMixedJob( K3bMixedDoc*, K3bJobHandler*, TQObject* parent = 0 );
~K3bMixedJob();
K3bDoc* doc() const;
K3bDevice::Device* writer() const;
TQString jobDescription() const;
TQString jobDetails() const;
public slots:
void cancel();
void start();
protected slots:
// iso imager slots
void slotIsoImagerFinished( bool success );
void slotIsoImagerPercent(int);
// ms info fetcher slots
void slotMsInfoFetched(bool);
// audio decoder slots
void slotAudioDecoderFinished( bool );
void slotAudioDecoderNextTrack( int, int );
void slotAudioDecoderPercent(int);
void slotAudioDecoderSubPercent( int );
// writer slots
void slotWriterFinished( bool success );
void slotWriterNextTrack(int, int);
void slotWriterJobPercent(int);
// normalizing slots
void slotNormalizeJobFinished( bool );
void slotNormalizeProgress( int );
void slotNormalizeSubProgress( int );
// misc slots
void slotMediaReloadedForSecondSession( bool );
void slotMaxSpeedJobFinished( bool );
private:
bool prepareWriter();
bool writeTocFile();
bool writeInfFiles();
bool startWriting();
void startFirstCopy();
void addAudioTracks( K3bCdrecordWriter* writer );
void addDataTrack( K3bCdrecordWriter* writer );
void cleanupAfterError();
void removeBufferFiles();
void createIsoImage();
void determineWritingMode();
void normalizeFiles();
void prepareProgressInformation();
void writeNextCopy();
void determinePreliminaryDataImageSize();
K3bMixedDoc* m_doc;
K3bIsoImager* m_isoImager;
K3bAudioImager* m_audioImager;
K3bAudioJobTempData* m_tempData;
K3bWaveFileWriter* m_waveFileWriter;
K3bAbstractWriter* m_writer;
K3bMsInfoFetcher* m_msInfoFetcher;
K3bAudioNormalizeJob* m_normalizeJob;
TQString m_isoImageFilePath;
KTempFile* m_tocFile;
enum Action { INITIALIZING_IMAGER,
PREPARING_DATA,
CREATING_ISO_IMAGE,
CREATING_AUDIO_IMAGE,
WRITING_ISO_IMAGE,
WRITING_AUDIO_IMAGE,
FETCHING_MSINFO };
int m_currentAction;
double m_audioDocPartOfProcess;
bool m_canceled;
bool m_errorOccuredAndAlreadyReported;
int m_usedDataMode;
int m_usedDataWritingApp;
int m_usedAudioWritingApp;
int m_usedDataWritingMode;
int m_usedAudioWritingMode;
TQString m_tempFilePrefix;
K3b::Msf m_projectSize;
class Private;
Private* d;
};
#endif
|