mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Fixed indentation bug
This commit is contained in:
parent
cd855d3740
commit
90dd1de91a
@ -641,31 +641,37 @@ _win_print(ProfWin *window, const char show_char, GDateTime *time,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_win_print_wrapped(WINDOW *win, const char * const message)
|
_win_indent(WINDOW *win, int size)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
for (i = 0; i < size; i++) {
|
||||||
|
waddch(win, ' ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_win_print_wrapped(WINDOW *win, const char * const message)
|
||||||
|
{
|
||||||
int linei = 0;
|
int linei = 0;
|
||||||
int wordi = 0;
|
int wordi = 0;
|
||||||
char *word = malloc(strlen(message) + 1);
|
char *word = malloc(strlen(message) + 1);
|
||||||
|
|
||||||
char *time_pref = prefs_get_string(PREF_TIME);
|
char *time_pref = prefs_get_string(PREF_TIME);
|
||||||
int wrap_space = 0;
|
int indent = 0;
|
||||||
if (g_strcmp0(time_pref, "minutes") == 0) {
|
if (g_strcmp0(time_pref, "minutes") == 0) {
|
||||||
wrap_space = 8;
|
indent = 8;
|
||||||
} else if (g_strcmp0(time_pref, "seconds") == 0) {
|
} else if (g_strcmp0(time_pref, "seconds") == 0) {
|
||||||
wrap_space = 11;
|
indent = 11;
|
||||||
}
|
}
|
||||||
free(time_pref);
|
free(time_pref);
|
||||||
|
|
||||||
while (message[linei] != '\0') {
|
while (message[linei] != '\0') {
|
||||||
if (message[linei] == ' ') {
|
if (message[linei] == ' ') {
|
||||||
wprintw(win, " ");
|
waddch(win, ' ');
|
||||||
linei++;
|
linei++;
|
||||||
} else if (message[linei] == '\n') {
|
} else if (message[linei] == '\n') {
|
||||||
waddch(win, '\n');
|
waddch(win, '\n');
|
||||||
for (i = 0; i < wrap_space; i++) {
|
_win_indent(win, indent);
|
||||||
waddch(win, ' ');
|
|
||||||
}
|
|
||||||
linei++;
|
linei++;
|
||||||
} else {
|
} else {
|
||||||
wordi = 0;
|
wordi = 0;
|
||||||
@ -678,28 +684,22 @@ _win_print_wrapped(WINDOW *win, const char * const message)
|
|||||||
int maxx = getmaxx(win);
|
int maxx = getmaxx(win);
|
||||||
|
|
||||||
// word larger than line
|
// word larger than line
|
||||||
if (strlen(word) > (maxx - wrap_space)) {
|
if (strlen(word) > (maxx - indent)) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < wordi; i++) {
|
for (i = 0; i < wordi; i++) {
|
||||||
curx = getcurx(win);
|
curx = getcurx(win);
|
||||||
if (curx < wrap_space) {
|
if (curx < indent) {
|
||||||
for (i = 0; i < wrap_space; i++) {
|
_win_indent(win, indent);
|
||||||
waddch(win, ' ');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
waddch(win, word[i]);
|
waddch(win, word[i]);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (curx + strlen(word) > maxx) {
|
if (curx + strlen(word) > maxx) {
|
||||||
waddch(win, '\n');
|
waddch(win, '\n');
|
||||||
for (i = 0; i < wrap_space; i++) {
|
_win_indent(win, indent);
|
||||||
waddch(win, ' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (curx < wrap_space) {
|
|
||||||
for (i = 0; i < wrap_space; i++) {
|
|
||||||
waddch(win, ' ');
|
|
||||||
}
|
}
|
||||||
|
if (curx < indent) {
|
||||||
|
_win_indent(win, indent);
|
||||||
}
|
}
|
||||||
wprintw(win, "%s", word);
|
wprintw(win, "%s", word);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user