1bb02e0acSNicolas Bonnefon /* 2*45ef183cSNicolas Bonnefon * Copyright (C) 2009, 2010, 2011, 2013, 2014, 2015 Nicolas Bonnefon 3bb02e0acSNicolas Bonnefon * and other contributors 4bb02e0acSNicolas Bonnefon * 5bb02e0acSNicolas Bonnefon * This file is part of glogg. 6bb02e0acSNicolas Bonnefon * 7bb02e0acSNicolas Bonnefon * glogg is free software: you can redistribute it and/or modify 8bb02e0acSNicolas Bonnefon * it under the terms of the GNU General Public License as published by 9bb02e0acSNicolas Bonnefon * the Free Software Foundation, either version 3 of the License, or 10bb02e0acSNicolas Bonnefon * (at your option) any later version. 11bb02e0acSNicolas Bonnefon * 12bb02e0acSNicolas Bonnefon * glogg is distributed in the hope that it will be useful, 13bb02e0acSNicolas Bonnefon * but WITHOUT ANY WARRANTY; without even the implied warranty of 14bb02e0acSNicolas Bonnefon * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15bb02e0acSNicolas Bonnefon * GNU General Public License for more details. 16bb02e0acSNicolas Bonnefon * 17bb02e0acSNicolas Bonnefon * You should have received a copy of the GNU General Public License 18bb02e0acSNicolas Bonnefon * along with glogg. If not, see <http://www.gnu.org/licenses/>. 19bb02e0acSNicolas Bonnefon */ 20bb02e0acSNicolas Bonnefon 21bb02e0acSNicolas Bonnefon #ifndef CRAWLERWIDGET_H 22bb02e0acSNicolas Bonnefon #define CRAWLERWIDGET_H 23bb02e0acSNicolas Bonnefon 24bb02e0acSNicolas Bonnefon #include <QSplitter> 25bb02e0acSNicolas Bonnefon #include <QComboBox> 26bb02e0acSNicolas Bonnefon #include <QPushButton> 27bb02e0acSNicolas Bonnefon #include <QCheckBox> 28bb02e0acSNicolas Bonnefon #include <QToolButton> 29bb02e0acSNicolas Bonnefon #include <QVBoxLayout> 30bb02e0acSNicolas Bonnefon #include <QHBoxLayout> 31bb02e0acSNicolas Bonnefon #include <QLabel> 32bb02e0acSNicolas Bonnefon 33bb02e0acSNicolas Bonnefon #include "logmainview.h" 34bb02e0acSNicolas Bonnefon #include "filteredview.h" 35bb02e0acSNicolas Bonnefon #include "data/logdata.h" 36bb02e0acSNicolas Bonnefon #include "data/logfiltereddata.h" 37f0708ca8SNicolas Bonnefon #include "viewinterface.h" 389cacd6a9SNicolas Bonnefon #include "signalmux.h" 390f9fd9edSNicolas Bonnefon #include "overview.h" 40812146a8SNicolas Bonnefon #include "loadingstatus.h" 41bb02e0acSNicolas Bonnefon 42bb02e0acSNicolas Bonnefon class InfoLine; 43bb02e0acSNicolas Bonnefon class QuickFindPattern; 44bb02e0acSNicolas Bonnefon class SavedSearches; 45bb02e0acSNicolas Bonnefon class QStandardItemModel; 46bb02e0acSNicolas Bonnefon class OverviewWidget; 47bb02e0acSNicolas Bonnefon 48bb02e0acSNicolas Bonnefon // Implements the central widget of the application. 49bb02e0acSNicolas Bonnefon // It includes both windows, the search line, the info 50bb02e0acSNicolas Bonnefon // lines and various buttons. 51f0708ca8SNicolas Bonnefon class CrawlerWidget : public QSplitter, 529cacd6a9SNicolas Bonnefon public QuickFindMuxSelectorInterface, public ViewInterface, 539cacd6a9SNicolas Bonnefon public MuxableDocumentInterface 54bb02e0acSNicolas Bonnefon { 55bb02e0acSNicolas Bonnefon Q_OBJECT 56bb02e0acSNicolas Bonnefon 57bb02e0acSNicolas Bonnefon public: 581b5e406eSNicolas Bonnefon CrawlerWidget( QWidget *parent=0 ); 59bb02e0acSNicolas Bonnefon 60bb02e0acSNicolas Bonnefon // Get the line number of the first line displayed. 61bb02e0acSNicolas Bonnefon int getTopLine() const; 62bb02e0acSNicolas Bonnefon // Get the selected text as a string (from the main window) 63bb02e0acSNicolas Bonnefon QString getSelectedText() const; 64bb02e0acSNicolas Bonnefon 65bb02e0acSNicolas Bonnefon // Display the QFB at the bottom, remembering where the focus was 66bb02e0acSNicolas Bonnefon void displayQuickFindBar( QuickFindMux::QFDirection direction ); 67bb02e0acSNicolas Bonnefon 68bb02e0acSNicolas Bonnefon // Instructs the widget to select all the text in the window the user 69bb02e0acSNicolas Bonnefon // is interacting with 70bb02e0acSNicolas Bonnefon void selectAll(); 71bb02e0acSNicolas Bonnefon 7232e44cfdSNicolas Bonnefon public slots: 737847299cSNicolas Bonnefon // Stop the asynchoronous loading of the file if one is in progress 747847299cSNicolas Bonnefon // The file is identified by the view attached to it. 757847299cSNicolas Bonnefon void stopLoading(); 7632e44cfdSNicolas Bonnefon // Reload the displayed file 7732e44cfdSNicolas Bonnefon void reload(); 7832e44cfdSNicolas Bonnefon 79bb02e0acSNicolas Bonnefon protected: 80f0708ca8SNicolas Bonnefon // Implementation of the ViewInterface functions 81039481acSNicolas Bonnefon virtual void doSetData( 82039481acSNicolas Bonnefon std::shared_ptr<LogData> log_data, 83039481acSNicolas Bonnefon std::shared_ptr<LogFilteredData> filtered_data ); 84b423cd88SNicolas Bonnefon virtual void doSetQuickFindPattern( 85b423cd88SNicolas Bonnefon std::shared_ptr<QuickFindPattern> qfp ); 861b5e406eSNicolas Bonnefon virtual void doSetSavedSearches( 871b5e406eSNicolas Bonnefon std::shared_ptr<SavedSearches> saved_searches ); 88a44d09bcSNicolas Bonnefon virtual void doSetViewContext( const char* view_context ); 89a44d09bcSNicolas Bonnefon virtual std::shared_ptr<const ViewContextInterface> 90a44d09bcSNicolas Bonnefon doGetViewContext( void ) const; 91f0708ca8SNicolas Bonnefon 92b423cd88SNicolas Bonnefon // Implementation of the mux selector interface 93b423cd88SNicolas Bonnefon // (for dispatching QuickFind to the right widget) 94b423cd88SNicolas Bonnefon virtual SearchableWidgetInterface* doGetActiveSearchable() const; 95b423cd88SNicolas Bonnefon virtual std::vector<QObject*> doGetAllSearchables() const; 96b423cd88SNicolas Bonnefon 979cacd6a9SNicolas Bonnefon // Implementation of the MuxableDocumentInterface 989cacd6a9SNicolas Bonnefon virtual void doSendAllStateSignals(); 999cacd6a9SNicolas Bonnefon 100bb02e0acSNicolas Bonnefon signals: 101bb02e0acSNicolas Bonnefon // Sent to signal the client load has progressed, 102bb02e0acSNicolas Bonnefon // passing the completion percentage. 103bb02e0acSNicolas Bonnefon void loadingProgressed( int progress ); 104bb02e0acSNicolas Bonnefon // Sent to the client when the loading has finished 105bb02e0acSNicolas Bonnefon // weither succesfull or not. 106812146a8SNicolas Bonnefon void loadingFinished( LoadingStatus status ); 107bb02e0acSNicolas Bonnefon // Sent when follow mode is enabled/disabled 108bb02e0acSNicolas Bonnefon void followSet( bool checked ); 109bb02e0acSNicolas Bonnefon // Sent up to the MainWindow to disable the follow mode 110bb02e0acSNicolas Bonnefon void followDisabled(); 111bb02e0acSNicolas Bonnefon // Sent up when the current line number is updated 112bb02e0acSNicolas Bonnefon void updateLineNumber( int line ); 113bb02e0acSNicolas Bonnefon 114f688be2eSNicolas Bonnefon // "auto-refresh" check has been changed 115f688be2eSNicolas Bonnefon void searchRefreshChanged( int state ); 116f688be2eSNicolas Bonnefon // "ignore case" check has been changed 117f688be2eSNicolas Bonnefon void ignoreCaseChanged( int state ); 118f688be2eSNicolas Bonnefon 119*45ef183cSNicolas Bonnefon // Sent when the data status (whether new not seen data are 120*45ef183cSNicolas Bonnefon // available) has changed 121*45ef183cSNicolas Bonnefon void dataStatusChanged( DataStatus status ); 122*45ef183cSNicolas Bonnefon 123bb02e0acSNicolas Bonnefon private slots: 124bb02e0acSNicolas Bonnefon // Instructs the widget to start a search using the current search line. 125bb02e0acSNicolas Bonnefon void startNewSearch(); 126bb02e0acSNicolas Bonnefon // Stop the currently ongoing search (if one exists) 127bb02e0acSNicolas Bonnefon void stopSearch(); 128bb02e0acSNicolas Bonnefon // Instructs the widget to reconfigure itself because Config() has changed. 129bb02e0acSNicolas Bonnefon void applyConfiguration(); 1308570d8d2SNicolas Bonnefon // QuickFind is being entered, save the focus for incremental qf. 1318570d8d2SNicolas Bonnefon void enteringQuickFind(); 1328570d8d2SNicolas Bonnefon // QuickFind is being closed. 1338570d8d2SNicolas Bonnefon void exitingQuickFind(); 134bb02e0acSNicolas Bonnefon // Called when new data must be displayed in the filtered window. 135bb02e0acSNicolas Bonnefon void updateFilteredView( int nbMatches, int progress ); 136bb02e0acSNicolas Bonnefon // Called when a new line has been selected in the filtered view, 137bb02e0acSNicolas Bonnefon // to instruct the main view to jump to the matching line. 138bb02e0acSNicolas Bonnefon void jumpToMatchingLine( int filteredLineNb ); 1399cacd6a9SNicolas Bonnefon // Called when the main view is on a new line number 1409cacd6a9SNicolas Bonnefon void updateLineNumberHandler( int line ); 141bb02e0acSNicolas Bonnefon // Mark a line that has been clicked on the main (top) view. 142bb02e0acSNicolas Bonnefon void markLineFromMain( qint64 line ); 143bb02e0acSNicolas Bonnefon // Mark a line that has been clicked on the filtered (bottom) view. 144bb02e0acSNicolas Bonnefon void markLineFromFiltered( qint64 line ); 145bb02e0acSNicolas Bonnefon 146812146a8SNicolas Bonnefon void loadingFinishedHandler( LoadingStatus status ); 147bb02e0acSNicolas Bonnefon // Manages the info lines to inform the user the file has changed. 148bb02e0acSNicolas Bonnefon void fileChangedHandler( LogData::MonitoredFileStatus ); 149bb02e0acSNicolas Bonnefon 150bb02e0acSNicolas Bonnefon void searchForward(); 151bb02e0acSNicolas Bonnefon void searchBackward(); 152bb02e0acSNicolas Bonnefon 153bb02e0acSNicolas Bonnefon // Called when the checkbox for search auto-refresh is changed 154bb02e0acSNicolas Bonnefon void searchRefreshChangedHandler( int state ); 155bb02e0acSNicolas Bonnefon 156bb02e0acSNicolas Bonnefon // Called when the text on the search line is modified 157bb02e0acSNicolas Bonnefon void searchTextChangeHandler(); 158bb02e0acSNicolas Bonnefon 159bb02e0acSNicolas Bonnefon // Called when the user change the visibility combobox 160bb02e0acSNicolas Bonnefon void changeFilteredViewVisibility( int index ); 161bb02e0acSNicolas Bonnefon 162bb02e0acSNicolas Bonnefon // Called when the user add the string to the search 163bb02e0acSNicolas Bonnefon void addToSearch( const QString& string ); 164bb02e0acSNicolas Bonnefon 165bb02e0acSNicolas Bonnefon // Called when a match is hovered on in the filtered view 166bb02e0acSNicolas Bonnefon void mouseHoveredOverMatch( qint64 line ); 167bb02e0acSNicolas Bonnefon 168*45ef183cSNicolas Bonnefon // Called when there was activity in the views 169*45ef183cSNicolas Bonnefon void activityDetected(); 170*45ef183cSNicolas Bonnefon 171bb02e0acSNicolas Bonnefon private: 172bb02e0acSNicolas Bonnefon // State machine holding the state of the search, used to allow/disallow 173bb02e0acSNicolas Bonnefon // auto-refresh and inform the user via the info line. 174bb02e0acSNicolas Bonnefon class SearchState { 175bb02e0acSNicolas Bonnefon public: 176bb02e0acSNicolas Bonnefon enum State { 177bb02e0acSNicolas Bonnefon NoSearch, 178bb02e0acSNicolas Bonnefon Static, 179bb02e0acSNicolas Bonnefon Autorefreshing, 180bb02e0acSNicolas Bonnefon FileTruncated, 18159d4e393SNicolas Bonnefon TruncatedAutorefreshing, 182bb02e0acSNicolas Bonnefon }; 183bb02e0acSNicolas Bonnefon 184bb02e0acSNicolas Bonnefon SearchState() { state_ = NoSearch; autoRefreshRequested_ = false; } 185bb02e0acSNicolas Bonnefon 186bb02e0acSNicolas Bonnefon // Reset the state (no search active) 187bb02e0acSNicolas Bonnefon void resetState(); 188bb02e0acSNicolas Bonnefon // The user changed auto-refresh request 189bb02e0acSNicolas Bonnefon void setAutorefresh( bool refresh ); 190bb02e0acSNicolas Bonnefon // The file has been truncated (stops auto-refresh) 191bb02e0acSNicolas Bonnefon void truncateFile(); 192bb02e0acSNicolas Bonnefon // The expression has been changed (stops auto-refresh) 193bb02e0acSNicolas Bonnefon void changeExpression(); 194bb02e0acSNicolas Bonnefon // The search has been stopped (stops auto-refresh) 195bb02e0acSNicolas Bonnefon void stopSearch(); 196bb02e0acSNicolas Bonnefon // The search has been started (enable auto-refresh) 197bb02e0acSNicolas Bonnefon void startSearch(); 198bb02e0acSNicolas Bonnefon 199bb02e0acSNicolas Bonnefon // Get the state in order to display the proper message 200bb02e0acSNicolas Bonnefon State getState() const { return state_; } 201bb02e0acSNicolas Bonnefon // Is auto-refresh allowed 202bb02e0acSNicolas Bonnefon bool isAutorefreshAllowed() const 20359d4e393SNicolas Bonnefon { return ( state_ == Autorefreshing || state_ == TruncatedAutorefreshing ); } 20459d4e393SNicolas Bonnefon bool isFileTruncated() const 20559d4e393SNicolas Bonnefon { return ( state_ == FileTruncated || state_ == TruncatedAutorefreshing ); } 206bb02e0acSNicolas Bonnefon 207bb02e0acSNicolas Bonnefon private: 208bb02e0acSNicolas Bonnefon State state_; 209bb02e0acSNicolas Bonnefon bool autoRefreshRequested_; 210bb02e0acSNicolas Bonnefon }; 211bb02e0acSNicolas Bonnefon 212bb02e0acSNicolas Bonnefon // Private functions 213039481acSNicolas Bonnefon void setup(); 214bb02e0acSNicolas Bonnefon void replaceCurrentSearch( const QString& searchText ); 215bb02e0acSNicolas Bonnefon void updateSearchCombo(); 216bb02e0acSNicolas Bonnefon AbstractLogView* activeView() const; 217bb02e0acSNicolas Bonnefon void printSearchInfoMessage( int nbMatches = 0 ); 218*45ef183cSNicolas Bonnefon void changeDataStatus( DataStatus status ); 219bb02e0acSNicolas Bonnefon 220bb02e0acSNicolas Bonnefon // Palette for error notification (yellow background) 221bb02e0acSNicolas Bonnefon static const QPalette errorPalette; 222bb02e0acSNicolas Bonnefon 223bb02e0acSNicolas Bonnefon LogMainView* logMainView; 224bb02e0acSNicolas Bonnefon QWidget* bottomWindow; 225bb02e0acSNicolas Bonnefon QLabel* searchLabel; 226bb02e0acSNicolas Bonnefon QComboBox* searchLineEdit; 227bb02e0acSNicolas Bonnefon QToolButton* searchButton; 228bb02e0acSNicolas Bonnefon QToolButton* stopButton; 229bb02e0acSNicolas Bonnefon FilteredView* filteredView; 230bb02e0acSNicolas Bonnefon QComboBox* visibilityBox; 231bb02e0acSNicolas Bonnefon InfoLine* searchInfoLine; 232bb02e0acSNicolas Bonnefon QCheckBox* ignoreCaseCheck; 233bb02e0acSNicolas Bonnefon QCheckBox* searchRefreshCheck; 234bb02e0acSNicolas Bonnefon OverviewWidget* overviewWidget_; 235bb02e0acSNicolas Bonnefon 236bb02e0acSNicolas Bonnefon QVBoxLayout* bottomMainLayout; 237bb02e0acSNicolas Bonnefon QHBoxLayout* searchLineLayout; 238bb02e0acSNicolas Bonnefon QHBoxLayout* searchInfoLineLayout; 239bb02e0acSNicolas Bonnefon 240bb02e0acSNicolas Bonnefon // Default palette to be remembered 241bb02e0acSNicolas Bonnefon QPalette searchInfoLineDefaultPalette; 242bb02e0acSNicolas Bonnefon 2431b5e406eSNicolas Bonnefon std::shared_ptr<SavedSearches> savedSearches_; 244bb02e0acSNicolas Bonnefon 245b423cd88SNicolas Bonnefon // Reference to the QuickFind Pattern (not owned) 246b423cd88SNicolas Bonnefon std::shared_ptr<QuickFindPattern> quickFindPattern_; 247bb02e0acSNicolas Bonnefon 248bb02e0acSNicolas Bonnefon LogData* logData_; 249bb02e0acSNicolas Bonnefon LogFilteredData* logFilteredData_; 250bb02e0acSNicolas Bonnefon 251bb02e0acSNicolas Bonnefon qint64 logFileSize_; 252bb02e0acSNicolas Bonnefon 253bb02e0acSNicolas Bonnefon QWidget* qfSavedFocus_; 254bb02e0acSNicolas Bonnefon 255bb02e0acSNicolas Bonnefon // Search state (for auto-refresh and truncation) 256bb02e0acSNicolas Bonnefon SearchState searchState_; 257bb02e0acSNicolas Bonnefon 258bb02e0acSNicolas Bonnefon // Matches overview 2590f9fd9edSNicolas Bonnefon Overview overview_; 260bb02e0acSNicolas Bonnefon 261bb02e0acSNicolas Bonnefon // Model for the visibility selector 262bb02e0acSNicolas Bonnefon QStandardItemModel* visibilityModel_; 2639cacd6a9SNicolas Bonnefon 2649cacd6a9SNicolas Bonnefon // Last main line number received 2659cacd6a9SNicolas Bonnefon qint64 currentLineNumber_; 26660864ff5SNicolas Bonnefon 26760864ff5SNicolas Bonnefon // Are we loading something? 26860864ff5SNicolas Bonnefon // Set to false when we receive a completion message from the LogData 26960864ff5SNicolas Bonnefon bool loadingInProgress_; 270*45ef183cSNicolas Bonnefon 271*45ef183cSNicolas Bonnefon // Is it not the first time we are loading something? 272*45ef183cSNicolas Bonnefon bool firstLoadDone_; 273*45ef183cSNicolas Bonnefon 274*45ef183cSNicolas Bonnefon // the current dataStatus (whether we have new, not seen, data) 275*45ef183cSNicolas Bonnefon DataStatus dataStatus_; 276bb02e0acSNicolas Bonnefon }; 277bb02e0acSNicolas Bonnefon 278bb02e0acSNicolas Bonnefon #endif 279