1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright (c) 1995-1998 by Sun Microsystems, Inc.
24  * All rights reserved.
25  */
26 
27 /* LINTLIBRARY */
28 
29 /*
30  * whln_st.c
31  *
32  * XCurses Library
33  *
34  * Copyright 1990, 1995 by Mortice Kern Systems Inc.  All rights reserved.
35  *
36  */
37 
38 #ifdef M_RCSID
39 #ifndef lint
40 static char rcsID[] = "$Header: /rd/src/libc/xcurses/rcs/whln_st.c 1.4 "
41 "1995/07/07 18:53:05 ant Exp $";
42 #endif
43 #endif
44 
45 #include <private.h>
46 
47 int
whline_set(WINDOW * w,const cchar_t * h,int n)48 whline_set(WINDOW *w, const cchar_t *h, int n)
49 {
50 	int	x, width;
51 
52 	if (h == NULL)
53 		h = WACS_HLINE;
54 
55 	n += w->_curx;
56 	if (w->_maxx < n)
57 		n = w->_maxx;
58 
59 	for (x = w->_curx; x < n; x += width)
60 		if ((width = __m_cc_replace(w, w->_cury, x, h, 0)) == -1)
61 			return (ERR);
62 
63 	WSYNC(w);
64 
65 	return (WFLUSH(w));
66 }
67 
68 int
wvline_set(WINDOW * w,const cchar_t * v,int n)69 wvline_set(WINDOW *w, const cchar_t *v, int n)
70 {
71 	int	y;
72 
73 	if (v == NULL)
74 		v = WACS_VLINE;
75 
76 	n += w->_cury;
77 	if (w->_maxy < n)
78 		n = w->_maxy;
79 
80 	for (y = w->_cury; y < n; ++y)
81 		if (__m_cc_replace(w, y, w->_curx, v, 0) == -1)
82 			return (ERR);
83 
84 	WSYNC(w);
85 
86 	return (WFLUSH(w));
87 }
88