I’ve bitten the bullet and announced to my PL class that we’ll be using #lang 
plai-typed. Right now, I’m trying to figure out if there’s an easy way to do 
type debugging; in particular, I anticipate wanting to make assertions about 
the type of expressions that are buried inside of other expressions. Is there a 
form that allows me to do this? I had imagined that I could do it with ‘let’, 
but ‘let’ doesn’t take any type annotations.

Currently, the best I’ve got is an in-line application to an identity function 
with a type attached.  So, for instance, if I have this function

(define (id x)
  x)

… and I want to ensure that the expression ‘x’ has type number, I can write:


(define (id x)
  ((lambda ((z : number)) z) x))

… but that’s pretty painful. Is there an easier way? (Yes, I could add a type 
annotation to the declaration of ‘x’ and to the return type of the function, 
but I’m imagining a larger function where the expression in question is neither 
an argument to nor the result of the function.)

Many thanks,

John




____________________
  Racket Users list:
  http://lists.racket-lang.org/users

Reply via email to