2012-03-18 21:45:56 -03:00
|
|
|
#!/usr/bin/perl
|
|
|
|
#
|
|
|
|
# zstack.pl - Convert 2.5D paths into a stack with limited Z steps
|
|
|
|
#
|
|
|
|
# Written 2012 by Werner Almesberger
|
|
|
|
# Copyright 2012 Werner Almesberger
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
sub usage
|
|
|
|
{
|
2012-03-18 23:20:27 -03:00
|
|
|
print STDERR "usage: $0 [-r] z-start z-maxstep [file ...]\n";
|
2012-03-19 15:21:24 -03:00
|
|
|
print STDERR " -r reverse Z stacking. Also swaps X and Y.\n";
|
2012-03-18 21:45:56 -03:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sub issue
|
|
|
|
{
|
2012-03-20 23:13:35 -03:00
|
|
|
local ($c, $z) = @_;
|
2012-03-18 21:45:56 -03:00
|
|
|
my $t;
|
|
|
|
|
|
|
|
#
|
|
|
|
# The order here is a bit arbitrary. We sort to make the outcome
|
|
|
|
# more predictable but it shouldn't really matter.
|
|
|
|
#
|
2012-03-20 23:13:35 -03:00
|
|
|
|
|
|
|
($t = $z{$c}) =~ s/\s+-?\d+(\.\d*)?$/ $z/mg;
|
|
|
|
print $t;
|
2012-03-18 21:45:56 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-03-18 23:20:27 -03:00
|
|
|
if ($ARGV[0] eq "-r") {
|
|
|
|
shift @ARGV;
|
|
|
|
$reverse = 1;
|
|
|
|
}
|
2012-03-19 15:21:24 -03:00
|
|
|
&usage if $ARGV[0] =~ /^-[^0-9]/;
|
2012-03-18 23:20:27 -03:00
|
|
|
|
2012-03-18 21:45:56 -03:00
|
|
|
$z0 = shift @ARGV;
|
|
|
|
$zs = shift @ARGV;
|
|
|
|
|
|
|
|
$z0 =~ s/mm$//;
|
|
|
|
$zs =~ s/mm$//;
|
|
|
|
|
|
|
|
&usage unless $zs > 0;
|
|
|
|
|
|
|
|
while (<>) {
|
|
|
|
if (/^\s*$/) {
|
|
|
|
$z{$z} .= "$s\n";
|
|
|
|
undef $s;
|
|
|
|
}
|
2013-11-07 04:55:57 -03:00
|
|
|
if (/^(-?\d+(\.\d*)?)\s+(-?\d+(\.\d*)?)\s+(-?\d+(\.\d*)?)/) {
|
2013-11-06 20:28:47 -03:00
|
|
|
$x = $1 unless defined $x;
|
2013-11-07 04:55:57 -03:00
|
|
|
$y = $3 unless defined $y;
|
|
|
|
$z = $5;
|
2013-11-06 20:28:47 -03:00
|
|
|
}
|
2012-03-18 21:45:56 -03:00
|
|
|
$s .= $_;
|
2012-03-18 23:20:27 -03:00
|
|
|
$zmax = $z if $z > $zmax || !defined $zmax;
|
2012-03-18 21:45:56 -03:00
|
|
|
}
|
|
|
|
$z{$z} .= "$s\n";
|
|
|
|
|
2012-03-18 23:20:27 -03:00
|
|
|
if ($reverse) {
|
|
|
|
for (keys %z) {
|
|
|
|
($t{$zmax-$_} = $z{$_}) =~
|
|
|
|
s/^(-?\d+(\.\d*)?)\s+(-?\d+(\.\d*)?)\s+/$3 $1 /mg;
|
|
|
|
}
|
|
|
|
%z = %t;
|
|
|
|
}
|
|
|
|
|
2013-11-06 20:28:47 -03:00
|
|
|
print "$x $y $z0\n\n";
|
|
|
|
|
2012-03-18 21:45:56 -03:00
|
|
|
$z = $z0;
|
|
|
|
for $c (sort { $b <=> $a } keys %z) {
|
|
|
|
while ($z > $c+$zs) {
|
|
|
|
$z -= $zs;
|
2012-03-20 23:13:35 -03:00
|
|
|
&issue($c, $z);
|
2012-03-18 21:45:56 -03:00
|
|
|
}
|
|
|
|
$z = $c;
|
2012-03-20 23:13:35 -03:00
|
|
|
&issue($c, $z);
|
2012-03-18 21:45:56 -03:00
|
|
|
}
|