• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdesdk API Reference
  • KDE Home
  • Contact Us
 

okteta

  • sources
  • kde-4.12
  • kdesdk
  • okteta
  • kasten
  • controllers
  • view
  • checksum
checksumtool.h
Go to the documentation of this file.
1 /*
2  This file is part of the Okteta Kasten module, made within the KDE community.
3 
4  Copyright 2009 Friedrich W. H. Kossebau <kossebau@kde.org>
5 
6  This library is free software; you can redistribute it and/or
7  modify it under the terms of the GNU Lesser General Public
8  License as published by the Free Software Foundation; either
9  version 2.1 of the License, or (at your option) version 3, or any
10  later version accepted by the membership of KDE e.V. (or its
11  successor approved by the membership of KDE e.V.), which shall
12  act as a proxy defined in Section 6 of version 3 of the license.
13 
14  This library is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  Lesser General Public License for more details.
18 
19  You should have received a copy of the GNU Lesser General Public
20  License along with this library. If not, see <http://www.gnu.org/licenses/>.
21 */
22 
23 #ifndef CHECKSUMTOOL_H
24 #define CHECKSUMTOOL_H
25 
26 // lib
27 #include "oktetakastencontrollers_export.h"
28 #include <config-qca2.h>
29 // Kasten core
30 #include <abstracttool.h>
31 // Okteta core
32 #include <addressrange.h>
33 
34 class AbstractByteArrayChecksumParameterSet;
35 class AbstractByteArrayChecksumAlgorithm;
36 
37 namespace Okteta {
38 class AbstractByteArrayModel;
39 }
40 namespace QCA {
41 class Initializer;
42 }
43 
44 
45 namespace Kasten2
46 {
47 
48 class ByteArrayView;
49 
50 
51 class OKTETAKASTENCONTROLLERS_EXPORT ChecksumTool : public AbstractTool
52 {
53  Q_OBJECT
54 
55  public:
56  ChecksumTool();
57  virtual ~ChecksumTool();
58 
59  public: // AbstractTool API
60 // virtual AbstractModel* targetModel() const;
61  virtual QString title() const;
62 
63  virtual void setTargetModel( AbstractModel* model );
64 
65  public: // status
66  QString checkSum() const;
67  int algorithmId() const;
68  bool isApplyable() const; // candidate for AbstractTool API
69  bool isUptodate() const;
70 
71  QList<AbstractByteArrayChecksumAlgorithm*> algorithmList() const;
72 
73  public:
74  AbstractByteArrayChecksumParameterSet* parameterSet();
75 
76  public Q_SLOTS: // actions
77  void calculateChecksum();
78 
79  void setAlgorithm( int algorithmId );
80  // TODO: hack, see checksum source
81  void resetSourceTool();
82 
83  Q_SIGNALS:
84  void checksumChanged( const QString& checksum );
85  void uptodateChanged( bool isUptodate );
86  void isApplyableChanged( bool isApplyable ); // candidate for AbstractTool API
87 
88  private:
89  void checkUptoDate();
90 
91  private Q_SLOTS:
92  void onSelectionChanged();
93  void onSourceChanged();
94  void onSourceDestroyed();
95 
96  private: // created data
97  QString mCheckSum;
98  bool mChecksumUptodate :1;
99  bool mSourceByteArrayModelUptodate :1;
100 
101  private: // settings
102  QList<AbstractByteArrayChecksumAlgorithm*> mAlgorithmList;
103 #ifdef HAVE_QCA2
104  QCA::Initializer* mQcaInitializer;
105 #endif
106  int mAlgorithmId;
107 
108  private: // sources
109  ByteArrayView* mByteArrayView;
110  // current
111  Okteta::AbstractByteArrayModel* mByteArrayModel;
112 
113  int mSourceAlgorithmId;
114  Okteta::AddressRange mSourceSelection;
115  Okteta::AbstractByteArrayModel* mSourceByteArrayModel;
116 };
117 
118 
119 inline int ChecksumTool::algorithmId() const { return mAlgorithmId; }
120 inline QString ChecksumTool::checkSum() const { return mCheckSum; }
121 inline bool ChecksumTool::isUptodate() const { return mChecksumUptodate; }
122 
123 }
124 
125 #endif
Okteta::AbstractByteArrayModel
could it be useful to hide the data access behind an iterator? * class KDataBufferIterator { public: ...
Definition: abstractbytearraymodel.h:79
AbstractByteArrayChecksumAlgorithm
Definition: abstractbytearraychecksumalgorithm.h:38
KDE::NumberRange< Address, Size >
Kasten2::ChecksumTool::isUptodate
bool isUptodate() const
Definition: checksumtool.h:121
addressrange.h
Kasten2::ChecksumTool
Definition: checksumtool.h:51
AbstractByteArrayChecksumParameterSet
Definition: abstractbytearraychecksumparameterset.h:27
oktetakastencontrollers_export.h
Kasten2::ChecksumTool::algorithmId
int algorithmId() const
Definition: checksumtool.h:119
Kasten2::AbstractTool
Definition: abstracttool.h:40
Kasten2::AbstractModel
Definition: abstractmodel.h:40
OKTETAKASTENCONTROLLERS_EXPORT
#define OKTETAKASTENCONTROLLERS_EXPORT
Definition: oktetakastencontrollers_export.h:36
Kasten2::ByteArrayView
Definition: bytearrayview.h:51
QList< AbstractByteArrayChecksumAlgorithm * >
Kasten2::ChecksumTool::checkSum
QString checkSum() const
Definition: checksumtool.h:120
abstracttool.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:04:07 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

okteta

Skip menu "okteta"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdesdk API Reference

Skip menu "kdesdk API Reference"
  • kapptemplate
  • kcachegrind
  • kompare
  • lokalize
  • okteta
  • umbrello
  •   umbrello

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal