cscopefrontend.h
来自「This a source insight software in Linux.」· C头文件 代码 · 共 145 行
H
145 行
/*************************************************************************** * * Copyright (C) 2005 Elad Lahav (elad_lahav@users.sourceforge.net) * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ***************************************************************************/#ifndef CSCOPEFRONTEND_H#define CSCOPEFRONTEND_H#include <qstringlist.h>#include <qprogressbar.h>#include <qlabel.h>#include "frontend.h"#define CSCOPE_RECORD_SIZE 4/** * Controls a Cscope process for the current project. * This class creates a Cscope process, using the project's files for * configuration. Once the process is running, KScope uses the query() method * to initiate Cscope queries on the project's files. The queries' output is * parsed into a set of records, each consisting of the following fields: * - File name * - Function name * - Line number * - The line's text * These records are used to display the output in different windows, such as * QueryWidget and CallTreeDlg. * @author Elad Lahav */class CscopeFrontend : public Frontend{ Q_OBJECTpublic: CscopeFrontend(bool bAutoDelete = false); ~CscopeFrontend(); /** * The available Cscope query types. */ enum QueryType { Reference = 0, Definition = 1, Called = 2, Calling = 3, Text = 4, Pattern = 6, FileName = 7, Including = 8, None = 9 }; void query(uint, const QString&, uint nMaxRecords = 0); void rebuild(); static void init(const QString&, const QStringList&); static bool verify(const QString&); public slots: void slotCancel();protected: virtual ParseResult parseStdout(QString&, ParserDelim); virtual void parseStderr(const QString&); virtual void finalize();private: /** * The possible states of the parser state machine. */ enum ParserState { Unknown = 0, BuildStart, BuildSymbol, Building, SearchSymbol, Searching, SearchEnd, File, Func, Line, LineText }; /** The current state of the parser state machine. */ ParserState m_state; /** Accumulates text sent by Cscope to the standard error stream. */ QString m_sErrMsg; /** The full path of the directory holding the project files. */ static QString s_sProjPath; /** Project-specific command-line arguments to pass to Cscope. */ static QStringList s_slProjArgs; /** If true, the rebuild process will be restarted when the process exits. */ bool m_bRebuildOnExit; /** The maximal number of records requested for the current query. The process aborts if this number if reached. */ int m_nMaxRecords; bool run(const QStringList&);};/** * Provides progress information on a Cscope query. * Classes used to display query results can use this class to show a * progress bar while a query is running, and a "Please Wait..." label while * output is being processed. * @author Elad Lahav */class CscopeProgress : public QObject{ Q_OBJECTpublic: CscopeProgress(QWidget*); ~CscopeProgress(); void setProgress(int, int); void finished(); private: /** The parent widget for the progress bar and label. */ QWidget* m_pMainWidget; /** A bar used to display query progress information. */ QProgressBar* m_pProgressBar; /** A label used to display a "Please wait..." message. */ QLabel* m_pLabel; private slots: void slotShowProgressBar(); void slotShowLabel();};#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?