72 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef NORCSID
 | |
| static char rcsid[] = "$Id$";
 | |
| #endif
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include "param.h"
 | |
| #include "types.h"
 | |
| #include "tes.h"
 | |
| #include "alloc.h"
 | |
| #include <em_spec.h>
 | |
| #include "ext.h"
 | |
| 
 | |
| /*
 | |
|  * (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
 | |
|  * See the copyright notice in the ACK home directory, in the file "Copyright".
 | |
|  *
 | |
|  * Author: Hans van Staveren
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Main program for EM optimizer
 | |
|  */
 | |
| 
 | |
| main(argc,argv) int argc; char *argv[]; {
 | |
| 	int somespace[STACKROOM];
 | |
| 
 | |
| 	progname = argv[0];
 | |
| 	while (argc-->1 && **++argv == '-')
 | |
| 		flags(*argv);
 | |
| 	if (argc>1) {
 | |
| 		fprintf(stderr,"Usage: %s [-Ln] [-m<num>] [name]\n",progname);
 | |
| 		exit(-1);
 | |
| 	}
 | |
| 	if (argc)
 | |
| 		if (freopen(*argv,"r",stdin) == NULL)
 | |
| 			error("Cannot open %s",*argv);
 | |
| 	fileinit();
 | |
| 	coreinit((short *)somespace,(short *)(somespace+STACKROOM));
 | |
| 	getlines();
 | |
| 	cleanup();
 | |
| 	return(0);
 | |
| }
 | |
| 
 | |
| flags(s) register char *s; {
 | |
| 
 | |
| 	for (s++;*s;s++)
 | |
| 		switch(*s) {
 | |
| 		case 'L':	Lflag = TRUE; break;
 | |
| 		case 'n':	nflag = TRUE; break;
 | |
| 		case 'm':	if (*(s+1) == 'l') {
 | |
| 					s++;
 | |
| 					repl_longmuls = TRUE;
 | |
| 				}
 | |
| 				repl_muls = atoi(s+1); break;
 | |
| 		}
 | |
| }
 | |
| 
 | |
| fileinit() {
 | |
| 	char *mktemp();
 | |
| 	short readshort();
 | |
| 
 | |
| 	if (readshort() != (short) sp_magic)
 | |
| 		error("wrong input file");
 | |
| 	if (Lflag) {
 | |
| 		outfile = fopen(mktemp(template),"w");
 | |
| 		if (outfile == NULL)
 | |
| 			error("can't create %s",template);
 | |
| 	} else {
 | |
| 		outfile = stdout;
 | |
| 		outshort(sp_magic);
 | |
| 	}
 | |
| }
 |