/usr/share/gEDA/scheme/gschem.scm is in geda-gschem 1:1.8.2-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 | ;;; gEDA - GPL Electronic Design Automation
;;; gschem - gEDA Schematic Capture
;;; Copyright (C) 1998-2010 Ales Hvezda
;;; Copyright (C) 1998-2011 gEDA Contributors (see ChangeLog for details)
;;;
;;; This program is free software; you can redistribute it and/or modify
;;; it under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 2 of the License, or
;;; (at your option) any later version.
;;;
;;; This program is distributed in the hope that it will be useful,
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with this program; if not, write to the Free Software
;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
;;; MA 02111-1301 USA.
(use-modules (gschem keymap)
(gschem selection)
(gschem window)
(gschem gschemdoc)
(geda object)
(srfi srfi-1))
;; Define an eval-in-currentmodule procedure
(define (eval-cm expr) (eval expr (current-module)))
(define last-action #f)
(define current-keys '())
(define %global-keymap (make-keymap))
(define current-keymap %global-keymap)
;; Set a global keybinding
(define (global-set-key key binding)
(bind-keys! %global-keymap key binding))
;; Called from C code to evaluate keys.
(define (press-key key)
(eval-pressed-key current-keymap key))
;; Function for resetting current key sequence
(define (reset-keys) (set! current-keys '()) #f)
;; Does the work of evaluating a key. Adds the key to the current key
;; sequence, then looks up the key sequence in the current keymap. If
;; the key sequence resolves to an action, calls the action. If the
;; key sequence can be resolved to an action, returns #t; if it
;; resolves to a keymap (i.e. it's a prefix key), returns the "prefix"
;; symbol; otherwise, returns #f. If the key is #f, clears the
;; current key sequence.
(define (eval-pressed-key keymap key)
(if key
(begin
;; Add key to current key sequence
(set! current-keys (cons key current-keys))
(let* ((keys (list->vector (reverse current-keys)))
(bound (lookup-keys keymap keys)))
(cond
;; Keys are a prefix -- do nothing successfully
((keymap? bound) 'prefix)
;; Keys are bound to something -- reset current key
;; sequence, then try to run the action
(bound (begin
(reset-keys)
(eval-keymap-action bound)))
;; No binding
(else (reset-keys)))))
(reset-keys)))
;; Evaluates a keymap action. A keymap action is expected to be a
;; symbol naming a thunk variable in the current module.
;;
;; The special-case symbol repeat-last-command causes the last action
;; executed via keypress to be repeated.
(define (eval-keymap-action action)
(define (invalid-action-error)
(error "~S is not a valid action for keybinding." action))
(cond
;; Handle repeat-last-command
((equal? 'repeat-last-command action)
(eval-keymap-action last-action))
;; Normal actions
((symbol? action)
(let ((proc (false-if-exception (eval-cm action))))
(if (thunk? proc)
(begin
(set! last-action action)
(proc)
#t)
(invalid-action-error))))
;; Otherwise, fail
(else (invalid-action-error))))
(define (eval-stroke stroke)
(let ((action (assoc stroke strokes)))
(cond ((not action)
; (display "No such stroke\n")
; (display stroke)
#f)
(else
; (display "Scheme found action ")
; (display action)
; (display "\n")
((eval-cm (cdr action)))
#t))))
;; Search the global keymap for a particular symbol and return the
;; keys which execute this hotkey, as a string suitable for display to
;; the user. This is used by the gschem menu system.
(define (find-key action)
(let ((keys (lookup-binding %global-keymap action)))
(and keys (keys->display-string keys))))
;; Printing out current key bindings for gEDA (gschem)
(define (dump-global-keymap)
(dump-keymap %global-keymap))
(define (dump-keymap keymap)
(define lst '())
(define (binding->entry prefix key binding)
(let ((keys (list->vector (reverse (cons key prefix)))))
(set! lst (cons (cons (symbol->string binding)
(keys->display-string keys))
lst))))
(define (build-dump! km prefix)
(keymap-for-each
(lambda (key binding)
(cond
((symbol? binding)
(binding->entry prefix key binding))
((keymap? binding)
(build-dump! binding (cons key prefix)))
(else (error "Invalid action ~S bound to ~S"
binding (list->vector (reverse (cons key prefix)))))))
km))
(build-dump! keymap '())
lst)
;;;; Documentation-related actions
(define (hierarchy-documentation)
"hierarchy-documentation
If a component is selected, search for and display corresponding
documentation in a browser or PDF viewer. If no documentation can be
found, shows a dialog with an error message."
(catch
'misc-error
(lambda ()
(let ((component
(any (lambda (obj) (and (component? obj) obj))
(page-selection (active-page)))))
(and component (show-component-documentation component))))
(lambda (key subr msg args . rest)
(gschem-msg (string-append
"Could not show documentation for selected component:\n\n"
(apply format #f msg args))))))
(define (help-manual)
"help-manual
Display the front page of the gEDA manuals in a browser."
(show-wiki "geda:documentation"))
(define (help-faq)
"help-faq
Display the gschem Frequently Asked Questions in a browser."
(show-wiki "geda:faq-gschem"))
(define (help-wiki)
"help-faq
Display the gEDA wiki in a browser."
(show-wiki))
|