make shift-arrow in preview work with qt4 and avoid reentrancy while loading a file
This commit is contained in:
parent
5d1931610f
commit
686b891f21
@ -1,5 +1,5 @@
|
|||||||
#ifndef lint
|
#ifndef lint
|
||||||
static char rcsid[] = "@(#$Id: preview_w.cpp,v 1.16 2007-02-08 17:05:12 dockes Exp $ (C) 2005 J.F.Dockes";
|
static char rcsid[] = "@(#$Id: preview_w.cpp,v 1.17 2007-02-19 18:15:14 dockes Exp $ (C) 2005 J.F.Dockes";
|
||||||
#endif
|
#endif
|
||||||
/*
|
/*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -89,6 +89,7 @@ void Preview::init()
|
|||||||
connect(bt, SIGNAL(clicked()), this, SLOT(closeCurrentTab()));
|
connect(bt, SIGNAL(clicked()), this, SLOT(closeCurrentTab()));
|
||||||
|
|
||||||
searchTextLine->installEventFilter(this);
|
searchTextLine->installEventFilter(this);
|
||||||
|
pvEdit->installEventFilter(this);
|
||||||
dynSearchActive = false;
|
dynSearchActive = false;
|
||||||
canBeep = true;
|
canBeep = true;
|
||||||
tabData.push_back(TabData(pvTab->currentPage()));
|
tabData.push_back(TabData(pvTab->currentPage()));
|
||||||
@ -96,6 +97,7 @@ void Preview::init()
|
|||||||
if (prefs.pvwidth > 100) {
|
if (prefs.pvwidth > 100) {
|
||||||
resize(prefs.pvwidth, prefs.pvheight);
|
resize(prefs.pvwidth, prefs.pvheight);
|
||||||
}
|
}
|
||||||
|
m_loading = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preview::destroy()
|
void Preview::destroy()
|
||||||
@ -116,7 +118,7 @@ bool Preview::eventFilter(QObject *target, QEvent *event)
|
|||||||
if (event->type() != QEvent::KeyPress)
|
if (event->type() != QEvent::KeyPress)
|
||||||
return QWidget::eventFilter(target, event);
|
return QWidget::eventFilter(target, event);
|
||||||
|
|
||||||
LOGDEB1(("Preview::eventFilter: keyEvent\n"));
|
LOGDEB(("Preview::eventFilter: keyEvent\n"));
|
||||||
QKeyEvent *keyEvent = (QKeyEvent *)event;
|
QKeyEvent *keyEvent = (QKeyEvent *)event;
|
||||||
if (keyEvent->key() == Qt::Key_Q &&
|
if (keyEvent->key() == Qt::Key_Q &&
|
||||||
(keyEvent->state() & Qt::ControlButton)) {
|
(keyEvent->state() & Qt::ControlButton)) {
|
||||||
@ -311,6 +313,8 @@ void Preview::textDoubleClicked(int, int)
|
|||||||
|
|
||||||
void Preview::closeCurrentTab()
|
void Preview::closeCurrentTab()
|
||||||
{
|
{
|
||||||
|
if (m_loading)
|
||||||
|
return;
|
||||||
if (pvTab->count() > 1) {
|
if (pvTab->count() > 1) {
|
||||||
QWidget *tw = pvTab->currentPage();
|
QWidget *tw = pvTab->currentPage();
|
||||||
if (!tw)
|
if (!tw)
|
||||||
@ -534,10 +538,23 @@ class WaiterThread : public QThread {
|
|||||||
#ifndef MIN
|
#ifndef MIN
|
||||||
#define MIN(A,B) ((A)<(B)?(A):(B))
|
#define MIN(A,B) ((A)<(B)?(A):(B))
|
||||||
#endif
|
#endif
|
||||||
|
class LoadGuard {
|
||||||
|
bool *m_bp;
|
||||||
|
public:
|
||||||
|
LoadGuard(bool *bp) {m_bp = bp ; *m_bp = true;}
|
||||||
|
~LoadGuard() {*m_bp = false;}
|
||||||
|
};
|
||||||
|
|
||||||
bool Preview::loadFileInCurrentTab(string fn, size_t sz, const Rcl::Doc &idoc,
|
bool Preview::loadFileInCurrentTab(string fn, size_t sz, const Rcl::Doc &idoc,
|
||||||
int docnum)
|
int docnum)
|
||||||
{
|
{
|
||||||
|
if (m_loading) {
|
||||||
|
LOGERR(("ALready loading\n"));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
LoadGuard guard(&m_loading);
|
||||||
|
|
||||||
Rcl::Doc doc = idoc;
|
Rcl::Doc doc = idoc;
|
||||||
bool cancel = false;
|
bool cancel = false;
|
||||||
|
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#ifndef _PREVIEW_W_H_INCLUDED_
|
#ifndef _PREVIEW_W_H_INCLUDED_
|
||||||
#define _PREVIEW_W_H_INCLUDED_
|
#define _PREVIEW_W_H_INCLUDED_
|
||||||
/* @(#$Id: preview_w.h,v 1.8 2007-01-19 15:22:50 dockes Exp $ (C) 2006 J.F.Dockes */
|
/* @(#$Id: preview_w.h,v 1.9 2007-02-19 18:15:14 dockes Exp $ (C) 2006 J.F.Dockes */
|
||||||
/*
|
/*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -109,6 +109,7 @@ private:
|
|||||||
int matchPara;
|
int matchPara;
|
||||||
bool dynSearchActive;
|
bool dynSearchActive;
|
||||||
bool canBeep;
|
bool canBeep;
|
||||||
|
bool m_loading;
|
||||||
list<TabData> tabData;
|
list<TabData> tabData;
|
||||||
QWidget *currentW;
|
QWidget *currentW;
|
||||||
HiliteData m_hData;
|
HiliteData m_hData;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user