mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Handle larger than line words in wrapping
This commit is contained in:
parent
8ec931eb84
commit
41c93c3350
@ -1085,6 +1085,7 @@ _win_print_wrapped(WINDOW *win, const char * const message, size_t indent, int p
|
||||
// handle word
|
||||
} else {
|
||||
wordi = 0;
|
||||
int wordlen = 0;
|
||||
while (*curr_ch != ' ' && *curr_ch != '\n' && *curr_ch != '\0') {
|
||||
size_t ch_len = mbrlen(curr_ch, 4, NULL);
|
||||
int offset = 0;
|
||||
@ -1094,21 +1095,23 @@ _win_print_wrapped(WINDOW *win, const char * const message, size_t indent, int p
|
||||
curr_ch = g_utf8_next_char(curr_ch);
|
||||
}
|
||||
word[wordi] = '\0';
|
||||
wordlen = utf8_display_len(word);
|
||||
|
||||
int curx = getcurx(win);
|
||||
int cury = getcury(win);
|
||||
int maxx = getmaxx(win);
|
||||
gboolean firstline = (cury == starty);
|
||||
|
||||
// wrap required
|
||||
if (curx + wordlen > maxx) {
|
||||
int linelen = maxx - (indent + pad_indent);
|
||||
|
||||
// word larger than line
|
||||
if ((firstline && (utf8_display_len(word) > (maxx - indent))) ||
|
||||
(!firstline && (utf8_display_len(word) > (maxx - (indent + pad_indent))))) {
|
||||
|
||||
if (wordlen > linelen) {
|
||||
gchar *word_ch = g_utf8_offset_to_pointer(word, 0);
|
||||
while(*word_ch != '\0') {
|
||||
curx = getcurx(win);
|
||||
cury = getcury(win);
|
||||
firstline = cury == starty;
|
||||
gboolean firstline = cury == starty;
|
||||
|
||||
if (firstline && curx < indent) {
|
||||
_win_indent(win, indent);
|
||||
@ -1117,29 +1120,42 @@ _win_print_wrapped(WINDOW *win, const char * const message, size_t indent, int p
|
||||
_win_indent(win, indent + pad_indent);
|
||||
}
|
||||
|
||||
gchar copy[wordi++];
|
||||
gchar copy[wordi+1];
|
||||
g_utf8_strncpy(copy, word_ch, 1);
|
||||
|
||||
if (curx + utf8_display_len(copy) > maxx) {
|
||||
waddch(win, '\n');
|
||||
_win_indent(win, indent + pad_indent);
|
||||
}
|
||||
waddstr(win, copy);
|
||||
|
||||
word_ch = g_utf8_next_char(word_ch);
|
||||
}
|
||||
|
||||
// newline and print word
|
||||
} else {
|
||||
if (curx + utf8_display_len(word) > maxx) {
|
||||
waddch(win, '\n');
|
||||
_win_indent(win, indent + pad_indent);
|
||||
}
|
||||
curx = getcurx(win);
|
||||
cury = getcury(win);
|
||||
gboolean firstline = cury == starty;
|
||||
|
||||
if (firstline && curx < indent) {
|
||||
_win_indent(win, indent);
|
||||
}
|
||||
if (!firstline && curx < (indent + pad_indent)) {
|
||||
_win_indent(win, indent + pad_indent);
|
||||
}
|
||||
wprintw(win, "%s", word);
|
||||
waddstr(win, word);
|
||||
}
|
||||
|
||||
// no wrap required
|
||||
} else {
|
||||
curx = getcurx(win);
|
||||
cury = getcury(win);
|
||||
gboolean firstline = cury == starty;
|
||||
|
||||
if (firstline && curx < indent) {
|
||||
_win_indent(win, indent);
|
||||
}
|
||||
if (!firstline && curx < (indent + pad_indent)) {
|
||||
_win_indent(win, indent + pad_indent);
|
||||
}
|
||||
waddstr(win, word);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user