2 # Books of Pumpkins, etc. Extensions to Quacks of Quedlinburg
3 # SPDX-License-Identifier: GPL-3.0-or-later OR CC-BY-SA-4.0
4 # Copyright 2020-2022 Ian Jackson
8 BEGIN { unshift @INC, '.'; }
13 for (@_) { $ps_framing .= $_ }
30 my $vhalf = sqrt( $spacing ** 2 - ($colspacing*0.5) ** 2 );
32 my $y_cut = 2.75 * $spacing;
34 my $x_pl_zero = $paper_x*0.5 - 3*$colspacing;
35 my $y_pl_zero = $y_cut + $spacing - $y_cutd* 0.5 * $x_cut/$colspacing;
37 my $y_top = $y_pl_zero + $y_cutd + $spacing*1.25;
39 sub some_cut_line($) {
49 o <<GS, some_cut_line(<<GR), <<END;
55 0 $y_cut $y_cutd add lineto
77 my $line_word = 'moveto';
83 /Helvetica-Bold findfont 6.5 scalefont setfont
85 foreach (split /\n/, $data) {
89 s{L}{ ($repi == 0 ? 1 : 0) }ge;
90 s{R}{ ($repi == $nrepis-1 ? 1 : 0) }ge;
92 s{V}{ $vhalf / $spacing }ge;
93 my ($x,$y,$money,$veeps,$ruby) = map { eval $_ } split /\s+/;
100 $line .= " $x $y $line_word";
101 $line_word = 'lineto';
102 next unless defined $money;
111 % place $x $y $money $veeps $ruby
114 gsave ${\ chip($anychip, 0) } grestore
115 -4 1 moveto ($money) show
121 newpath -$sqx -$sqy moveto
124 $sqx -$sqy lineto closepath
126 gsave 1 setgray fill grestore
132 ($veeps) dup stringwidth pop -0.5 mul -2.5 rmoveto show
137 $o .= <<END if $ruby;
153 (" newpath $line stroke ", $o)
157 for my $places_i (qw(0 1)) {
158 for my $repi (0..$nrepis-1) {
160 % repi $places_i $repi
162 $repi $colspacing 2 mul mul 0 translate
165 o( (places($repi))[$places_i] );
177 $paper_x $x_cut sub 0 translate
181 o some_cut_line <<END;
184 $paper_x $x_cut sub $y_top lineto
193 print $ps_framing or die $!;