Stronger types for a few Typed Racket operators
Go to file
2016-03-19 23:50:45 -04:00
icfp-2016 [function] following the protocol now 2016-03-19 09:18:21 -04:00
test [test] more function/curry tests 2016-03-19 23:43:50 -04:00
trivial [function] really working 2016-03-19 23:44:00 -04:00
.gitignore ** add buttons 2015-12-14 05:37:17 -05:00
.travis.yml ** travis: specify tests 2016-03-19 23:50:45 -04:00
LICENSE.txt ** update inline comments 2015-12-14 02:36:53 -05:00
README.md ** add docs button 2015-12-16 03:08:21 -05:00

trivial

Build Status Coverage Status Scribble

This library provides "smarter" versions of Typed Racket standard library functions. For example:

#lang typed/racket/base

(require trivial)

(printf: "hello, ~a")

;; > raco make test.rkt
;; format:: arity mismatch;
;;  the expected number of arguments does not match the given number
;;    expected: 1
;;      given: 0

The printf: (with a colon) checks whether its first argument is a string literal. If so, it parses the string's format sequences for arity and type constraints. Unless the constraints fail, printf: then calls the standard printf.

When the first argument to printf: is not a string literal, nothing special happens; we just call the standard printf.

#lang typed/racket/base

(require trivial)

(let ([s "hello, ~a\n"])
  (printf: s)) ;; Non-trivial!

;; Compiles successfully, but throws arity error at runtime

Besides printf:, this library also provides macros for:

  • regexp-match:, to count the number of groups in a pattern and give the match result a more specific type
  • +:, -:, *:, /:, to reduce constants where possible, yielding results with more specific types.

See the documentation for the full story.

Install

From Github:

> git clone https://github.com/bennn/trivial
> raco pkg install ./trivial

From the Racket package server:

> raco pkg install trivial

Use (require trivial) to import all bindings from this library. Each file in the root directory of this repo can be imported specifically, as in:

  • (require trivial/format)
  • (require trivial/regexp)
  • (require trivial/math)

These files only export macros.

Naming

  • The library is "trivial" because it solves only the simplest typechecking problems, and does so simply by analyzing a local chunk of source code.

  • By convention, we suffix all our exports with a trailing colon. This is a hint that the macro will attempt some extra static analysis (including typechecking) at its call-site.

Contributing

The perfect feature request would start like:

"Typed Racket rejects this program, but it is obviously well-typed because ..."

If the right type really is obvious, syntactically, we'll extend this library.