Source code for stl.main

import sys
import random
import argparse

from . import stl


def _get_parser(description):
    parser = argparse.ArgumentParser(description=description)
    parser.add_argument('infile', nargs='?', type=argparse.FileType('rb'),
                        default=sys.stdin, help='STL file to read')
    parser.add_argument('outfile', nargs='?', type=argparse.FileType('wb'),
                        default=sys.stdout, help='STL file to write')
    parser.add_argument('--name', nargs='?', help='Name of the mesh')
    parser.add_argument(
        '-n', '--use-file-normals', action='store_true',
        help='Read the normals from the file instead of recalculating them')
    parser.add_argument(
        '-r', '--remove-empty-areas', action='store_true',
        help='Remove areas with 0 surface areas to prevent errors during '
        'normal calculation')
    parser.add_argument('-s', '--disable-speedups', action='store_true',
                        help='Disable Cython speedups')
    return parser


def _get_name(args):
    names = [
        args.name,
        getattr(args.outfile, 'name', None),
        getattr(args.infile, 'name', None),
        'numpy-stl-%06d' % random.randint(0, 1e6),
    ]

    for name in names:  # pragma: no branch
        if name and isinstance(name, str) and not name.startswith('<'):
            return name


[docs]def main(): parser = _get_parser('Convert STL files from ascii to binary and back') parser.add_argument('-a', '--ascii', action='store_true', help='Write ASCII file (default is binary)') parser.add_argument('-b', '--binary', action='store_true', help='Force binary file (for TTYs)') args = parser.parse_args() name = _get_name(args) stl_file = stl.StlMesh(filename=name, fh=args.infile, calculate_normals=False, remove_empty_areas=args.remove_empty_areas, speedups=not args.disable_speedups) if args.binary: mode = stl.BINARY elif args.ascii: mode = stl.ASCII else: mode = stl.AUTOMATIC stl_file.save(name, args.outfile, mode=mode, update_normals=not args.use_file_normals)
[docs]def to_ascii(): parser = _get_parser('Convert STL files to ASCII (text) format') args = parser.parse_args() name = _get_name(args) stl_file = stl.StlMesh(filename=name, fh=args.infile, calculate_normals=False, remove_empty_areas=args.remove_empty_areas, speedups=not args.disable_speedups) stl_file.save(name, args.outfile, mode=stl.ASCII, update_normals=not args.use_file_normals)
[docs]def to_binary(): parser = _get_parser('Convert STL files to binary format') args = parser.parse_args() name = _get_name(args) stl_file = stl.StlMesh(filename=name, fh=args.infile, calculate_normals=False, remove_empty_areas=args.remove_empty_areas, speedups=not args.disable_speedups) stl_file.save(name, args.outfile, mode=stl.BINARY, update_normals=not args.use_file_normals)