diff options
-rw-r--r-- | src/FbTk/TextBox.cc | 14 | ||||
-rw-r--r-- | src/FbTk/TextBox.hh | 5 |
2 files changed, 10 insertions, 9 deletions
diff --git a/src/FbTk/TextBox.cc b/src/FbTk/TextBox.cc index 838a069..e1f9e32 100644 --- a/src/FbTk/TextBox.cc +++ b/src/FbTk/TextBox.cc | |||
@@ -54,7 +54,7 @@ TextBox::TextBox(int screen_num, | |||
54 | m_cursor_pos(0), | 54 | m_cursor_pos(0), |
55 | m_start_pos(0), | 55 | m_start_pos(0), |
56 | m_end_pos(0), | 56 | m_end_pos(0), |
57 | m_select_pos(-1) { | 57 | m_select_pos(std::string::npos) { |
58 | 58 | ||
59 | FbTk::EventManager::instance()->add(*this, *this); | 59 | FbTk::EventManager::instance()->add(*this, *this); |
60 | } | 60 | } |
@@ -68,7 +68,7 @@ TextBox::TextBox(const FbWindow &parent, | |||
68 | m_cursor_pos(0), | 68 | m_cursor_pos(0), |
69 | m_start_pos(0), | 69 | m_start_pos(0), |
70 | m_end_pos(0), | 70 | m_end_pos(0), |
71 | m_select_pos(-1) { | 71 | m_select_pos(std::string::npos) { |
72 | 72 | ||
73 | FbTk::EventManager::instance()->add(*this, *this); | 73 | FbTk::EventManager::instance()->add(*this, *this); |
74 | } | 74 | } |
@@ -277,7 +277,7 @@ void TextBox::keyPressEvent(XKeyEvent &event) { | |||
277 | if (IsModifierKey(ks)) return; | 277 | if (IsModifierKey(ks)) return; |
278 | 278 | ||
279 | 279 | ||
280 | if (m_select_pos == -1 && (event.state & ShiftMask) == ShiftMask) { | 280 | if (m_select_pos == std::string::npos && (event.state & ShiftMask) == ShiftMask) { |
281 | m_select_pos = m_cursor_pos + m_start_pos; | 281 | m_select_pos = m_cursor_pos + m_start_pos; |
282 | } | 282 | } |
283 | 283 | ||
@@ -407,7 +407,7 @@ void TextBox::keyPressEvent(XKeyEvent &event) { | |||
407 | insertText(val); | 407 | insertText(val); |
408 | } | 408 | } |
409 | if ((event.state & ShiftMask) != ShiftMask) | 409 | if ((event.state & ShiftMask) != ShiftMask) |
410 | m_select_pos = -1; | 410 | m_select_pos = std::string::npos; |
411 | clear(); | 411 | clear(); |
412 | } | 412 | } |
413 | 413 | ||
@@ -432,7 +432,7 @@ void TextBox::adjustStartPos() { | |||
432 | const char* visual = m_text.visual().c_str(); | 432 | const char* visual = m_text.visual().c_str(); |
433 | 433 | ||
434 | int text_width = font().textWidth(visual, m_end_pos); | 434 | int text_width = font().textWidth(visual, m_end_pos); |
435 | if (m_cursor_pos > -1 && text_width < static_cast<signed>(width())) | 435 | if (m_cursor_pos >= 0 && text_width < static_cast<signed>(width())) |
436 | return; | 436 | return; |
437 | 437 | ||
438 | int start_pos = 0; | 438 | int start_pos = 0; |
@@ -459,7 +459,7 @@ unsigned int TextBox::findEmptySpaceLeft(){ | |||
459 | break; | 459 | break; |
460 | pos = next_pos; | 460 | pos = next_pos; |
461 | } | 461 | } |
462 | if (pos < 0) | 462 | if (pos < 0) |
463 | pos = 0; | 463 | pos = 0; |
464 | 464 | ||
465 | return pos; | 465 | return pos; |
@@ -517,7 +517,7 @@ void TextBox::select(std::string::size_type pos, int length) | |||
517 | 517 | ||
518 | adjustPos(); | 518 | adjustPos(); |
519 | } else { | 519 | } else { |
520 | m_select_pos = -1; | 520 | m_select_pos = std::string::npos; |
521 | } | 521 | } |
522 | clear(); | 522 | clear(); |
523 | } | 523 | } |
diff --git a/src/FbTk/TextBox.hh b/src/FbTk/TextBox.hh index 2c1ef9d..a3b857f 100644 --- a/src/FbTk/TextBox.hh +++ b/src/FbTk/TextBox.hh | |||
@@ -39,7 +39,7 @@ public: | |||
39 | void setText(const FbTk::BiDiString &text); | 39 | void setText(const FbTk::BiDiString &text); |
40 | void setFont(const Font &font); | 40 | void setFont(const Font &font); |
41 | void setGC(GC gc); | 41 | void setGC(GC gc); |
42 | void setCursorPosition(int cursor); | 42 | void setCursorPosition(int cursor); |
43 | void setInputFocus(); | 43 | void setInputFocus(); |
44 | void cursorEnd(); | 44 | void cursorEnd(); |
45 | void cursorHome(); | 45 | void cursorHome(); |
@@ -65,7 +65,8 @@ public: | |||
65 | int cursorPosition() const { return m_cursor_pos; } | 65 | int cursorPosition() const { return m_cursor_pos; } |
66 | int textStartPos() const { return m_start_pos; } | 66 | int textStartPos() const { return m_start_pos; } |
67 | 67 | ||
68 | bool hasSelection() const { return m_select_pos != -1 && m_select_pos != m_cursor_pos + m_start_pos; } | 68 | bool hasSelection() const { |
69 | return (m_select_pos != std::string::npos) && (m_select_pos != m_cursor_pos + m_start_pos); } | ||
69 | void select(std::string::size_type pos, int length); | 70 | void select(std::string::size_type pos, int length); |
70 | void selectAll(); | 71 | void selectAll(); |
71 | 72 | ||