diff options
| author | megabigbug <megabigbug@arrakis.(none)> | 2010-09-11 13:27:11 +0200 | 
|---|---|---|
| committer | megabigbug <megabigbug@arrakis.(none)> | 2010-09-11 13:27:11 +0200 | 
| commit | 2bb95ad564a8befa09ab6188341b4928166517ed (patch) | |
| tree | 5f2d8af152e5b89e1b250cec4d3de819ce957d91 /src | |
| parent | Merge branch 'iconFixes2' (diff) | |
| download | rekonq-2bb95ad564a8befa09ab6188341b4928166517ed.tar.xz | |
properly handle modifiers+return key when the completion list is displayed
TODO: fix when the completion list is not displayed
Diffstat (limited to 'src')
| -rw-r--r-- | src/urlbar/completionwidget.cpp | 37 | 
1 files changed, 32 insertions, 5 deletions
| diff --git a/src/urlbar/completionwidget.cpp b/src/urlbar/completionwidget.cpp index be189001..f8bf6ee2 100644 --- a/src/urlbar/completionwidget.cpp +++ b/src/urlbar/completionwidget.cpp @@ -273,12 +273,39 @@ bool CompletionWidget::eventFilter(QObject *obj, QEvent *ev)              case Qt::Key_Enter:              case Qt::Key_Return: -                 -                // let urlbar handle Return + Modifiers -                if(!(kev->modifiers() & Qt::NoModifier)) -                    return false; -                                  w = qobject_cast<UrlBar *>(parent()); + +                if (!w->text().startsWith(QL1S("http://"), Qt::CaseInsensitive)) +                { +                    QString append; +                    if (kev->modifiers() == Qt::ControlModifier) +                    { +                        append = QL1S(".com"); +                    } +                    else if (kev->modifiers() == (Qt::ControlModifier | Qt::ShiftModifier)) +                    { +                        append = QL1S(".org"); +                    } +                    else if (kev->modifiers() == Qt::ShiftModifier) +                    { +                        append = QL1S(".net"); +                    } + +                    if (!append.isEmpty()) +                    { +                        QUrl url(QL1S("http://www.") + w->text()); +                        QString host = url.host(); +                        if (!host.endsWith(append, Qt::CaseInsensitive)) +                        { +                            host += append; +                            url.setHost(host); +                        } +                         +                        emit chosenUrl(url, Rekonq::CurrentTab); +                    } +                } + +                                  if( _currentIndex == -1)                      _currentIndex = 0;                  child = findChild<ListItem *>(QString::number(_currentIndex)); | 
