2019-07-22 20:32:33 +00:00
|
|
|
/* #includes */ /*{{{C}}}*//*{{{*/
|
|
|
|
#ifndef NO_POSIX_SOURCE
|
|
|
|
#undef _POSIX_SOURCE
|
|
|
|
#define _POSIX_SOURCE 1
|
|
|
|
#undef _POSIX_C_SOURCE
|
|
|
|
#define _POSIX_C_SOURCE 2
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef DMALLOC
|
|
|
|
#include "dmalloc.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <limits.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
|
|
|
|
#include "htmlio.h"
|
|
|
|
#include "main.h"
|
|
|
|
#include "misc.h"
|
|
|
|
/*}}}*/
|
|
|
|
|
|
|
|
/* savehtml -- save as HTML table */ /*{{{*/
|
2019-07-27 04:14:26 +00:00
|
|
|
const char *savehtml(Sheet *sheet, const char *name, int body,
|
|
|
|
const Location beg, const Location end,
|
|
|
|
unsigned int *count)
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
2019-07-27 04:14:26 +00:00
|
|
|
assert(sheet != (Sheet*)0);
|
2019-09-05 07:24:24 +00:00
|
|
|
assert(name != NULL);
|
|
|
|
|
|
|
|
*count = 0;
|
|
|
|
Location w;
|
2019-07-27 04:14:26 +00:00
|
|
|
w[X] = beg[X];
|
|
|
|
for (w[Z]=beg[Z]; w[Z]<=end[Z]; ++(w[Z]))
|
|
|
|
for (w[Y]=beg[Y]; w[Y]<=end[Y]; ++(w[Y]))
|
2019-09-03 08:41:37 +00:00
|
|
|
if (shadowed(sheet, w)) return _("Shadowed cells in first column");
|
2019-09-05 07:24:24 +00:00
|
|
|
FILE *fp = (FILE*)0; /* cause runtime error */
|
|
|
|
if (!body && (fp = fopen(name,"w")) == (FILE*)0) return strerror(errno);
|
2019-07-27 04:14:26 +00:00
|
|
|
for (w[Z]=beg[Z]; w[Z]<=end[Z]; ++(w[Z]))
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
|
|
|
if (body) /* open new file */ /*{{{*/
|
|
|
|
{
|
2019-09-05 07:24:24 +00:00
|
|
|
char num[20];
|
2019-07-27 04:14:26 +00:00
|
|
|
sprintf(num, ".%d", w[Z]);
|
2019-09-05 07:24:24 +00:00
|
|
|
char fullname[PATH_MAX];
|
2019-07-22 20:32:33 +00:00
|
|
|
fullname[sizeof(fullname)-strlen(num)-1]='\0';
|
|
|
|
(void)strncpy(fullname,name,sizeof(fullname)-strlen(num)-1);
|
|
|
|
fullname[sizeof(fullname)-1]='\0';
|
|
|
|
(void)strncat(fullname,num,sizeof(fullname)-strlen(num)-1);
|
|
|
|
fullname[sizeof(fullname)-1]='\0';
|
|
|
|
if ((fp=fopen(fullname,"w"))==(FILE*)0) return strerror(errno);
|
|
|
|
}
|
|
|
|
/*}}}*/
|
|
|
|
else /* print header */ /*{{{*/
|
|
|
|
if (fputs_close("<html>\n<head>\n<title>\n</title>\n</head>\n<body>\n",fp)==EOF) return strerror(errno);
|
|
|
|
/*}}}*/
|
|
|
|
|
|
|
|
if (fputs_close("<table>\n",fp)==EOF) return strerror(errno);
|
2019-07-27 04:14:26 +00:00
|
|
|
for (w[Y]=beg[Y]; w[Y]<=end[Y]; ++(w[Y])) /* print contents */ /*{{{*/
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
|
|
|
if (fputs_close("<tr>",fp)==EOF) return strerror(errno);
|
2019-07-27 04:14:26 +00:00
|
|
|
for (w[X]=beg[X]; w[X]<=end[X]; )
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
2019-09-03 08:41:37 +00:00
|
|
|
Location mw; LOCATION_GETS(mw, w);
|
2019-09-05 07:24:24 +00:00
|
|
|
for (++(mw[X]); (size_t)(mw[X]) < sheet->dim[X] && shadowed(sheet, mw);
|
|
|
|
++(mw[X]));
|
2019-09-03 08:41:37 +00:00
|
|
|
int multicols = mw[X] - w[X];
|
|
|
|
if (multicols > 1) fprintf(fp,"<td colspan=%d",multicols);
|
2019-07-22 20:32:33 +00:00
|
|
|
else fprintf(fp,"<td");
|
2019-09-03 08:41:37 +00:00
|
|
|
Style cs = getstyle(sheet, w);
|
|
|
|
switch (cs.adjust)
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
|
|
|
case LEFT: if (fputs_close(" align=left>",fp)==EOF) return strerror(errno); break;
|
|
|
|
case RIGHT: if (fputs_close(" align=right>",fp)==EOF) return strerror(errno); break;
|
|
|
|
case CENTER: if (fputs_close(" align=center>",fp)==EOF) return strerror(errno); break;
|
|
|
|
default: assert(0);
|
|
|
|
}
|
2019-09-05 07:24:24 +00:00
|
|
|
char buf[1024];
|
2019-09-03 08:41:37 +00:00
|
|
|
printvalue(buf, sizeof(buf), 0, DIRECT_STRING, cs.fform, cs.precision,
|
|
|
|
sheet, w);
|
|
|
|
if (cs.transparent)
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
2019-09-03 08:41:37 +00:00
|
|
|
if (fputs_close(buf,fp) == EOF) return strerror(errno);
|
2019-07-22 20:32:33 +00:00
|
|
|
}
|
2019-09-03 08:41:37 +00:00
|
|
|
else for (char *bufp = buf; *bufp; ++bufp) switch (*bufp)
|
2019-07-22 20:32:33 +00:00
|
|
|
{
|
|
|
|
case '<': if (fputs_close("<",fp)==EOF) return strerror(errno); break;
|
|
|
|
case '>': if (fputs_close(">",fp)==EOF) return strerror(errno); break;
|
|
|
|
case '&': if (fputs_close("&",fp)==EOF) return strerror(errno); break;
|
|
|
|
case '"': if (fputs_close(""",fp)==EOF) return strerror(errno); break;
|
|
|
|
default: if (fputc_close(*bufp,fp)==EOF) return strerror(errno);
|
|
|
|
}
|
|
|
|
if (fputs_close("</td>",fp)==EOF) return strerror(errno);
|
2019-07-27 04:14:26 +00:00
|
|
|
w[X] += multicols;
|
2019-07-22 20:32:33 +00:00
|
|
|
++*count;
|
|
|
|
}
|
|
|
|
if (fputs_close("</tr>\n",fp)==EOF) return strerror(errno);
|
|
|
|
}
|
|
|
|
/*}}}*/
|
|
|
|
if (fputs_close("</table>\n",fp)==EOF) return strerror(errno);
|
|
|
|
if (body)
|
|
|
|
{
|
2019-09-03 08:41:37 +00:00
|
|
|
if (fclose(fp) == EOF) return strerror(errno);
|
2019-07-22 20:32:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!body)
|
|
|
|
{
|
2019-09-03 08:41:37 +00:00
|
|
|
if (fputs_close("</body>\n</html>\n",fp) == EOF) return strerror(errno);
|
|
|
|
if (fclose(fp) == EOF) return strerror(errno);
|
2019-07-22 20:32:33 +00:00
|
|
|
}
|
2019-09-03 08:41:37 +00:00
|
|
|
return NULL;
|
2019-07-22 20:32:33 +00:00
|
|
|
}
|
|
|
|
/*}}}*/
|