Use context queries based on language capabilities.
svn: r10955
This commit is contained in:
parent
a871476756
commit
bc435dc640
|
@ -66,12 +66,8 @@
|
|||
(define (goto-plt-license)
|
||||
(send-main-page "license/index.html"))
|
||||
|
||||
(define (help-desk [key #f] #:module [mod #f] #:manual [man #f])
|
||||
(if (or key mod man)
|
||||
(perform-search (string-append (or key "")
|
||||
(if mod (format " L:~a" mod) "")
|
||||
(if man (format " T:~a" man) "")))
|
||||
(send-main-page)))
|
||||
(define (help-desk [key #f] [context #f])
|
||||
(if key (perform-search key context) (send-main-page)))
|
||||
|
||||
;; here for legacy code that should be removed
|
||||
(define (get-docs) '())
|
||||
|
|
|
@ -252,73 +252,44 @@ TODO
|
|||
(eq? fn-name stacktrace-runtime-name))))
|
||||
|
||||
(define drs-bindings-keymap (make-object keymap:aug-keymap%))
|
||||
|
||||
(let ([with-drs-frame
|
||||
(λ (obj f)
|
||||
(when (is-a? obj editor<%>)
|
||||
(let ([canvas (send obj get-canvas)])
|
||||
(when canvas
|
||||
(let ([frame (send canvas get-top-level-window)])
|
||||
(when (is-a? frame drscheme:unit:frame%)
|
||||
(f frame)))))))])
|
||||
|
||||
(send drs-bindings-keymap add-function
|
||||
"search-help-desk"
|
||||
|
||||
(let* ([get-frame
|
||||
(λ (obj)
|
||||
(and (is-a? obj editor<%>)
|
||||
(let ([canvas (send obj get-canvas)])
|
||||
(and canvas
|
||||
(let ([frame (send canvas get-top-level-window)])
|
||||
(and (is-a? frame drscheme:unit:frame%)
|
||||
frame))))))]
|
||||
[add-drs-function
|
||||
(λ (name f)
|
||||
(send drs-bindings-keymap add-function name
|
||||
(λ (obj evt) (cond [(get-frame obj) => f]))))])
|
||||
(send drs-bindings-keymap add-function "search-help-desk"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame)
|
||||
(cond
|
||||
[(is-a? obj text%)
|
||||
(let* ([start (send obj get-start-position)]
|
||||
[end (send obj get-end-position)]
|
||||
[str (if (= start end)
|
||||
(drscheme:unit:find-symbol obj start)
|
||||
(send obj get-text start end))])
|
||||
(if (equal? "" str)
|
||||
(drscheme:help-desk:help-desk)
|
||||
(let ([language (let ([canvas (send obj get-canvas)])
|
||||
(and canvas
|
||||
(let ([tlw (send canvas get-top-level-window)])
|
||||
(and (is-a? tlw drscheme:unit:frame<%>)
|
||||
(send (send tlw get-definitions-text)
|
||||
get-next-settings)))))])
|
||||
(drscheme:help-desk:help-desk str #|!!!!!!|#))))]
|
||||
[else
|
||||
(drscheme:help-desk:help-desk)])))))
|
||||
|
||||
(send drs-bindings-keymap add-function
|
||||
"execute"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame)
|
||||
(send frame execute-callback)))))
|
||||
|
||||
(send drs-bindings-keymap add-function
|
||||
"next-tab"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame) (send frame next-tab)))))
|
||||
(send drs-bindings-keymap add-function
|
||||
"prev-tab"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame) (send frame prev-tab)))))
|
||||
(send drs-bindings-keymap add-function
|
||||
"collapse"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame) (send frame collapse)))))
|
||||
(send drs-bindings-keymap add-function
|
||||
"split"
|
||||
(λ (obj evt)
|
||||
(with-drs-frame
|
||||
obj
|
||||
(λ (frame) (send frame split))))))
|
||||
(if (not (and (is-a? obj text%) (get-frame obj))) ; is `get-frame' needed?
|
||||
(drscheme:help-desk:help-desk)
|
||||
(let* ([start (send obj get-start-position)]
|
||||
[end (send obj get-end-position)]
|
||||
[str (if (= start end)
|
||||
(drscheme:unit:find-symbol obj start)
|
||||
(send obj get-text start end))])
|
||||
(if (or (not str) (equal? "" str))
|
||||
(drscheme:help-desk:help-desk)
|
||||
(let* ([l (send obj get-canvas)]
|
||||
[l (and l (send l get-top-level-window))]
|
||||
[l (and l (is-a? l drscheme:unit:frame<%>) (send l get-definitions-text))]
|
||||
[l (and l (send l get-next-settings))]
|
||||
[l (and l (drscheme:language-configuration:language-settings-language l))]
|
||||
[ctxt (and l (send l capability-value 'drscheme:help-context-term))]
|
||||
[name (and l (send l get-language-name))])
|
||||
(drscheme:help-desk:help-desk
|
||||
str (and ctxt (list ctxt name)))))))))
|
||||
(add-drs-function "execute" (λ (frame) (send frame execute-callback)))
|
||||
(add-drs-function "next-tab" (λ (frame) (send frame next-tab)))
|
||||
(add-drs-function "prev-tab" (λ (frame) (send frame prev-tab)))
|
||||
(add-drs-function "collapse" (λ (frame) (send frame collapse)))
|
||||
(add-drs-function "split" (λ (frame) (send frame split))))
|
||||
|
||||
(send drs-bindings-keymap map-function "f5" "execute")
|
||||
(send drs-bindings-keymap map-function "f1" "search-help-desk")
|
||||
|
|
|
@ -124,24 +124,25 @@ module browser threading seems wrong.
|
|||
(let* ([end (send text get-end-position)]
|
||||
[start (send text get-start-position)])
|
||||
(unless (= 0 (send text last-position))
|
||||
(let ([str (if (= end start)
|
||||
(find-symbol
|
||||
text
|
||||
(call-with-values
|
||||
(λ ()
|
||||
(send text dc-location-to-editor-location
|
||||
(send event get-x)
|
||||
(send event get-y)))
|
||||
(λ (x y)
|
||||
(send text find-position x y))))
|
||||
(send text get-text start end))]
|
||||
[language
|
||||
(let ([canvas (send text get-canvas)])
|
||||
(and canvas
|
||||
(let ([tlw (send canvas get-top-level-window)])
|
||||
(and (is-a? tlw -frame<%>)
|
||||
(send (send tlw get-definitions-text)
|
||||
get-next-settings)))))])
|
||||
(let* ([str (if (= end start)
|
||||
(find-symbol
|
||||
text
|
||||
(call-with-values
|
||||
(λ ()
|
||||
(send text dc-location-to-editor-location
|
||||
(send event get-x)
|
||||
(send event get-y)))
|
||||
(λ (x y)
|
||||
(send text find-position x y))))
|
||||
(send text get-text start end))]
|
||||
;; almost the same code as "search-help-desk" in "rep.ss"
|
||||
[l (send text get-canvas)]
|
||||
[l (and l (send l get-top-level-window))]
|
||||
[l (and l (is-a? l -frame<%>) (send l get-definitions-text))]
|
||||
[l (and l (send l get-next-settings))]
|
||||
[l (and l (drscheme:language-configuration:language-settings-language l))]
|
||||
[ctxt (and l (send l capability-value 'drscheme:help-context-term))]
|
||||
[name (and l (send l get-language-name))])
|
||||
(unless (string=? str "")
|
||||
(add-sep)
|
||||
(make-object menu-item%
|
||||
|
@ -151,7 +152,7 @@ module browser threading seems wrong.
|
|||
str
|
||||
(- 200 (string-length (string-constant search-help-desk-for)))))
|
||||
menu
|
||||
(λ x (help-desk:help-desk str #|!!!!|#)))))))
|
||||
(λ x (help-desk:help-desk str (list ctxt name))))))))
|
||||
|
||||
(when (is-a? text editor:basic<%>)
|
||||
(let-values ([(pos text) (send text get-pos/text event)])
|
||||
|
|
Loading…
Reference in New Issue
Block a user