53 lines
		
	
	
	
		
			882 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
	
		
			882 B
		
	
	
	
		
			C
		
	
	
	
	
	
#include "f2c.h"
 | 
						|
#include "fio.h"
 | 
						|
#include "lio.h"
 | 
						|
#include "fmt.h"
 | 
						|
 | 
						|
x_wsne(a)
 | 
						|
 cilist *a;
 | 
						|
{
 | 
						|
	Namelist *nl;
 | 
						|
	char *s;
 | 
						|
	Vardesc *v, **vd, **vde;
 | 
						|
	ftnint *number, type;
 | 
						|
	ftnlen *dims;
 | 
						|
	ftnlen size;
 | 
						|
	static ftnint one = 1;
 | 
						|
	extern ftnlen typesize[];
 | 
						|
 | 
						|
	nl = (Namelist *)a->cifmt;
 | 
						|
	PUT('&');
 | 
						|
	for(s = nl->name; *s; s++)
 | 
						|
		PUT(*s);
 | 
						|
	PUT(' ');
 | 
						|
	vd = nl->vars;
 | 
						|
	vde = vd + nl->nvars;
 | 
						|
	while(vd < vde) {
 | 
						|
		v = *vd++;
 | 
						|
		s = v->name;
 | 
						|
		if (recpos+strlen(s)+2 >= L_len)
 | 
						|
			(*donewrec)();
 | 
						|
		while(*s)
 | 
						|
			PUT(*s++);
 | 
						|
		PUT(' ');
 | 
						|
		PUT('=');
 | 
						|
		number = (dims = v->dims) ? dims + 1 : &one;
 | 
						|
		type = v->type;
 | 
						|
		if (type < 0) {
 | 
						|
			size = -type;
 | 
						|
			type = TYCHAR;
 | 
						|
			}
 | 
						|
		else
 | 
						|
			size = typesize[type];
 | 
						|
		l_write(number, v->addr, size, type);
 | 
						|
		if (vd < vde) {
 | 
						|
			if (recpos+2 >= L_len)
 | 
						|
				(*donewrec)();
 | 
						|
			PUT(',');
 | 
						|
			PUT(' ');
 | 
						|
			}
 | 
						|
		else if (recpos+1 >= L_len)
 | 
						|
			(*donewrec)();
 | 
						|
		}
 | 
						|
	PUT('/');
 | 
						|
	}
 |