Home | History | Annotate | Line # | Download | only in wsfont
wsfont.h revision 1.5
      1  1.5  ad /* 	$NetBSD: wsfont.h,v 1.5 1999/04/29 02:42:43 ad Exp $ */
      2  1.1  ad 
      3  1.4  ad /*
      4  1.2  ad  * Copyright (c) 1999 Andy Doran <ad (at) NetBSD.org>
      5  1.1  ad  * All rights reserved.
      6  1.1  ad  *
      7  1.1  ad  * Redistribution and use in source and binary forms, with or without
      8  1.1  ad  * modification, are permitted provided that the following conditions
      9  1.1  ad  * are met:
     10  1.1  ad  * 1. Redistributions of source code must retain the above copyright
     11  1.1  ad  *    notice, this list of conditions and the following disclaimer.
     12  1.1  ad  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  ad  *    notice, this list of conditions and the following disclaimer in the
     14  1.1  ad  *    documentation and/or other materials provided with the distribution.
     15  1.1  ad  *
     16  1.2  ad  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
     17  1.2  ad  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     18  1.2  ad  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     19  1.2  ad  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     20  1.2  ad  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     21  1.2  ad  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     22  1.2  ad  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     23  1.2  ad  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     24  1.2  ad  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.2  ad  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.2  ad  * SUCH DAMAGE.
     27  1.2  ad  *
     28  1.1  ad  */
     29  1.1  ad 
     30  1.1  ad #ifndef _WSFONT_H_
     31  1.1  ad #define _WSFONT_H_ 1
     32  1.1  ad 
     33  1.1  ad /*
     34  1.1  ad  * wsfont_find() can be called with any of the parameters as 0, meaning we
     35  1.1  ad  * don't care about that aspect of the font. It returns a cookie which
     36  1.1  ad  * we can use with the other functions. When more flexibility is required,
     37  1.1  ad  * wsfont_enum() should be used. The last two parameters to wsfont_lock()
     38  1.3  ad  * are the bit order and byte order required (WSFONT_L2R or WSFONT_R2L).
     39  1.1  ad  *
     40  1.1  ad  * Example:
     41  1.1  ad  *
     42  1.3  ad  *	struct wsdisplay_font *font;
     43  1.1  ad  *	int cookie;
     44  1.1  ad  *
     45  1.5  ad  *	if ((cookie = wsfont_find(NULL, 8, 16, 0, 0)) <= 0)
     46  1.1  ad  *		panic("unable to get 8x16 font");
     47  1.1  ad  *
     48  1.5  ad  *	if (wsfont_lock(cookie, &font, WSFONT_L2R, WSFONT_R2L) <= 0)
     49  1.1  ad  *		panic("unable to lock font");
     50  1.1  ad  *
     51  1.1  ad  *	... do stuff ...
     52  1.1  ad  *
     53  1.1  ad  *	wsfont_unlock(cookie);
     54  1.1  ad  */
     55  1.1  ad struct wsdisplay_font;
     56  1.1  ad 
     57  1.3  ad /* Left to Right, Right to Left */
     58  1.4  ad #define WSFONT_L2R	(1)
     59  1.4  ad #define WSFONT_R2L	(2)
     60  1.1  ad 
     61  1.1  ad void	wsfont_init __P((void));
     62  1.1  ad int	wsfont_find __P((char *name, int width, int height, int stride));
     63  1.1  ad int	wsfont_add __P((struct wsdisplay_font *font, int copy));
     64  1.1  ad int	wsfont_remove __P((int cookie));
     65  1.1  ad void	wsfont_enum __P((void (*func) __P((char *n, int w, int h, int s))));
     66  1.1  ad int	wsfont_lock __P((int cookie, struct wsdisplay_font **font, int, int));
     67  1.1  ad int	wsfont_unlock __P((int cookie));
     68  1.1  ad int	wsfont_getflg __P((int cookie, int *flg, int *lockcount));
     69  1.1  ad 
     70  1.1  ad #endif /* _WSFONT_H_ */
     71