added basic information about project
[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/^(\x00*)\x1B//;
24         warn "WARNING: ", length($1), " extra nulls before ESC\n" if $1;
25         chomp;
26         my @a = split(/;/,$_);
27         my $c = shift @a;
28         if ( $c eq 'Pmi' ) {
29                 my $f = $a[0] || die 'missing feeder';
30                 print "feeder $f | $feeder->{$f}\n";
31                 $a[1] eq 's' or die;
32         } elsif ( $c eq 'Pc' ) {
33                 my $color = $a[0];
34                 $a[1] eq '=' or die;
35                 my $temperature = $a[2];
36                 print "temperature $color = $temperature\n";
37         } elsif ( $c eq 'Pr' ) {
38                 print "improve $a[0]\n";
39                 # FIXME windows sends it, cups doesn't
40         } elsif ( $c eq 'Sv' ) {
41                 print "even page on duplex printing\n";
42         } elsif ( $c eq 'Db' ) { # XXX not in cups
43                 my ( $color, $two, $data ) = @a;
44                 $two eq '2' or die '2';
45                 my $path = "page-Db-$color-$page.pbm";
46                 $page++;
47                 save_pbm $path, 648, 1015, $data;       # FIXME 1016?
48         } elsif ( $c eq 'Dbc' ) { # XXX not in cups
49                 my ( $color, $line, $len, $comp ) = @a;
50                 while ( $len > length($comp) ) {
51                         warn "# slurp more ",length($comp), " < $len\n";
52                         $comp .= <>;
53                 }
54                 $len == length $comp or warn "wrong length $len != ", length $comp;
55
56                 my $w = 648 / 2;
57
58 =for non-working
59
60                 my $data;
61
62                 my $i = 0;
63                 while ( $i < length $comp ) {
64                         my $len = ord(substr($comp,$i,4));
65                         $i += 1;
66                         warn "$i comp $len\n";
67                         $data .= substr($comp,$i,$len);
68                         $data .= "\x00" x ( $w - $len );
69                         $i += $len;
70                 }
71
72 =cut
73
74                 my $data = $comp;
75
76                 my $path = "page-Dbc-$color-$page.pbm";
77                 $page++;
78
79                 my $h = int( $len / 128 );
80                 save_pbm $path, $w, $h, $data;
81
82         } else {
83                 warn "UNKNOWN: $c ", dump(@a);
84         }
85 }
86
87 sub save_pbm {
88         my ( $path, $w, $h, $data ) = @_;
89         open(my $pbm, '>', $path);
90         print $pbm "P4\n$w $h\n", $data;
91         close($pbm);
92         print "saved $path $w * $h size ", -s $path, "\n";
93 }