/* $NetBSD: ttyscrn.cc,v 1.5 2012/10/06 19:39:51 christos Exp $ */ /*- * Copyright (c) 2003 The NetBSD Foundation, Inc. * All rights reserved. * * This code is derived from software contributed to The NetBSD Foundation * by Christos Zoulas. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ /* * ttyscrn.C: Curses screen implementation for dots */ #include "defs.h" RCSID("$NetBSD: ttyscrn.cc,v 1.5 2012/10/06 19:39:51 christos Exp $") #include <stdio.h> #include <curses.h> #include <sys/ioctl.h> #include "player.h" #include "ttyscrn.h" void TTYSCRN::clean(void) { clear(); } void TTYSCRN::moveto(size_t y, size_t x) { move(y + TTYSCRN::offsy, x + TTYSCRN::offsx); } void TTYSCRN::addsym(const int sym) { addch(sym); } void TTYSCRN::addedge(const int sym) { int nsym; #ifdef A_ALTCHARSET if (_acs) { switch (sym) { case GS_HLINE: nsym = ACS_HLINE; break; case GS_VLINE: nsym = ACS_VLINE; break; case GS_ULCORNER: nsym = ACS_ULCORNER; break; case GS_URCORNER: nsym = ACS_URCORNER; break; case GS_LLCORNER: nsym = ACS_LLCORNER; break; case GS_LRCORNER: nsym = ACS_LRCORNER; break; case GS_LTEE: nsym = ACS_LTEE; break; case GS_RTEE: nsym = ACS_RTEE; break; case GS_TTEE: nsym = ACS_TTEE; break; case GS_BTEE: nsym = ACS_BTEE; break; case GS_PLUS: nsym = ACS_PLUS; break; case ' ': addsym(' '); return; default: ::abort(); } attron(A_ALTCHARSET); addch(nsym); attroff(A_ALTCHARSET); return; } #endif switch (sym) { case GS_HLINE: nsym = '-'; break; case GS_VLINE: nsym = '|'; break; case GS_ULCORNER: nsym = '.'; break; case GS_URCORNER: nsym = '.'; break; case GS_LLCORNER: nsym = '.'; break; case GS_LRCORNER: nsym = '.'; break; case GS_LTEE: nsym = '.'; break; case GS_RTEE: nsym = '.'; break; case GS_TTEE: nsym = '.'; break; case GS_BTEE: nsym = '.'; break; case GS_PLUS: nsym = '+'; break; case ' ': addsym(' '); return; default: ::abort(); } addsym(nsym); } void TTYSCRN::redraw(void) { refresh(); doupdate(); } void TTYSCRN::bell(void) { putc('\007', stdout); } int TTYSCRN::getinput(void) { return getch(); } void TTYSCRN::score(size_t s, const PLAYER& p) { mvwprintw(stdscr, _sy + s + TTYSCRN::offsscore, _sx, "S %c:%5zd", p.getWho(), p.getScore()); } void TTYSCRN::total(size_t s, const PLAYER& p) { mvwprintw(stdscr, _sy + s + TTYSCRN::offstotal, _sx, "T %c:%5zd", p.getWho(), p.getTotal()); } void TTYSCRN::games(size_t s, const PLAYER& p) { mvwprintw(stdscr, _sy + s + TTYSCRN::offsgames, _sx, "G %c:%5zd", p.getWho(), p.getGames()); } void TTYSCRN::ties(const PLAYER& p) { mvwprintw(stdscr, _sy + TTYSCRN::offsties, _sx, "G =:%5zd", p.getTies()); } TTYSCRN* TTYSCRN::create(int acs, size_t *y, size_t *x) { int tx, ty; initscr(); tx = getmaxx(stdscr); ty = getmaxy(stdscr); if (tx == ERR || ty == ERR || static_cast<size_t>(tx) < *x * 2 + TTYSCRN::offsx + 14 || static_cast<size_t>(ty) < *y * 2 + TTYSCRN::offsy) { endwin(); return NULL; } if (*x == 0) *x = (tx - 14 - TTYSCRN::offsx) / 2; if (*y == 0) *y = (ty - TTYSCRN::offsy) / 2; cbreak(); noecho(); TTYSCRN* that = new TTYSCRN; that->_tx = tx; that->_ty = ty; that->_sx = tx - 12; that->_sy = TTYSCRN::offsy; that->_acs = acs; return that; } TTYSCRN::~TTYSCRN(void) { nocbreak(); echo(); endwin(); }