mirror of
git://projects.qi-hardware.com/eda-tools.git
synced 2024-11-29 11:56:15 +02:00
eeshow/gfx/cro.c: support PDF TOC addition; option -T to suppress it
This commit is contained in:
parent
71d03c7281
commit
5fd877a6f8
@ -28,6 +28,7 @@
|
|||||||
#include "gfx/text.h"
|
#include "gfx/text.h"
|
||||||
#include "gfx/gfx.h"
|
#include "gfx/gfx.h"
|
||||||
#include "gfx/record.h"
|
#include "gfx/record.h"
|
||||||
|
#include "gfx/pdftoc.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "gfx/cro.h"
|
#include "gfx/cro.h"
|
||||||
|
|
||||||
@ -55,6 +56,9 @@ struct cro_ctx {
|
|||||||
|
|
||||||
const char *output_name;
|
const char *output_name;
|
||||||
|
|
||||||
|
bool add_toc;
|
||||||
|
struct pdftoc *toc;
|
||||||
|
|
||||||
int color_override; /* FIG color, COLOR_NONE if no override */
|
int color_override; /* FIG color, COLOR_NONE if no override */
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -273,6 +277,8 @@ static struct cro_ctx *new_cc(void)
|
|||||||
|
|
||||||
cc->output_name = NULL;
|
cc->output_name = NULL;
|
||||||
|
|
||||||
|
cc->add_toc = 1;
|
||||||
|
cc->toc = NULL;
|
||||||
/*
|
/*
|
||||||
* record_init does not perform allocations or such, so it's safe to
|
* record_init does not perform allocations or such, so it's safe to
|
||||||
* call it here even if we don't use this facility.
|
* call it here even if we don't use this facility.
|
||||||
@ -288,7 +294,7 @@ static struct cro_ctx *init_common(int argc, char *const *argv)
|
|||||||
struct cro_ctx *cc = new_cc();
|
struct cro_ctx *cc = new_cc();
|
||||||
char c;
|
char c;
|
||||||
|
|
||||||
while ((c = getopt(argc, argv, "o:s:")) != EOF)
|
while ((c = getopt(argc, argv, "o:s:T")) != EOF)
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'o':
|
case 'o':
|
||||||
cc->output_name = optarg;
|
cc->output_name = optarg;
|
||||||
@ -296,6 +302,9 @@ static struct cro_ctx *init_common(int argc, char *const *argv)
|
|||||||
case 's':
|
case 's':
|
||||||
cc->scale = atof(optarg) * DEFAULT_SCALE;
|
cc->scale = atof(optarg) * DEFAULT_SCALE;
|
||||||
break;
|
break;
|
||||||
|
case 'T':
|
||||||
|
cc->add_toc = 0;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
usage(*argv);
|
usage(*argv);
|
||||||
}
|
}
|
||||||
@ -353,6 +362,16 @@ static cairo_status_t stream_to_stdout(void *closure,
|
|||||||
/* ----- PDF (auto-sizing, using redraw) ----------------------------------- */
|
/* ----- PDF (auto-sizing, using redraw) ----------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
|
static cairo_status_t stream_to_pdftoc(void *closure,
|
||||||
|
const unsigned char *data, unsigned length)
|
||||||
|
{
|
||||||
|
struct cro_ctx *cc = closure;
|
||||||
|
|
||||||
|
return pdftoc_write(cc->toc, data, length) ?
|
||||||
|
CAIRO_STATUS_SUCCESS : CAIRO_STATUS_WRITE_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void *cr_pdf_init(int argc, char *const *argv)
|
static void *cr_pdf_init(int argc, char *const *argv)
|
||||||
{
|
{
|
||||||
struct cro_ctx *cc;
|
struct cro_ctx *cc;
|
||||||
@ -364,10 +383,22 @@ static void *cr_pdf_init(int argc, char *const *argv)
|
|||||||
cc->s = cairo_pdf_surface_create(NULL, 16, 16);
|
cc->s = cairo_pdf_surface_create(NULL, 16, 16);
|
||||||
cc->cr = cairo_create(cc->s);
|
cc->cr = cairo_create(cc->s);
|
||||||
|
|
||||||
|
if (cc->add_toc)
|
||||||
|
cc->toc = pdftoc_begin(cc->output_name);
|
||||||
|
|
||||||
return cc;
|
return cc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void cr_pdf_sheet_name(void *ctx, const char *name)
|
||||||
|
{
|
||||||
|
struct cro_ctx *cc = ctx;
|
||||||
|
|
||||||
|
if (cc->toc)
|
||||||
|
pdftoc_title(cc->toc, name ? name : "???");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void cr_pdf_new_sheet(void *ctx)
|
static void cr_pdf_new_sheet(void *ctx)
|
||||||
{
|
{
|
||||||
struct cro_ctx *cc = ctx;
|
struct cro_ctx *cc = ctx;
|
||||||
@ -389,7 +420,10 @@ static void cr_pdf_end(void *ctx)
|
|||||||
|
|
||||||
end_common(cc, &w, &h, NULL, NULL);
|
end_common(cc, &w, &h, NULL, NULL);
|
||||||
|
|
||||||
if (cc->output_name)
|
if (cc->toc)
|
||||||
|
cc->s = cairo_pdf_surface_create_for_stream(stream_to_pdftoc,
|
||||||
|
cc, w, h);
|
||||||
|
else if (cc->output_name)
|
||||||
cc->s = cairo_pdf_surface_create(cc->output_name, w, h);
|
cc->s = cairo_pdf_surface_create(cc->output_name, w, h);
|
||||||
else
|
else
|
||||||
cc->s = cairo_pdf_surface_create_for_stream(stream_to_stdout,
|
cc->s = cairo_pdf_surface_create_for_stream(stream_to_stdout,
|
||||||
@ -419,6 +453,10 @@ static void cr_pdf_end(void *ctx)
|
|||||||
|
|
||||||
cairo_surface_destroy(cc->s);
|
cairo_surface_destroy(cc->s);
|
||||||
cairo_destroy(cc->cr);
|
cairo_destroy(cc->cr);
|
||||||
|
|
||||||
|
if (cc->toc)
|
||||||
|
pdftoc_end(cc->toc);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -597,6 +635,7 @@ const struct gfx_ops cro_pdf_ops = {
|
|||||||
.text = record_text,
|
.text = record_text,
|
||||||
.text_width = cr_text_width,
|
.text_width = cr_text_width,
|
||||||
.init = cr_pdf_init,
|
.init = cr_pdf_init,
|
||||||
|
.sheet_name = cr_pdf_sheet_name,
|
||||||
.new_sheet = cr_pdf_new_sheet,
|
.new_sheet = cr_pdf_new_sheet,
|
||||||
.end = cr_pdf_end,
|
.end = cr_pdf_end,
|
||||||
};
|
};
|
||||||
|
@ -78,9 +78,10 @@ void usage(const char *name)
|
|||||||
" -s scale scale by indicated factor (default: 1.0)\n"
|
" -s scale scale by indicated factor (default: 1.0)\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Cairo PDF driver spec:\n"
|
"Cairo PDF driver spec:\n"
|
||||||
" pdf [-o output.pdf] [-s scale]\n"
|
" pdf [-o output.pdf] [-s scale] [-T]\n"
|
||||||
"\n"
|
"\n"
|
||||||
" see PNG\n"
|
" see PNG for -o and -s\n"
|
||||||
|
" -T do not add table of contents\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Diff driver spec:\n"
|
"Diff driver spec:\n"
|
||||||
" diff [-o output.pdf] [-s scale] [file.lib ...] file.sch\n"
|
" diff [-o output.pdf] [-s scale] [file.lib ...] file.sch\n"
|
||||||
|
Loading…
Reference in New Issue
Block a user