File: online-check-syntax.rkt

package info (click to toggle)
racket-mode 20250711~git.8a80578-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,024 kB
  • sloc: lisp: 17,215; makefile: 106
file content (62 lines) | stat: -rw-r--r-- 2,380 bytes parent folder | download | duplicates (2)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
;; Copyright (c) 2013-2022 by Greg Hendershott.
;; SPDX-License-Identifier: GPL-3.0-or-later

#lang racket/base

(require racket/logging
         racket/match
         racket/set
         syntax/parse/define
         "util.rkt")

(provide current-online-check-syntax
         with-online-check-syntax)

;;; online-check-syntax logger monitor

;; There exists a protocol for macros to communicate tooltips to
;; DrRacket via a log-message to the logger 'online-check-syntax. This
;; might seem strange, but one motivation for this protocol is that
;; e.g. a type-checker might learn things during expansion that it
;; would like to show the user -- even if expansion fails.

(define current-online-check-syntax (make-parameter (mutable-set)))

(define-simple-macro (with-online-check-syntax source:expr e:expr ...+)
  (call-with-online-check-syntax source (λ () e ...)))

(define (call-with-online-check-syntax source proc)
  (current-online-check-syntax (mutable-set)) ;reset
  (with-intercepted-logging (make-interceptor source) proc
    'info 'online-check-syntax))

(define ((make-interceptor src) event)
  (match-define (vector _level _message stxs _topic) event)
  (for ([stx (in-list stxs)])
    (let walk ([v (syntax-property stx 'mouse-over-tooltips)])
      (match v
        ;; "The value of the 'mouse-over-tooltips property is
        ;; expected to be to be a tree of cons pairs (in any
        ;; configuration)..."
        [(cons v more)
         (walk v)
         (walk more)]
        ;; "...whose leaves are either ignored or are vectors of the
        ;; shape:"
        [(vector (? syntax? stx)
                 (? exact-positive-integer? beg)
                 (? exact-positive-integer? end)
                 (or (? string? string-or-thunk)
                     (? procedure? string-or-thunk)))
         (when (equal? src (syntax-source stx))
           ;; Force now; the resulting string will likely use less
           ;; memory than a thunk closure.
           (define (force v) (if (procedure? v) (v) v))
           (define str (force string-or-thunk))
           (set-add! (current-online-check-syntax)
                     (list beg end str)))]
        ;; Expected; quietly ignore
        [(or (list) #f) (void)]
        ;; Unexpected; log warning and ignore
        [v (log-racket-mode-warning "unknown online-check-syntax ~v" v)
           (void)]))))