File: gui.rkt

package info (click to toggle)
racket-mode 20210916git0-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,076 kB
  • sloc: lisp: 10,354; makefile: 58
file content (47 lines) | stat: -rw-r--r-- 1,832 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#lang racket/base

;; Note that racket/gui/dynamic is in `base` package --- requiring it
;; does NOT create a dependency on the `gui-lib` package.
(require racket/gui/dynamic)

(provide txt/gui
         make-initial-repl-namespace)

;; Load racket/gui/base eagerly, if available, instantiating it in our
;; namespace and under our main custodian (as opposed to those for
;; user programs). This is our strategy to avoid "racket/gui/base
;; cannot be instantiated more than once per process". The only reason
;; it won't be loaded here now is if we're on a minimal Racket
;; installation where gui-lib is not installed.
(with-handlers ([exn:fail? void])
  (dynamic-require 'racket/gui/base #f))

;; If that succeeded, then it is important for REPL namespaces
;; initially to have racket/gui/base _attached_, regardless of whether
;; a user program _requires_ it. See also issue #555.
(define-namespace-anchor anchor)
(define (make-initial-repl-namespace)
  (define ns (make-base-namespace))
  (when (gui-available?)
    (namespace-attach-module (namespace-anchor->empty-namespace anchor)
                             'racket/gui/base
                             ns))
  ns)

;; #301: On Windows, show then hide an initial frame.
(when (and (gui-available?)
           (eq? (system-type) 'windows))
  (define make-object (dynamic-require 'racket/class 'make-object))
  (define frame% (dynamic-require 'racket/gui/base 'frame%))
  (define f (make-object frame% "Emacs Racket Mode initialization" #f 100 100))
  (define dynamic-send (dynamic-require 'racket/class 'dynamic-send))
  (dynamic-send f 'show #t)
  (dynamic-send f 'show #f))

;; Like mz/mr from racket/sandbox.
(define-syntax txt/gui
  (syntax-rules ()
    [(_ txtval guisym)
     (if (gui-available?)
         (dynamic-require 'racket/gui/base 'guisym)
         txtval)]))