colloring fix
This commit is contained in:
parent
8598010d36
commit
983518170b
|
|
@ -603,14 +603,17 @@ static void refreshMultiLine(struct linenoiseState *l) {
|
||||||
} else {
|
} else {
|
||||||
int colors[] = {31, 32, 33, 35, 36};
|
int colors[] = {31, 32, 33, 35, 36};
|
||||||
int nesting = 0;
|
int nesting = 0;
|
||||||
|
int incode = 1; /* not in literal; TODO add in comment */
|
||||||
for (int i = 0; i < l->len; i++) {
|
for (int i = 0; i < l->len; i++) {
|
||||||
if (l->buf[i]=='(') {
|
if (l->buf[i] == '"' && !(i > 0 && l->buf[i-1] == '\\'))
|
||||||
snprintf(seq,64,"\033[%d;1m(\033[0m",colors[nesting % sizeof(colors)]);
|
incode = (incode == 1 ? 0 : 1);
|
||||||
|
if (incode == 1 && l->buf[i] == '(') {
|
||||||
|
snprintf(seq,64,"\033[%d;1m(\033[0m",colors[nesting % (sizeof(colors)/sizeof(colors[0]))]);
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
nesting++;
|
nesting++;
|
||||||
} else if (l->buf[i]==')') {
|
} else if (incode == 1 && l->buf[i] == ')') {
|
||||||
nesting--;
|
nesting--;
|
||||||
snprintf(seq,64,"\033[%d;1m)\033[0m",colors[nesting % sizeof(colors)]);
|
snprintf(seq,64,"\033[%d;1m)\033[0m",colors[nesting % (sizeof(colors)/sizeof(colors[0]))]);
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
} else {
|
} else {
|
||||||
abAppend(&ab,l->buf+i,1);
|
abAppend(&ab,l->buf+i,1);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue