* ./vslsisapd/src/configuration:

- New: Integrate the FilePathEdit widget, courtesy of D. Dupuis.
    - Bug: In ConfEditorMain, new boolean switch to allow disable of GtkStyle
        which make FilePathEdit to coredump (Linux feature only!).
This commit is contained in:
Jean-Paul Chaput 2010-09-16 13:26:36 +00:00
parent a2d5823fce
commit 7b1fd28df0
11 changed files with 171 additions and 17 deletions

View File

@ -6,7 +6,8 @@
${LIBXML2_INCLUDE_DIR}
)
set ( mocIncludes vlsisapd/configuration/ConfigurationWidget.h
set ( mocIncludes vlsisapd/configuration/FilePathEdit.h
vlsisapd/configuration/ConfigurationWidget.h
vlsisapd/configuration/ParameterWidget.h
vlsisapd/configuration/ConfTabWidget.h
vlsisapd/configuration/ConfEditorWidget.h
@ -18,6 +19,7 @@
set ( cpps Parameter.cpp
LayoutDescription.cpp
Configuration.cpp
FilePathEdit.cpp
ParameterWidget.cpp
ConfTabWidget.cpp
ConfigurationWidget.cpp
@ -26,8 +28,9 @@
set ( editorcpp ConfEditorMain.cpp )
qt4_wrap_cpp ( mocCpps ${mocIncludes} )
qt4_add_resources ( RCC_SRCS Configuration.qrc )
add_library ( configuration ${cpps} ${mocCpps} )
add_library ( configuration ${cpps} ${mocCpps} ${RCC_SRCS} )
target_link_libraries ( configuration ${QT_LIBRARIES}
${PYTHON_LIBRARIES}
${LIBXML2_LIBRARIES}

View File

@ -48,11 +48,15 @@ int main ( int argc, char* argv[] )
int returnCode = 0;
try {
bool disableGtkStyle;
boptions::options_description options ("Command line arguments & options");
options.add_options()
( "help,h", "Print this help." )
( "conf,c", boptions::value<string>()
, "The path of the configuration file." );
( "help,h" , "Print this help." )
( "disable-gtkstyle", boptions::bool_switch(&disableGtkStyle)->default_value(false)
, "Run the detailed router (Kite).")
( "conf,c" , boptions::value<string>()
, "The path of the configuration file." );
boptions::variables_map arguments;
boptions::store ( boptions::parse_command_line(argc,argv,options), arguments );
@ -65,7 +69,7 @@ int main ( int argc, char* argv[] )
auto_ptr<QApplication> qa ( new QApplication(argc,argv) );
#if (QT_VERSION >= QT_VERSION_CHECK(4,5,0)) and not defined (__APPLE__)
qa->setStyle ( new QGtkStyle() );
if ( not disableGtkStyle ) qa->setStyle ( new QGtkStyle() );
#endif
bfs::path::default_name_check ( bfs::portable_posix_name );

View File

@ -39,7 +39,7 @@ namespace Cfg {
ConfEditorWidget::ConfEditorWidget ( QWidget* parent )
: QMainWindow (parent)
, _configurationWidget (Configuration::get()->buildWidget(ConfigurationWidget::StandAlone))
, _configurationWidget (Configuration::get()->buildWidget(ConfigurationWidget::Embedded))
, _fileMenu (NULL)
, _saveAction (NULL)
, _quitAction (NULL)
@ -90,7 +90,8 @@ namespace Cfg {
cout << "Saving configuration file: <" << dotConfigFile << ">."<< endl;
Configuration::get()->writeToStream ( file, Configuration::DriveValues|Configuration::DriveLayout );
Configuration::get()->writeToStream ( file, 0 );
//Configuration::get()->writeToStream ( file, Configuration::DriveValues|Configuration::DriveLayout );
file.close ();
}

View File

@ -273,12 +273,14 @@ namespace {
{
if ( xmlTextReaderNodeType(_reader) == XML_READER_TYPE_END_ELEMENT ) return;
string attrId = _getAttributeValue("id");
string attrType = _getAttributeValue("type");
string attrLabel = _getAttributeValue("label");
string attrColumn = _getAttributeValue("column");
string attrSpan = _getAttributeValue("span");
string attrSpinBox = _getAttributeValue("spinbox");
string attrId = _getAttributeValue("id");
string attrType = _getAttributeValue("type");
string attrLabel = _getAttributeValue("label");
string attrColumn = _getAttributeValue("column");
string attrSpan = _getAttributeValue("span");
string attrSpinBox = _getAttributeValue("spinbox");
string attrFileName = _getAttributeValue("filename");
string attrPathName = _getAttributeValue("pathname");
if ( attrId.empty() and attrType.empty() ) {
cerr << "[ERROR] In <widget> tag, neither \"id\" nor \"type\" attribute." << endl;
@ -309,7 +311,9 @@ namespace {
}
int flags = 0;
if ( attrSpinBox == "true" ) flags |= ParameterWidget::UseSpinBox;
if ( attrSpinBox == "true" ) flags |= ParameterWidget::UseSpinBox;
if ( attrFileName == "true" ) flags |= ParameterWidget::IsFileName;
if ( attrPathName == "true" ) flags |= ParameterWidget::IsPathName;
_configuration->getLayout().getBackTab()->addWidget ( WidgetDescription::parameter(attrId,attrLabel,column,span,flags) );
}

View File

@ -0,0 +1,5 @@
<!DOCTYPE RCC><RCC version="1.0">
<qresource>
<file>images/choose.png</file>
</qresource>
</RCC>

View File

@ -0,0 +1,73 @@
// -*- C++ -*-
//
// This file is part of the VSLSI Stand-Alone Software.
// Copyright (c) UPMC/LIP6 2010-2010, All Rights Reserved
//
// ===================================================================
//
// $Id$
//
// x-----------------------------------------------------------------x
// | |
// | C O R I O L I S |
// | C o n f i g u r a t i o n D a t a - B a s e |
// | |
// | Author : Damien Dupuis |
// | E-mail : Damien.Dupuis@soc.lip6.fr |
// | =============================================================== |
// | C++ Module : "./FilePathEdit.h" |
// | *************************************************************** |
// | U p d a t e s |
// | |
// x-----------------------------------------------------------------x
#include <iostream>
#include <QToolButton>
#include <QStyle>
#include <QFileDialog>
#include "vlsisapd/configuration/FilePathEdit.h"
namespace Cfg {
FilePathEdit::FilePathEdit ( Type type, std::string filter, QWidget* parent )
: QLineEdit(parent)
, _type (type)
, _filter (filter)
{
_chooseButton = new QToolButton(this);
QPixmap pixmap(":/images/choose.png");
_chooseButton->setIcon(QIcon(pixmap));
_chooseButton->setIconSize(pixmap.size());
_chooseButton->setCursor(Qt::ArrowCursor);
_chooseButton->setStyleSheet("QToolButton { border: none; padding: 0px; }");
_chooseButton->setToolTip(tr( (type&Filename)?"Choose file ...":"Choose directory ..." ));
connect(_chooseButton, SIGNAL(clicked()), this, SLOT(updateLineEdit()));
setStyleSheet(QString("QLineEdit { padding-right: %1px; } ").arg(_chooseButton->sizeHint().width() + 1));
}
void FilePathEdit::resizeEvent(QResizeEvent *)
{
QSize sz = _chooseButton->sizeHint();
int l, t, r, b;
getContentsMargins(&l, &t, &r, &b);
_chooseButton->move(rect().right() - r - sz.width(), (rect().bottom() + 2 - sz.height())/2);
}
void FilePathEdit::updateLineEdit()
{
if (_type == FilePathEdit::Filename) {
setText(QFileDialog::getOpenFileName(this, tr("Choose file"), "", tr(_filter.c_str())));
} else {
setText(QFileDialog::getExistingDirectory(this, tr("Choose directory"), "", QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks));
}
}
} // End of Cfg namespace.

View File

@ -154,6 +154,8 @@ namespace Cfg {
if ( widget->getSpan() != 1 ) out << " span=\"" << widget->getSpan() << "\"";
if ( widget->getFlags() & ParameterWidget::UseSpinBox ) out << " spinbox=\"true\"";
if ( widget->getFlags() & ParameterWidget::IsFileName ) out << " filename=\"true\"";
if ( widget->getFlags() & ParameterWidget::IsPathName ) out << " pathname=\"true\"";
break;
}

View File

@ -32,6 +32,7 @@
#include <QIntValidator>
#include <QDoubleValidator>
#include "vlsisapd/configuration/Parameter.h"
#include "vlsisapd/configuration/FilePathEdit.h"
#include "vlsisapd/configuration/ParameterWidget.h"
#include "vlsisapd/configuration/ConfigurationWidget.h"
@ -62,7 +63,11 @@ namespace Cfg {
break;
case Parameter::String:
{
QLineEdit* lineEdit = new QLineEdit();
QLineEdit* lineEdit = NULL;
if ( hasFlags(IsFileName) ) lineEdit = new FilePathEdit ( FilePathEdit::Filename );
else if ( hasFlags(IsPathName) ) lineEdit = new FilePathEdit ( FilePathEdit::Pathname );
else lineEdit = new QLineEdit();
lineEdit->setSizePolicy ( QSizePolicy::Expanding, QSizePolicy::Fixed );
lineEdit->setMinimumWidth ( 375 );
lineEdit->setText ( QString("%1").arg(_parameter->asString().c_str()) );

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

View File

@ -0,0 +1,57 @@
// -*- C++ -*-
//
// This file is part of the VSLSI Stand-Alone Software.
// Copyright (c) UPMC/LIP6 2010-2010, All Rights Reserved
//
// ===================================================================
//
// $Id$
//
// x-----------------------------------------------------------------x
// | |
// | C O R I O L I S |
// | C o n f i g u r a t i o n D a t a - B a s e |
// | |
// | Author : Damien Dupuis |
// | E-mail : Damien.Dupuis@soc.lip6.fr |
// | =============================================================== |
// | C++ Header : "./vlsisapd/configuration/FilePathEdit.h" |
// | *************************************************************** |
// | U p d a t e s |
// | |
// x-----------------------------------------------------------------x
#ifndef __CFG_FILE_LINE_EDIT__
#define __CFG_FILE_LINE_EDIT__
#include <string>
#include <QLineEdit>
class QToolButton;
namespace Cfg {
class FilePathEdit : public QLineEdit
{
Q_OBJECT;
public:
enum Type { Filename=0x1, Pathname=0x2 };
public:
FilePathEdit ( Type type=Filename, std::string filter="", QWidget* parent=NULL );
protected:
void resizeEvent ( QResizeEvent* );
private slots:
void updateLineEdit ();
private:
QToolButton* _chooseButton;
Type _type;
std::string _filter;
};
} // End of Cfg namespace.
#endif // __CFG_FILE_LINE_EDIT__

View File

@ -44,7 +44,7 @@ namespace Cfg {
class ParameterWidget : public QObject {
Q_OBJECT;
public:
enum Flags { UseSpinBox=0x1 };
enum Flags { UseSpinBox=0x1, IsFileName=0x2, IsPathName=0x4 };
public:
ParameterWidget ( QObject* parent, Parameter*, const std::string& label, int flags );
inline Parameter* getParameter ();