2N/A/*
2N/A * CDDL HEADER START
2N/A *
2N/A * The contents of this file are subject to the terms of the
2N/A * Common Development and Distribution License, Version 1.0 only
2N/A * (the "License"). You may not use this file except in compliance
2N/A * with the License.
2N/A *
2N/A * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
2N/A * or http://www.opensolaris.org/os/licensing.
2N/A * See the License for the specific language governing permissions
2N/A * and limitations under the License.
2N/A *
2N/A * When distributing Covered Code, include this CDDL HEADER in each
2N/A * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
2N/A * If applicable, add the following below this CDDL HEADER, with the
2N/A * fields enclosed by brackets "[]" replaced with your own identifying
2N/A * information: Portions Copyright [yyyy] [name of copyright owner]
2N/A *
2N/A * CDDL HEADER END
2N/A */
2N/A/*
2N/A * Copyright (c) 1995, by Sun Microsystems, Inc.
2N/A * All rights reserved.
2N/A */
2N/A
2N/A#pragma ident "%Z%%M% %I% %E% SMI"
2N/A
2N/A/*
2N/A * baudrate.c
2N/A *
2N/A * XCurses Library
2N/A *
2N/A * Copyright 1990, 1995 by Mortice Kern Systems Inc. All rights reserved.
2N/A *
2N/A */
2N/A
2N/A#ifdef M_RCSID
2N/A#ifndef lint
2N/Astatic char rcsID[] = "$Header: /rd/src/libc/xcurses/rcs/baudrate.c 1.2 1995/09/27 19:09:07 ant Exp $";
2N/A#endif
2N/A#endif
2N/A
2N/A#include <private.h>
2N/A
2N/Atypedef struct {
2N/A speed_t speed;
2N/A int value;
2N/A} t_baud;
2N/A
2N/Astatic t_baud speeds[] = {
2N/A { B0, 0 },
2N/A { B50, 50 },
2N/A { B75, 75 },
2N/A { B110, 110 },
2N/A { B134, 134 },
2N/A { B150, 150 },
2N/A { B200, 200 },
2N/A { B300, 300 },
2N/A { B600, 600 },
2N/A { B1200, 1200 },
2N/A { B1800, 1800 },
2N/A { B2400, 2400 },
2N/A { B4800, 4800 },
2N/A { B9600, 9600 },
2N/A { B19200, 19200 },
2N/A { B38400, 38400 },
2N/A { (speed_t) -1, -1 }
2N/A};
2N/A
2N/A/*f
2N/A * Return the output speed of the terminal. The number returned is in
2N/A * bits per second and is an integer.
2N/A */
2N/Aint
2N/Abaudrate()
2N/A{
2N/A int i;
2N/A speed_t value;
2N/A
2N/A#ifdef M_CURSES_TRACE
2N/A __m_trace("baudrate(void)");
2N/A#endif
2N/A
2N/A value = cfgetospeed(&cur_term->_prog);
2N/A
2N/A for (i = 0; speeds[i].speed != (speed_t) -1; ++i)
2N/A if (speeds[i].speed == value)
2N/A break;
2N/A
2N/A return __m_return_int("baudrate", speeds[i].value);
2N/A}