NetBSD/games/atc/extern.h

141 lines
4.5 KiB
C
Raw Normal View History

2005-08-10 21:53:28 +04:00
/* $NetBSD: extern.h,v 1.13 2005/08/10 17:53:28 rpaulo Exp $ */
1995-03-21 18:03:38 +03:00
1993-03-21 12:45:37 +03:00
/*-
1995-03-21 18:03:38 +03:00
* Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved.
1993-03-21 12:45:37 +03:00
*
* This code is derived from software contributed to Berkeley by
* Ed James.
*
* 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.
* 3. Neither the name of the University nor the names of its contributors
1993-03-21 12:45:37 +03:00
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
*
1995-03-21 18:03:38 +03:00
* @(#)extern.h 8.1 (Berkeley) 5/31/93
1993-03-21 12:45:37 +03:00
*/
/*
* Copyright (c) 1987 by Ed James, UC Berkeley. All rights reserved.
*
* Copy permission is hereby granted provided that this notice is
* retained on all partial or complete copies.
*
* For more info on this and all of my stuff, mail edjames@berkeley.edu.
*/
extern char GAMES[];
2005-07-01 04:48:34 +04:00
extern const char *filename;
1993-03-21 12:45:37 +03:00
extern int clck, safe_planes, start_time, test_mode;
2005-08-10 21:53:28 +04:00
#if 0
1993-03-21 12:45:37 +03:00
extern FILE *filein, *fileout;
2005-08-10 21:53:28 +04:00
#endif
1993-03-21 12:45:37 +03:00
extern C_SCREEN screen, *sp;
extern LIST air, ground;
1995-04-28 01:22:19 +04:00
extern struct termios tty_start, tty_new;
1993-03-21 12:45:37 +03:00
extern DISPLACEMENT displacement[MAXDIR];
2004-01-27 23:30:28 +03:00
int addplane(void);
void append(LIST *, PLANE *);
void check_adir(int, int, int);
void check_edge(int, int);
void check_edir(int, int, int);
void check_line(int, int, int, int);
void check_linepoint(int, int);
void check_point(int, int);
int checkdefs(void);
int compar(const void *, const void *);
void delete(LIST *, PLANE *);
int dir_deg(int);
2005-07-01 04:48:34 +04:00
int dir_no(int);
2004-01-27 23:30:28 +03:00
void done_screen(void);
void draw_all(void);
void draw_line(WINDOW *, int, int, int, int, const char *);
void erase_all(void);
int getAChar(void);
int getcommand(void);
int gettoken(void);
void init_gr(void);
void ioaddstr(int, const char *);
void ioclrtobot(void);
void ioclrtoeol(int);
void ioerror(int, int, const char *);
void iomove(int);
int list_games(void);
int log_score(int);
void log_score_quit(int) __attribute__((__noreturn__));
void loser(const PLANE *, const char *) __attribute__((__noreturn__));
int main(int, char *[]);
char name(const PLANE *);
int next_plane(void);
void noise(void);
2005-07-01 04:48:34 +04:00
int number(int);
2004-01-27 23:30:28 +03:00
void open_score_file(void);
void planewin(void);
int pop(void);
void push(int, int);
void quit(int);
int read_file(const char *);
void redraw(void);
void rezero(void);
void setup_screen(const C_SCREEN *);
int too_close(const PLANE *p1, const PLANE *p2, int);
void update(int);
int yyerror(const char *);
int yylex(void);
2001-02-05 03:22:52 +03:00
#ifndef YYEMPTY
2004-01-27 23:30:28 +03:00
int yyparse(void);
2001-02-05 03:22:52 +03:00
#endif
2005-07-01 04:48:34 +04:00
const char *Left(int);
const char *Right(int);
const char *airport(int);
const char *beacon(int);
const char *benum(int);
const char *circle(int);
const char *climb(int);
2004-01-27 23:30:28 +03:00
const char *command(const PLANE *);
const char *default_game(void);
2005-07-01 04:48:34 +04:00
const char *delayb(int);
const char *descend(int);
const char *ex_it(int);
2004-01-27 23:30:28 +03:00
PLANE *findplane(int);
2005-07-01 04:48:34 +04:00
const char *ignore(int);
const char *left(int);
const char *mark(int);
2004-01-27 23:30:28 +03:00
PLANE *newplane(void);
const char *okay_game(const char *);
2005-07-01 04:48:34 +04:00
const char *rel_dir(int);
const char *right(int);
const char *setalt(int);
const char *setplane(int);
const char *setrelalt(int);
2004-01-27 23:30:28 +03:00
const char *timestr(int);
2005-07-01 04:48:34 +04:00
const char *to_dir(int);
const char *turn(int);
const char *unmark(int);