summaryrefslogtreecommitdiff
path: root/app/xterm/print.c
diff options
context:
space:
mode:
Diffstat (limited to 'app/xterm/print.c')
-rw-r--r--app/xterm/print.c217
1 files changed, 106 insertions, 111 deletions
diff --git a/app/xterm/print.c b/app/xterm/print.c
index 555b41a40..7ea1c8e1a 100644
--- a/app/xterm/print.c
+++ b/app/xterm/print.c
@@ -1,8 +1,4 @@
-/* $XTermId: print.c,v 1.81 2009/01/09 01:43:01 tom Exp $ */
-
-/*
- * $XFree86: xc/programs/xterm/print.c,v 1.24 2006/06/19 00:36:51 dickey Exp $
- */
+/* $XTermId: print.c,v 1.105 2009/08/07 00:25:10 tom Exp $ */
/************************************************************
@@ -61,22 +57,30 @@ authorization.
#define VMS_TEMP_PRINT_FILE "sys$scratch:xterm_print.txt"
#endif
-static void charToPrinter(unsigned chr);
-static void printLine(int row, unsigned chr);
-static void send_CharSet(int row);
-static void send_SGR(unsigned attr, unsigned fg, unsigned bg);
-static void stringToPrinter(char *str);
+static void charToPrinter(XtermWidget /* xw */ ,
+ unsigned /* chr */ );
+static void printLine(XtermWidget /* xw */ ,
+ int /* row */ ,
+ unsigned /* chr */ );
+static void send_CharSet(XtermWidget /* xw */ ,
+ LineData * /* ld */ );
+static void send_SGR(XtermWidget /* xw */ ,
+ unsigned /* attr */ ,
+ unsigned /* fg */ ,
+ unsigned /* bg */ );
+static void stringToPrinter(XtermWidget /* xw */ ,
+ char * /*str */ );
static FILE *Printer;
static pid_t Printer_pid;
static int initialized;
static void
-closePrinter(void)
+closePrinter(XtermWidget xw GCC_UNUSED)
{
- if (xtermHasPrinter() != 0) {
+ if (xtermHasPrinter(xw) != 0) {
#ifdef VMS
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
char pcommand[256];
(void) sprintf(pcommand, "%s %s;",
@@ -103,12 +107,12 @@ closePrinter(void)
}
static void
-printCursorLine(void)
+printCursorLine(XtermWidget xw)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
TRACE(("printCursorLine\n"));
- printLine(screen->cur_row, '\n');
+ printLine(xw, screen->cur_row, '\n');
}
#define NO_COLOR ((unsigned)-1)
@@ -119,85 +123,71 @@ printCursorLine(void)
* characters that xterm would allow as a selection (which may include blanks).
*/
static void
-printLine(int row, unsigned chr)
+printLine(XtermWidget xw, int row, unsigned chr)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
int inx = ROW2INX(screen, row);
- Char *c = SCRN_BUF_CHARS(screen, inx);
- Char *a = SCRN_BUF_ATTRS(screen, inx);
+ LineData *ld;
Char attr = 0;
unsigned ch;
int last = MaxCols(screen);
int col;
#if OPT_ISO_COLORS && OPT_PRINT_COLORS
-#if OPT_EXT_COLORS
- Char *fbf = 0;
- Char *fbb = 0;
-#define ColorOf(col) (unsigned)((fbf[col] << 8) | fbb[col])
-#else
- Char *fb = 0;
-#define ColorOf(col) (fb[col])
-#endif
+ CellColor *fb = 0;
+#define ColorOf(ld,col) (ld->color[col])
#endif
unsigned fg = NO_COLOR, last_fg = NO_COLOR;
unsigned bg = NO_COLOR, last_bg = NO_COLOR;
int cs = CSET_IN;
int last_cs = CSET_IN;
+ ld = getLineData(screen, inx);
TRACE(("printLine(row=%d/%d, top=%d:%d, chr=%d):%s\n",
row, ROW2INX(screen, row), screen->topline, screen->max_row, chr,
- visibleChars(PAIRED_CHARS(c,
- (screen->utf8_mode
- ? SCRN_BUF_WIDEC(screen, inx)
- : 0)),
- (unsigned) last)));
-
- if_OPT_EXT_COLORS(screen, {
- fbf = SCRN_BUF_FGRND(screen, inx);
- fbb = SCRN_BUF_BGRND(screen, inx);
- });
- if_OPT_ISO_TRADITIONAL_COLORS(screen, {
- fb = SCRN_BUF_COLOR(screen, inx);
+ visibleIChars(ld->charData, (unsigned) last)));
+
+ if_OPT_ISO_COLORS(screen, {
+ fb = ld->color;
});
while (last > 0) {
- if ((a[last - 1] & CHARDRAWN) == 0)
+ if ((ld->attribs[last - 1] & CHARDRAWN) == 0)
last--;
else
break;
}
if (last) {
if (screen->print_attributes) {
- send_CharSet(row);
- send_SGR(0, NO_COLOR, NO_COLOR);
+ send_CharSet(xw, ld);
+ send_SGR(xw, 0, NO_COLOR, NO_COLOR);
}
for (col = 0; col < last; col++) {
- ch = c[col];
+ ch = ld->charData[col];
if_OPT_WIDE_CHARS(screen, {
ch = XTERM_CELL(row, col);
});
#if OPT_PRINT_COLORS
if (screen->colorMode) {
if (screen->print_attributes > 1) {
- fg = (a[col] & FG_COLOR)
- ? extract_fg(term, ColorOf(col), a[col])
+ fg = (ld->attribs[col] & FG_COLOR)
+ ? extract_fg(xw, ColorOf(ld, col), ld->attribs[col])
: NO_COLOR;
- bg = (a[col] & BG_COLOR)
- ? extract_bg(term, ColorOf(col), a[col])
+ bg = (ld->attribs[col] & BG_COLOR)
+ ? extract_bg(xw, ColorOf(ld, col), ld->attribs[col])
: NO_COLOR;
}
}
#endif
- if ((((a[col] & SGR_MASK) != attr)
+ if ((((ld->attribs[col] & SGR_MASK) != attr)
#if OPT_PRINT_COLORS
|| (last_fg != fg) || (last_bg != bg)
#endif
)
&& ch) {
- attr = CharOf(a[col] & SGR_MASK);
+ attr = CharOf(ld->attribs[col] & SGR_MASK);
last_fg = fg;
last_bg = bg;
if (screen->print_attributes)
- send_SGR(attr, fg, bg);
+ send_SGR(xw, attr, fg, bg);
}
if (ch == 0)
@@ -211,7 +201,8 @@ printLine(int row, unsigned chr)
cs = (ch >= ' ' && ch != ANSI_DEL) ? CSET_IN : CSET_OUT;
if (last_cs != cs) {
if (screen->print_attributes) {
- charToPrinter((unsigned) ((cs == CSET_OUT)
+ charToPrinter(xw,
+ (unsigned) ((cs == CSET_OUT)
? SHIFT_OUT
: SHIFT_IN));
}
@@ -223,34 +214,38 @@ printLine(int row, unsigned chr)
* corresponding charset information is not encoded
* into the CSETS array.
*/
- charToPrinter(((cs == CSET_OUT)
+ charToPrinter(xw,
+ ((cs == CSET_OUT)
? (ch == ANSI_DEL ? 0x5f : (ch + 0x5f))
: ch));
if_OPT_WIDE_CHARS(screen, {
- int off;
- for (off = OFF_FINAL; off < MAX_PTRS; off += 2) {
- if ((ch = XTERM_CELLC(row, col, off)) == 0)
+ size_t off;
+ for_each_combData(off, ld) {
+ ch = XTERM_CELLC(row, col, off);
+ if (ch == 0)
break;
- charToPrinter(ch);
+ charToPrinter(xw, ch);
}
});
}
if (screen->print_attributes) {
- send_SGR(0, NO_COLOR, NO_COLOR);
+ send_SGR(xw, 0, NO_COLOR, NO_COLOR);
if (cs != CSET_IN)
- charToPrinter(SHIFT_IN);
+ charToPrinter(xw, SHIFT_IN);
}
}
if (screen->print_attributes)
- charToPrinter('\r');
- charToPrinter(chr);
+ charToPrinter(xw, '\r');
+ charToPrinter(xw, chr);
+
+ return;
}
void
-xtermPrintScreen(Bool use_DECPEX)
+xtermPrintScreen(XtermWidget xw, Bool use_DECPEX)
{
- if (XtIsRealized((Widget) term)) {
- TScreen *screen = TScreenOf(term);
+ if (XtIsRealized((Widget) xw)) {
+ TScreen *screen = TScreenOf(xw);
Bool extent = (use_DECPEX && screen->printer_extent);
int top = extent ? 0 : screen->top_marg;
int bot = extent ? screen->max_row : screen->bot_marg;
@@ -259,12 +254,12 @@ xtermPrintScreen(Bool use_DECPEX)
TRACE(("xtermPrintScreen, rows %d..%d\n", top, bot));
while (top <= bot)
- printLine(top++, '\n');
+ printLine(xw, top++, '\n');
if (screen->printer_formfeed)
- charToPrinter('\f');
+ charToPrinter(xw, '\f');
if (!was_open || screen->printer_autoclose) {
- closePrinter();
+ closePrinter(xw);
}
} else {
Bell(XkbBI_MinorError, 0);
@@ -276,36 +271,35 @@ xtermPrintScreen(Bool use_DECPEX)
* the normal screen plus all scrolled-back lines. The distinction is made
* because the normal screen's buffer is part of the overall scrollback buffer.
*/
-static void
-xtermPrintEverything(void)
+void
+xtermPrintEverything(XtermWidget xw)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
int top = 0;
int bot = screen->max_row;
int was_open = initialized;
- if (!screen->altbuf)
+ if (!screen->whichBuf)
top = -screen->savedlines;
TRACE(("xtermPrintEverything, rows %d..%d\n", top, bot));
while (top <= bot)
- printLine(top++, '\n');
+ printLine(xw, top++, '\n');
if (screen->printer_formfeed)
- charToPrinter('\f');
+ charToPrinter(xw, '\f');
if (!was_open || screen->printer_autoclose) {
- closePrinter();
+ closePrinter(xw);
}
}
static void
-send_CharSet(int row)
+send_CharSet(XtermWidget xw, LineData * ld)
{
#if OPT_DEC_CHRSET
- TScreen *screen = TScreenOf(term);
char *msg = 0;
- switch (SCRN_BUF_CSETS(screen, row)[0]) {
+ switch (GetLineDblCS(ld)) {
case CSET_SWL:
msg = "\033#5";
break;
@@ -320,14 +314,15 @@ send_CharSet(int row)
break;
}
if (msg != 0)
- stringToPrinter(msg);
+ stringToPrinter(xw, msg);
#else
- (void) row;
+ (void) xw;
+ (void) ld;
#endif /* OPT_DEC_CHRSET */
}
static void
-send_SGR(unsigned attr, unsigned fg, unsigned bg)
+send_SGR(XtermWidget xw, unsigned attr, unsigned fg, unsigned bg)
{
char msg[80];
strcpy(msg, "\033[0");
@@ -345,7 +340,7 @@ send_SGR(unsigned attr, unsigned fg, unsigned bg)
}
if (fg != NO_COLOR) {
#if OPT_PC_COLORS
- if (term->screen.boldColors
+ if (xw->screen.boldColors
&& fg > 8
&& (attr & BOLD) != 0)
fg -= 8;
@@ -357,18 +352,18 @@ send_SGR(unsigned attr, unsigned fg, unsigned bg)
(void) fg;
#endif
strcat(msg, "m");
- stringToPrinter(msg);
+ stringToPrinter(xw, msg);
}
/*
* This implementation only knows how to write to a pipe.
*/
static void
-charToPrinter(unsigned chr)
+charToPrinter(XtermWidget xw, unsigned chr)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
- if (!initialized && xtermHasPrinter()) {
+ if (!initialized && xtermHasPrinter(xw)) {
#if defined(VMS)
/*
* This implementation only knows how to write to a file. When the
@@ -440,10 +435,10 @@ charToPrinter(unsigned chr)
}
static void
-stringToPrinter(char *str)
+stringToPrinter(XtermWidget xw, char *str)
{
while (*str)
- charToPrinter(CharOf(*str++));
+ charToPrinter(xw, CharOf(*str++));
}
/*
@@ -453,39 +448,39 @@ stringToPrinter(char *str)
* Corp., March 1987).
*/
void
-xtermMediaControl(int param, int private_seq)
+xtermMediaControl(XtermWidget xw, int param, int private_seq)
{
TRACE(("MediaCopy param=%d, private=%d\n", param, private_seq));
if (private_seq) {
switch (param) {
case 1:
- printCursorLine();
+ printCursorLine(xw);
break;
case 4:
- setPrinterControlMode(0);
+ setPrinterControlMode(xw, 0);
break;
case 5:
- setPrinterControlMode(1);
+ setPrinterControlMode(xw, 1);
break;
case 10: /* VT320 */
- xtermPrintScreen(False);
+ xtermPrintScreen(xw, False);
break;
case 11: /* VT320 */
- xtermPrintEverything();
+ xtermPrintEverything(xw);
break;
}
} else {
switch (param) {
case -1:
case 0:
- xtermPrintScreen(True);
+ xtermPrintScreen(xw, True);
break;
case 4:
- setPrinterControlMode(0);
+ setPrinterControlMode(xw, 0);
break;
case 5:
- setPrinterControlMode(2);
+ setPrinterControlMode(xw, 2);
break;
}
}
@@ -498,13 +493,13 @@ xtermMediaControl(int param, int private_seq)
* or VT) that moved the cursor off the previous line.
*/
void
-xtermAutoPrint(unsigned chr)
+xtermAutoPrint(XtermWidget xw, unsigned chr)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
if (screen->printer_controlmode == 1) {
TRACE(("AutoPrint %d\n", chr));
- printLine(screen->cursorp.row, chr);
+ printLine(xw, screen->cursorp.row, chr);
if (Printer != 0)
fflush(Printer);
}
@@ -523,9 +518,9 @@ xtermAutoPrint(unsigned chr)
#define LB '['
int
-xtermPrinterControl(int chr)
+xtermPrinterControl(XtermWidget xw, int chr)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
/* *INDENT-OFF* */
static struct {
Char seq[5];
@@ -562,10 +557,10 @@ xtermPrinterControl(int chr)
if (length == len
&& Strcmp(bfr, tbl[n].seq) == 0) {
- setPrinterControlMode(tbl[n].active);
+ setPrinterControlMode(xw, tbl[n].active);
if (screen->printer_autoclose
&& screen->printer_controlmode == 0)
- closePrinter();
+ closePrinter(xw);
length = 0;
return 0;
} else if (len > length
@@ -579,7 +574,7 @@ xtermPrinterControl(int chr)
default:
for (n = 0; n < length; n++)
- charToPrinter(bfr[n]);
+ charToPrinter(xw, bfr[n]);
bfr[0] = CharOf(chr);
length = 1;
return 0;
@@ -590,9 +585,9 @@ xtermPrinterControl(int chr)
* If there is no printer command, we will ignore printer controls.
*/
Bool
-xtermHasPrinter(void)
+xtermHasPrinter(XtermWidget xw)
{
- TScreen *screen = TScreenOf(term);
+ TScreen *screen = TScreenOf(xw);
return (strlen(screen->printer_command) != 0);
}
@@ -605,18 +600,18 @@ xtermHasPrinter(void)
: "printer controller"))
void
-setPrinterControlMode(int mode)
+setPrinterControlMode(XtermWidget xw, int mode)
{
- if (xtermHasPrinter()
- && term->screen.printer_controlmode != mode) {
+ if (xtermHasPrinter(xw)
+ && xw->screen.printer_controlmode != mode) {
TRACE(("%s %s mode\n",
(mode
? "set"
: "reset"),
(mode
? showPrinterControlMode(mode)
- : showPrinterControlMode(term->screen.printer_controlmode))));
- term->screen.printer_controlmode = mode;
+ : showPrinterControlMode(xw->screen.printer_controlmode))));
+ xw->screen.printer_controlmode = mode;
update_print_redir();
}
}