4 releases (2 breaking)

new 0.3.0 Sep 10, 2024
0.2.3 Sep 9, 2024
0.2.0 Aug 23, 2024
0.1.0 Aug 16, 2024

#970 in Parser implementations

Download history 89/week @ 2024-08-11 158/week @ 2024-08-18 19/week @ 2024-08-25 2/week @ 2024-09-01 250/week @ 2024-09-08

459 downloads per month

GPL-3.0-or-later

38KB
621 lines

Minparser

Simple parsing functions


lib.rs:

Simple parsing tools

This crate is a collection of objects and algorithms shared among different crates that needs to implement a parser.

The [predicates] module contains some useful functions in order to analize ASCII and Unicode characters. Some of these functions are just wrappers of functions defined in the standard library.

A Position is an object that identifies a (textual) file and a position inside it, represented as a line index and a column index. The main role of a [Position] object is to uniquely identify a single character or a (textual) token inside a file in order to allow the user to easily find it.

A Pos<T> is just an object containing a T object and a Position. Usually you set T to be equal to char or to a custom token type.

A DefLine is a sort of "iterator" that returns Pos<Option<char>, FILE> in place of Option<char>. Moreover, it defines a lot of useful functions for parsing tokens from a text source.

This crate assumes a single \n character separates lines in a text file. If you need to deal with char iterators that use \r\n as a line delimiter (or both \n and \r\n) you can use the NLIterator iterator wrapper to automatically discard any \r character so that \r\n becomes just \n.

No runtime deps

Features