OpenTTD
|
Helper/buffer for input fields. More...
#include <textbuf_type.h>
Public Member Functions | |
Textbuf (uint16 max_bytes, uint16 max_chars=UINT16_MAX) | |
Initialize the textbuffer by supplying it the buffer to write into and the maximum length of this buffer. | |
void | Assign (StringID string) |
Render a string into the textbuffer. | |
void | Assign (const char *text) |
Copy a string into the textbuffer. | |
void CDECL | Print (const char *format,...) WARN_FORMAT(2 |
Print a formatted string into the textbuffer. | |
void CDECL void | DeleteAll () |
Delete every character in the textbuffer. | |
bool | InsertClipboard () |
Insert a chunk of text from the clipboard onto the textbuffer. | |
bool | InsertChar (uint32 key) |
Insert a character to a textbuffer. | |
bool | InsertString (const char *str, bool marked, const char *caret=NULL, const char *insert_location=NULL, const char *replacement_end=NULL) |
Insert a string into the text buffer. | |
bool | DeleteChar (uint16 keycode) |
Delete a character from a textbuffer, either with 'Delete' or 'Backspace' The character is delete from the position the caret is at. | |
bool | MovePos (uint16 keycode) |
Handle text navigation with arrow keys left/right. | |
HandleKeyPressResult | HandleKeyPress (WChar key, uint16 keycode) |
bool | HandleCaret () |
Handle the flashing of the caret. | |
void | UpdateSize () |
Update Textbuf type with its actual physical character and screenlength Get the count of characters in the string as well as the width in pixels. | |
void | DiscardMarkedText (bool update=true) |
Discard any marked text. |
Data Fields | |
CharSetFilter | afilter |
Allowed characters. | |
char *const | buf |
buffer in which text is saved | |
uint16 | max_bytes |
the maximum size of the buffer in bytes (including terminating '\0') | |
uint16 | max_chars |
the maximum size of the buffer in characters (including terminating '\0') | |
uint16 | bytes |
the current size of the string in bytes (including terminating '\0') | |
uint16 | chars |
the current size of the string in characters (including terminating '\0') | |
uint16 | pixels |
the current size of the string in pixels | |
bool | caret |
is the caret ("_") visible or not | |
uint16 | caretpos |
the current position of the caret in the buffer, in bytes | |
uint16 | caretxoffs |
the current position of the caret in pixels | |
uint16 | markpos |
the start position of the marked area in the buffer, in bytes | |
uint16 | markend |
the end position of the marked area in the buffer, in bytes | |
uint16 | markxoffs |
the start position of the marked area in pixels | |
uint16 | marklength |
the length of the marked area in pixels |
Private Member Functions | |
bool | CanDelChar (bool backspace) |
Checks if it is possible to delete a character. | |
void | DeleteText (uint16 from, uint16 to, bool update) |
Delete a part of the text. | |
void | UpdateStringIter () |
Update the character iter after the text has changed. | |
void | UpdateWidth () |
Update pixel width of the text. | |
void | UpdateCaretPosition () |
Update pixel position of the caret. | |
void | UpdateMarkedText () |
Update pixel positions of the marked text area. |
Private Attributes | |
StringIterator * | char_iter |
Helper/buffer for input fields.
Definition at line 32 of file textbuf_type.h.
|
explicit |
Initialize the textbuffer by supplying it the buffer to write into and the maximum length of this buffer.
buf | the buffer that will be holding the data for input |
max_bytes | maximum size in bytes, including terminating '\0' |
max_chars | maximum size in chars, including terminating '\0' |
Definition at line 374 of file textbuf.cpp.
References afilter, caret, StringIterator::Create(), CS_ALPHANUMERAL, DeleteAll(), max_bytes, and max_chars.
void Textbuf::Assign | ( | StringID | string | ) |
Render a string into the textbuffer.
string | String |
Definition at line 399 of file textbuf.cpp.
References buf, max_bytes, and UpdateSize().
Referenced by AIDebugWindow::AIDebugWindow(), NetworkChatWindow::ChatTabCompletion(), IConsoleHistoryNavigate(), OskWindow::OnClick(), and SaveLoadWindow::OnClick().
void Textbuf::Assign | ( | const char * | text | ) |
Copy a string into the textbuffer.
text | Source. |
Definition at line 409 of file textbuf.cpp.
References buf, max_bytes, strecpy(), and UpdateSize().
|
private |
Checks if it is possible to delete a character.
backspace | if set, delete the character before the caret, otherwise, delete the character after it. |
Definition at line 44 of file textbuf.cpp.
References bytes, and caretpos.
Referenced by DeleteChar().
bool Textbuf::DeleteChar | ( | uint16 | keycode | ) |
Delete a character from a textbuffer, either with 'Delete' or 'Backspace' The character is delete from the position the caret is at.
keycode | Type of deletion, either WKC_BACKSPACE or WKC_DELETE |
Definition at line 55 of file textbuf.cpp.
References buf, bytes, CanDelChar(), caretpos, chars, StringIterator::ITER_CHARACTER, StringIterator::ITER_WORD, StringIterator::Next(), StringIterator::Prev(), UpdateCaretPosition(), UpdateMarkedText(), UpdateStringIter(), UpdateWidth(), Utf8Decode(), and Utf8PrevChar().
Referenced by OskWindow::OnClick().
|
private |
Delete a part of the text.
from | Start of the text to delete. |
to | End of the text to delete. |
update | Set to true if the internal state should be updated. |
Definition at line 242 of file textbuf.cpp.
References buf, bytes, caretpos, chars, UpdateCaretPosition(), UpdateMarkedText(), and UpdateStringIter().
Referenced by DiscardMarkedText(), and InsertString().
void Textbuf::DiscardMarkedText | ( | bool | update = true | ) |
Discard any marked text.
update | Set to true if the internal state should be updated. |
Definition at line 276 of file textbuf.cpp.
References DeleteText(), markend, marklength, markpos, and markxoffs.
Referenced by InsertString().
bool Textbuf::HandleCaret | ( | ) |
Handle the flashing of the caret.
Definition at line 459 of file textbuf.cpp.
References caret.
Referenced by IConsoleWindow::OnMouseLoop().
bool Textbuf::InsertChar | ( | uint32 | key | ) |
Insert a character to a textbuffer.
If maxwidth of the Textbuf is zero, we don't care about the visual-length but only about the physical length of the string
key | Character to be inserted |
Definition at line 134 of file textbuf.cpp.
References buf, bytes, caretpos, chars, max_bytes, max_chars, UpdateCaretPosition(), UpdateMarkedText(), UpdateStringIter(), UpdateWidth(), Utf8CharLen(), and Utf8Encode().
Referenced by OskWindow::OnClick().
bool Textbuf::InsertClipboard | ( | ) |
Insert a chunk of text from the clipboard onto the textbuffer.
Get TEXT clipboard and append this up to the maximum length (either absolute or screenlength). If maxlength is zero, we don't care about the screenlength but only about the physical length of the string
Definition at line 227 of file textbuf.cpp.
References GetClipboardContents(), InsertString(), and lastof.
bool Textbuf::InsertString | ( | const char * | str, |
bool | marked, | ||
const char * | caret = NULL , |
||
const char * | insert_location = NULL , |
||
const char * | replacement_end = NULL |
||
) |
Insert a string into the text buffer.
If maxwidth of the Textbuf is zero, we don't care about the visual-length but only about the physical length of the string.
str | String to insert. |
marked | Replace the currently marked text with the new text. |
caret | Move the caret to this point in the insertion string. |
insert_location | Position at which to insert the string. |
replacement_end | Replace all characters from #insert_location up to this location with the new string. |
Definition at line 164 of file textbuf.cpp.
References afilter, buf, bytes, caretpos, chars, DeleteText(), DiscardMarkedText(), IsValidChar(), markend, marklength, markpos, max_bytes, max_chars, UpdateCaretPosition(), UpdateMarkedText(), UpdateStringIter(), UpdateWidth(), and Utf8CharLen().
Referenced by InsertClipboard(), IConsoleWindow::InsertTextString(), and Window::InsertTextString().
bool Textbuf::MovePos | ( | uint16 | keycode | ) |
Handle text navigation with arrow keys left/right.
This defines where the caret will blink and the next character interaction will occur
keycode | Direction in which navigation occurs (WKC_CTRL |) WKC_LEFT, (WKC_CTRL |) WKC_RIGHT, WKC_END, WKC_HOME |
Definition at line 321 of file textbuf.cpp.
References bytes, caretpos, StringIterator::END, StringIterator::ITER_CHARACTER, StringIterator::ITER_WORD, StringIterator::Next(), StringIterator::Prev(), StringIterator::SetCurPosition(), and UpdateCaretPosition().
Referenced by OskWindow::OnClick().
|
private |
Update pixel position of the caret.
Definition at line 299 of file textbuf.cpp.
References buf, caretpos, caretxoffs, chars, FS_NORMAL, and GetCharPosInString().
Referenced by DeleteChar(), DeleteText(), InsertChar(), InsertString(), MovePos(), and UpdateSize().
|
private |
Update pixel positions of the marked text area.
Definition at line 305 of file textbuf.cpp.
References buf, FS_NORMAL, GetCharPosInString(), markend, marklength, markpos, and markxoffs.
Referenced by DeleteChar(), DeleteText(), InsertChar(), InsertString(), and UpdateSize().
void Textbuf::UpdateSize | ( | ) |
Update Textbuf type with its actual physical character and screenlength Get the count of characters in the string as well as the width in pixels.
Useful when copying in a larger amount of text at once
Definition at line 433 of file textbuf.cpp.
References buf, bytes, caretpos, chars, max_bytes, max_chars, UpdateCaretPosition(), UpdateMarkedText(), UpdateStringIter(), UpdateWidth(), and Utf8CharLen().
Referenced by Assign(), SaveLoadWindow::GenerateFileName(), and Print().
|
private |
Update the character iter after the text has changed.
Definition at line 285 of file textbuf.cpp.
References buf, caretpos, StringIterator::END, StringIterator::SetCurPosition(), and StringIterator::SetString().
Referenced by DeleteAll(), DeleteChar(), DeleteText(), InsertChar(), InsertString(), and UpdateSize().
|
private |
Update pixel width of the text.
Definition at line 293 of file textbuf.cpp.
References buf, FS_NORMAL, GetStringBoundingBox(), and pixels.
Referenced by DeleteChar(), InsertChar(), InsertString(), and UpdateSize().