/usr/include/klfapp/klflibbrowser.h is in libklatexformula3-dev 3.2.7-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 | /***************************************************************************
* file klflibbrowser.h
* This file is part of the KLatexFormula Project.
* Copyright (C) 2011 by Philippe Faist
* philippe.faist at bluewin.ch
* *
* 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. *
* *
* This program 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 General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
/* $Id: klflibbrowser.h 603 2011-02-26 23:14:55Z phfaist $ */
#ifndef KLFLIBBROWSER_H
#define KLFLIBBROWSER_H
#include <QWidget>
#include <QMovie>
#include <QMenu>
#include <QPushButton>
#include <QLabel>
#include <klflib.h>
namespace Ui { class KLFLibBrowser; }
class KLFLibBrowserViewContainer;
class KLFProgressReporter;
class KLFAbstractLibView;
class KLF_EXPORT KLFLibBrowser : public QWidget
{
Q_OBJECT
public:
KLFLibBrowser(QWidget *parent = NULL);
virtual ~KLFLibBrowser();
enum ResourceRoleFlag {
NoRoleFlag = 0x00000000, //!< This resource has nothing special
NoCloseRoleFlag = 0x00000001, //!< Resource 'Close' GUI button is disabled (grayed)
HistoryRoleFlag = 0x00010000, //!< This resource is the History resource
ArchiveRoleFlag = 0x00020000, //!< This resource is the Archive resource
SpecialResourceRoleMask = 0x00ff0000, //!< Mask to extract the 'special resource' type (eg. history)
NoChangeFlag = 0x01000000, //!< Instructs to not set new flags for already-open resources
OpenNoRaise = 0x02000000, //!< Instructs not to raise the tab during this call of openResource()
NowMask = 0xff000000 //!< These flags are not stored, they act upon the openResource() call only.
};
virtual bool eventFilter(QObject *object, QEvent *event);
QList<QUrl> openUrls() const;
//! Returns the URL of the current tab page
QUrl currentUrl();
//! Returns the index of \ref currentUrl() in \ref openUrls()
int currentUrlIndex();
/** Returns the KLFLibResourceEngine that is managing the display of the
* currently open URL \c url. The url must currently be open.
*
* \note Mind that KLFLibBrowser deletes the views and their corresponding
* engines upon destruction. */
KLFLibResourceEngine * getOpenResource(const QUrl& url);
/** Returns the view that is used to display the resource with URL \c url.
*
* \note the returned view belongs to this KLFLibBrowser object. */
KLFAbstractLibView * getView(const QUrl& url);
/** Returns the view that is used to display the resource \c resource.
*
* \note the returned view belongs to this KLFLibBrowser object. */
KLFAbstractLibView * getView(KLFLibResourceEngine *resource);
QVariantMap saveGuiState();
void loadGuiState(const QVariantMap& state, bool openURLs = true);
static QString displayTitle(KLFLibResourceEngine *resource);
signals:
void requestRestore(const KLFLibEntry& entry, uint restoreFlags);
void requestRestoreStyle(const KLFStyle& style);
void resourceTabChanged(const QUrl& currentUrl);
void libEntriesSelected(const KLFLibEntryList& entries);
public slots:
/** If the \c url is not already open, opens the given URL. An appropriate factory
* needs to be installed supporting that scheme. Then an appropriate view is created
* using the view factories.
*
* If the \c url is already open, then the appropriate tab is raised.
*
* Resource flags are updated in both cases.
*
* If an empty \c viewTypeIdentifier is given, the view type identifier suggested by
* the resource itself is taken. If the latter is empty, then the default view type
* identifier (\ref KLFLibViewFactory::defaultViewTypeIdentifier) is considered.
*/
bool openResource(const QUrl& url, uint resourceRoleFlags = NoChangeFlag,
const QString& viewTypeIdentifier = QString());
/** Convenience function. Equivalent to
* \code openResource(QUrl(url), ...) \endcode
*/
bool openResource(const QString& url, uint resourceRoleFlags = NoChangeFlag,
const QString& viewTypeIdentifier = QString());
/** Overloaded member, provided for convenience.
*
* Opens a previously (independently) open \c resource and displays it in the library.
*
* \warning this library browser takes ownership of the resource and will delete it
* when done using it.
*/
bool openResource(KLFLibResourceEngine *resource, uint resourceRoleFlags = NoChangeFlag,
const QString& viewTypeIdentifier = QString());
/**
* [ADVANCED USAGE]
* Overloaded member, provided for conenience. This function should not be called
* directly normally, use it only if you want to play with the library browser's
* advanced functions. Use loadGuiState() to load saved GUI state instead.
*
* [internal:] The \c guiState is exactly in the format that can be given to
* KLFLibBrowserViewContainer::loadGuiState().
*/
bool openResourceFromGuiState(const QUrl& url, const QVariantMap& guiState);
bool closeResource(const QUrl& url);
void retranslateUi(bool alsoBaseUi = true);
protected slots:
void slotRestoreWithStyle();
void slotRestoreLatexOnly();
void slotDeleteSelected();
void slotRefreshResourceActionsEnabled();
void slotTabResourceShown(int tabIndex);
void slotShowTabContextMenu(const QPoint& pos);
void slotResourceRename();
void slotResourceRenameSubResource();
/** implements both slotResourceRename() and slotResourceRenameSubResource(). If
* \c renameSubResource is false, renames the resource. If true renames the sub-resource.
*/
void slotResourceRename(bool renameSubResource);
void slotResourceRenameFinished();
bool slotResourceClose(KLFLibBrowserViewContainer *view = NULL, bool force = false);
void slotResourceProperties();
bool slotResourceNewSubRes();
bool slotResourceDelSubRes();
bool slotResourceOpen();
bool slotResourceNew();
bool slotResourceSaveTo();
/** sender is used to find resource engine emitter. */
void slotResourceDataChanged(const QList<KLFLib::entryId>& entryIdList);
/** sender is used to find resource engine emitter. */
void slotResourcePropertyChanged(int propId);
void slotUpdateForResourceProperty(KLFLibResourceEngine *resource, int propId);
/** sender is used to find resource engine emitter. */
void slotSubResourcePropertyChanged(const QString& subResource, int propId);
/** sender is used to find resource engine emitter. */
void slotDefaultSubResourceChanged(const QString& subResource);
void slotEntriesSelected(const KLFLibEntryList& entries);
void slotAddCategorySuggestions(const QStringList& catlist);
void slotShowContextMenu(const QPoint& pos);
void slotMetaInfoChanged(const QMap<int,QVariant>& props);
/** \note important data is defined in sender's custom properties (a QAction) */
void slotCopyToResource();
/** \note important data is defined in sender's custom properties (a QAction) */
void slotMoveToResource();
/** common code to slotCopyToResource() and slotMoveToResource() */
void slotCopyMoveToResource(QObject *sender, bool move);
void slotCopyMoveToResource(KLFAbstractLibView *dest, KLFAbstractLibView *source, bool move);
void slotCut();
void slotCopy();
void slotPaste();
void slotOpenAll();
bool slotExport();
bool slotExportSelection();
void slotStartProgress(KLFProgressReporter *progressReporter, const QString& text);
protected:
KLFLibBrowserViewContainer * findOpenUrl(const QUrl& url);
KLFLibBrowserViewContainer * findOpenResource(KLFLibResourceEngine *resource);
KLFLibBrowserViewContainer * curView();
KLFAbstractLibView * curLibView();
KLFLibBrowserViewContainer * viewForTabIndex(int tab);
QList<KLFLibBrowserViewContainer*> findByRoleFlags(uint flags, uint mask);
inline KLFLibBrowserViewContainer *findSpecialResource(uint specialResourceRoleFlag)
{ QList<KLFLibBrowserViewContainer*> l = findByRoleFlags(specialResourceRoleFlag, SpecialResourceRoleMask);
if (l.isEmpty()) { return NULL; } return l[0]; }
bool event(QEvent *event);
void showEvent(QShowEvent *event);
void timerEvent(QTimerEvent *event);
private:
Ui::KLFLibBrowser *u;
QList<KLFLibBrowserViewContainer*> pLibViews;
QMenu *pResourceMenu;
QMenu *pImportExportMenu;
QPushButton *pTabCornerButton;
private slots:
void updateResourceRoleFlags(KLFLibBrowserViewContainer *view, uint flags);
};
#endif
|