Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Toutes les fonctions  ·  Vues d'ensemble  · 

filemanager.h Example File
network/torrent/filemanager.h

 /****************************************************************************
 **
 ** Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies).
 ** Contact: Qt Software Information (qt-info@nokia.com)
 **
 ** This file is part of the example classes of the Qt Toolkit.
 **
 ** Commercial Usage
 ** Licensees holding valid Qt Commercial licenses may use this file in
 ** accordance with the Qt Commercial License Agreement provided with the
 ** Software or, alternatively, in accordance with the terms contained in
 ** a written agreement between you and Nokia.
 **
 **
 ** GNU General Public License Usage
 ** Alternatively, this file may be used under the terms of the GNU
 ** General Public License versions 2.0 or 3.0 as published by the Free
 ** Software Foundation and appearing in the file LICENSE.GPL included in
 ** the packaging of this file.  Please review the following information
 ** to ensure GNU General Public Licensing requirements will be met:
 ** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
 ** http://www.gnu.org/copyleft/gpl.html.  In addition, as a special
 ** exception, Nokia gives you certain additional rights. These rights
 ** are described in the Nokia Qt GPL Exception version 1.3, included in
 ** the file GPL_EXCEPTION.txt in this package.
 **
 ** Qt for Windows(R) Licensees
 ** As a special exception, Nokia, as the sole copyright holder for Qt
 ** Designer, grants users of the Qt/Eclipse Integration plug-in the
 ** right for the Qt/Eclipse Integration to link to functionality
 ** provided by Qt Designer and its related libraries.
 **
 ** If you are unsure which license is appropriate for your use, please
 ** contact the sales department at qt-sales@nokia.com.
 **
 ****************************************************************************/

 #ifndef FILEMANAGER_H
 #define FILEMANAGER_H

 #include <QBitArray>
 #include <QList>
 #include <QMutex>
 #include <QThread>
 #include <QWaitCondition>

 #include "metainfo.h"

 class QByteArray;
 class QFile;
 class QTimerEvent;

 class FileManager : public QThread
 {
     Q_OBJECT

 public:
     FileManager(QObject *parent = 0);
     virtual ~FileManager();

     inline void setMetaInfo(const MetaInfo &info) { metaInfo = info; }
     inline void setDestinationFolder(const QString &directory) { destinationPath = directory; }

     int read(int pieceIndex, int offset, int length);
     void write(int pieceIndex, int offset, const QByteArray &data);
     void verifyPiece(int pieceIndex);
     inline qint64 totalSize() const { return totalLength; }

     inline int pieceCount() const { return numPieces; }
     int pieceLengthAt(int pieceIndex) const;

     QBitArray completedPieces() const;
     void setCompletedPieces(const QBitArray &pieces);

     QString errorString() const;

 public slots:
     void startDataVerification();

 signals:
     void dataRead(int id, int pieceIndex, int offset, const QByteArray &data);
     void error();
     void verificationProgress(int percent);
     void verificationDone();
     void pieceVerified(int pieceIndex, bool verified);

 protected:
     void run();

 private slots:
     bool verifySinglePiece(int pieceIndex);
     void wakeUp();

 private:
     bool generateFiles();
     QByteArray readBlock(int pieceIndex, int offset, int length);
     bool writeBlock(int pieceIndex, int offset, const QByteArray &data);
     void verifyFileContents();

     struct WriteRequest {
         int pieceIndex;
         int offset;
         QByteArray data;
     };
     struct ReadRequest {
         int pieceIndex;
         int offset;
         int length;
         int id;
     };

     QString errString;
     QString destinationPath;
     MetaInfo metaInfo;
     QList<QFile *> files;
     QList<QByteArray> sha1s;
     QBitArray verifiedPieces;

     bool newFile;
     int pieceLength;
     qint64 totalLength;
     int numPieces;
     int readId;
     bool startVerification;
     bool quit;
     bool wokeUp;

     QList<WriteRequest> writeRequests;
     QList<ReadRequest> readRequests;
     QList<int> pendingVerificationRequests;
     QList<int> newPendingVerificationRequests;
     QList<qint64> fileSizes;

     mutable QMutex mutex;
     mutable QWaitCondition cond;
 };

 #endif

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt qtextended4.4
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web