/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/* Copyright (c) 1988 AT&T */
/* All Rights Reserved */
/*
* University Copyright- Copyright (c) 1982, 1986, 1988
* The Regents of the University of California
* All Rights Reserved
*
* University Acknowledgment- Portions of this document are derived from
* software developed by the University of California, Berkeley, and its
* contributors.
*/
#pragma ident "%Z%%M% %I% %E% SMI"
/*
*************************************************************************
* COPYRIGHT NOTICE *
*************************************************************************
* This software is copyright(C) 1982 by Pavel Curtis *
* *
* Permission is granted to reproduce and distribute *
* this file by any means so long as no fee is charged *
* above a nominal handling fee and so long as this *
* notice is always included in the copies. *
* *
* Other rights are reserved except as explicitly granted *
* by written permission of the author. *
* Pavel Curtis *
* Computer Science Dept. *
* 405 Upson Halli *
* Cornell Universityi *
* Ithaca, NY 14853 *
* *
* Ph- (607) 256-4934 *
* *
* Pavel.Cornell@Udel-Relay(ARPAnet) *
* decvax!cornell!pavel(UUCPnet) *
*********************************************************************** */
/*
* comp_main.c --- Main program for terminfo compiler
*
* $Log: RCS/comp_main.v $
* Revision 2.1 82/10/25 14:45:37 pavel
* Added Copyright Notice
*
* Revision 2.0 82/10/24 15:16:37 pavel
* Beta-one Test Release
*
* Revision 1.3 82/08/23 22:29:36 pavel
* The REAL Alpha-one Release Version
*
* Revision 1.2 82/08/19 19:09:49 pavel
* Alpha Test Release One
*
* Revision 1.1 82/08/12 18:36:55 pavel
* Initial revision
*
*
*/
#define EXTERN /* EXTERN=extern in other .c files */
#include <sys/types.h>
#include <sys/stat.h>
#include <stdlib.h>
#include <unistd.h>
#include "compiler.h"
char *source_file = "./terminfo.src";
char *destination = SRCDIR;
char *usage_string = "[-v[n]] [-c] source-file\n";
char check_only = 0;
char *progname;
extern void make_hash_table(); /* should be in a header file :-( */
extern void compile(); /* should be in a header file :-( */
extern void syserr_abort(); /* should be in a header file :-( */
static void init();
int
main(int argc, char *argv[])
{
int i;
int argflag = FALSE;
debug_level = 0;
progname = argv[0];
umask(022);
for (i = 1; i < argc; i++) {
if (argv[i][0] == '-') {
switch (argv[i][1]) {
case 'c':
check_only = 1;
break;
case 'v':
debug_level = argv[i][2] ? atoi(&argv[i][2]) : 1;
break;
default:
fprintf(stderr,
"%s: Unknown option. Usage is:\n\t%s: %s\n",
argv[0], progname, usage_string);
exit(1);
}
} else if (argflag) {
fprintf(stderr, "%s: Too many file names. Usage is:\n\t%s\n",
argv[0], usage_string);
exit(1);
} else {
argflag = TRUE;
source_file = argv[i];
}
}
init();
make_hash_table();
compile();
exit(0);
return(0);
}
/*
* init()
*
* Miscellaneous initializations
*
* Open source file as standard input
* Change directory to working terminfo directory.
*
*/
static void
init()
{
char *env = getenv("TERMINFO");
start_time = time((time_t *) 0);
curr_line = 0;
if (freopen(source_file, "r", stdin) == NULL) {
fprintf(stderr, "%s: Can't open %s\n", progname, source_file);
exit(1);
}
if (env && *env)
destination = env;
if (check_only) {
DEBUG(1, "Would be working in %s\n", destination);
} else {
DEBUG(1, "Working in %s\n", destination);
}
if (access(destination, 7) < 0) {
fprintf(stderr, "%s: %s nonexistent or permission denied\n",
progname, destination);
exit(1);
}
if (chdir(destination) < 0) {
fprintf(stderr, "%s: %s is not a directory\n",
progname, destination);
exit(1);
}
}
/*
*
* check_dir(dirletter)
*
* Check for access rights to the destination directory.
* Create any directories which don't exist.
*
*/
void
check_dir(char dirletter)
{
struct stat64 statbuf;
static char dirnames[128];
static char dir[2] = " ";
if (dirnames[dirletter] == 0) {
dir[0] = dirletter;
if (stat64(dir, &statbuf) < 0) {
if (mkdir(dir, 0755) < 0)
syserr_abort("mkdir %s returned bad status", dir);
dirnames[dirletter] = 1;
} else if (access(dir, 7) < 0) {
fprintf(stderr, "%s: %s/%s: Permission denied\n",
progname, destination, dir);
perror(dir);
exit(1);
} else if ((statbuf.st_mode & S_IFMT) != S_IFDIR) {
fprintf(stderr, "%s: %s/%s: Not a directory\n",
progname, destination, dir);
perror(dir);
exit(1);
}
}
return;
}
#include <curses.h>
#if (defined(SYSV) || defined(USG)) && !defined(SIGPOLL)
/*
* mkdir(dirname, mode)
*
* forks and execs the mkdir program to create the given directory
*
*/
mkdir(dirname, mode)
#ifdef __STDC__
const
#endif
char *dirname;
int mode;
{
int fork_rtn;
int status;
fork_rtn = fork();
switch (fork_rtn) {
case 0: /* Child */
(void) execl("/bin/mkdir", "mkdir", dirname, (char *)0);
_exit(1);
case -1: /* Error */
fprintf(stderr, "%s: SYSTEM ERROR!! Fork failed!!!\n",
progname);
exit(1);
default:
(void) wait(&status);
if ((status != 0) || (chmod(dirname, mode) == -1))
return (-1);
return (0);
}
}
#endif