#lang typed/racket/base (require "compiler/expression-structs.rkt" "compiler/lexical-structs.rkt" "sets.rkt" racket/path racket/port) (require/typed "logger.rkt" [log-warning (String -> Void)]) (provide current-defined-name current-module-path current-root-path current-warn-unimplemented-kernel-primitive current-seen-unimplemented-kernel-primitives current-kernel-module-locator? current-compress-javascript? current-one-module-per-file? current-with-cache? current-report-port current-timing-port ) (: current-module-path (Parameterof (U False Path))) (define current-module-path (make-parameter (build-path (current-directory) "anonymous-module.rkt"))) (: current-root-path (Parameterof Path)) (define current-root-path (make-parameter (normalize-path (current-directory)))) (: current-warn-unimplemented-kernel-primitive (Parameterof (Symbol -> Void))) (define current-warn-unimplemented-kernel-primitive (make-parameter (lambda: ([id : Symbol]) (log-warning (format "WARNING: Primitive Kernel Value ~s has not been implemented\n" id))))) (: current-kernel-module-locator? (Parameterof (ModuleLocator -> Boolean))) ;; Produces true if the given module locator should be treated as a primitive root one ;; that is implemented by us. (define current-kernel-module-locator? (make-parameter (lambda: ([locator : ModuleLocator]) (or (kernel-locator? locator) (paramz-locator? locator))))) (: kernel-locator? (ModuleLocator -> Boolean)) (define (kernel-locator? locator) (or (and (eq? (ModuleLocator-name locator) '#%kernel) (eq? (ModuleLocator-real-path locator) '#%kernel)) (eq? (ModuleLocator-name locator) 'whalesong/lang/kernel.rkt))) (: paramz-locator? (ModuleLocator -> Boolean)) (define (paramz-locator? locator) (or (and (eq? (ModuleLocator-name locator) '#%paramz) (eq? (ModuleLocator-real-path locator) '#%paramz)))) (: current-compress-javascript? (Parameterof Boolean)) (define current-compress-javascript? (make-parameter #f)) ;; Turn this one so that js-assembler/package generates a file per module, as ;; opposed to trying to bundle them all together. (: current-one-module-per-file? (Parameterof Boolean)) (define current-one-module-per-file? (make-parameter #f)) ;; Turns on caching of compiled programs, so that repeated compilations ;; will reuse existing work. (: current-with-cache? (Parameterof Boolean)) (define current-with-cache? (make-parameter #t)) (: current-report-port (Parameterof Output-Port)) (define current-report-port (make-parameter (current-output-port))) (: current-timing-port (Parameterof Output-Port)) (define current-timing-port (make-parameter (open-output-nowhere) ;(current-output-port) )) ;;; Do not touch the following parameters: they're used internally by package ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (: current-seen-unimplemented-kernel-primitives (Parameterof (Setof Symbol))) (define current-seen-unimplemented-kernel-primitives (make-parameter ((inst new-seteq Symbol)))) ;;; These parameters below will probably go away soon. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (: current-defined-name (Parameterof (U Symbol LamPositionalName))) (define current-defined-name (make-parameter 'unknown))