|
|
0ab051 |
diff --git a/devices/gdev3852.c b/devices/gdev3852.c
|
|
|
0ab051 |
index 2bee8ec..9d99068 100644
|
|
|
0ab051 |
--- a/devices/gdev3852.c
|
|
|
0ab051 |
+++ b/devices/gdev3852.c
|
|
|
0ab051 |
@@ -62,116 +62,117 @@ jetp3852_print_page(gx_device_printer *pdev, FILE *prn_stream)
|
|
|
0ab051 |
#define DATA_SIZE (LINE_SIZE * 8)
|
|
|
0ab051 |
|
|
|
0ab051 |
unsigned int cnt_2prn;
|
|
|
0ab051 |
- unsigned int count,tempcnt;
|
|
|
0ab051 |
- unsigned char vtp,cntc1,cntc2;
|
|
|
0ab051 |
- int line_size_color_plane;
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- byte data[DATA_SIZE];
|
|
|
0ab051 |
- byte plane_data[LINE_SIZE * 3];
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- /* Set initial condition for printer */
|
|
|
0ab051 |
- fputs("\033@",prn_stream);
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- /* Send each scan line in turn */
|
|
|
0ab051 |
- { int lnum;
|
|
|
0ab051 |
- int line_size = gdev_mem_bytes_per_scan_line((gx_device *)pdev);
|
|
|
0ab051 |
- int num_blank_lines = 0;
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- if (line_size > DATA_SIZE) {
|
|
|
0ab051 |
- emprintf2(pdev->memory, "invalid resolution and/or width gives line_size = %d, max. is %d\n",
|
|
|
0ab051 |
- line_size, DATA_SIZE);
|
|
|
0ab051 |
- return_error(gs_error_rangecheck);
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- for ( lnum = 0; lnum < pdev->height; lnum++ )
|
|
|
0ab051 |
- { byte *end_data = data + line_size;
|
|
|
0ab051 |
- gdev_prn_copy_scan_lines(pdev, lnum,
|
|
|
0ab051 |
- (byte *)data, line_size);
|
|
|
0ab051 |
- /* Remove trailing 0s. */
|
|
|
0ab051 |
- while ( end_data > data && end_data[-1] == 0 )
|
|
|
0ab051 |
- end_data--;
|
|
|
0ab051 |
- if ( end_data == data )
|
|
|
0ab051 |
- { /* Blank line */
|
|
|
0ab051 |
- num_blank_lines++;
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- else
|
|
|
0ab051 |
- { int i;
|
|
|
0ab051 |
- byte *odp;
|
|
|
0ab051 |
- byte *row;
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- /* Pad with 0s to fill out the last */
|
|
|
0ab051 |
- /* block of 8 bytes. */
|
|
|
0ab051 |
- memset(end_data, 0, 7);
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- /* Transpose the data to get pixel planes. */
|
|
|
0ab051 |
- for ( i = 0, odp = plane_data; i < DATA_SIZE;
|
|
|
0ab051 |
- i += 8, odp++
|
|
|
0ab051 |
- )
|
|
|
0ab051 |
- { /* The following is for 16-bit machines */
|
|
|
0ab051 |
+ unsigned int count,tempcnt;
|
|
|
0ab051 |
+ unsigned char vtp,cntc1,cntc2;
|
|
|
0ab051 |
+ int line_size_color_plane;
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ byte data[DATA_SIZE];
|
|
|
0ab051 |
+ byte plane_data[LINE_SIZE * 3];
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ /* Initialise data to zeros, otherwise later on, uninitialised bytes in
|
|
|
0ab051 |
+ dp[] can be greater than 7, which breaks spr8[dp[]]. */
|
|
|
0ab051 |
+ memset(data, 0x00, DATA_SIZE);
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ /* Set initial condition for printer */
|
|
|
0ab051 |
+ fputs("\033@",prn_stream);
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ /* Send each scan line in turn */
|
|
|
0ab051 |
+ { int lnum;
|
|
|
0ab051 |
+ int line_size = gdev_mem_bytes_per_scan_line((gx_device *)pdev);
|
|
|
0ab051 |
+ int num_blank_lines = 0;
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ if (line_size > DATA_SIZE) {
|
|
|
0ab051 |
+ emprintf2(pdev->memory, "invalid resolution and/or width gives line_size = %d, max. is %d\n",
|
|
|
0ab051 |
+ line_size, DATA_SIZE);
|
|
|
0ab051 |
+ return_error(gs_error_rangecheck);
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ for ( lnum = 0; lnum < pdev->height; lnum++ )
|
|
|
0ab051 |
+ { byte *end_data = data + line_size;
|
|
|
0ab051 |
+ gdev_prn_copy_scan_lines(pdev, lnum,
|
|
|
0ab051 |
+ (byte *)data, line_size);
|
|
|
0ab051 |
+ /* Remove trailing 0s. */
|
|
|
0ab051 |
+ while ( end_data > data && end_data[-1] == 0 )
|
|
|
0ab051 |
+ end_data--;
|
|
|
0ab051 |
+ if ( end_data == data )
|
|
|
0ab051 |
+ { /* Blank line */
|
|
|
0ab051 |
+ num_blank_lines++;
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ else
|
|
|
0ab051 |
+ { int i;
|
|
|
0ab051 |
+ byte *odp;
|
|
|
0ab051 |
+ byte *row;
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ /* Transpose the data to get pixel planes. */
|
|
|
0ab051 |
+ for ( i = 0, odp = plane_data; i < DATA_SIZE;
|
|
|
0ab051 |
+ i += 8, odp++
|
|
|
0ab051 |
+ )
|
|
|
0ab051 |
+ { /* The following is for 16-bit machines */
|
|
|
0ab051 |
#define spread3(c)\
|
|
|
0ab051 |
{ 0, c, c*0x100, c*0x101, c*0x10000L, c*0x10001L, c*0x10100L, c*0x10101L }
|
|
|
0ab051 |
- static ulong spr40[8] = spread3(0x40);
|
|
|
0ab051 |
- static ulong spr8[8] = spread3(8);
|
|
|
0ab051 |
- static ulong spr2[8] = spread3(2);
|
|
|
0ab051 |
- register byte *dp = data + i;
|
|
|
0ab051 |
- register ulong pword =
|
|
|
0ab051 |
- (spr40[dp[0]] << 1) +
|
|
|
0ab051 |
- (spr40[dp[1]]) +
|
|
|
0ab051 |
- (spr40[dp[2]] >> 1) +
|
|
|
0ab051 |
- (spr8[dp[3]] << 1) +
|
|
|
0ab051 |
- (spr8[dp[4]]) +
|
|
|
0ab051 |
- (spr8[dp[5]] >> 1) +
|
|
|
0ab051 |
- (spr2[dp[6]]) +
|
|
|
0ab051 |
- (spr2[dp[7]] >> 1);
|
|
|
0ab051 |
- odp[0] = (byte)(pword >> 16);
|
|
|
0ab051 |
- odp[LINE_SIZE] = (byte)(pword >> 8);
|
|
|
0ab051 |
- odp[LINE_SIZE*2] = (byte)(pword);
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- /* Skip blank lines if any */
|
|
|
0ab051 |
- if ( num_blank_lines > 0 )
|
|
|
0ab051 |
- {
|
|
|
0ab051 |
- /* Do "dot skips" */
|
|
|
0ab051 |
- while(num_blank_lines > 255)
|
|
|
0ab051 |
- {
|
|
|
0ab051 |
- fputs("\033e\377",prn_stream);
|
|
|
0ab051 |
- num_blank_lines -= 255;
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- vtp = num_blank_lines;
|
|
|
0ab051 |
- fprintf(prn_stream,"\033e%c",vtp);
|
|
|
0ab051 |
- num_blank_lines = 0;
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- /* Transfer raster graphics in the order R, G, B. */
|
|
|
0ab051 |
- /* Apparently it is stored in B, G, R */
|
|
|
0ab051 |
- /* Calculate the amount of data to send by what */
|
|
|
0ab051 |
- /* Ghostscript tells us the scan line_size in (bytes) */
|
|
|
0ab051 |
-
|
|
|
0ab051 |
- count = line_size / 3;
|
|
|
0ab051 |
- line_size_color_plane = count / 3;
|
|
|
0ab051 |
- cnt_2prn = line_size_color_plane * 3 + 5;
|
|
|
0ab051 |
- tempcnt = cnt_2prn;
|
|
|
0ab051 |
- cntc1 = (tempcnt & 0xFF00) >> 8;
|
|
|
0ab051 |
- cntc2 = (tempcnt & 0x00FF);
|
|
|
0ab051 |
- fprintf(prn_stream, "\033[O%c%c\200\037",cntc2,cntc1);
|
|
|
0ab051 |
- fputc('\000',prn_stream);
|
|
|
0ab051 |
+ static ulong spr40[8] = spread3(0x40);
|
|
|
0ab051 |
+ static ulong spr8[8] = spread3(8);
|
|
|
0ab051 |
+ static ulong spr2[8] = spread3(2);
|
|
|
0ab051 |
+ register byte *dp = data + i;
|
|
|
0ab051 |
+ register ulong pword =
|
|
|
0ab051 |
+ (spr40[dp[0]] << 1) +
|
|
|
0ab051 |
+ (spr40[dp[1]]) +
|
|
|
0ab051 |
+ (spr40[dp[2]] >> 1) +
|
|
|
0ab051 |
+ (spr8[dp[3]] << 1) +
|
|
|
0ab051 |
+ (spr8[dp[4]]) +
|
|
|
0ab051 |
+ (spr8[dp[5]] >> 1) +
|
|
|
0ab051 |
+ (spr2[dp[6]]) +
|
|
|
0ab051 |
+ (spr2[dp[7]] >> 1);
|
|
|
0ab051 |
+ odp[0] = (byte)(pword >> 16);
|
|
|
0ab051 |
+ odp[LINE_SIZE] = (byte)(pword >> 8);
|
|
|
0ab051 |
+ odp[LINE_SIZE*2] = (byte)(pword);
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ /* Skip blank lines if any */
|
|
|
0ab051 |
+ if ( num_blank_lines > 0 )
|
|
|
0ab051 |
+ {
|
|
|
0ab051 |
+ /* Do "dot skips" */
|
|
|
0ab051 |
+ while(num_blank_lines > 255)
|
|
|
0ab051 |
+ {
|
|
|
0ab051 |
+ fputs("\033e\377",prn_stream);
|
|
|
0ab051 |
+ num_blank_lines -= 255;
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ vtp = num_blank_lines;
|
|
|
0ab051 |
+ fprintf(prn_stream,"\033e%c",vtp);
|
|
|
0ab051 |
+ num_blank_lines = 0;
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ /* Transfer raster graphics in the order R, G, B. */
|
|
|
0ab051 |
+ /* Apparently it is stored in B, G, R */
|
|
|
0ab051 |
+ /* Calculate the amount of data to send by what */
|
|
|
0ab051 |
+ /* Ghostscript tells us the scan line_size in (bytes) */
|
|
|
0ab051 |
+
|
|
|
0ab051 |
+ count = line_size / 3;
|
|
|
0ab051 |
+ line_size_color_plane = count / 3;
|
|
|
0ab051 |
+ cnt_2prn = line_size_color_plane * 3 + 5;
|
|
|
0ab051 |
+ tempcnt = cnt_2prn;
|
|
|
0ab051 |
+ cntc1 = (tempcnt & 0xFF00) >> 8;
|
|
|
0ab051 |
+ cntc2 = (tempcnt & 0x00FF);
|
|
|
0ab051 |
+ fprintf(prn_stream, "\033[O%c%c\200\037",cntc2,cntc1);
|
|
|
0ab051 |
+ fputc('\000',prn_stream);
|
|
|
0ab051 |
fputs("\124\124",prn_stream);
|
|
|
0ab051 |
|
|
|
0ab051 |
- for ( row = plane_data + LINE_SIZE * 2, i = 0;
|
|
|
0ab051 |
- i < 3; row -= LINE_SIZE, i++ )
|
|
|
0ab051 |
- { int jj;
|
|
|
0ab051 |
- byte ctemp;
|
|
|
0ab051 |
- odp = row;
|
|
|
0ab051 |
- /* Complement bytes */
|
|
|
0ab051 |
- for (jj=0; jj< line_size_color_plane; jj++)
|
|
|
0ab051 |
- { ctemp = *odp;
|
|
|
0ab051 |
- *odp++ = ~ctemp;
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- fwrite(row, sizeof(byte),
|
|
|
0ab051 |
- line_size_color_plane, prn_stream);
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
- }
|
|
|
0ab051 |
+ for ( row = plane_data + LINE_SIZE * 2, i = 0;
|
|
|
0ab051 |
+ i < 3; row -= LINE_SIZE, i++ )
|
|
|
0ab051 |
+ { int jj;
|
|
|
0ab051 |
+ byte ctemp;
|
|
|
0ab051 |
+ odp = row;
|
|
|
0ab051 |
+ /* Complement bytes */
|
|
|
0ab051 |
+ for (jj=0; jj< line_size_color_plane; jj++)
|
|
|
0ab051 |
+ { ctemp = *odp;
|
|
|
0ab051 |
+ *odp++ = ~ctemp;
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ fwrite(row, sizeof(byte),
|
|
|
0ab051 |
+ line_size_color_plane, prn_stream);
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
+ }
|
|
|
0ab051 |
|
|
|
0ab051 |
/* eject page */
|
|
|
0ab051 |
fputs("\014", prn_stream);
|