|
724 | 724 | (λ (x y) #f) |
725 | 725 | #:untyped |
726 | 726 | #:msg #rx"promised:.*#t.*produced:.*#f") |
727 | | - |
| 727 | + |
| 728 | + ;; #:rest-star args |
| 729 | + (t (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean)) |
| 730 | + (t (->* (list -Zero) (make-Rest (list -Zero -Zero)) -Zero)) |
| 731 | + (t (->* (list) (make-Rest (list -Boolean -String -Boolean -String -Boolean -String)) -Zero)) |
| 732 | + (t (->optkey [-Zero] #:rest Univ -Boolean)) |
| 733 | + (t-int (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 734 | + (λ (c) (c 0)) |
| 735 | + (case-lambda |
| 736 | + [(zero) #t] |
| 737 | + [(zero . rst) #f]) |
| 738 | + #:untyped) |
| 739 | + (t-int (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 740 | + (λ (c) (c 0)) |
| 741 | + (case-lambda |
| 742 | + [(zero) #t] |
| 743 | + [(zero . rst) #f]) |
| 744 | + #:typed) |
| 745 | + (t-int (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 746 | + (λ (c) (c 0 0 'zero)) |
| 747 | + (case-lambda |
| 748 | + [(zero) #t] |
| 749 | + [(zero . rst) #f]) |
| 750 | + #:untyped) |
| 751 | + (t-int (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 752 | + (λ (c) (c 0 0 'zero 0 'zero)) |
| 753 | + (case-lambda |
| 754 | + [(zero) #t] |
| 755 | + [(zero . rst) #f]) |
| 756 | + #:untyped) |
| 757 | + (t-int (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 758 | + (λ (c) (c 0 0 'zero 0 'zero)) |
| 759 | + (case-lambda |
| 760 | + [(zero) #t] |
| 761 | + [(zero . rst) #f]) |
| 762 | + #:typed) |
| 763 | + ;; shouldn't error since we should trust the typed side, right? |
| 764 | + ;(t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 765 | + ; (λ (c) (c 'zero 'zero)) |
| 766 | + ; (case-lambda |
| 767 | + ; [(zero) #t] |
| 768 | + ; [(zero . rst) #f]) |
| 769 | + ; #:untyped |
| 770 | + ; #:msg #rx"given: '(zero)") |
| 771 | + (t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 772 | + (λ (c) (c 0)) |
| 773 | + (case-lambda |
| 774 | + [(zero) 'true] |
| 775 | + [(zero . rst) 'false]) |
| 776 | + #:untyped |
| 777 | + #:msg #rx"produced: 'true") |
| 778 | + (t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 779 | + (λ (c) (c 0)) |
| 780 | + (case-lambda |
| 781 | + [(zero) 'true] |
| 782 | + [(zero . rst) 'false]) |
| 783 | + #:untyped |
| 784 | + #:msg #rx"produced: 'true") |
| 785 | + (t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 786 | + (λ (c) (c 0 'zero)) |
| 787 | + (case-lambda |
| 788 | + [(zero) #t] |
| 789 | + [(zero . rst) #f]) |
| 790 | + #:typed |
| 791 | + #:msg #rx"contract violation") |
| 792 | + (t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 793 | + (λ (c) (c 0 0 0)) |
| 794 | + (case-lambda |
| 795 | + [(zero) #t] |
| 796 | + [(zero . rst) #f]) |
| 797 | + #:typed |
| 798 | + #:msg #rx"contract violation") |
| 799 | + (t-int/fail (->* (list -Zero) (make-Rest (list -Zero -Symbol)) -Boolean) |
| 800 | + (λ (c) (c 0 0 'zero 0)) |
| 801 | + (case-lambda |
| 802 | + [(zero) #t] |
| 803 | + [(zero . rst) #f]) |
| 804 | + #:typed |
| 805 | + #:msg #rx"contract violation") |
728 | 806 | )) |
0 commit comments