Using normal magic-chars on LiNUX platform.

This commit is contained in:
ainmarh 2001-03-09 08:30:37 +00:00
parent bcee4e834b
commit c02dcab88d
3 changed files with 41 additions and 0 deletions

View File

@ -37,7 +37,11 @@
#include <gcurses.h> #include <gcurses.h>
#else #else
#define ACS_BOARD '°' #define ACS_BOARD '°'
#ifndef __linux__
#define ACS_BLOCK 'Û' #define ACS_BLOCK 'Û'
#else
#define ACS_BLOCK ' '
#endif
#endif #endif
#if defined(__WIN32__) #if defined(__WIN32__)
#include <windows.h> #include <windows.h>

View File

@ -404,14 +404,23 @@ int GVid::detectadapter() {
#elif defined(__UNIX__) #elif defined(__UNIX__)
const char* term = getenv("TERM"); const char* term = getenv("TERM");
#ifndef __linux__
if(term and strneql(term, "xterm", 5)) { if(term and strneql(term, "xterm", 5)) {
#endif
gvid_xterm = true; gvid_xterm = true;
for(int n=0; n<8; n++) for(int n=0; n<8; n++)
__box_table[n] = __box_table[8]; __box_table[n] = __box_table[8];
#ifndef __linux__
} }
#endif
#ifndef __linux__
gvid_acs_enable = gvid_xterm ? "\033)0\033(B\016" : "\033[11m"; gvid_acs_enable = gvid_xterm ? "\033)0\033(B\016" : "\033[11m";
gvid_acs_disable = gvid_xterm ? "\033(B\033)B\017" : "\033[10m"; gvid_acs_disable = gvid_xterm ? "\033(B\033)B\017" : "\033[10m";
#else
gvid_acs_enable = gvid_xterm ? "\016" : "";
gvid_acs_disable = gvid_xterm ? "\017" : "";
#endif
gvid_stdout = fileno(stdout); gvid_stdout = fileno(stdout);

View File

@ -309,10 +309,18 @@ int wshadow(int attr) {
// read current screen characters/attributes and save in shadow's buffer // read current screen characters/attributes and save in shadow's buffer
vatch tmp[2]; vatch tmp[2];
*q = vgetw(crow, ccol); *q = vgetw(crow, ccol);
#ifndef __linux__
tmp[0] = vsattr(*q, attr); tmp[0] = vsattr(*q, attr);
#else
tmp[0] = vsattr(' ', attr);
#endif
q++; q++;
*q = vgetw(crow, ccol + 1); *q = vgetw(crow, ccol + 1);
#ifndef __linux__
tmp[1] = vsattr(*q, attr); tmp[1] = vsattr(*q, attr);
#else
tmp[1] = vsattr(' ', attr);
#endif
q++; q++;
// write characters back to screen using shadow's attribute // write characters back to screen using shadow's attribute
@ -331,7 +339,11 @@ int wshadow(int attr) {
// read attribs/chars and store in buffers // read attribs/chars and store in buffers
*q = vgetw(crow, ccol++); *q = vgetw(crow, ccol++);
#ifndef __linux__
*wptr++ = vsattr(*q, attr); *wptr++ = vsattr(*q, attr);
#else
*wptr++ = vsattr(' ', attr);
#endif
q++; q++;
} }
@ -1879,8 +1891,13 @@ void wpropbar(int mode, int xx, int yy, long len, long barlen, int attr, long po
// pos = present position. // pos = present position.
// size = total size of field. // size = total size of field.
#ifndef __linux__
const vchar _fld = ACS_BOARD; const vchar _fld = ACS_BOARD;
const vchar _bar = ACS_BLOCK; const vchar _bar = ACS_BLOCK;
#else
const vchar _fld = ' ';
const vchar _bar = _box_table(gwin.active->btype, 13);
#endif
const vchar _up = '\x18'; const vchar _up = '\x18';
const vchar _dwn = '\x19'; const vchar _dwn = '\x19';
@ -2035,6 +2052,9 @@ void wscrollbar(int orientation, uint total, uint maxpos, uint pos, int sadd) {
const vchar arrowrightchar = '\x1A'; const vchar arrowrightchar = '\x1A';
int attr = (gwin.active->sbattr == -1) ? gwin.active->battr : gwin.active->sbattr; int attr = (gwin.active->sbattr == -1) ? gwin.active->battr : gwin.active->sbattr;
#ifdef __linux__
int thumbattr = revsattr(attr);
#endif
int srow, scol; int srow, scol;
uint visiblelen, barlen; uint visiblelen, barlen;
@ -2077,7 +2097,11 @@ void wscrollbar(int orientation, uint total, uint maxpos, uint pos, int sadd) {
while(row < erow1) while(row < erow1)
vputc(row++, scol, attr|ACSET, barchar); vputc(row++, scol, attr|ACSET, barchar);
while(row < erow2) while(row < erow2)
#ifdef __linux__
vputc(row++, scol, thumbattr|ACSET, thumbchar);
#else
vputc(row++, scol, attr|ACSET, thumbchar); vputc(row++, scol, attr|ACSET, thumbchar);
#endif
while(row < erow3) while(row < erow3)
vputc(row++, scol, attr|ACSET, barchar); vputc(row++, scol, attr|ACSET, barchar);
vputc(row, scol, revsattr(attr), arrowdownchar); vputc(row, scol, revsattr(attr), arrowdownchar);
@ -2091,7 +2115,11 @@ void wscrollbar(int orientation, uint total, uint maxpos, uint pos, int sadd) {
while(col < ecol1) while(col < ecol1)
vputc(srow, col++, attr|ACSET, barchar); vputc(srow, col++, attr|ACSET, barchar);
while(col < ecol2) while(col < ecol2)
#ifdef __linux__
vputc(srow, col++, thumbattr|ACSET, thumbchar);
#else
vputc(srow, col++, attr|ACSET, thumbchar); vputc(srow, col++, attr|ACSET, thumbchar);
#endif
while(col < ecol3) while(col < ecol3)
vputc(srow, col++, attr|ACSET, barchar); vputc(srow, col++, attr|ACSET, barchar);
vputc(srow, col, revsattr(attr), arrowrightchar); vputc(srow, col, revsattr(attr), arrowrightchar);