2001-05-17 02:59:29 +08:00
|
|
|
#include "config.h"
|
1998-02-01 09:37:08 +08:00
|
|
|
#include "f2c.h"
|
|
|
|
#include "fio.h"
|
|
|
|
#include "lio.h"
|
|
|
|
#include "fmt.h"
|
|
|
|
|
|
|
|
extern int f__Aquote;
|
|
|
|
|
|
|
|
static VOID
|
|
|
|
nl_donewrec(Void)
|
|
|
|
{
|
|
|
|
(*f__donewrec)();
|
|
|
|
PUT(' ');
|
|
|
|
}
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
VOID
|
|
|
|
x_wsne(cilist *a)
|
|
|
|
{
|
|
|
|
Namelist *nl;
|
|
|
|
char *s;
|
|
|
|
Vardesc *v, **vd, **vde;
|
2000-12-09 23:34:53 +08:00
|
|
|
ftnint number, type;
|
1998-02-01 09:37:08 +08:00
|
|
|
ftnlen *dims;
|
|
|
|
ftnlen size;
|
|
|
|
extern ftnlen f__typesize[];
|
|
|
|
|
|
|
|
nl = (Namelist *)a->cifmt;
|
|
|
|
PUT('&');
|
|
|
|
for(s = nl->name; *s; s++)
|
|
|
|
PUT(*s);
|
|
|
|
PUT(' ');
|
|
|
|
f__Aquote = 1;
|
|
|
|
vd = nl->vars;
|
|
|
|
vde = vd + nl->nvars;
|
|
|
|
while(vd < vde) {
|
|
|
|
v = *vd++;
|
|
|
|
s = v->name;
|
|
|
|
#ifdef No_Extra_Namelist_Newlines
|
|
|
|
if (f__recpos+strlen(s)+2 >= L_len)
|
|
|
|
#endif
|
|
|
|
nl_donewrec();
|
|
|
|
while(*s)
|
|
|
|
PUT(*s++);
|
|
|
|
PUT(' ');
|
|
|
|
PUT('=');
|
2000-12-09 23:34:53 +08:00
|
|
|
number = (dims = v->dims) ? dims[1] : 1;
|
1998-02-01 09:37:08 +08:00
|
|
|
type = v->type;
|
|
|
|
if (type < 0) {
|
|
|
|
size = -type;
|
|
|
|
type = TYCHAR;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
size = f__typesize[type];
|
2000-12-09 23:34:53 +08:00
|
|
|
l_write(&number, v->addr, size, type);
|
1998-02-01 09:37:08 +08:00
|
|
|
if (vd < vde) {
|
|
|
|
if (f__recpos+2 >= L_len)
|
|
|
|
nl_donewrec();
|
|
|
|
PUT(',');
|
|
|
|
PUT(' ');
|
|
|
|
}
|
|
|
|
else if (f__recpos+1 >= L_len)
|
|
|
|
nl_donewrec();
|
|
|
|
}
|
|
|
|
f__Aquote = 0;
|
|
|
|
PUT('/');
|
|
|
|
}
|