55 lines
1.1 KiB
Perl
Executable File
55 lines
1.1 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
# This script reads a file and outputs information about it
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
BEGIN {
|
|
use FindBin;
|
|
use lib "$FindBin::Bin/../lib";
|
|
}
|
|
|
|
use File::Basename qw(basename);
|
|
use Getopt::Long qw(:config no_auto_abbrev);
|
|
use Slic3r;
|
|
$|++;
|
|
|
|
my %opt = ();
|
|
{
|
|
my %options = (
|
|
'help' => sub { usage() },
|
|
);
|
|
GetOptions(%options) or usage(1);
|
|
$ARGV[0] or usage(1);
|
|
}
|
|
|
|
{
|
|
my $input_file = $ARGV[0];
|
|
die "This script doesn't support AMF yet\n" if $input_file =~ /\.amf$/i;
|
|
|
|
my $model;
|
|
$model = Slic3r::Format::STL->read_file($input_file) if $input_file =~ /\.stl$/i;
|
|
die "Unable to read file\n" if !$model;
|
|
|
|
printf "Info about %s:\n", basename($input_file);
|
|
my $mesh = $model->mesh;
|
|
$mesh->check_manifoldness;
|
|
printf " number of facets: %d\n", scalar @{$mesh->facets};
|
|
printf " size: x=%s y=%s z=%s\n", $mesh->size;
|
|
}
|
|
|
|
|
|
sub usage {
|
|
my ($exit_code) = @_;
|
|
|
|
print <<"EOF";
|
|
Usage: file_info.pl [ OPTIONS ] file.stl
|
|
|
|
--help Output this usage screen and exit
|
|
|
|
EOF
|
|
exit ($exit_code || 0);
|
|
}
|
|
|
|
__END__
|