• 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
  • document
  • info
documentinfotool.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 2008,2010,2012 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 DOCUMENTINFOTOOL_H
24 #define DOCUMENTINFOTOOL_H
25 
26 // lib
27 #include "oktetakastencontrollers_export.h"
28 // Kasten core
29 #include <abstracttool.h>
30 // KDE
31 #include <KMimeType>
32 
33 namespace Okteta {
34 class AbstractByteArrayModel;
35 }
36 class KUrl;
37 class QString;
38 class QTimer;
39 
40 
41 namespace Kasten2
42 {
43 
44 class ByteArrayDocument;
45 class AbstractModelSynchronizer;
46 class DocumentSyncManager;
47 
48 
49 class OKTETAKASTENCONTROLLERS_EXPORT DocumentInfoTool : public AbstractTool
50 {
51  Q_OBJECT
52 
53  public:
54  explicit DocumentInfoTool( DocumentSyncManager* syncManager );
55  virtual ~DocumentInfoTool();
56 
57  public: // AbstractTool API
58 // virtual AbstractModel* targetModel() const;
59  virtual QString title() const;
60 
61  virtual void setTargetModel( AbstractModel* model );
62 
63  public:
64  QString documentTitle() const;
65  KMimeType::Ptr mimeType() const;
66  QString location() const;
67  int documentSize() const;
68 
69  Q_SIGNALS:
70  void documentTitleChanged( const QString& documentTitle );
71  void documentMimeTypeChanged( KMimeType::Ptr mimeType );
72  void locationChanged( const QString& location );
73  void documentSizeChanged( int newSize );
74 
75  private Q_SLOTS:
76  void updateMimeType();
77 
78  void onContentsChanged();
79  void onSynchronizerChanged( Kasten2::AbstractModelSynchronizer* synchronizer );
80  void onUrlChanged( const KUrl& url );
81 
82  private:
83  ByteArrayDocument* mDocument;
84  Okteta::AbstractByteArrayModel *mByteArrayModel;
85 
86  AbstractModelSynchronizer* mSynchronizer;
87 
88  DocumentSyncManager* mDocumentSyncManager;
89 
90  QTimer* mMimeTypeUpdateTimer;
91  KMimeType::Ptr mMimeType;
92 };
93 
94 
95 inline KMimeType::Ptr DocumentInfoTool::mimeType() const { return mMimeType; }
96 
97 }
98 
99 #endif
Okteta::AbstractByteArrayModel
could it be useful to hide the data access behind an iterator? * class KDataBufferIterator { public: ...
Definition: abstractbytearraymodel.h:79
Kasten2::DocumentInfoTool::mimeType
KMimeType::Ptr mimeType() const
Definition: documentinfotool.h:95
Kasten2::DocumentInfoTool
Definition: documentinfotool.h:49
oktetakastencontrollers_export.h
Kasten2::AbstractModelSynchronizer
possible actions:
Definition: abstractmodelsynchronizer.h:61
Kasten2::ByteArrayDocument
Definition: bytearraydocument.h:54
Kasten2::AbstractTool
Definition: abstracttool.h:40
Kasten2::AbstractModel
Definition: abstractmodel.h:40
OKTETAKASTENCONTROLLERS_EXPORT
#define OKTETAKASTENCONTROLLERS_EXPORT
Definition: oktetakastencontrollers_export.h:36
Kasten2::DocumentSyncManager
Definition: documentsyncmanager.h:45
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:08 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