5
0
mirror of git://git.proxmox.com/git/spiceterm.git synced 2025-01-10 01:18:01 +03:00

rename vncterm to spiceterm

This commit is contained in:
Dietmar Maurer 2013-09-11 07:20:40 +02:00
parent 8c22ae7f43
commit d6a5f5a9fc
2 changed files with 92 additions and 92 deletions

View File

@ -76,7 +76,7 @@ static void
print_usage (const char *msg)
{
if (msg) { fprintf (stderr, "ERROR: %s\n", msg); }
fprintf (stderr, "USAGE: vncterm [vncopts] [-c command [args]]\n");
fprintf (stderr, "USAGE: spiceterm [spiceopts] [-c command [args]]\n");
}
/* Convert UCS2 to UTF8 sequence, trailing zero */
@ -106,7 +106,7 @@ ucs2_to_utf8 (unicode c, char *out)
*/
static void
draw_char_at (vncTerm *vt, int x, int y, unicode ch, TextAttributes attrib)
draw_char_at (spiceTerm *vt, int x, int y, unicode ch, TextAttributes attrib)
{
if (x < 0 || y < 0 || x >= vt->width || y >= vt->height) {
return;
@ -116,7 +116,7 @@ draw_char_at (vncTerm *vt, int x, int y, unicode ch, TextAttributes attrib)
}
static void
vncterm_update_xy (vncTerm *vt, int x, int y)
spiceterm_update_xy (spiceTerm *vt, int x, int y)
{
if (x < 0 || y < 0 || x >= vt->width || y >= vt->height) { return; }
@ -132,7 +132,7 @@ vncterm_update_xy (vncTerm *vt, int x, int y)
}
static void
vncterm_clear_xy (vncTerm *vt, int x, int y)
spiceterm_clear_xy (spiceTerm *vt, int x, int y)
{
if (x < 0 || y < 0 || x >= vt->width || y >= vt->height) { return; }
@ -153,7 +153,7 @@ vncterm_clear_xy (vncTerm *vt, int x, int y)
}
static void
vncterm_show_cursor (vncTerm *vt, int show)
spiceterm_show_cursor (spiceTerm *vt, int show)
{
int x = vt->cx;
if (x >= vt->width) {
@ -181,7 +181,7 @@ vncterm_show_cursor (vncTerm *vt, int show)
}
static void
vncterm_refresh (vncTerm *vt)
spiceterm_refresh (spiceTerm *vt)
{
int x, y, y1;
@ -199,11 +199,11 @@ vncterm_refresh (vncTerm *vt)
}
//rfbMarkRectAsModified (vt->screen, 0, 0, vt->maxx, vt->maxy);
vncterm_show_cursor (vt, 1);
spiceterm_show_cursor (vt, 1);
}
static void
vncterm_scroll_down (vncTerm *vt, int top, int bottom, int lines)
spiceterm_scroll_down (spiceTerm *vt, int top, int bottom, int lines)
{
if ((top + lines) >= bottom) {
lines = bottom - top -1;
@ -241,7 +241,7 @@ vncterm_scroll_down (vncTerm *vt, int top, int bottom, int lines)
}
static void
vncterm_scroll_up (vncTerm *vt, int top, int bottom, int lines, int moveattr)
spiceterm_scroll_up (spiceTerm *vt, int top, int bottom, int lines, int moveattr)
{
if ((top + lines) >= bottom) {
lines = bottom - top - 1;
@ -286,7 +286,7 @@ vncterm_scroll_up (vncTerm *vt, int top, int bottom, int lines, int moveattr)
}
static void
vncterm_virtual_scroll (vncTerm *vt, int lines)
spiceterm_virtual_scroll (spiceTerm *vt, int lines)
{
if (vt->altbuf || lines == 0) return;
@ -315,10 +315,10 @@ vncterm_virtual_scroll (vncTerm *vt, int lines)
}
vncterm_refresh (vt);
spiceterm_refresh (vt);
}
static void
vncterm_respond_esc (vncTerm *vt, const char *esc)
spiceterm_respond_esc (spiceTerm *vt, const char *esc)
{
int len = strlen (esc);
int i;
@ -332,17 +332,17 @@ vncterm_respond_esc (vncTerm *vt, const char *esc)
}
static void
vncterm_put_lf (vncTerm *vt)
spiceterm_put_lf (spiceTerm *vt)
{
if (vt->cy + 1 == vt->region_bottom) {
if (vt->altbuf || vt->region_top != 0 || vt->region_bottom != vt->height) {
vncterm_scroll_up (vt, vt->region_top, vt->region_bottom, 1, 1);
spiceterm_scroll_up (vt, vt->region_top, vt->region_bottom, 1, 1);
return;
}
if (vt->y_displ == vt->y_base) {
vncterm_scroll_up (vt, vt->region_top, vt->region_bottom, 1, 0);
spiceterm_scroll_up (vt, vt->region_top, vt->region_bottom, 1, 0);
}
if (vt->y_displ == vt->y_base) {
@ -377,7 +377,7 @@ vncterm_put_lf (vncTerm *vt)
static void
vncterm_csi_m (vncTerm *vt)
spiceterm_csi_m (spiceTerm *vt)
{
int i;
@ -475,7 +475,7 @@ vncterm_csi_m (vncTerm *vt)
}
static void
vncterm_save_cursor (vncTerm *vt)
spiceterm_save_cursor (spiceTerm *vt)
{
vt->cx_saved = vt->cx;
vt->cy_saved = vt->cy;
@ -487,7 +487,7 @@ vncterm_save_cursor (vncTerm *vt)
}
static void
vncterm_restore_cursor (vncTerm *vt)
spiceterm_restore_cursor (spiceTerm *vt)
{
vt->cx = vt->cx_saved;
vt->cy = vt->cy_saved;
@ -499,7 +499,7 @@ vncterm_restore_cursor (vncTerm *vt)
}
static void
vncterm_set_alternate_buffer (vncTerm *vt, int on_off)
spiceterm_set_alternate_buffer (spiceTerm *vt, int on_off)
{
int x, y;
@ -513,7 +513,7 @@ vncterm_set_alternate_buffer (vncTerm *vt, int on_off)
/* alternate buffer & cursor */
vncterm_save_cursor (vt);
spiceterm_save_cursor (vt);
/* save screen to altcels */
for (y = 0; y < vt->height; y++) {
int y1 = (vt->y_base + y) % vt->total_height;
@ -525,7 +525,7 @@ vncterm_set_alternate_buffer (vncTerm *vt, int on_off)
/* clear screen */
for (y = 0; y <= vt->height; y++) {
for (x = 0; x < vt->width; x++) {
vncterm_clear_xy (vt, x, y);
spiceterm_clear_xy (vt, x, y);
}
}
@ -543,14 +543,14 @@ vncterm_set_alternate_buffer (vncTerm *vt, int on_off)
}
}
vncterm_restore_cursor (vt);
spiceterm_restore_cursor (vt);
}
vncterm_refresh (vt);
spiceterm_refresh (vt);
}
static void
vncterm_set_mode (vncTerm *vt, int on_off)
spiceterm_set_mode (spiceTerm *vt, int on_off)
{
int i;
@ -562,7 +562,7 @@ vncterm_set_mode (vncTerm *vt, int on_off)
vt->report_mouse = on_off;
break;
case 1049: /* start/end special app mode (smcup/rmcup) */
vncterm_set_alternate_buffer (vt, on_off);
spiceterm_set_alternate_buffer (vt, on_off);
break;
case 25: /* Cursor on/off */
case 9: /* X10 mouse reporting on/off */
@ -580,7 +580,7 @@ vncterm_set_mode (vncTerm *vt, int on_off)
}
static void
vncterm_gotoxy (vncTerm *vt, int x, int y)
spiceterm_gotoxy (spiceTerm *vt, int x, int y)
{
/* verify all boundaries */
@ -610,7 +610,7 @@ enum { ESnormal, ESesc, ESsquare, ESgetpars, ESgotpars, ESfunckey,
ESpalette, ESidquery, ESosc1, ESosc2};
static void
vncterm_putchar (vncTerm *vt, unicode ch)
spiceterm_putchar (spiceTerm *vt, unicode ch)
{
int x, y, i, c;
@ -633,10 +633,10 @@ vncterm_putchar (vncTerm *vt, unicode ch)
vt->tty_state = ESpercent;
break;
case '7':
vncterm_save_cursor (vt);
spiceterm_save_cursor (vt);
break;
case '8':
vncterm_restore_cursor (vt);
spiceterm_restore_cursor (vt);
break;
case '(':
vt->tty_state = ESsetG0; // SET G0
@ -647,7 +647,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
case 'M':
/* cursor up (ri) */
if (vt->cy == vt->region_top)
vncterm_scroll_down (vt, vt->region_top, vt->region_bottom, 1);
spiceterm_scroll_down (vt, vt->region_top, vt->region_bottom, 1);
else if (vt->cy > 0) {
vt->cy--;
}
@ -798,16 +798,16 @@ vncterm_putchar (vncTerm *vt, unicode ch)
switch (ch) {
case 'h':
vncterm_set_mode (vt, 1);
spiceterm_set_mode (vt, 1);
break;
case 'l':
vncterm_set_mode (vt, 0);
spiceterm_set_mode (vt, 0);
break;
case 'm':
if (!vt->esc_count) {
vt->esc_count++; // default parameter 0
}
vncterm_csi_m (vt);
spiceterm_csi_m (vt);
break;
case 'n':
/* report cursor position */
@ -858,16 +858,16 @@ vncterm_putchar (vncTerm *vt, unicode ch)
case 'G':
case '`':
/* move cursor to column */
vncterm_gotoxy (vt, vt->esc_buf[0] - 1, vt->cy);
spiceterm_gotoxy (vt, vt->esc_buf[0] - 1, vt->cy);
break;
case 'd':
/* move cursor to row */
vncterm_gotoxy (vt, vt->cx , vt->esc_buf[0] - 1);
spiceterm_gotoxy (vt, vt->cx , vt->esc_buf[0] - 1);
break;
case 'f':
case 'H':
/* move cursor to row, column */
vncterm_gotoxy (vt, vt->esc_buf[1] - 1, vt->esc_buf[0] - 1);
spiceterm_gotoxy (vt, vt->esc_buf[1] - 1, vt->esc_buf[0] - 1);
break;
case 'J':
switch (vt->esc_buf[0]) {
@ -878,7 +878,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
if (y == vt->cy && x < vt->cx) {
continue;
}
vncterm_clear_xy (vt, x, y);
spiceterm_clear_xy (vt, x, y);
}
}
break;
@ -889,7 +889,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
if (y == vt->cy && x > vt->cx) {
break;
}
vncterm_clear_xy (vt, x, y);
spiceterm_clear_xy (vt, x, y);
}
}
break;
@ -897,7 +897,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
/* clear entire screen */
for (y = 0; y <= vt->height; y++) {
for (x = 0; x < vt->width; x++) {
vncterm_clear_xy (vt, x, y);
spiceterm_clear_xy (vt, x, y);
}
}
break;
@ -908,19 +908,19 @@ vncterm_putchar (vncTerm *vt, unicode ch)
case 0:
/* clear to eol */
for(x = vt->cx; x < vt->width; x++) {
vncterm_clear_xy (vt, x, vt->cy);
spiceterm_clear_xy (vt, x, vt->cy);
}
break;
case 1:
/* clear from beginning of line */
for (x = 0; x <= vt->cx; x++) {
vncterm_clear_xy (vt, x, vt->cy);
spiceterm_clear_xy (vt, x, vt->cy);
}
break;
case 2:
/* clear entire line */
for(x = 0; x < vt->width; x++) {
vncterm_clear_xy (vt, x, vt->cy);
spiceterm_clear_xy (vt, x, vt->cy);
}
break;
}
@ -934,7 +934,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
else if (!c)
c = 1;
vncterm_scroll_down (vt, vt->cy, vt->region_bottom, c);
spiceterm_scroll_down (vt, vt->cy, vt->region_bottom, c);
break;
case 'M':
/* delete line */
@ -945,19 +945,19 @@ vncterm_putchar (vncTerm *vt, unicode ch)
else if (!c)
c = 1;
vncterm_scroll_up (vt, vt->cy, vt->region_bottom, c, 1);
spiceterm_scroll_up (vt, vt->cy, vt->region_bottom, c, 1);
break;
case 'T':
/* scroll down */
c = vt->esc_buf[0];
if (!c) c = 1;
vncterm_scroll_down (vt, vt->region_top, vt->region_bottom, c);
spiceterm_scroll_down (vt, vt->region_top, vt->region_bottom, c);
break;
case 'S':
/* scroll up */
c = vt->esc_buf[0];
if (!c) c = 1;
vncterm_scroll_up (vt, vt->region_top, vt->region_bottom, c, 1);
spiceterm_scroll_up (vt, vt->region_top, vt->region_bottom, c, 1);
break;
case 'P':
/* delete c character */
@ -973,19 +973,19 @@ vncterm_putchar (vncTerm *vt, unicode ch)
TextCell *dst = &vt->cells[y1 * vt->width + x];
TextCell *src = dst + c;
*dst = *src;
vncterm_update_xy (vt, x + c, vt->cy);
spiceterm_update_xy (vt, x + c, vt->cy);
src->ch = ' ';
src->attrib = vt->default_attrib;
vncterm_update_xy (vt, x, vt->cy);
spiceterm_update_xy (vt, x, vt->cy);
}
break;
case 's':
/* save cursor position */
vncterm_save_cursor (vt);
spiceterm_save_cursor (vt);
break;
case 'u':
/* restore cursor position */
vncterm_restore_cursor (vt);
spiceterm_restore_cursor (vt);
break;
case 'X':
/* erase c characters */
@ -995,7 +995,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
if (c > (vt->width - vt->cx)) c = vt->width - vt->cx;
for(i = 0; i < c; i++) {
vncterm_clear_xy (vt, vt->cx + i, vt->cy);
spiceterm_clear_xy (vt, vt->cx + i, vt->cy);
}
break;
case '@':
@ -1011,10 +1011,10 @@ vncterm_putchar (vncTerm *vt, unicode ch)
TextCell *src = &vt->cells[y1 * vt->width + x];
TextCell *dst = src + c;
*dst = *src;
vncterm_update_xy (vt, x + c, vt->cy);
spiceterm_update_xy (vt, x + c, vt->cy);
src->ch = ' ';
src->attrib = vt->cur_attrib;
vncterm_update_xy (vt, x, vt->cy);
spiceterm_update_xy (vt, x, vt->cy);
}
break;
@ -1095,7 +1095,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
#ifdef DEBUG
fprintf (stderr, "ESC[>c Query term ID\n");
#endif
vncterm_respond_esc (vt, TERMIDCODE);
spiceterm_respond_esc (vt, TERMIDCODE);
}
break;
case ESpercent:
@ -1127,7 +1127,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
case 9: /* tabspace */
if (vt->cx + (8 - (vt->cx % 8)) > vt->width) {
vt->cx = 0;
vncterm_put_lf (vt);
spiceterm_put_lf (vt);
} else {
vt->cx = vt->cx + (8 - (vt->cx % 8));
}
@ -1135,7 +1135,7 @@ vncterm_putchar (vncTerm *vt, unicode ch)
case 10: /* LF,*/
case 11: /* VT */
case 12: /* FF */
vncterm_put_lf (vt);
spiceterm_put_lf (vt);
break;
case 13: /* carriage return */
vt->cx = 0;
@ -1165,14 +1165,14 @@ vncterm_putchar (vncTerm *vt, unicode ch)
if (vt->cx >= vt->width) {
/* line wrap */
vt->cx = 0;
vncterm_put_lf (vt);
spiceterm_put_lf (vt);
}
int y1 = (vt->y_base + vt->cy) % vt->total_height;
TextCell *c = &vt->cells[y1*vt->width + vt->cx];
c->attrib = vt->cur_attrib;
c->ch = ch;
vncterm_update_xy (vt, vt->cx, vt->cy);
spiceterm_update_xy (vt, vt->cx, vt->cy);
vt->cx++;
break;
}
@ -1181,11 +1181,11 @@ vncterm_putchar (vncTerm *vt, unicode ch)
}
static int
vncterm_puts (vncTerm *vt, const char *buf, int len)
spiceterm_puts (spiceTerm *vt, const char *buf, int len)
{
unicode tc;
vncterm_show_cursor (vt, 0);
spiceterm_show_cursor (vt, 0);
while (len) {
unsigned char c = *buf;
@ -1245,19 +1245,19 @@ vncterm_puts (vncTerm *vt, const char *buf, int len)
}
}
vncterm_putchar (vt, tc);
spiceterm_putchar (vt, tc);
}
vncterm_show_cursor (vt, 1);
spiceterm_show_cursor (vt, 1);
return len;
}
/* fixme:
void
vncterm_set_xcut_text (char* str, int len, struct _rfbClientRec* cl)
spiceterm_set_xcut_text (char* str, int len, struct _rfbClientRec* cl)
{
vncTerm *vt =(vncTerm *)cl->screen->screenData;
spiceTerm *vt =(spiceTerm *)cl->screen->screenData;
// seems str is Latin-1 encoded
if (vt->selection) free (vt->selection);
@ -1271,19 +1271,19 @@ vncterm_set_xcut_text (char* str, int len, struct _rfbClientRec* cl)
*/
/*
static void
mouse_report (vncTerm *vt, int butt, int mrx, int mry)
mouse_report (spiceTerm *vt, int butt, int mrx, int mry)
{
char buf[8];
sprintf (buf, "[M%c%c%c", (char)(' ' + butt), (char)('!' + mrx),
(char)('!' + mry));
vncterm_respond_esc (vt, buf);
spiceterm_respond_esc (vt, buf);
}
*/
void
vncterm_toggle_marked_cell (vncTerm *vt, int pos)
spiceterm_toggle_marked_cell (spiceTerm *vt, int pos)
{
/* fixme:
@ -1307,10 +1307,10 @@ vncterm_toggle_marked_cell (vncTerm *vt, int pos)
/* fixme:
void
vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
spiceterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
{
vncTerm *vt =(vncTerm *)cl->screen->screenData;
spiceTerm *vt =(spiceTerm *)cl->screen->screenData;
static int button2_released = 1;
static int last_mask = 0;
static int sel_start_pos = 0;
@ -1355,7 +1355,7 @@ vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
}
if (vt->y_displ != vt->y_base) {
vt->y_displ = vt->y_base;
vncterm_refresh (vt);
spiceterm_refresh (vt);
}
}
button2_released = 0;
@ -1366,13 +1366,13 @@ vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
if (buttonMask & 1) {
int pos = cy*vt->width + cx;
// code borrowed from libvncserver (VNConsole.c)
// code borrowed from libspiceserver (SPICEonsole.c)
if (!vt->mark_active) {
vt->mark_active = 1;
sel_start_pos = sel_end_pos = pos;
vncterm_toggle_marked_cell (vt, pos);
spiceterm_toggle_marked_cell (vt, pos);
} else {
@ -1391,7 +1391,7 @@ vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
}
while (cx <= cy) {
vncterm_toggle_marked_cell (vt, cx);
spiceterm_toggle_marked_cell (vt, cx);
cx++;
}
@ -1429,7 +1429,7 @@ vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
free (sel_latin1);
while (sel_start_pos <= sel_end_pos) {
vncterm_toggle_marked_cell (vt, sel_start_pos++);
spiceterm_toggle_marked_cell (vt, sel_start_pos++);
}
}
@ -1441,7 +1441,7 @@ vncterm_pointer_event (int buttonMask, int x, int y, rfbClientPtr cl)
static void my_kbd_push_key(SpiceKbdInstance *sin, uint8_t frag)
{
// vncTerm *vt = SPICE_CONTAINEROF(sin, vncTerm, keyboard_sin);
// spiceTerm *vt = SPICE_CONTAINEROF(sin, spiceTerm, keyboard_sin);
/* we no not need this */
@ -1450,7 +1450,7 @@ static void my_kbd_push_key(SpiceKbdInstance *sin, uint8_t frag)
static void my_kbd_push_keyval(SpiceKbdInstance *sin, uint32_t keySym, int flags)
{
vncTerm *vt = SPICE_CONTAINEROF(sin, vncTerm, keyboard_sin);
spiceTerm *vt = SPICE_CONTAINEROF(sin, spiceTerm, keyboard_sin);
static int control = 0;
static int shift = 0;
char *esc = NULL;
@ -1512,13 +1512,13 @@ static void my_kbd_push_keyval(SpiceKbdInstance *sin, uint32_t keySym, int flags
esc = "OD";break;
case GDK_KEY_Page_Up:
if (shift) {
vncterm_virtual_scroll (vt, -vt->height/2);
spiceterm_virtual_scroll (vt, -vt->height/2);
goto ret;
}
esc = "[5~";break;
case GDK_KEY_Page_Down:
if (shift) {
vncterm_virtual_scroll (vt, vt->height/2);
spiceterm_virtual_scroll (vt, vt->height/2);
goto ret;
}
esc = "[6~";break;
@ -1560,11 +1560,11 @@ static void my_kbd_push_keyval(SpiceKbdInstance *sin, uint32_t keySym, int flags
if (vt->y_displ != vt->y_base) {
vt->y_displ = vt->y_base;
vncterm_refresh (vt);
spiceterm_refresh (vt);
}
if (esc) {
vncterm_respond_esc(vt, esc);
spiceterm_respond_esc(vt, esc);
} else if (uc > 0) {
if (vt->utf8) {
gchar buf[10];
@ -1615,8 +1615,8 @@ static SpiceKbdInterface my_keyboard_sif = {
.get_leds = my_kbd_get_leds,
};
vncTerm *
create_vncterm (int argc, char** argv, int maxx, int maxy)
spiceTerm *
create_spiceterm (int argc, char** argv, int maxx, int maxy)
{
int i;
@ -1628,7 +1628,7 @@ create_vncterm (int argc, char** argv, int maxx, int maxy)
test_add_display_interface(test);
test_add_agent_interface(test->server);
vncTerm *vt = (vncTerm *)calloc (sizeof(vncTerm), 1);
spiceTerm *vt = (spiceTerm *)calloc (sizeof(spiceTerm), 1);
vt->keyboard_sin.base.sif = &my_keyboard_sif.base;
spice_server_add_interface(test->server, &vt->keyboard_sin.base);
@ -1645,13 +1645,13 @@ create_vncterm (int argc, char** argv, int maxx, int maxy)
cmap->is16 = FALSE;
screen->serverFormat.trueColour = FALSE;
screen->kbdAddEvent = vncterm_kbd_event;
screen->kbdAddEvent = spiceterm_kbd_event;
screen->setXCutText = vncterm_set_xcut_text;
screen->setXCutText = spiceterm_set_xcut_text;
screen->ptrAddEvent = vncterm_pointer_event;
screen->ptrAddEvent = spiceterm_pointer_event;
screen->desktopName = "VNC Command Terminal";
screen->desktopName = "SPICE Command Terminal";
screen->newClientHook = new_client;
@ -1703,7 +1703,7 @@ create_vncterm (int argc, char** argv, int maxx, int maxy)
static void master_watch(int master, int event, void *opaque)
{
vncTerm *vt = (vncTerm *)opaque;
spiceTerm *vt = (spiceTerm *)opaque;
printf("CHANNEL EVENT %d\n", event);
@ -1718,7 +1718,7 @@ static void master_watch(int master, int event, void *opaque)
if (c == -1) {
g_error("got read error"); // fixme
}
vncterm_puts (vt, buffer, c);
spiceterm_puts (vt, buffer, c);
} else {
if (vt->ibuf_count > 0) {
printf ("DEBUG: WRITE %x %d\n", vt->ibuf[0], vt->ibuf_count);
@ -1754,7 +1754,7 @@ main (int argc, char** argv)
if (0) print_usage(NULL); // fixme:
vncTerm *vt = create_vncterm (argc, argv, 745, 400);
spiceTerm *vt = create_spiceterm (argc, argv, 745, 400);
setlocale(LC_ALL, ""); // set from environment

View File

@ -10,7 +10,7 @@ typedef struct TextCell {
TextAttributes attrib;
} TextCell;
typedef struct vncTerm {
typedef struct spiceTerm {
int maxx;
int maxy;
@ -73,7 +73,7 @@ typedef struct vncTerm {
unsigned int report_mouse:1;
} vncTerm;
} spiceTerm;
/* Unicode translations copied from kernel source consolemap.c */