blob: 07820790e575020f4e3c6e0234bf1cb406755c4b (
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
|
/*
*
* $Id: k3bdatatrackreader.h 619556 2007-01-03 17:38:12Z trueg $
* Copyright (C) 2003 Sebastian Trueg <[email protected]>
*
* This file is part of the K3b project.
* Copyright (C) 1998-2007 Sebastian Trueg <[email protected]>
*
* 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 _K3B_DATATRACK_READER_H_
#define _K3B_DATATRACK_READER_H_
#include <k3bthreadjob.h>
#include <k3bmsf.h>
#include <k3bglobals.h>
namespace K3bDevice {
class Device;
}
/**
* This is a replacement for readcd. We need this since
* it is not possible to influence the sector size used
* by readcd and readcd is not very good to handle anyway.
*
* The sector size read is the following:
* @li Mode1: 2048 bytes (only user data)
* @li Mode2 Form1: 2056 bytes containing the subheader and the user data
* @li Mode2 Form2: 2332 bytes containing the subheader and the user data
*
* Formless Mode2 sectors will not be read.
*/
class K3bDataTrackReader : public K3bThreadJob
{
public:
K3bDataTrackReader( K3bJobHandler*, TQObject* tqparent = 0, const char* name = 0 );
~K3bDataTrackReader();
enum SectorSize {
AUTO = 0,
MODE1 = K3b::SECTORSIZE_DATA_2048,
MODE2FORM1 = K3b::SECTORSIZE_DATA_2048_SUBHEADER,
MODE2FORM2 = K3b::SECTORSIZE_DATA_2324_SUBHEADER
};
void setSectorSize( SectorSize size );
void setDevice( K3bDevice::Device* );
/**
* @param start the first sector to be read
* @end the last sector to be read
*/
void setSectorRange( const K3b::Msf& start, const K3b::Msf& end );
void setRetries( int );
/**
* If true unreadable sectors will be replaced by zero data to always
* maintain the track length.
*/
void setIgnoreErrors( bool b );
void setNoCorrection( bool b );
/**
* the data gets written directly into fd instead of the imagefile.
* Be aware that this only makes sense before starting the job.
* To disable just set fd to -1
*/
void writeToFd( int fd );
void setImagePath( const TQString& p );
private:
class WorkThread;
WorkThread* m_thread;
};
#endif
|