calltreemanager.cpp

来自「This a source insight software in Linux.」· C++ 代码 · 共 137 行

CPP
137
字号
/*************************************************************************** * * 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. * ***************************************************************************/#include "calltreemanager.h"#include "calltreedlg.h"#include "projectmanager.h"/** * Class constructor. * @param	pParent	The widget to use as the parent of all Call Tree   *					dialogues */CallTreeManager::CallTreeManager(QWidget* pParent) : QObject(pParent){	// Delete dialogue objects when they are removed from the list	m_lstDialogs.setAutoDelete(true);}/** * Class destructor. */CallTreeManager::~CallTreeManager(){}/**  * Saves all call trees into the project directory. * @param	sProjPath	The project's directory * @param	slFiles		Holds a list of saved file names, upon return */void CallTreeManager::saveOpenDialogs(const QString& sProjPath,	QStringList& slFiles){	CallTreeDlg *pDlg;		// Iterate over the open dialogues	for (pDlg = m_lstDialogs.first(); pDlg != NULL; 		pDlg = m_lstDialogs.next()) {		pDlg->store(sProjPath);		slFiles += pDlg->getFileName();	}}/**  * Loads all call trees according to the list of files  * @param	sProjPath	The project's directory * @param	slFiles		A list of file names to open */void CallTreeManager::loadOpenDialogs(const QString& sProjPath,	const QStringList& slFiles){	QStringList::ConstIterator itr;	CallTreeDlg *pDlg;		for (itr = slFiles.begin(); itr != slFiles.end(); ++itr) {		// Create a new dialogue for this file		pDlg = addDialog();				// Try to load the graph from the file		if (!pDlg->load(sProjPath, *itr)) {			m_lstDialogs.remove(pDlg);			continue;		}				// Show the call tree		pDlg->show();	}}/**  * Creates a new Call Tree dialogue. * @return	The newly allocated dialogue object */CallTreeDlg* CallTreeManager::addDialog() {	CallTreeDlg* pDlg;		// Create a modeless call tree dialogue	pDlg = new CallTreeDlg((QWidget*)parent());	m_lstDialogs.append(pDlg); 		// Open an editor whenever a function name is double-clicked	connect(pDlg, SIGNAL(lineRequested(const QString&, uint)),		this, SIGNAL(lineRequested(const QString&, uint)));	// Track the closing of the call tree dialog	connect(pDlg, SIGNAL(closed(const CallTreeDlg*)), this,		SLOT(slotRemoveDialog(const CallTreeDlg*)));		return pDlg;}/**  * Closes all Call Tree dialogues. */void CallTreeManager::closeAll(){	m_lstDialogs.clear();}/**  * Removes a Call Tree dialogue from the list of open Call Trees. * This slot is connected to the closed() signal emitted by the dialogue. * @param	pDlg	The dialogue to remove from the list */void CallTreeManager::slotRemoveDialog(const CallTreeDlg* pDlg) {	m_lstDialogs.remove(pDlg);}#include "calltreemanager.moc"

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?