#parser #gerber #file #buf-reader #now #gerber-types #gerber-doc

bin+lib gerber_parser

A simple gerber parser for the gerber-types crate

2 releases

0.1.2 Jun 29, 2022
0.1.1 Jun 29, 2022

#1631 in Parser implementations


Used in gerber2svg

AGPL-3.0

35KB
437 lines

Gerber-parser

A simple gerber parser written in rust to be used with the gerber-types crate.

use std::fs::File;
use std::io::{BufRead, BufReader};
use gerber_parser::parser::parse_gerber;

// open a .gbr file from system
let file = File::open(path).unwrap();
let reader = BufReader::new(file);

// Now we parse the file to a GerberDoc 
let gerber_doc: GerberDoc = parse_gerber(reader);

// it is possible to convert to an 'atomic' representation purely 
// in terms of Vec<Command> of the gerber-types crate
let commands:Vec<Command> = gerber_doc.to_commands();

Current State

⚠️ Note: this package is still in development and does not cover the full Gerber spec

Currently missing

  • All TD, TO commands
  • All AM commands
  • LM, LR, LS commands
  • SR commands
  • AB commands

Partial:

  • The TF and TA commands only support a limited range of arguments; custom attributes will result in an error

In addition, comments in the header section of the file (i.e. unit type declaration, format specification and aperture declarations) will be placed below the header when the parsed Gerber is converted back to string via serialisation.

General to-do

  • Make parsing a bit cleaner, with Result
  • Reduce the number of panics
  • Make error messages clearer
  • Mini-tests for all commands
  • Do proper coordinate check (compatibility with format specification)

Dependencies

~4–5.5MB
~100K SLoC