80 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include	"debug.h"
 | |
| 
 | |
| #include	<em.h>
 | |
| #include	<assert.h>
 | |
| 
 | |
| #include	"LLlex.h"
 | |
| #include	"def.h"
 | |
| #include	"main.h"
 | |
| #include	"scope.h"
 | |
| #include	"type.h"
 | |
| 
 | |
| static int extflc;			/* number of external files */
 | |
| static int inpflag = 0;			/* input mentioned in heading ? */
 | |
| static int outpflag = 0;		/* output mentioned in heading ? */
 | |
| static label extfl_label;		/* label of array of file pointers */
 | |
| 
 | |
| set_inp()
 | |
| {
 | |
| 	inpflag = 1;
 | |
| }
 | |
| 
 | |
| set_outp()
 | |
| {
 | |
| 	outpflag = 1;
 | |
| }
 | |
| 
 | |
| make_extfl()
 | |
| {
 | |
| 	if( err_occurred ) return; 
 | |
| 
 | |
| 	extfl_label = ++data_label;
 | |
| 	C_df_dlb(extfl_label);
 | |
| 
 | |
| 	if( inpflag ) {
 | |
| 		C_ina_dnam(input);
 | |
| 		C_con_dnam(input, (arith) 0);
 | |
| 	}
 | |
| 	else
 | |
| 		C_con_ucon("0", pointer_size);
 | |
| 
 | |
| 	if( outpflag ) {
 | |
| 		C_ina_dnam(output);
 | |
| 		C_con_dnam(output, (arith) 0);
 | |
| 	}
 | |
| 	else
 | |
| 		C_con_ucon("0", pointer_size);
 | |
| 
 | |
| 	extflc = 2;
 | |
| 
 | |
| 	/* Process the identifiers in the global scope (at this point only
 | |
| 	 * the program parameters) in order of specification.
 | |
| 	 */
 | |
| 	make_extfl_args( GlobalScope->sc_def );
 | |
| }
 | |
| 
 | |
| make_extfl_args(df)
 | |
| 	register struct def *df;
 | |
| {
 | |
| 	if( !df ) return;
 | |
| 	make_extfl_args(df->df_nextinscope);
 | |
| 	assert(df->df_flags & D_PROGPAR);
 | |
| 	if( df->var_name != input && df->var_name != output ) {
 | |
| 		C_ina_dnam(df->var_name);
 | |
| 		C_con_dnam(df->var_name, (arith) 0);
 | |
| 		extflc++;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| call_ini()
 | |
| {
 | |
| 	C_lxl((arith) 0);
 | |
| 	if( extflc )
 | |
| 		C_lae_dlb(extfl_label, (arith) 0);
 | |
| 	else
 | |
| 		C_zer(pointer_size);
 | |
| 	C_loc((arith) extflc);
 | |
| 	C_lxa((arith) 0);
 | |
| 	C_cal("_ini");
 | |
| 	C_asp(3 * pointer_size + word_size);
 | |
| }
 |