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
|
/* This file is part of the KDE libraries
Copyright (C) 2000 David Faure <faure@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef _TAR_H
#define _TAR_H
#include <sys/types.h>
#include <kio/global.h>
#include <kio/slavebase.h>
class ArchiveProtocol : public KIO::SlaveBase
{
public:
ArchiveProtocol( const QCString &pool, const QCString &app );
virtual ~ArchiveProtocol();
virtual void listDir( const KURL & url );
virtual void stat( const KURL & url );
virtual void get( const KURL & url );
protected:
void createUDSEntry( const KArchiveEntry * tarEntry, KIO::UDSEntry & entry );
/**
* \brief find, check and open the archive file
* \param url The URL of the archive
* \param path Path where the archive really is (returned value)
* \param errNum KIO error number (undefined if the function returns true)
* \return true if file was found, false if there was an error
*/
bool checkNewFile( const KURL & url, QString & path, KIO::Error& errorNum );
KArchive * m_archiveFile;
QString m_archiveName;
time_t m_mtime;
};
#endif
|