MrKWatkins.Ast Help

MrKWatkins.Ast

Build Status NuGet Version and Download Count

Background

As part of my Oakley project to create a compiler, and it's associated OakAsm project to create an assembler (details coming soon), I needed to represent abstract syntax trees in C#. This library was created so that I could share the code between those two projects.

Usage

Create a base node type for your abstract syntax tree:

public abstract class Expression : Node<Expression> { }

Create more specific nodes:

public sealed class ConstantNumber : Expression { public ConstantNumber(int value) { Value = value; } public int Value { get => Properties.GetOrThrow<int>(nameof(Value)); init => Properties.Set(nameof(Value), value); } } public sealed class Addition : Expression { public Addition(ConstantNumber x, ConstantNumber y) { Children.Add(x); Children.Add(y); } }

Walk the tree:

var fifty = new ConstantNumber(50); var sixty = new ConstantNumber(60); var expression = new Addition(fifty, sixty); var allNodes = expression.ThisAndDescendents; var fiftyAndParent = fifty.ThisAndAncestors; var fiftyAndSixty = fifty.ThisAndNextSiblings; var justSixty = sixty.PreviousSibling; var result = expression.Children.OfType<ConstantNumber>().Sum(n => n.Value);

Mark nodes with errors, warnings and info messages:

sixty.AddError("Value must be less than 55."); var expressionHasErrors = expression.HasErrors; // true.

Associate nodes with their position in source code during parsing:

var source = new TextFile(new FileInfo("MySource.code")); // Contains "50 + 60". expression.SourcePosition = source.CreatePosition(0, 7, 0, 0); // startIndex, length, startLineIndex, startColumnIndex. fifty.SourcePosition = source.CreatePosition(0, 2, 0, 0); sixty.SourcePosition = source.CreatePosition(5, 2, 0, 5);

Output errors with highlighted source information:

var errors = MessageFormatter.FormatErrors(expression); // MySource.code (1, 6): Error: Parent Value must be less than 55. // 50 + 60 // --

Manipulate and copy the tree:

sixty.ReplaceWith(new ConstantNumber(55)); var copy = expression.Copy();

Full documentation will be available with version 1.0.x.

Install

dotnet add package MrKWatkins.Ast

Pull Requests

I'm not accepting pull requests at the current time; this project is tailored for some other projects of mine and I want to get them in a suitable state first.

Feel free to raise issues for bugs or suggestions, but I make no guarantees they will get looked at I'm afraid!

License

MIT

Last modified: 09 September 2024