mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 12:41:20 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			54 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			54 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__
 | 
