From 085a818deccba673d057e39100a16f5eeae37b25 Mon Sep 17 00:00:00 2001 From: Alessandro Ranellucci Date: Wed, 11 Apr 2012 19:02:33 +0200 Subject: New file_info.pl script --- utils/file_info.pl | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100755 utils/file_info.pl (limited to 'utils') diff --git a/utils/file_info.pl b/utils/file_info.pl new file mode 100755 index 000000000..36e57e9b0 --- /dev/null +++ b/utils/file_info.pl @@ -0,0 +1,52 @@ +#!/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]; + my $mesh; + $mesh = Slic3r::Format::STL->read_file($input_file) if $input_file =~ /\.stl$/i; + die "This script doesn't support AMF yet\n" if $input_file =~ /\.amf$/i; + die "Unable to read file\n" if !$mesh; + + printf "Info about %s:\n", basename($input_file); + $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__ -- cgit v1.2.3