blob: 9eca0ed692a4ab345877a7b9c1c3e5950f975c6b (
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
|
/*
*
* $Id: k3bvcdjob.h 619556 2007-01-03 17:38:12Z trueg $
* Copyright (C) 2003-2004 Christian Kvasny <chris@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 K3BVCDJOB_H
#define K3BVCDJOB_H
#include <k3bjob.h>
class K3bVcdDoc;
class K3bVcdTrack;
class TQString;
class K3bProcess;
class TDEProcess;
class TQDataStream;
class K3bAbstractWriter;
namespace K3bDevice {
class Device;
}
class K3bVcdJob : public K3bBurnJob
{
Q_OBJECT
public:
K3bVcdJob( K3bVcdDoc*, K3bJobHandler*, TQObject* parent = 0, const char* name = 0 );
~K3bVcdJob();
K3bDoc* doc() const;
K3bVcdDoc* vcdDoc() const
{
return m_doc;
}
K3bDevice::Device* writer() const;
TQString jobDescription() const;
TQString jobDetails() const;
public slots:
void start();
void cancel();
private slots:
void cancelAll();
protected slots:
void slotVcdxBuildFinished();
void slotParseVcdxBuildOutput( TDEProcess*, char* output, int len );
void slotWriterJobPercent( int p );
void slotProcessedSize( int cs, int ts );
void slotWriterNextTrack( int t, int tt );
void slotWriterJobFinished( bool success );
private:
bool prepareWriterJob();
void xmlGen();
void vcdxBuild();
void parseInformation( const TQString& );
void startWriterjob();
int m_copies;
int m_finishedCopies;
unsigned long m_blocksToCopy;
unsigned long m_bytesFinishedTracks;
unsigned long m_bytesFinished;
enum { stageUnknown, stageScan, stageWrite, _stage_max };
K3bVcdDoc* m_doc;
K3bDevice::Device* m_writer;
K3bDevice::Device* m_reader;
K3bVcdTrack* m_currentWrittenTrack;
int m_speed;
int m_stage;
int m_currentcopy;
int m_currentWrittenTrackNumber;
double m_createimageonlypercent;
bool firstTrack;
bool m_burnProof;
bool m_keepImage;
bool m_onlyCreateImage;
bool m_onTheFly;
bool m_dummy;
bool m_fastToc;
bool m_readRaw;
bool m_imageFinished;
bool m_canceled;
TQString m_tempPath;
TQString m_cueFile;
TQString m_xmlFile;
TQString m_collectedOutput;
K3bAbstractWriter* m_writerJob;
K3bProcess* m_process;
};
#endif
|