Mercurial > freewnn
view Xwnmo/xwnmo/box.c @ 5:338478efe78d
some cleanups
author | Yoshiki Yazawa <yaz@cc.rim.or.jp> |
---|---|
date | Thu, 13 Dec 2007 22:24:18 +0900 |
parents | bbc77ca4def5 |
children |
line wrap: on
line source
/* * $Id: box.c,v 1.2 2001/06/14 18:16:14 ura Exp $ */ /* * FreeWnn is a network-extensible Kana-to-Kanji conversion system. * This file is part of FreeWnn. * * Copyright OMRON Corporation. 1987, 1988, 1989, 1990, 1991, 1992, 1999 * Copyright 1991, 1992 by Massachusetts Institute of Technology * * Author: OMRON SOFTWARE Co., Ltd. <freewnn@rd.kyoto.omronsoft.co.jp> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with GNU Emacs; see the file COPYING. If not, write to the * Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * Commentary: * * Change log: * * Last modified date: 8,Feb.1999 * * Code: * */ /* Version 4.0 */ #include <stdio.h> #include "commonhd.h" #include "sdefine.h" #ifdef XJUTIL #include "xjutil.h" #include "sxheader.h" #include "xext.h" #else /* XJUTIL */ #include "xim.h" #include "sheader.h" #include "ext.h" #endif /* XJUTIL */ BoxRec * create_box (parent, x, y, width, height, bw, fg, bg, bp, cursor, rev) Window parent; int x, y; int width, height; int bw; unsigned long fg, bg, bp; Cursor cursor; char rev; { register BoxRec *box; XGCValues xgcv; if ((box = (BoxRec *) Malloc (sizeof (BoxRec))) == NULL) { malloc_error ("allocation of box struct"); return (NULL); } box->x = x; box->y = y; box->width = width; box->height = height; box->border_width = bw; box->fg = fg; box->bg = bg; box->bp = bp; box->redraw_cb = NULL; box->redraw_cb_data = NULL; box->cb = NULL; box->cb_data = NULL; box->do_ret = False; box->sel_ret = -1; box->reverse = rev; box->in = box->map = '\0'; box->freeze = '\0'; box->next = NULL; box->window = XCreateSimpleWindow (dpy, parent, (x - bw), (y - bw), width, height, bw, bp, bg); xgcv.foreground = fg; xgcv.function = GXinvert; xgcv.plane_mask = XOR (fg, bg); box->invertgc = XCreateGC (dpy, box->window, (GCForeground | GCFunction | GCPlaneMask), &xgcv); if (!box->window || !box->invertgc) { print_out ("Could not create X resources for box."); Free ((char *) box); return (NULL); } if (cursor) XDefineCursor (dpy, box->window, cursor); if (rev) { XSelectInput (dpy, box->window, (ButtonPressMask | ButtonReleaseMask | EnterWindowMask | LeaveWindowMask | ExposureMask)); } else { XSelectInput (dpy, box->window, (ButtonPressMask | ButtonReleaseMask | ExposureMask)); } box->next = box_list; box_list = box; return (box); } int remove_box (b) register BoxRec *b; { register BoxRec *p, **prev; for (prev = &box_list; p = *prev; prev = &p->next) { if (p == b) { *prev = p->next; XFreeGC (dpy, p->invertgc); Free ((char *) p); return (0); } } return (-1); } void map_box (p) register BoxRec *p; { XMapWindow (dpy, p->window); p->map = 1; } void unmap_box (p) register BoxRec *p; { XUnmapWindow (dpy, p->window); p->map = '\0'; p->in = '\0'; } void freeze_box (p) register BoxRec *p; { p->freeze = 1; } void unfreeze_box (p) register BoxRec *p; { p->freeze = '\0'; } void moveresize_box (p, x, y, width, height) register BoxRec *p; int x, y; int width, height; { p->x = x; p->y = y; p->width = width; p->height = height; XMoveResizeWindow (dpy, p->window, (x - p->border_width), (y - p->border_width), width, height); } void changecolor_box (p, fg, bg, bp, flg) register BoxRec *p; unsigned long fg, bg, bp; unsigned long flg; { XGCValues xgcv; if ((flg & BoxBackground) && (bg != p->bg)) { p->bg = bg; XSetWindowBackground (dpy, p->window, p->bg); xgcv.background = bg; xgcv.plane_mask = XOR (p->fg, p->bg); XChangeGC (dpy, p->invertgc, (GCPlaneMask | GCBackground), &xgcv); XClearWindow (dpy, p->window); } if ((flg & BoxForeground) && (fg != p->fg)) { p->fg = fg; xgcv.foreground = fg; xgcv.plane_mask = XOR (p->fg, p->bg); XChangeGC (dpy, p->invertgc, (GCPlaneMask | GCForeground), &xgcv); } if ((flg & BoxBorderPixel) && (bp != p->bp)) { p->bp = bp; XSetWindowBorder (dpy, p->window, p->bp); } } void redraw_box (p) register BoxRec *p; { XClearWindow (dpy, p->window); /* JW3Mputc(p->string, p->window, 0, (int)p->in, IN_BORDER); */ JW3Mputc (p->string, p->window, 0, 0, IN_BORDER); if (p->in) reverse_box (p, p->invertgc); } void reverse_box (p, invertgc) register BoxRec *p; GC invertgc; { XFillRectangle (dpy, p->window, invertgc, 0, 0, p->width, p->height); } void change_reverse_box (p, rev) register BoxRec *p; char rev; { if (rev) { XSelectInput (dpy, p->window, (ButtonPressMask | ButtonReleaseMask | EnterWindowMask | LeaveWindowMask | ExposureMask)); } else { XSelectInput (dpy, p->window, (ButtonPressMask | ButtonReleaseMask | ExposureMask)); } p->reverse = rev; }