<div align="center">
<h1>LogoSky</h1>
</div>
<div align="center">
A seamless integration layer between [Logos](https://github.com/maciejhirsz/logos) and [Chumsky](https://github.com/zesterer/chumsky) parser combinator, providing zero-copy `TokenStream` adapter and `Parseable` trait for building robust parsers
[<img alt="github" src="https://img.shields.io/badge/github-al8n/logosky-8da0cb?style=for-the-badge&logo=Github" height="22">][Github-url]
<img alt="LoC" src="https://img.shields.io/endpoint?url=https%3A%2F%2Fgist.githubusercontent.com%2Fal8n%2F327b2a8aef9003246e45c6e47fe63937%2Fraw%2Flogosky" height="22">
[<img alt="Build" src="https://img.shields.io/github/actions/workflow/status/al8n/logosky/ci.yml?logo=Github-Actions&style=for-the-badge" height="22">][CI-url]
[<img alt="codecov" src="https://img.shields.io/codecov/c/gh/al8n/logosky?style=for-the-badge&token=6R3QFWRWHL&logo=codecov" height="22">][codecov-url]
[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-logosky-66c2a5?style=for-the-badge&labelColor=555555&logo=" height="20">][doc-url]
[<img alt="crates.io" src="https://img.shields.io/crates/v/logosky?style=for-the-badge&logo=" height="22">][crates-url]
[<img alt="crates.io" src="https://img.shields.io/crates/d/logosky?color=critical&logo=&style=for-the-badge" height="22">][crates-url]
<img alt="license" src="https://img.shields.io/badge/License-Apache%202.0/MIT-blue.svg?style=for-the-badge&fontColor=white&logoColor=f5c076&logo=" height="22">
English | [įŽäŊ䏿][zh-cn-url]
</div>
## Overview
**LogoSky** is a Rust library that bridges [Logos](https://github.com/maciejhirsz/logos) and [Chumsky](https://github.com/zesterer/chumsky), combining the speed of Logos' lexical analysis with the expressiveness of Chumsky's parser combinators. It provides a seamless integration layer that allows you to use Logos for tokenization and Chumsky for parsing in a unified, type-safe manner.
## Features
- đ **High-performance tokenization** with Logos
- đ¯ **Expressive parser combinators** with Chumsky
- đ **Seamless integration** via `TokenStream` adapter
- đ **Rich span tracking** with `Span` and `Spanned` types
- đ¨ **Flexible parseable trait** for building composable parsers
- đ§ **No-std support** with optional allocator
- đ§Š **Multiple source types** support (`str`, `[u8]`, `Bytes`, `BStr`, `HipStr`)
- ⥠**Zero-cost abstractions** for efficient parsing
## Installation
Add this to your `Cargo.toml`:
```toml
[dependencies]
logosky = "0.2"
```
### Feature Flags
- `std` (default) - Enable standard library support
- `alloc` - Enable allocator support for no-std environments
- `bytes` - Support for `bytes::Bytes` as token source
- `bstr` - Support for `bstr::BStr` as token source
- `hipstr` - Support for `hipstr::HipStr` as token source
- `either` - Enable `Either<L, R>` parseable support
- `among` - Enable `Among<L, M, R>` parseable support
- `smallvec` - Enable small vector optimization utilities
## Core Components
- `TokenStream<'a, T>`
An zero-copy adapter that bridges Logos lexer output to Chumsky parser input. Implements Chumsky's `Input`, `ValueInput`, `SliceInput`, and `ExactSizeInput` traits.
- `Token<'a>` Trait
The core trait for defining tokens. Requires:
- `Char`: Character type (usually `char` or `u8`)
- `Kind`: Token kind discriminator
- `Logos`: Associated Logos token enum
- `LosslessToken<'a>` Trait
Extends `Token<'a>` for tokens that preserve all source information, including trivia (whitespace, comments).
- Provides `is_trivia()` method to identify non-semantic tokens
- Essential for building formatters, linters, and language servers that need to preserve formatting
- Works seamlessly with `Tokenizer` trivia handling utilities
- `Tokenizer<'a, T>` Trait
Provides parser combinators for working with token streams:
- `skip_trivias()`: Skip over trivia tokens (whitespace, comments)
- `collect_trivias()`: Collect trivia tokens into a container for later processing
- `Parseable<'a, I, T, Error>` Trait
A trait for types that can be parsed from a token stream. Implement this to create composable parsers.
- `Span` and `Spanned<T>`
- `Span`: Lightweight span tracking (start/end positions)
- `Spanned<T>`: Wraps a value with its source span
- Utility Traits
- `IsAsciiChar`: ASCII character checking utilities
- `AsSpan` / `IntoSpan`: Span access traits
- `IntoComponents`: Destructure parsed elements
## Who uses `logosky`?
- [`smear`](https://github.com/al8n/smear): Blazing fast, fully spec-compliant, reusable parser combinators for standard GraphQL and GraphQL-like DSLs.
## License
`logosky` is dual-licensed under:
- MIT License ([LICENSE-MIT](LICENSE-MIT))
- Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE))
You may choose either license for your purposes.
Copyright (c) 2025 Al Liu.
[Github-url]: https://github.com/al8n/logosky/
[CI-url]: https://github.com/al8n/logosky/actions/workflows/ci.yml
[doc-url]: https://docs.rs/logosky
[crates-url]: https://crates.io/crates/logosky
[codecov-url]: https://app.codecov.io/gh/al8n/logosky/
[zh-cn-url]: https://github.com/al8n/logosky/tree/main/README-zh_CN.md