projects
/
quassel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge pull request #151 from Tucos/ws-hist
[quassel.git]
/
src
/
uisupport
/
multilineedit.cpp
diff --git
a/src/uisupport/multilineedit.cpp
b/src/uisupport/multilineedit.cpp
index
0651abf
..
37f1f62
100644
(file)
--- a/
src/uisupport/multilineedit.cpp
+++ b/
src/uisupport/multilineedit.cpp
@@
-41,6
+41,7
@@
MultiLineEdit::MultiLineEdit(QWidget *parent)
_scrollBarsEnabled(true),
_pasteProtectionEnabled(true),
_emacsMode(false),
_scrollBarsEnabled(true),
_pasteProtectionEnabled(true),
_emacsMode(false),
+ _completionSpace(0),
_lastDocumentHeight(-1)
{
document()->setDocumentMargin(0);
_lastDocumentHeight(-1)
{
document()->setDocumentMargin(0);
@@
-670,8
+671,12
@@
void MultiLineEdit::on_returnPressed()
}
}
-void MultiLineEdit::on_returnPressed(
const QString &
text)
+void MultiLineEdit::on_returnPressed(
QString
text)
{
{
+ if (_completionSpace && text.endsWith(" ")) {
+ text.chop(1);
+ }
+
if (!text.isEmpty()) {
foreach(const QString &line, text.split('\n', QString::SkipEmptyParts)) {
if (line.isEmpty())
if (!text.isEmpty()) {
foreach(const QString &line, text.split('\n', QString::SkipEmptyParts)) {
if (line.isEmpty())
@@
-690,6
+695,8
@@
void MultiLineEdit::on_returnPressed(const QString &text)
void MultiLineEdit::on_textChanged()
{
void MultiLineEdit::on_textChanged()
{
+ _completionSpace = qMax(_completionSpace - 1, 0);
+
QString newText = text();
newText.replace("\r\n", "\n");
newText.replace('\r', '\n');
QString newText = text();
newText.replace("\r\n", "\n");
newText.replace('\r', '\n');
@@
-772,3
+779,12
@@
void MultiLineEdit::showHistoryEntry()
setTextCursor(cursor);
updateScrollBars();
}
setTextCursor(cursor);
updateScrollBars();
}
+
+
+void MultiLineEdit::addCompletionSpace()
+{
+ // Inserting the space emits textChanged, which should not disable removal
+ _completionSpace = 2;
+ insertPlainText(" ");
+}
+