Generating a fluent api with syntax checking from an LR grammar

11Citations
Citations of this article
9Readers
Mendeley users who have this article in their library.

Abstract

This paper proposes a fluent API generator for Scala, Haskell, and C++. It receives a grammar definition and generates a code skeleton of the library in the host programming language. The generated library is accessed through a chain of method calls; this style of API is called a fluent API. The library uses the host-language type checker to detect an invalid chain of method calls. Each method call is regarded as a lexical token in the embedded domain specific language implemented by that library. A sequence of the lexical tokens is checked and, if the sequence is not acceptable by the grammar, a type error is reported during compilation time. A contribution of this paper is to present an algorithm for generating the code-skeleton for a fluent API that reports a type error when a chain of method calls to the library does not match the given LR grammar. Our algorithm works in Scala, Haskell, and C++. To encode LR parsing, it uses the method/function overloading available in those languages. It does not need an advanced type system, or exponential compilation time or memory consumption. This paper also presents our implementation of the proposed generator.

Cite

CITATION STYLE

APA

Yamazaki, T., Nakamaru, T., Ichikawa, K., & Chiba, S. (2019). Generating a fluent api with syntax checking from an LR grammar. Proceedings of the ACM on Programming Languages, 3(OOPSLA). https://doi.org/10.1145/3360560

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free