Michael-F-Bryan / gcodes

A basic C# gcode parser and interpreter
https://michael-f-bryan.github.io/gcodes/
MIT License
31 stars 9 forks source link

Gcodes

Build status

A basic C# gcode parser and interpreter.

Getting Started

Once you've downloaded a copy of the repository (e.g. as a git submodule), you should be able to start using the gcodes library by asking Visual Studio to add a reference to it.

Analysing Gcode Programs

If you just want to inspect a gcode program without doing any simulation you just need to run the Parser and inspect its output.

Parsing the input text takes place in two steps:

public static void ParseGcodeFile(string filename) {
    string src = File.ReadAllText(filename);

    var lexer = new Lexer(src);
    List<Token> tokens = lexer.Tokenize().ToList();

    var parser = new Parser(tokens);
    List<Code> gcodes = parser.Parse().ToList();

    // do something with the gcodes
}

Note: For convenience, Parser also has a constructor which accepts a string and will tokenize everything for you.

There is no guarantee that every argument is provided to a gcode, therefore if you want to fetch an argument's value (e.g. X or feed rate) you can use the ValueFor() method. This will search the arguments provided to a particular gcode for the specified ArgumentKind, and return its value.

Simulating A CNC Machine