Attempt at cross-phase structs, didn't work out well.
This commit is contained in:
parent
b79ec821d4
commit
a110b20df1
27
comments/typed-cross-phase-structs-wrappers.rkt
Normal file
27
comments/typed-cross-phase-structs-wrappers.rkt
Normal file
|
@ -0,0 +1,27 @@
|
|||
#lang typed/racket
|
||||
|
||||
(require typed/racket/unsafe)
|
||||
(require "untyped-cross-phase-structs-wrappers.rkt")
|
||||
(unsafe-require/typed "untyped-cross-phase-structs-wrappers.rkt"
|
||||
[#:struct (A) NonSexp ([v : A]) #:type-name NonSexpOf]
|
||||
[#:struct (A) NonSyntax ([v : A]) #:type-name NonSyntaxOf]
|
||||
[#:struct (A) Some ([v : A])])
|
||||
|
||||
;(require typed-racket/base-env/prims-struct)
|
||||
;(dtsi* (A) NonSexp NonSexpOf ([v : A]) #:maker make-NonSexp)
|
||||
|
||||
(provide (struct-out NonSexp))
|
||||
;(struct (A) NonSexp ([v : A]) #:type-name NonSexpOf #:constructor-name make-NonSexp)
|
||||
|
||||
#;(module* test typed/racket
|
||||
(require (submod ".."))
|
||||
(require typed/rackunit)
|
||||
(check-pred procedure? NonSexp)
|
||||
(check-pred NonSexp? (ann (ann (NonSexp 1) (NonSexpOf Number)) Any))
|
||||
(check-not-exn
|
||||
(λ ()
|
||||
(ann (let ([n : (NonSexpOf Any) (NonSexp 1)])
|
||||
(if (number? (NonSexp-v n))
|
||||
(NonSexp-v n)
|
||||
0))
|
||||
Number))))
|
47
comments/typed-cross-phase-structs.rkt
Normal file
47
comments/typed-cross-phase-structs.rkt
Normal file
|
@ -0,0 +1,47 @@
|
|||
(module typed-cross-phase-structs '#%kernel
|
||||
(#%declare #:cross-phase-persistent)
|
||||
|
||||
(#%provide struct:NonSexp make-NonSexp NonSexp? NonSexp-ref)
|
||||
(define-values (struct:NonSexp make-NonSexp NonSexp? NonSexp-ref NonSexp-set!)
|
||||
(make-struct-type 'NonSexp ;; name
|
||||
#f ;; parent
|
||||
1 ;; arguments to the constructor
|
||||
0 ;; auto-fields
|
||||
#f ;; auto-v
|
||||
'() ;; props
|
||||
#f ;; inspector
|
||||
#f ;; proc-spec
|
||||
(list 0) ;; immutables
|
||||
#f ;; guard
|
||||
'NonSexp ;; constructor-name
|
||||
))
|
||||
|
||||
(#%provide struct:NonSyntax make-NonSyntax NonSyntax? NonSyntax-ref)
|
||||
(define-values (struct:NonSyntax make-NonSyntax NonSyntax? NonSyntax-ref NonSyntax-set!)
|
||||
(make-struct-type 'NonSyntax ;; name
|
||||
#f ;; parent
|
||||
1 ;; arguments to the constructor
|
||||
0 ;; auto-fields
|
||||
#f ;; auto-v
|
||||
'() ;; props
|
||||
#f ;; inspector
|
||||
#f ;; proc-spec
|
||||
(list 0) ;; immutables
|
||||
#f ;; guard
|
||||
'NonSyntax ;; constructor-name
|
||||
))
|
||||
|
||||
(#%provide struct:Some make-Some Some? Some-ref)
|
||||
(define-values (struct:Some make-Some Some? Some-ref Some-set!)
|
||||
(make-struct-type 'Some ;; name
|
||||
#f ;; parent
|
||||
1 ;; arguments to the constructor
|
||||
0 ;; auto-fields
|
||||
#f ;; auto-v
|
||||
'() ;; props
|
||||
#f ;; inspector
|
||||
#f ;; proc-spec
|
||||
(list 0) ;; immutables
|
||||
#f ;; guard
|
||||
'Some ;; constructor-name
|
||||
)))
|
48
comments/untyped-cross-phase-structs-wrappers.rkt
Normal file
48
comments/untyped-cross-phase-structs-wrappers.rkt
Normal file
|
@ -0,0 +1,48 @@
|
|||
#lang racket
|
||||
|
||||
(require "typed-cross-phase-structs.rkt"
|
||||
(for-syntax racket/struct-info))
|
||||
|
||||
(define-syntax-rule (define+provide-struct-wrapper-single-field
|
||||
[struct:S make-S S? S-ref S field S-field S-struct-info]
|
||||
...)
|
||||
(begin
|
||||
(begin
|
||||
(provide (struct-out S))
|
||||
(define S-field
|
||||
(values (make-struct-field-accessor S-ref 0 'field)))
|
||||
(begin-for-syntax
|
||||
(struct S-struct-info ()
|
||||
#:transparent
|
||||
#:property prop:struct-info
|
||||
(λ (self)
|
||||
(list #'struct:S
|
||||
#'make-S
|
||||
#'S?
|
||||
(list #'S-field) ;; in reverse order
|
||||
(list #f) ;; in reverse order
|
||||
#t))
|
||||
#:property prop:set!-transformer
|
||||
(lambda (stx)
|
||||
(syntax-case stx (set!)
|
||||
[(set! id _)
|
||||
(raise-syntax-error 'set! "Cannot mutate struct identifier" stx)]
|
||||
[id
|
||||
(identifier? #'id)
|
||||
#'make-S]
|
||||
[(id . args)
|
||||
(identifier? #'id)
|
||||
(syntax/loc stx
|
||||
(make-S . args))]))))
|
||||
(define-syntax S (S-struct-info)))
|
||||
...))
|
||||
|
||||
(define+provide-struct-wrapper-single-field
|
||||
[struct:NonSexp make-NonSexp NonSexp? NonSexp-ref
|
||||
NonSexp v NonSexp-v NonSexp-struct-info]
|
||||
|
||||
[struct:NonSyntax make-NonSyntax NonSyntax? NonSyntax-ref
|
||||
NonSyntax v NonSyntax-v NonSyntax-struct-info]
|
||||
|
||||
[struct:Some make-Some Some? Some-ref
|
||||
Some v Some-v Some-struct-info])
|
Loading…
Reference in New Issue
Block a user