comment out non-woring decompression
[Printer-EVOLIS.git] / evolis-printer.pl
1 #!/usr/bin/perl
2
3 # Simulate EVOLIS Dualys printer
4
5 use warnings;
6 use strict;
7
8 use Data::Dump qw(dump);
9
10 my $feeder = {qw(
11 F Feeder
12 M Manual
13 B Auto
14 )};
15
16 local $/ = "\r";
17
18 my $page = 1;
19
20 sub save_pbm;
21
22 while(<>) {
23         die "no escape at beginning",dump($_) unless s/^\x1B//;
24         chomp;
25         my @a = split(/;/,$_);
26         my $c = shift @a;
27         if ( $c eq 'Pmi' ) {
28                 my $f = $a[0] || die 'missing feeder';
29                 print "feeder $f | $feeder->{$f}\n";
30                 $a[1] eq 's' or die;
31         } elsif ( $c eq 'Pc' ) {
32                 my $color = $a[0];
33                 $a[1] eq '=' or die;
34                 my $temperature = $a[2];
35                 print "temperature $color = $temperature\n";
36         } elsif ( $c eq 'Pr' ) {
37                 print "improve $a[0]\n";
38                 # FIXME windows sends it, cups doesn't
39         } elsif ( $c eq 'Db' ) { # XXX not in cups
40                 my ( $color, $two, $data ) = @a;
41                 $two eq '2' or die '2';
42                 my $path = "page-Db-$color-$page.pbm";
43                 $page++;
44                 save_pbm $path, 648, 1015, $data;       # FIXME 1016?
45         } elsif ( $c eq 'Dbc' ) { # XXX not in cups
46                 my ( $color, $line, $len, $comp ) = @a;
47                 while ( $len > length($comp) ) {
48                         warn "# slurp more ",length($comp), " < $len\n";
49                         $comp .= <>;
50                 }
51                 $len == length $comp or warn "wrong length $len != ", length $comp;
52
53                 my ( $w, $h ) = ( 646, 1081 );  # from driver
54
55 =for non-working
56
57                 my $data;
58
59                 my $i = 0;
60                 while ( $i < length $comp ) {
61                         my $len = ord(substr($comp,$i,4));
62                         $i += 1;
63                         warn "$i comp $len\n";
64                         $data .= substr($comp,$i,$len);
65                         $data .= "\x00" x ( $w - $len );
66                         $i += $len;
67                 }
68
69 =cut
70
71                 my $data = $comp;
72
73                 my $path = "page-Dbc-$color-$page.pbm";
74                 $page++;
75
76                 #$h = int( length($data) * 8 / $w );
77                 save_pbm $path, $w, $h, $data;
78
79         } else {
80                 warn "UNKNOWN: $c ", dump(@a);
81         }
82 }
83
84 sub save_pbm {
85         my ( $path, $w, $h, $data ) = @_;
86         open(my $pbm, '>', $path);
87         print $pbm "P4\n$w $h\n", $data;
88         close($pbm);
89         print "saved $path $w * $h size ", -s $path, "\n";
90 }