#lang scheme/unit (require racket/class "drsig.rkt") (import [prefix drracket:unit: drracket:unit^] [prefix drracket:frame: drracket:frame^] [prefix drracket:rep: drracket:rep^] [prefix drracket:debug: drracket:debug^] [prefix drracket:tracing: drracket:tracing^] [prefix drracket:module-language-tools: drracket:module-language-tools^]) (export drracket:get/extend^) (define make-extender (λ (get-base% name) (let ([extensions (λ (x) x)] [built-yet? #f] [built #f] [verify (λ (f) (λ (%) (let ([new% (f %)]) (if (and (class? new%) (subclass? new% %)) new% (error 'extend-% "expected output of extension to create a subclass of its input, got: ~a" new%)))))]) (values (letrec ([add-extender (case-lambda [(extension) (add-extender extension #t)] [(extension before?) (when built-yet? (error 'extender "cannot build a new extension of ~a after initialization" name)) (set! extensions (if before? (compose (verify extension) extensions) (compose extensions (verify extension))))])]) add-extender) (λ () (unless built-yet? (set! built-yet? #t) (set! built (extensions (get-base%)))) built))))) (define (get-base-tab%) (drracket:module-language-tools:tab-mixin (drracket:tracing:tab-mixin (drracket:debug:test-coverage-tab-mixin (drracket:debug:profile-tab-mixin drracket:unit:tab%))))) (define-values (extend-tab get-tab) (make-extender get-base-tab% 'tab%)) (define (get-base-interactions-canvas%) drracket:unit:interactions-canvas%) (define-values (extend-interactions-canvas get-interactions-canvas) (make-extender get-base-interactions-canvas% 'interactions-canvas%)) (define (get-base-definitions-canvas%) drracket:unit:definitions-canvas%) (define-values (extend-definitions-canvas get-definitions-canvas) (make-extender get-base-definitions-canvas% 'definitions-canvas%)) (define (get-base-unit-frame%) (drracket:module-language-tools:frame-mixin (drracket:tracing:frame-mixin (drracket:debug:profile-unit-frame-mixin drracket:unit:frame%)))) (define-values (extend-unit-frame get-unit-frame) (make-extender get-base-unit-frame% 'drracket:unit:frame)) (define (get-base-interactions-text%) (drracket:debug:test-coverage-interactions-text-mixin drracket:rep:text%)) (define-values (extend-interactions-text get-interactions-text) (make-extender get-base-interactions-text% 'interactions-text%)) (define (get-base-definitions-text%) (drracket:module-language-tools:definitions-text-mixin (drracket:debug:test-coverage-definitions-text-mixin (drracket:debug:profile-definitions-text-mixin (drracket:unit:get-definitions-text%))))) (define-values (extend-definitions-text get-definitions-text) (make-extender get-base-definitions-text% 'definitions-text%))