diff --git a/dist/changes-2.0.0 b/dist/changes-2.0.0 index eef365f6f90..41bc216a664 100644 --- a/dist/changes-2.0.0 +++ b/dist/changes-2.0.0 @@ -17,7 +17,7 @@ General of Qt creator * Added option to set interface language explicitly, overriding the locale setting - * New "Design" mode for visual editors (.ui & .qml files) + * New "Design" mode for visual editors * Fixed crash when working with empty pro-file * Ask for close, save, or save as when file is removed while open in Qt Creator * Use shadowbuilding by default in new projects whenever possible @@ -94,11 +94,6 @@ QML/JS Support * New qml based .qmlproject file format (replaces old format) - * New QmlDesigner - * Allows visual manipulation of .qml files - * Supports changing top-level states - * Integrates tighly with text editor, e.g. shared history, navigation facilities ... - Platform Specific Mac diff --git a/dist/changes-2.1.0 b/dist/changes-2.1.0 new file mode 100644 index 00000000000..c64f208e927 --- /dev/null +++ b/dist/changes-2.1.0 @@ -0,0 +1,35 @@ +The QtCreator 2.1 release contains bug fixes and new features. + +Below is a list of relevant changes. You can find a complete list of changes +within the logs of Qt Creator's sources. Simply check it out from the public git +repository e.g., + +git clone git://gitorious.org/qt-creator/qt-creator.git +git log --cherry-pick --pretty=oneline v2.0.0...v2.1.0 + +General + +Editing + +C++ Support + +Project support + +Debugging + +QML/JS Support + * New QmlDesigner + * Allows visual manipulation of .qml files + * Supports changing top-level states + * Integrates tighly with text editor, e.g. shared history, navigation facilities ... + +Platform Specific + +Mac + +Linux (GNOME and KDE) + +Windows + +Additional credits go to: + diff --git a/doc/doc.pri b/doc/doc.pri index b4c8800f634..c161582f7f8 100644 --- a/doc/doc.pri +++ b/doc/doc.pri @@ -15,10 +15,20 @@ equals(QMAKE_DIR_SEP, /) { # unix, mingw+msys QHP_FILE = $$OUT_PWD/doc/html/qtcreator.qhp QCH_FILE = $$IDE_DOC_PATH/qtcreator.qch +HELP_DEP_FILES = $$PWD/qtcreator.qdoc \ + $$PWD/addressbook-sdk.qdoc \ + $$PWD/qt-defines.qdocconf \ + $$PWD/qt-html-templates.qdocconf \ + $$PWD/qtcreator.qdocconf \ + $$PWD/qtcreator-online.qdocconf + html_docs.commands = $$QDOC $$PWD/qtcreator.qdocconf -html_docs.depends += $$PWD/qtcreator.qdoc $$PWD/qtcreator.qdocconf +html_docs.depends += $$HELP_DEP_FILES html_docs.files = $$QHP_FILE +html_docs_online.commands = $$QDOC $$PWD/qtcreator-online.qdocconf +html_docs_online.depends += $$HELP_DEP_FILES + qch_docs.commands = $$HELPGENERATOR -o \"$$QCH_FILE\" $$QHP_FILE qch_docs.depends += html_docs qch_docs.files = $$QCH_FILE @@ -29,10 +39,10 @@ unix:!macx { INSTALLS += qch_docs } +docs_online.depends = html_docs_online docs.depends = qch_docs -QMAKE_EXTRA_TARGETS += html_docs qch_docs docs +QMAKE_EXTRA_TARGETS += html_docs html_docs_online qch_docs docs docs_online -OTHER_FILES = $$PWD/qtcreator.qdoc \ - $$PWD/qtcreator.qdocconf -OTHER_FILES += $$PWD/api/qtcreator-api.qdoc \ - $$PWD/api/qtcreator-api.qdocconf +OTHER_FILES = $$HELP_DEP_FILES \ + $$PWD/api/qtcreator-api.qdoc \ + $$PWD/api/qtcreator-api.qdocconf diff --git a/doc/images/qtcreator-qt4-addbutton.png b/doc/images/qtcreator-qt4-addbutton.png index c464644a572..4c7836835e6 100644 Binary files a/doc/images/qtcreator-qt4-addbutton.png and b/doc/images/qtcreator-qt4-addbutton.png differ diff --git a/doc/images/qtcreator-target-remove.png b/doc/images/qtcreator-target-remove.png new file mode 100644 index 00000000000..4cab5536306 Binary files /dev/null and b/doc/images/qtcreator-target-remove.png differ diff --git a/doc/images/remotecompiler-fn-logon.png b/doc/images/remotecompiler-fn-logon.png new file mode 100644 index 00000000000..6e0be9093f3 Binary files /dev/null and b/doc/images/remotecompiler-fn-logon.png differ diff --git a/doc/qt-defines.qdocconf b/doc/qt-defines.qdocconf index f3239272c78..67d8e0348ce 100644 --- a/doc/qt-defines.qdocconf +++ b/doc/qt-defines.qdocconf @@ -20,53 +20,46 @@ codeindent = 1 # See also qhp.Qt.extraFiles extraimages.HTML = qt-logo \ trolltech-logo \ - api_examples.png \ - bg_ll.png \ - bg_ul_blank.png \ - bullet_gt.png \ - horBar.png \ - qt_ref_doc.png \ - api_lookup.png \ - bg_ll_blank.png \ - bg_ur.png \ - bullet_sq.png \ - bullet_dn.png \ - bullet_up.png \ - page_bg.png \ - qt_tools.png \ - api_topics.png \ - bg_lr.png \ - bg_ur_blank.png \ - content_bg.png \ - print.png \ - sep.png \ - bg_l.png \ - bg_r.png \ - box_bg.png \ - feedbackground.png \ - qt_guide.png \ - sprites-combined.png \ - bg_l_blank.png \ - bg_ul.png \ - breadcrumb.png \ - form_bg.png \ - qt_icon.png \ - header.png \ - qtcreator-screenshots.png \ - taskmenuextension-example.png \ - coloreditorfactoryimage.png \ - dynamiclayouts-example.png \ - stylesheet-coffee-plastique.png + api_examples.png \ + api_lookup.png \ + arrow_down.png \ + bg_ll.png \ + bg_l.png \ + bg_lr.png \ + bg_r.png \ + bg_ul_blank.png \ + bg_ll_blank.png \ + bg_l_blank.png \ + breadcrumb.png \ + bullet_dn.png \ + bullet_gt.png \ + bullet_sq.png \ + box_bg.png \ + feedbackground.png \ + horBar.png \ + page_bg.png \ + sprites-combined.png \ + qtcreator-screenshots.png # This stuff is used by the new doc format. scriptdirs = $SRCDIR/templates/scripts styledirs = $SRCDIR/templates/style scripts.HTML = functions.js \ + shBrushCpp.js \ + shCore.js \ + shLegacy.js \ + narrow.js \ + superfish.js \ jquery.js -styles.HTML = OfflineStyle.css \ - style.css \ - style_ie6.css \ - style_ie7.css \ - style_ie8.css +styles.HTML = style.css \ + shCore.css \ + shThemeDefault.css \ + narrow.css \ + superfish.css \ + superfish_skin.css \ + OfflineStyle.css \ + style_ie6.css \ + style_ie7.css \ + style_ie8.css diff --git a/doc/qt-html-templates.qdocconf b/doc/qt-html-templates.qdocconf index 1e69f880f90..d821d0d2853 100644 --- a/doc/qt-html-templates.qdocconf +++ b/doc/qt-html-templates.qdocconf @@ -1,8 +1,19 @@ -HTML.stylesheets = style/style.css +HTML.stylesheets = style/style.css \ + style/OfflineStyle.css \ + style/style_ie7.css \ + style/style_ie8.css \ + style/style_ie6.css + HTML.postheader = "
\n" \ + "
\n" \ "
\n" \ " Home
\n" \ " Qt Creator Documentation\n" \ + "
\n" \ + "
\n" \ + " \n" \ + "
\n" \ + "
\n" \ "
\n" \ "
\n" \ "
\n" \ @@ -31,55 +43,49 @@ HTML.postheader = "
\n" \ "
\n" \ " Search index:
\n" \ "
\n" \ - "
\n" \ + " \n" \ "
\n" \ - " \n" \ + " \n" \ "
\n" \ "
\n" \ "
\n" \ "
\n" \ - "

\n" \ + "

\n" \ " API Lookup

\n" \ - "
\n" \ - " \n" \ - "
\n" \ - "
\n" \ + "
\n" \ + " \n" \ "
\n" \ "
\n" \ "
\n" \ - "

\n" \ - " API Topics

\n" \ - "
\n" \ - " \n" \ - "
\n" \ - "
\n" \ + "

\n" \ + " Qt Topics

\n" \ + "
\n" \ + " \n" \ "
\n" \ "
\n" \ "
\n" \ - "

\n" \ - " API Examples

\n" \ - "
\n" \ - " \n" \ - "
\n" \ - "
\n" \ + "

\n" \ + " Examples

\n" \ + "
\n" \ + " \n" \ "
\n" \ "
\n" \ "
\n" \ @@ -98,20 +104,21 @@ HTML.postpostheader = " \n" \ "
  • A
  • \n" \ "
  • A
  • \n" \ "
  • \n" \ - " \"\"\"Print
  • \n" \ + " Print\n" \ " \n" \ "
    \n" \ "
    \n" \ "
    \n" -HTML.footer = "
    \n" \ - "
    \n" \ +HTML.footer = " \n" \ + "
    \n" \ " [+] Documentation Feedback
    \n" \ "
    \n" \ "
    \n" \ "
    \n" \ " \n" \ "
    \n" \ + "
    \n" \ "
    \n" \ "

    \n" \ " © 2008-2010 Nokia Corporation and/or its\n" \ @@ -122,13 +129,10 @@ HTML.footer = "

    \n" \ " href=\"http://qt.nokia.com/about/privacy-policy\">Privacy Policy

    \n" \ "
    \n" \ "
    \n" \ - "
    \n" \ - " X\n" \ - "
    \n" \ - "
    \n" \ - " \n" \ - " \n" \ + "
    X
    \n" \ + " \n" \ + "

    \n" \ + "

    \n" \ "
    \n" \ "
    \n" \ "
    \n" \ diff --git a/doc/qtcreator-online.qdocconf b/doc/qtcreator-online.qdocconf new file mode 100644 index 00000000000..adfa30760be --- /dev/null +++ b/doc/qtcreator-online.qdocconf @@ -0,0 +1,4 @@ +online = true +# Run qdoc from the directory that contains this file. +include(qtcreator.qdocconf) + diff --git a/doc/qtcreator.qdoc b/doc/qtcreator.qdoc index 99e50fea7d3..13435a31fe4 100644 --- a/doc/qtcreator.qdoc +++ b/doc/qtcreator.qdoc @@ -1344,7 +1344,7 @@ Qt Creator provides support for \l{Building and Running Applications}{building and running} Qt applications for desktop environment and mobile devices. When you install the Nokia Qt SDK, - the build and run settings for the desktop, Maemo, and Symbian targets are set up + the build and run settings for the Maemo and Symbian targets are set up automatically. However, you need to install and configure some additional software on the devices: @@ -1868,9 +1868,17 @@ Qt Creator provides support for building and running Qt applications for desktop environment and mobile devices. When you install the Nokia Qt SDK, - the build and run settings for the desktop, Maemo, and Symbian targets are + the build and run settings for the Maemo and Symbian targets are set up automatically. + You can add a target if the necessary tool chain is installed on the + development PC and the Qt version is configured. Click + \inlineimage qtcreator-qt4-addbutton.png "Add Target button" + and select from a list of available + targets. To remove a target, select it and click + \inlineimage qtcreator-target-remove.png "Remove Target button" + . + You can select the targets and click the \gui Run button to build and run the applications on the targets. @@ -1884,6 +1892,8 @@ The project pane consists of the following tabs: \list \o \l{Building for Multiple Targets}{Targets} + \note If you have installed only one tool chain, the \gui Targets + tab is replaced by a \gui {Build and Run} tab. \o \l{Specifying Editor Settings}{Editor Settings} \o \l{Specifying Dependencies}{Dependencies} \endlist @@ -2159,16 +2169,71 @@ If you cannot run the application in the emulator, check if: \list \o You selected the \gui{Symbian Emulator} target for your application. + + \o If you cannot select \gui {Symbian Emulator} as target, check that + Carbide.c++ is installed correctly and that the path to the Carbide.c++ + installation directory is specified in the \gui{Carbide directory} field + in the build settings. + \o If the emulator process cannot be started, try closing Qt Creator and starting the application directly from your file manager. Having done this, Qt Creator should be able to run your projects in the emulator. + \endlist + \note Qt Creator does not create release configurations for the + \gui {Symbian Emulator} target, because Symbian Emulator supports only debug + builds. + If this does not help to solve your problem, search the qt-creator@trolltech.com mailing list archives or provide feedback to us via the methods described on the \l{http://qt.gitorious.org/qt-creator/pages/Home}{Qt Creator Development Wiki}. + + \section1 Building with Remote Compiler + + The \gui {Remote Compiler} target is an interface to a compilation service at + Forum Nokia. It provides a simple, standardized environment for building Qt + applications and creating installation packages for Symbian and Maemo devices + when you do not have the necessary tool chains and SDKs installed or they are + not supported on the development PC. You can choose from a set of supported + devices, such as S60 3rd Edition or S60 5th Edition devices. + + \note Remote Compiler is an experimental component that you must install + separately from the package that is included in the Nokia Qt SDK. + + \list 1 + + \o In the Nokia Qt SDK installation directory, double-click + SDKMaintenanceTool.exe to install \gui {Experimental APIs}. + + \o In Qt Creator, choose \gui {Tools > Options > Projects > Remote Compiler} + to log on to Forum Nokia. + + \image remotecompiler-fn-logon.png "Remote Compiler options" + + \o Choose \gui {Projects}. + + \o Click + \inlineimage qtcreator-qt4-addbutton.png "Add Target button" + and select \gui {Remote Compiler} to add Remote Compiler as a target. + + \o Click \gui Add to add mobile device platforms as build configurations. + + \o Click the \gui {Target Selector} and select a build configuration. + + \o Choose \gui {Build > Build All}. + + \endlist + + The installation package is generated in the \gui {Build directory} on + the development PC. + + For more information about Remote Compiler, choose \gui {Help > Contents > + Remote Compiler}. The document is added during the installation of experimental + APIs. + */ @@ -6083,6 +6148,40 @@ \endlist + \section1 Troubleshooting + + The addresses used in this example might be reserved by some other application + in your network. If you cannot establish a connection, try the following optional + configurations: + + \table + + \header + \o usb0 in Mad Developer on Device + \o USB Network on Development PC + \o Host Name in Qt Creator Build Settings + + \row + \o 172.30.7.15 255.255.255.0 + \o 172.30.7.14 255.255.255.0 + \o 172.30.7.15 + + \row + \o 10.133.133.15 + \o 10.133.133.14 + \o 10.133.133.15 + + \row + \o 192.168.133.15 + \o 192.168.133.14 + \o 192.168.133.15 + + \note You cannot use the value localhost for connections to a device. + + \endtable + + \note VPN connections might block the device connection. + */ @@ -7208,6 +7307,11 @@ \o Creating new \c CMake projects with Qt Creator is not supported. + \o Building and packaging sub-projects is not supported for Maemo devices. + + \o You must create projects for Maemo targets on the same partition where + you installed Nokia Qt SDK, Qt Creator, and MADDE. + \endlist \section1 Debugging diff --git a/doc/qtcreator.qdocconf b/doc/qtcreator.qdocconf index 3e119c127f4..7a083f61ce8 100644 --- a/doc/qtcreator.qdocconf +++ b/doc/qtcreator.qdocconf @@ -37,30 +37,23 @@ qhp.QtCreator.extraFiles = \ scripts/jquery.js \ images/api_examples.png \ images/api_lookup.png \ - images/api_topics.png \ + images/arrow_down.png \ images/bg_ll.png \ - images/bg_l_blank.png \ images/bg_l.png \ images/bg_lr.png \ images/bg_r.png \ images/bg_ul_blank.png \ - images/bg_ul.png \ - images/bg_ur_blank.png \ - images/bg_ur.png \ + images/bg_ll_blank.png \ + images/bg_l_blank.png \ images/breadcrumb.png \ images/bullet_dn.png \ images/bullet_gt.png \ + images/bullet_sq.png \ + images/box_bg.png \ images/feedbackground.png \ - images/form_bg.png \ images/horBar.png \ images/page_bg.png \ - images/print.png \ - images/qt_guide.png \ images/qt-logo.png \ - images/qt_ref_doc.png \ - images/qt_tools.png \ - images/sep.png \ - images/header.png \ images/sprites-combined.png # macros.qdocconf diff --git a/doc/templates/images/arrow_down.png b/doc/templates/images/arrow_down.png new file mode 100644 index 00000000000..9d01e97f6a9 Binary files /dev/null and b/doc/templates/images/arrow_down.png differ diff --git a/doc/templates/images/header_bg.png b/doc/templates/images/header_bg.png new file mode 100644 index 00000000000..a436aa61eff Binary files /dev/null and b/doc/templates/images/header_bg.png differ diff --git a/doc/templates/images/page.png b/doc/templates/images/page.png new file mode 100644 index 00000000000..1db151bd31e Binary files /dev/null and b/doc/templates/images/page.png differ diff --git a/doc/templates/images/spinner.gif b/doc/templates/images/spinner.gif new file mode 100644 index 00000000000..1ed786f2ece Binary files /dev/null and b/doc/templates/images/spinner.gif differ diff --git a/doc/templates/style/style.css b/doc/templates/style/style.css index 47fe2e0a04a..28d558f847e 100644 --- a/doc/templates/style/style.css +++ b/doc/templates/style/style.css @@ -678,7 +678,7 @@ padding-left: 3px; background: transparent url( ../images/sprites-combined.png) no-repeat 0px -58px; height: 20px; - width: 47px; + width: 110px; } .shortCut-topleft-inactive span { diff --git a/src/libs/qmljs/qmljsdocument.cpp b/src/libs/qmljs/qmljsdocument.cpp index 40b71bed698..6a2c9dc3e43 100644 --- a/src/libs/qmljs/qmljsdocument.cpp +++ b/src/libs/qmljs/qmljsdocument.cpp @@ -172,7 +172,11 @@ bool Document::parse_helper(int startToken) Lexer lexer(_engine); Parser parser(_engine); - lexer.setCode(_source, /*line = */ 1); + QString source = _source; + if (startToken == QmlJSGrammar::T_FEED_JS_PROGRAM) + extractPragmas(&source); + + lexer.setCode(source, /*line = */ 1); switch (startToken) { case QmlJSGrammar::T_FEED_UI_PROGRAM: @@ -224,6 +228,86 @@ Bind *Document::bind() const return _bind; } +// this is essentially a copy of QDeclarativeScriptParser::extractPragmas +void Document::extractPragmas(QString *source) +{ + const QChar forwardSlash(QLatin1Char('/')); + const QChar star(QLatin1Char('*')); + const QChar newline(QLatin1Char('\n')); + const QChar dot(QLatin1Char('.')); + const QChar semicolon(QLatin1Char(';')); + const QChar space(QLatin1Char(' ')); + const QString pragma(QLatin1String(".pragma ")); + + const QChar *pragmaData = pragma.constData(); + + QString &script = *source; + const QChar *data = script.constData(); + const int length = script.count(); + for (int ii = 0; ii < length; ++ii) { + const QChar &c = data[ii]; + + if (c.isSpace()) + continue; + + if (c == forwardSlash) { + ++ii; + if (ii >= length) + return; + + const QChar &c = data[ii]; + if (c == forwardSlash) { + // Find next newline + while (ii < length && data[++ii] != newline) {}; + } else if (c == star) { + // Find next star + while (true) { + while (ii < length && data[++ii] != star) {}; + if (ii + 1 >= length) + return; + + if (data[ii + 1] == forwardSlash) { + ++ii; + break; + } + } + } else { + return; + } + } else if (c == dot) { + // Could be a pragma! + if (ii + pragma.length() >= length || + 0 != ::memcmp(data + ii, pragmaData, sizeof(QChar) * pragma.length())) + return; + + int pragmaStatementIdx = ii; + + ii += pragma.length(); + + while (ii < length && data[ii].isSpace()) { ++ii; } + + int startIdx = ii; + + while (ii < length && data[ii].isLetter()) { ++ii; } + + int endIdx = ii; + + if (ii != length && data[ii] != forwardSlash && !data[ii].isSpace() && data[ii] != semicolon) + return; + + QString p(data + startIdx, endIdx - startIdx); + + if (p != QLatin1String("library")) + return; + + for (int jj = pragmaStatementIdx; jj < endIdx; ++jj) script[jj] = space; + + } else { + return; + } + } +} + LibraryInfo::LibraryInfo() : _valid(false) { diff --git a/src/libs/qmljs/qmljsdocument.h b/src/libs/qmljs/qmljsdocument.h index 39931c54a40..1e6b239cf2e 100644 --- a/src/libs/qmljs/qmljsdocument.h +++ b/src/libs/qmljs/qmljsdocument.h @@ -93,6 +93,7 @@ public: private: bool parse_helper(int kind); + static void extractPragmas(QString *source); private: QmlJS::Engine *_engine; diff --git a/src/plugins/cmakeprojectmanager/cmakeprojectmanager.cpp b/src/plugins/cmakeprojectmanager/cmakeprojectmanager.cpp index 0ef46a5f647..3a4cc432bbe 100644 --- a/src/plugins/cmakeprojectmanager/cmakeprojectmanager.cpp +++ b/src/plugins/cmakeprojectmanager/cmakeprojectmanager.cpp @@ -37,6 +37,7 @@ #include #include #include +#include #include #include #include @@ -255,7 +256,8 @@ QString CMakeSettingsPage::category() const QString CMakeSettingsPage::displayCategory() const { - return tr(ProjectExplorer::Constants::PROJECTEXPLORER_SETTINGS_TR_CATEGORY); + return QCoreApplication::translate("ProjectExplorer", + ProjectExplorer::Constants::PROJECTEXPLORER_SETTINGS_TR_CATEGORY); } QIcon CMakeSettingsPage::categoryIcon() const diff --git a/src/plugins/coreplugin/editormanager/openeditorswindow.cpp b/src/plugins/coreplugin/editormanager/openeditorswindow.cpp index 393ee6bdb65..399ab26486a 100644 --- a/src/plugins/coreplugin/editormanager/openeditorswindow.cpp +++ b/src/plugins/coreplugin/editormanager/openeditorswindow.cpp @@ -82,8 +82,8 @@ OpenEditorsWindow::OpenEditorsWindow(QWidget *parent) : void OpenEditorsWindow::selectAndHide() { - selectEditor(m_editorList->currentItem()); setVisible(false); + selectEditor(m_editorList->currentItem()); } void OpenEditorsWindow::setVisible(bool visible) diff --git a/src/plugins/projectexplorer/doubletabwidget.cpp b/src/plugins/projectexplorer/doubletabwidget.cpp index 91c9c12bb0e..3f9ce39e0c0 100644 --- a/src/plugins/projectexplorer/doubletabwidget.cpp +++ b/src/plugins/projectexplorer/doubletabwidget.cpp @@ -86,6 +86,13 @@ void DoubleTabWidget::setCurrentIndex(int index) update(); } +int DoubleTabWidget::currentSubIndex() const +{ + if (m_currentIndex >= 0 && m_currentIndex < m_tabs.size()) + return m_tabs.at(m_currentIndex).currentSubTab; + return -1; +} + void DoubleTabWidget::setTitle(const QString &title) { m_title = title; @@ -104,10 +111,6 @@ void DoubleTabWidget::addTab(const QString &name, const QStringList &subTabs) tab.subTabs = subTabs; tab.currentSubTab = tab.subTabs.isEmpty() ? -1 : 0; m_tabs.append(tab); - if (m_currentIndex == -1) { - m_currentIndex = m_tabs.size()-1; - emit currentIndexChanged(m_currentIndex, m_tabs.at(m_currentIndex).currentSubTab); - } update(); } @@ -118,10 +121,7 @@ void DoubleTabWidget::insertTab(int index, const QString &name, const QStringLis tab.subTabs = subTabs; tab.currentSubTab = tab.subTabs.isEmpty() ? -1 : 0; m_tabs.insert(index, tab); - if (m_currentIndex == -1) { - m_currentIndex = index; - emit currentIndexChanged(m_currentIndex, m_tabs.at(m_currentIndex).currentSubTab); - } else if (m_currentIndex >= index) { + if (m_currentIndex >= index) { ++m_currentIndex; emit currentIndexChanged(m_currentIndex, m_tabs.at(m_currentIndex).currentSubTab); } diff --git a/src/plugins/projectexplorer/doubletabwidget.h b/src/plugins/projectexplorer/doubletabwidget.h index cebe0406a1c..704eb373c8b 100644 --- a/src/plugins/projectexplorer/doubletabwidget.h +++ b/src/plugins/projectexplorer/doubletabwidget.h @@ -30,6 +30,8 @@ public: int currentIndex() const; void setCurrentIndex(int index); + int currentSubIndex() const; + signals: void currentIndexChanged(int index, int subIndex); diff --git a/src/plugins/projectexplorer/projectexplorersettingspage.cpp b/src/plugins/projectexplorer/projectexplorersettingspage.cpp index db70b96890a..806b9b4570c 100644 --- a/src/plugins/projectexplorer/projectexplorersettingspage.cpp +++ b/src/plugins/projectexplorer/projectexplorersettingspage.cpp @@ -36,6 +36,7 @@ #include #include +#include namespace ProjectExplorer { namespace Internal { @@ -136,7 +137,8 @@ QString ProjectExplorerSettingsPage::category() const QString ProjectExplorerSettingsPage::displayCategory() const { - return tr(Constants::PROJECTEXPLORER_SETTINGS_TR_CATEGORY); + return QCoreApplication::translate("ProjectExplorer", + Constants::PROJECTEXPLORER_SETTINGS_TR_CATEGORY); } QIcon ProjectExplorerSettingsPage::categoryIcon() const diff --git a/src/plugins/projectexplorer/sessiondialog.cpp b/src/plugins/projectexplorer/sessiondialog.cpp index fb9bb71ca1b..c4f1f608ec3 100644 --- a/src/plugins/projectexplorer/sessiondialog.cpp +++ b/src/plugins/projectexplorer/sessiondialog.cpp @@ -74,23 +74,27 @@ void SessionValidator::fixup(QString &input) const input = copy; } + class SessionNameInputDialog : public QDialog { Q_OBJECT public: - SessionNameInputDialog(const QStringList& sessions, const QString &initialValue = QString()); + SessionNameInputDialog(const QStringList &sessions, QWidget *parent = 0); + + void setValue(const QString &value); QString value() const; + private: QLineEdit *m_newSessionLineEdit; }; -SessionNameInputDialog::SessionNameInputDialog(const QStringList& sessions, const QString &initialValue) +SessionNameInputDialog::SessionNameInputDialog(const QStringList &sessions, QWidget *parent) + : QDialog(parent) { QVBoxLayout *hlayout = new QVBoxLayout(this); QLabel *label = new QLabel(tr("Enter the name of the session:"), this); hlayout->addWidget(label); m_newSessionLineEdit = new QLineEdit(this); - m_newSessionLineEdit->setText(initialValue); m_newSessionLineEdit->setValidator(new SessionValidator(this, sessions)); hlayout->addWidget(m_newSessionLineEdit); QDialogButtonBox *buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, Qt::Horizontal, this); @@ -100,11 +104,17 @@ SessionNameInputDialog::SessionNameInputDialog(const QStringList& sessions, cons setLayout(hlayout); } +void SessionNameInputDialog::setValue(const QString &value) +{ + m_newSessionLineEdit->setText(value); +} + QString SessionNameInputDialog::value() const { return m_newSessionLineEdit->text(); } + SessionDialog::SessionDialog(SessionManager *sessionManager) : m_sessionManager(sessionManager) { @@ -174,7 +184,7 @@ void SessionDialog::updateActions() void SessionDialog::createNew() { - SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions()); + SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions(), this); newSessionInputDialog.setWindowTitle(tr("New session name")); if (newSessionInputDialog.exec() == QDialog::Accepted) { @@ -192,8 +202,10 @@ void SessionDialog::createNew() void SessionDialog::clone() { - SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions(), m_ui.sessionList->currentItem()->text()); + SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions(), this); + newSessionInputDialog.setValue(m_ui.sessionList->currentItem()->text()); newSessionInputDialog.setWindowTitle(tr("New session name")); + if (newSessionInputDialog.exec() == QDialog::Accepted) { QString newSession = newSessionInputDialog.value(); if (m_sessionManager->cloneSession(m_ui.sessionList->currentItem()->text(), newSession)) { @@ -213,11 +225,12 @@ void SessionDialog::remove() markItems(); } - void SessionDialog::rename() { - SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions(), m_ui.sessionList->currentItem()->text()); + SessionNameInputDialog newSessionInputDialog(m_sessionManager->sessions(), this); + newSessionInputDialog.setValue(m_ui.sessionList->currentItem()->text()); newSessionInputDialog.setWindowTitle(tr("Rename session")); + if (newSessionInputDialog.exec() == QDialog::Accepted) { m_sessionManager->renameSession(m_ui.sessionList->currentItem()->text(), newSessionInputDialog.value()); m_ui.sessionList->clear(); @@ -226,7 +239,6 @@ void SessionDialog::rename() } } - void SessionDialog::switchToSession() { if (m_ui.sessionList->currentItem()) { diff --git a/src/plugins/projectexplorer/targetselector.cpp b/src/plugins/projectexplorer/targetselector.cpp index 70601a8b035..dd920ec46ec 100644 --- a/src/plugins/projectexplorer/targetselector.cpp +++ b/src/plugins/projectexplorer/targetselector.cpp @@ -46,9 +46,7 @@ void TargetSelector::insertTarget(int index, const QString &name) m_targets.insert(index, target); - if (m_currentTargetIndex == -1) - setCurrentIndex(index); - else if (m_currentTargetIndex >= index) + if (m_currentTargetIndex >= index) setCurrentIndex(m_currentTargetIndex + 1); update(); } @@ -59,12 +57,13 @@ void TargetSelector::removeTarget(int index) m_targets.removeAt(index); - if (m_currentTargetIndex >= m_targets.count()) - setCurrentIndex(m_targets.count() - 1); - else if (m_currentTargetIndex >= index) - // force a signal since the target pointed to has changed: + if (m_currentTargetIndex >= m_targets.count()) { + setCurrentIndex(-1); + } else if (m_currentTargetIndex >= index) { + --m_currentTargetIndex; + // force a signal since the index has changed emit currentChanged(m_currentTargetIndex, m_targets.at(m_currentTargetIndex).currentSubIndex); - + } update(); } diff --git a/src/plugins/projectexplorer/targetsettingspanel.cpp b/src/plugins/projectexplorer/targetsettingspanel.cpp index 2887a886cd9..7bcd1b5db20 100644 --- a/src/plugins/projectexplorer/targetsettingspanel.cpp +++ b/src/plugins/projectexplorer/targetsettingspanel.cpp @@ -111,23 +111,25 @@ void TargetSettingsPanelWidget::setupUi() noTargetLayout->addStretch(10); m_centralWidget->addWidget(m_noTargetLabel); - connect(m_selector, SIGNAL(currentChanged(int,int)), - this, SLOT(currentTargetChanged(int,int))); - - // Save active target now as it will change when targets are added: - Target *activeTarget = m_project->activeTarget(); - foreach (Target *t, m_project->targets()) targetAdded(t); + // Now set the correct target + int index = m_targets.indexOf(m_project->activeTarget()); + m_selector->setCurrentIndex(index); + m_selector->setCurrentSubIndex(0); + + currentTargetChanged(index, 0); + + connect(m_selector, SIGNAL(currentChanged(int,int)), + this, SLOT(currentTargetChanged(int,int))); + connect(m_selector, SIGNAL(addButtonClicked()), this, SLOT(addTarget())); connect(m_selector, SIGNAL(removeButtonClicked()), this, SLOT(removeTarget())); updateTargetAddAndRemoveButtons(); - - activeTargetChanged(activeTarget); } void TargetSettingsPanelWidget::currentTargetChanged(int targetIndex, int subIndex) diff --git a/src/plugins/qmldesigner/components/stateseditor/stateseditorview.cpp b/src/plugins/qmldesigner/components/stateseditor/stateseditorview.cpp index ec756d5b2a3..657e696b33c 100644 --- a/src/plugins/qmldesigner/components/stateseditor/stateseditorview.cpp +++ b/src/plugins/qmldesigner/components/stateseditor/stateseditorview.cpp @@ -355,7 +355,11 @@ void StatesEditorView::nodeInstancePropertyChanged(const ModelNode &node, const } + // sets currentState() used in sceneChanged QmlModelView::nodeInstancePropertyChanged(node, propertyName); + + if (!m_settingSilentState) + sceneChanged(); } void StatesEditorView::stateChanged(const QmlModelState &newQmlModelState, const QmlModelState &oldQmlModelState) @@ -479,8 +483,11 @@ void StatesEditorView::sceneChanged() if (debug) qDebug() << __FUNCTION__; - // If we are in base state we have to update the pixmaps of all states - // otherwise only the pixmpap for the current state + // If we are in base state we have to update the pixmaps of all states, + // otherwise only the pixmap for the current state + + // TODO: Since a switch to the base state also results in nodePropertyChanged and + // therefore sceneChanged calls, we're rendering too much here if (currentState().isValid()) { //during setup we might get sceneChanged signals with an invalid currentState() if (currentState().isBaseState()) { diff --git a/src/plugins/qmldesigner/designercore/model/qmlmodelview.cpp b/src/plugins/qmldesigner/designercore/model/qmlmodelview.cpp index ad888c5ae49..0f9edd2c7da 100644 --- a/src/plugins/qmldesigner/designercore/model/qmlmodelview.cpp +++ b/src/plugins/qmldesigner/designercore/model/qmlmodelview.cpp @@ -43,6 +43,7 @@ enum { debug = false }; + namespace QmlDesigner { QmlModelView::QmlModelView(QObject *parent) diff --git a/src/plugins/qmljseditor/qmljscodecompletion.cpp b/src/plugins/qmljseditor/qmljscodecompletion.cpp index 1c5e80fcabd..a58fedc057f 100644 --- a/src/plugins/qmljseditor/qmljscodecompletion.cpp +++ b/src/plugins/qmljseditor/qmljscodecompletion.cpp @@ -79,7 +79,7 @@ enum CompletionRelevance { }; // Temporary workaround until we have proper icons for QML completion items -QIcon iconForColor(const QColor &color) +static QIcon iconForColor(const QColor &color) { QPixmap pix(6, 6); @@ -109,7 +109,7 @@ QIcon iconForColor(const QColor &color) return pix; } -bool checkStartOfIdentifier(const QString &word) +static bool checkStartOfIdentifier(const QString &word) { if (word.isEmpty()) return false; @@ -125,7 +125,7 @@ bool checkStartOfIdentifier(const QString &word) } } -bool isIdentifierChar(QChar ch) +static bool isIdentifierChar(QChar ch) { switch (ch.unicode()) { case '_': case '$': diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp index 3095352c589..29fae962dd2 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp @@ -241,11 +241,7 @@ bool MaemoPackageCreationStep::runCommand(QProcess &proc, const QString &command return false; } proc.write("\n"); // For dh_make - if (!proc.waitForFinished(60000) && proc.error() == QProcess::Timedout) { - raiseError(tr("Packaging failed."), - tr("Packaging Error: Command '%1' timed out.").arg(command)); - return false; - } + proc.waitForFinished(-1); if (proc.error() != QProcess::UnknownError || proc.exitCode() != 0) { QString mainMessage = tr("Packaging Error: Command '%1' failed.") .arg(command); diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemosettingswidget.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemosettingswidget.cpp index e56ef654653..6ef22cf3d4f 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemosettingswidget.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/maemosettingswidget.cpp @@ -357,7 +357,8 @@ void MaemoSettingsWidget::deployKey() } m_ui->deployKeyButton->disconnect(); - const QString command = QLatin1String("test -d .ssh || mkdir .ssh && echo '") + const QString command = QLatin1String("test -d .ssh " + "|| mkdir .ssh && chmod 0700 .ssh && echo '") + key + QLatin1String("' >> .ssh/authorized_keys"); m_keyDeployer = new MaemoSshRunner(currentConfig().server, command); connect(m_keyDeployer, SIGNAL(finished()), diff --git a/src/plugins/qt4projectmanager/qt-maemo/qemuruntimemanager.cpp b/src/plugins/qt4projectmanager/qt-maemo/qemuruntimemanager.cpp index b6bf6e44b46..b8ae2671adb 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/qemuruntimemanager.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/qemuruntimemanager.cpp @@ -379,9 +379,9 @@ void QemuRuntimeManager::startRuntime() m_qemuProcess->setProcessEnvironment(env); m_qemuProcess->setWorkingDirectory(rt.m_root); - const QString app =(QFileInfo(rt.m_bin).isRelative() - ? root % QLatin1String("madlib/") % rt.m_bin // Fremantle. - : rt.m_bin) // Haramattan. + const QString app = root + (QFileInfo(rt.m_bin).isRelative() + ? QLatin1String("madlib/") % rt.m_bin // Fremantle. + : rt.m_bin) // Haramattan. #ifdef Q_OS_WIN % QLatin1String(".exe") #endif @@ -389,6 +389,9 @@ void QemuRuntimeManager::startRuntime() m_qemuProcess->start(app % QLatin1Char(' ') % rt.m_args, QIODevice::ReadWrite); + if (!m_qemuProcess->waitForStarted()) + return; + emit qemuProcessStatus(QemuStarting); connect(m_qemuAction, SIGNAL(triggered()), this, SLOT(terminateRuntime())); disconnect(m_qemuAction, SIGNAL(triggered()), this, SLOT(startRuntime())); diff --git a/src/plugins/qt4projectmanager/qt4nodes.cpp b/src/plugins/qt4projectmanager/qt4nodes.cpp index a04d22189ea..1ea6eff9d84 100644 --- a/src/plugins/qt4projectmanager/qt4nodes.cpp +++ b/src/plugins/qt4projectmanager/qt4nodes.cpp @@ -790,7 +790,7 @@ void Qt4PriFileNode::changeFiles(const FileType fileType, { QFile qfile(m_projectFilePath); if (qfile.open(QIODevice::ReadOnly | QIODevice::Text)) { - contents = QString::fromLatin1(qfile.readAll()); // yes, really latin1 + contents = QString::fromLocal8Bit(qfile.readAll()); qfile.close(); lines = contents.split(QLatin1Char('\n')); while (!lines.isEmpty() && lines.last().isEmpty()) @@ -841,7 +841,7 @@ void Qt4PriFileNode::save(const QStringList &lines) QFile qfile(m_projectFilePath); if (qfile.open(QIODevice::WriteOnly | QIODevice::Text)) { foreach (const QString &str, lines) { - qfile.write(str.toLatin1()); // yes, really latin1 + qfile.write(str.toLocal8Bit()); qfile.write("\n"); } qfile.close(); @@ -1024,15 +1024,10 @@ void Qt4ProFileNode::setupReader() bool Qt4ProFileNode::evaluate() { bool parserError = false; - if (!m_readerExact->readProFile(m_projectFilePath)) { - m_project->proFileParseError(tr("Error while parsing file %1. Giving up.").arg(m_projectFilePath)); + if (!m_readerExact->readProFile(m_projectFilePath)) parserError = true; - } - - if (!m_readerCumulative->readProFile(m_projectFilePath)) { - m_project->proFileParseError(tr("Error while parsing file %1. Giving up.").arg(m_projectFilePath)); + if (!m_readerCumulative->readProFile(m_projectFilePath)) parserError = true; - } return parserError; } @@ -1074,8 +1069,10 @@ void Qt4ProFileNode::applyEvaluate(bool parseResult, bool async) if (m_readerCumulative) m_project->destroyProFileReader(m_readerCumulative); m_readerExact = m_readerCumulative = 0; - if (!parseResult) // Invalidate + if (!parseResult) { + m_project->proFileParseError(tr("Error while parsing file %1. Giving up.").arg(m_projectFilePath)); invalidate(); + } return; } diff --git a/src/plugins/qt4projectmanager/qt4project.cpp b/src/plugins/qt4projectmanager/qt4project.cpp index c09fc97532f..0b123a22d81 100644 --- a/src/plugins/qt4projectmanager/qt4project.cpp +++ b/src/plugins/qt4projectmanager/qt4project.cpp @@ -939,7 +939,8 @@ ProFileReader *Qt4Project::createProFileReader(Qt4ProFileNode *qt4ProFileNode) ProFileReader *reader = new ProFileReader(m_proFileOption); connect(reader, SIGNAL(errorFound(QString)), - this, SLOT(proFileParseError(QString))); + this, SLOT(proFileParseError(QString)), + Qt::QueuedConnection); reader->setOutputDir(qt4ProFileNode->buildDir()); diff --git a/tests/manual/proparser/main.cpp b/tests/manual/proparser/main.cpp index 701786436f8..d26b56f241f 100644 --- a/tests/manual/proparser/main.cpp +++ b/tests/manual/proparser/main.cpp @@ -65,7 +65,7 @@ static int evaluate(const QString &fileName, const QString &in_pwd, const QStrin if (!(pro = visitor.parsedProFile(fileName))) return 2; if (!visitor.accept(pro)) { - delete pro; + pro->deref(); return 2; } @@ -108,7 +108,7 @@ static int evaluate(const QString &fileName, const QString &in_pwd, const QStrin } } - delete pro; + pro->deref(); return 0; } diff --git a/tests/manual/proparser/testreader.pro b/tests/manual/proparser/testreader.pro index 2702b3840c5..6b15b666f5d 100644 --- a/tests/manual/proparser/testreader.pro +++ b/tests/manual/proparser/testreader.pro @@ -1,5 +1,6 @@ VPATH += ../../../src/shared/proparser INCLUDEPATH += ../../../src/shared/proparser +DEPENDPATH += ../../../src/shared/proparser TEMPLATE = app TARGET = testreader