skip to main content
10.5555/3005729.3005731acmotherconferencesArticle/Chapter ViewAbstractPublication PageselsConference Proceedingsconference-collections
Article

Type-Checking of Heterogeneous Sequences in Common Lisp

Published: 09 May 2016 Publication History

Abstract

We introduce the abstract concept of rational type expression and show its relationship to rational language theory. We further present a concrete syntax, regular type expression, and a Common Lisp implementation thereof which allows the programmer to declaratively express the types of heterogeneous sequences in a way which is natural in the Common Lisp language. The implementation uses techniques well known and well founded in rational theory, in particular the use of the Brzozowski derivative and deterministic automata to reach a solution which can match a sequence in linear time. We illustrate the concept with several motivating examples, and finally explain many details of its implementation.

References

[1]
Declaring the elements of a list, discussion on comp.lang.lisp, 2015.
[2]
H. G. Baker. A decision procedure for Common Lisp's SUBTYPEP predicate. Lisp and Symbolic Computation, 5(3):157-190, 1992.
[3]
J. A. Brzozowski. Derivatives of regular expressions. J. ACM, 11(4):481-494, 1964.
[4]
R. D. Cameron. Perl style regular expressions in Prolog, CMPT 384 lecture notes, 1999.
[5]
J. Chroboczek. CL-Yacc, a LALR(1) parser generator for Common Lisp, 2009.
[6]
P. Domain. Alexandria implementation of destructuring-case.
[7]
N. Funato. Public domain implementation of destructuring-bind, 2013.
[8]
H. Hosoya, J. Vouillon, and B. C. Pierce. Regular expression types for XML. ACM Trans. Program. Lang. Syst., 27(1):46-90, Jan. 2005.
[9]
J. D. U. Johh E. Hopcroft, Rajeev Motwani. Introduction to Automata Theory, Languages, and Computation. Addison Wesley, 2001.
[10]
W. H. Newman. Steel Bank Common Lisp user manual, 2015.
[11]
J. Newton. Report: Efficient dynamic type checking of heterogeneous sequences. Technical report, EPITA/LRDE, 2016.
[12]
S. Owens, J. Reppy, and A. Turon. Regular-expression derivatives re-examined. J. Funct. Program., 19(2):173-190, Mar. 2009.
[13]
C. Rhodes. User-extensible sequences in Common Lisp. In Proceedings of the 2007 International Lisp Conference, ILC '07, pages 13:1-13:14, New York, NY, USA, 2009. ACM.
[14]
A. Shinn, J. Cowan, and A. A. Gleckler. Revised 7 report on the algorithmic language scheme. Technical report, 2013.
[15]
ANSI. American National Standard: Programming Language - Common Lisp. ANSI X3.226:1994 (R1999), 1994.
[16]
E. Weitz. Common Lisp Recipes: A Problem-solution Approach. Apress, 2015.
[17]
G. Xing. Minimized Thompson NFA. Int. J. Comput. Math., 81(9):1097-1106, 2004.
[18]
F. Yvon and A. Demaille. Théorie des Langages Rationnels. 2014.

Cited By

View all

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Other conferences
ELS2016: Proceedings of the 9th European Lisp Symposium on European Lisp Symposium
May 2016
117 pages
ISBN:9782955747407

In-Cooperation

Publisher

European Lisp Scientific Activities Association

Publication History

Published: 09 May 2016

Check for updates

Author Tags

  1. Finite automata
  2. Rational languages
  3. Type checking

Qualifiers

  • Article

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)0
  • Downloads (Last 6 weeks)0
Reflects downloads up to 20 Jan 2025

Other Metrics

Citations

Cited By

View all

View Options

View options

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media