home *** CD-ROM | disk | FTP | other *** search
/ OpenStep 4.2 / Openstep-4.2-Intel-User.iso / usr / lib / emacs / lisp / sun-mouse.elc < prev    next >
Text File  |  1992-10-23  |  20KB  |  361 lines

  1.  
  2. (provide (quote sun-mouse))
  3.  
  4. (defvar extra-click-wait 150 "\
  5. *Number of milliseconds to wait for an extra click.
  6. Set this to zero if you don't want chords or double clicks.")
  7.  
  8. (defvar scrollbar-width 5 "\
  9. *The character width of the scrollbar.
  10. The cursor is deemed to be in the right edge scrollbar if it is this near the
  11. right edge, and more than two chars past the end of the indicated line.
  12. Setting to nil limits the scrollbar to the edge or vertical dividing bar.")
  13.  
  14. (defun make-mousemap nil "\
  15. Returns a new mousemap." (byte-code "ˋ¹BÇ" [nil mousemap] 2))
  16.  
  17. (defun copy-mousemap (mousemap) "\
  18. Return a copy of mousemap." (byte-code "ˋ!Ç" [mousemap copy-alist] 2))
  19.  
  20. (defun define-mouse (mousemap mouse-list def) "\
  21. Args MOUSEMAP, MOUSE-LIST, DEF.  Define MOUSE-LIST in MOUSEMAP as DEF.
  22. MOUSE-LIST is a list of atoms specifing a mouse hit according to these rules:
  23.   * One of these atoms specifies the active region of the definition.
  24.     text, scrollbar, modeline, minibuffer
  25.   * One or two or these atoms specify the button or button combination.
  26.         left, middle, right, double
  27.   * Any combination of these atoms specify the active shift keys.
  28.         control, shift, meta
  29.   * With a single unshifted button, you can add
  30.     up
  31.     to indicate an up-click.
  32. The atom `double' is used with a button designator to denote a double click.
  33. Two button chords are denoted by listing the two buttons.
  34. See sun-mouse-handler for the treatment of the form DEF." (byte-code "ˆ˜!    
  35. #Ç" [mouse-list mousemap def mousemap-set mouse-list-to-mouse-code] 5))
  36.  
  37. (defun global-set-mouse (mouse-list def) "\
  38. Give MOUSE-EVENT-LIST a local definition of DEF.
  39. See define-mouse for a description of MOUSE-EVENT-LIST and DEF.
  40. Note that if MOUSE-EVENT-LIST has a local definition in the current buffer,
  41. that local definition will continue to shadow any global definition." (interactive "xMouse event: 
  42. xDefinition: ") (byte-code "ˆÈ˜    
  43. #Ç" [current-global-mousemap mouse-list def nil define-mouse] 4))
  44.  
  45. (defun local-set-mouse (mouse-list def) "\
  46. Give MOUSE-EVENT-LIST a local definition of DEF.
  47. See define-mouse for a description of the arguments.
  48. The definition goes in the current buffer's local mousemap.
  49. Normally buffers in the same major mode share a local mousemap." (interactive "xMouse event: 
  50. xDefinition: ") (byte-code "ˆÈ?Ä ˜ Éȯ    
  51. #Ç" [current-local-mousemap mouse-list def nil make-mousemap define-mouse] 5))
  52.  
  53. (defun use-global-mousemap (mousemap) "\
  54. Selects MOUSEMAP as the global mousemap." (byte-code "    ÉÇ" [current-global-mousemap mousemap] 2))
  55.  
  56. (defun use-local-mousemap (mousemap) "\
  57. Selects MOUSEMAP as the local mousemap.
  58. nil for MOUSEMAP means no local mousemap." (byte-code "    ÉÇ" [current-local-mousemap mousemap] 2))
  59.  
  60. (defun logtest (x y) "\
  61. True if any bits set in X are also set in Y.
  62. Just like the Common Lisp function of the same name." (byte-code "´ˆ    \"!?Ç" [x y zerop logand] 4))
  63.  
  64. (defconst sm::ButtonBits 7)
  65.  
  66. (defconst sm::ShiftmaskBits 56)
  67.  
  68. (defconst sm::DoubleBits 64)
  69.  
  70. (defconst sm::UpBits 128)
  71.  
  72. (defmacro sm::hit-code (hit) (byte-code "ˋ´EÇ" [hit nth 0] 3))
  73.  
  74. (defmacro sm::hit-button (hit) (byte-code "ˋ´ˆ˜EEÇ" [hit logand sm::ButtonBits nth 0] 5))
  75.  
  76. (defmacro sm::hit-shiftmask (hit) (byte-code "ˋ´ˆ˜EEÇ" [hit logand sm::ShiftmaskBits nth 0] 5))
  77.  
  78. (defmacro sm::hit-double (hit) (byte-code "ˋ´ˆ˜EEÇ" [hit logand sm::DoubleBits nth 0] 5))
  79.  
  80. (defmacro sm::hit-up (hit) (byte-code "ˋ´ˆ˜EEÇ" [hit logand sm::UpBits nth 0] 5))
  81.  
  82. (defmacro sm::hit-x (hit) (byte-code "ˋ´EÇ" [hit nth 1] 3))
  83.  
  84. (defmacro sm::hit-y (hit) (byte-code "ˋ´EÇ" [hit nth 2] 3))
  85.  
  86. (defmacro sm::hit-delta (hit) (byte-code "ˋ´EÇ" [hit nth 3] 3))
  87.  
  88. (defmacro sm::hit-up-p (hit) (byte-code "ˋ´ˆDDDÇ" [hit not zerop sm::hit-up] 4))
  89.  
  90. (defmacro sm::loc-w (loc) (byte-code "ˋ´EÇ" [loc nth 0] 3))
  91.  
  92. (defmacro sm::loc-x (loc) (byte-code "ˋ´EÇ" [loc nth 1] 3))
  93.  
  94. (defmacro sm::loc-y (loc) (byte-code "ˋ´EÇ" [loc nth 2] 3))
  95.  
  96. (defmacro eval-in-buffer (buffer &rest forms) "Macro to switches to BUFFER, evaluates FORMS, returns to original buffer." (byte-code "´ˆ˜¯˘˙DD    \"¨EEÇ" [buffer forms let ((StartBuffer (current-buffer))) unwind-protect append progn set-buffer (set-buffer StartBuffer)] 7))
  97.  
  98. (put (quote eval-in-buffer) (quote lisp-indent-hook) 1)
  99.  
  100. (defmacro eval-in-window (window &rest forms) "Switch to WINDOW, evaluate FORMS, return to original window." (byte-code "´ˆ˜¯˘˙DD    \"¨EEÇ" [window forms let ((OriginallySelectedWindow (selected-window))) unwind-protect append progn select-window (if (window-point OriginallySelectedWindow) (select-window OriginallySelectedWindow))] 7))
  101.  
  102. (put (quote eval-in-window) (quote lisp-indent-hook) 1)
  103.  
  104. (defmacro eval-in-windows (form &optional yesmini) "Switches to each window and evaluates FORM.  Optional argument
  105. YESMINI says to include the minibuffer as a window.
  106. This is a macro, and does not evaluate its arguments." (byte-code "´ˆ˜¯˘˙¨²˚¸³    EDEDED˝EEÇ" [form yesmini let ((OriginallySelectedWindow (selected-window))) unwind-protect while progn not eq OriginallySelectedWindow select-window next-window nil (select-window OriginallySelectedWindow)] 13))
  107.  
  108. (put (quote eval-in-window) (quote lisp-indent-hook) 0)
  109.  
  110. (defun move-to-loc (x y) "\
  111. Move cursor to window location X, Y.
  112. Handles wrapped and horizontally scrolled lines correctly." (byte-code "˜!Èi¯˘˙ !Âi¨ ²Z ^\\Á\"˚˙ ¸¨ S ^#!
  113.     Z*Ç" [y cc nc x move-to-window-line move-to-column zerop window-hscroll window-width 2 + -1] 13))
  114.  
  115. (defun minibuffer-window-p (window) "\
  116. True iff this WINDOW is minibuffer." (byte-code "ˋ ´ˆ!8UÇ" [window screen-height 3 window-edges] 5))
  117.  
  118. (setq *mouse-help* nil)
  119.  
  120. (defun sun-mouse-handler (&optional hit) "\
  121. Evaluates the function or list associated with a mouse hit.
  122. Expecting to read a hit, which is a list: (button x y delta).  
  123. A form bound to button by define-mouse is found by mouse-lookup. 
  124. The variables: *mouse-window*, *mouse-x*, *mouse-y* are bound.  
  125. If the form is a symbol (symbolp), it is funcall'ed with *mouse-window*,
  126. *mouse-x*, and *mouse-y* as arguments; if the form is a list (listp),
  127. the form is eval'ed; if the form is neither of these, it is an error.
  128. Returns nil." (interactive) (byte-code "˝È?Ä ˛ ÉÈˇ—8±8\"¼    8—    8±    8½    \"p¾Îà
  129. !qÈá!))?ÂVâã¼8\"!??ÄSäåçè!!\"Á§9ÂÉ    È
  130. Âué
  131. F!Èê Á|ë
  132. $Á§<¢@É    È
  133. ÂÝé!Èê Á÷ì!Á§äÆ\"),)È    í=Ä• É    È˝Ç" [hit loc *mouse-window* *mouse-x* *mouse-y* mouse-code form StartBuffer sm::UpBits this-command *mouse-help* t last-command nil sm::combined-hits sm::window-xy 1 2 0 mouse-event-code ((byte-code "qÇ" [StartBuffer] 1)) window-buffer mouse-lookup zerop logand error "Undefined mouse event: %s" prin1-to-string mouse-code-to-mouse-list prin1 exit-recursive-edit funcall eval "Mouse action must be symbol or list, but was: %s" sun-mouse-handler] 19))
  134.  
  135. (defun mouse-help nil (interactive) (byte-code "´Èˋˆ )Ç" [*mouse-help* t nil recursive-edit] 2))
  136.  
  137. (defun sm::combined-hits nil "\
  138. Read and return next mouse-hit, include possible double click" (byte-code "˘ ˙¨    ²8\"!??Ä9˚ !
  139. Ä8¸³²8²
  140. 8¨ ²8\"¨ ²
  141. 8\"UÂ5Á6²#\")È)Ç" [hit1 sm::UpBits hit2 extra-click-wait sm::ButtonBits sm::DoubleBits mouse-hit-read zerop logand 0 mouse-second-hit setcar logior] 15))
  142.  
  143. (defun mouse-hit-read nil "\
  144. Read mouse-hit list from keyboard.  Like (read 'read-char),
  145. but that uses minibuffer, and mucks up last-command." (byte-code "ˋˋˆ˜rÉ
  146. BÉÈ\"?ÄˋÈÁȯ˘˙¨!²#!*Ç" [char-list nil char equal 13 read mapconcat char-to-string nreverse ""] 7))
  147.  
  148. (defvar mouse-prefix1 24 "\
  149. First char of mouse-prefix.  Used to detect double clicks and chords.")
  150.  
  151. (defvar mouse-prefix2 0 "\
  152. Second char of mouse-prefix.  Used to detect double clicks and chords.")
  153.  
  154. (defun mouse-second-hit (hit-wait) "\
  155. Returns the next mouse hit occurring within HIT-WAIT milliseconds." (byte-code "²!Â
  156. ˋÁZr˚
  157. \"?Ų¸!Â\"
  158. ÉÈˋÁYr˚\"?Â8
  159. Éȳ ÈˋÁX˝ ˛ˇ—8\"!?ÂU±¸8Z!ÁW)))Ç" [hit-wait nil pc1 mouse-prefix1 unread-command-char pc2 mouse-prefix2 new-hit sm::UpBits sit-for-millisecs equal 3 ding mouse-hit-read zerop logand 0 mouse-second-hit] 12))
  160.  
  161. (defun sm::window-xy (x y) "\
  162. Find window containing screen coordinates X and Y.
  163. Returns list (window x y) where x and y are relative to window." (byte-code "ˆ˜ÍÅ
  164. ¹    
  165. EÇ" [nil x y found (byte-code "˚ ¸Î³˚ !˝    8˛    8ˇ    8—    8 ± UÄ% TÉȼ UÄ1TÉÈ
  166. YÄK WÄK YÄKWÄ\\½¾˚ 
  167. Z ZE\",)Èàᨲ\"!=?Äp¨ÈÁ))Ç" [OriginallySelectedWindow we le te re be x y nil t selected-window ((byte-code "ˋ!Ç" [OriginallySelectedWindow select-window] 2)) window-edges 0 1 2 3 screen-width screen-height throw found select-window next-window] 12)] 3))
  168.  
  169. (defun sm::window-region (loc) "\
  170. Parse LOC into a region symbol.
  171. Returns one of (text scrollbar modeline minibuffer)" (byte-code "¨    8²    8˚    8¸!S³!S˝! ˛ÁS YÂ*ˇÁS
  172. YÂ4—ÁSÄK
  173. ZYÄK
  174. ˚±
  175. #\\YÂR—ÁS¼*+Ç" [w loc x y right bottom scrollbar-width t 0 1 2 window-width window-height minibuffer-window-p minibuffer modeline scrollbar window-line-end text] 9))
  176.  
  177. (defun window-line-end (w x y) "\
  178. Return WINDOW column (ignore X) containing end of line Y" (byte-code "ˆ ˜Î¯    !ÈÊ˘˙ 
  179. \")))Ç" [OriginallySelectedWindow w y selected-window ((byte-code "ˋ!Ä    ´!Ç" [OriginallySelectedWindow window-point select-window] 3)) select-window move-to-loc screen-width] 6))
  180.  
  181. (defconst sm::keyword-alist (quote ((left . 1) (middle . 2) (right . 4) (shift . 8) (control . 16) (meta . 32) (double . 64) (up . 128) (text . 256) (scrollbar . 512) (modeline . 1024) (minibuffer . 2048))))
  182.  
  183. (defun mouse-event-code (hit loc) "\
  184. Maps MOUSE-HIT and LOC into a mouse-code." (byte-code "´ˆ8˜¯    !!\"Ç" [hit loc logior 0 mouse-region-to-code sm::window-region] 5))
  185.  
  186. (defun mouse-region-to-code (region) "\
  187. Returns partial mouse-code for specified REGION." (byte-code "´    \"AÇ" [region sm::keyword-alist assq] 3))
  188.  
  189. (defun mouse-list-to-mouse-code (mouse-list) "\
  190. Map a MOUSE-LIST to a mouse-code." (byte-code "ˋ´ˆ˜\"\"Ç" [mouse-list apply logior mapcar (lambda (x) (byte-code "´    \"AÇ" [x sm::keyword-alist assq] 3))] 5))
  191.  
  192. (defun mouse-code-to-mouse-list (mouse-code) "\
  193. Map a MOUSE-CODE to a mouse-list." (byte-code "ˋ´ˆ˜\"\"Ç" [sm::keyword-alist apply nconc mapcar (lambda (x) (byte-code "´    A\"Ä     @CÇ" [mouse-code x logtest] 3))] 5))
  194.  
  195. (defun mousemap-set (code mousemap value) (byte-code "    A¯ \"
  196. ¢
  197. \"Á˘     BB\"*Ç" [alist mousemap assq-result code value assq setcdr] 6))
  198.  
  199. (defun mousemap-get (code mousemap) (byte-code "´    A\"AÇ" [code mousemap assq] 3))
  200.  
  201. (defun mouse-lookup (mouse-code) "\
  202. Look up MOUSE-EVENT and return the definition. nil means undefined." (byte-code "ˆ    \"Å ˆ
  203. \"Ç" [mouse-code current-local-mousemap current-global-mousemap mousemap-get] 4))
  204.  
  205. (defun mouse-mask-lookup (mask list) "\
  206. Args MASK (a bit mask) and LIST (a list of (code . form) pairs).
  207. Returns a list of elements of LIST whose code or'ed with MASK is non-zero." (byte-code "ˋ
  208. Ę
  209. @@\"Ä
  210. @BÉÈ
  211. AÉÈÁÈ)Ç" [result nil list mask logtest] 4))
  212.  
  213. (defun mouse-union (l l-unique) "\
  214. Return the union of list of mouse (code . form) pairs L and L-UNIQUE,
  215. where L-UNIQUE is considered to be union'ized already." (byte-code "    
  216. Ä!
  217. @˜ @\"?Ä BÉ)È
  218. AÉÈÁÈ)Ç" [result l-unique l code-form-pair assq] 4))
  219.  
  220. (defun mouse-union-first-prefered (l1 l2) "\
  221. Return the union of lists of mouse (code . form) pairs L1 and L2,
  222. based on the code's, with preference going to elements in L1." (byte-code "ˆˆ    ´\"\"Ç" [l2 l1 nil mouse-union] 5))
  223.  
  224. (defun mouse-code-function-pairs-of-region (region) "\
  225. Return a list of (code . function) pairs, where each code is
  226. currently set in the REGION." (byte-code "˜    !¯˘
  227. A\"˘ A\"\")Ç" [mask region current-local-mousemap current-global-mousemap mouse-region-to-code mouse-union-first-prefered mouse-mask-lookup] 7))
  228.  
  229. (defun one-line-doc-string (function) "\
  230. Returns first line of documentation string for FUNCTION.
  231. If there is no documentation string, then the string
  232. \"No documentation\" is returned." (byte-code ":Ä@ÉÈÁÈ´!    ?ˆÁ&˜¯    \"È    ˘˙˘!O)Ç" [function doc documentation "No documentation." string-match "^.*$" 0 match-end] 6))
  233.  
  234. (defun print-mouse-format (binding) (byte-code "ˋ@!Èˋ´!Ȉ˜A\"ȯ Èˋ˘!Èˋ˙@!!ȯ Ç" [binding princ ": " mapcar (lambda (mouse-list) (byte-code "ˋ!Èˋ´!Ç" [mouse-list princ " "] 3)) terpri "  " one-line-doc-string] 9))
  235.  
  236. (defun print-mouse-bindings (region) "\
  237. Prints mouse-event bindings for REGION." (byte-code "ˋ´ˆ!\"Ç" [region mapcar print-mouse-format sm::event-bindings] 4))
  238.  
  239. (defun sm::event-bindings (region) "\
  240. Returns an alist of (function . (mouse-list1 ... mouse-listN)) for REGION,
  241. where each mouse-list is bound to the function in REGION." (byte-code "˘    !ˆÄ:@˙ A
  242. \"Â$¨² @!AB\"Á0 A² @!CB
  243. BÉ*ÈAÉÈÁÈ
  244. *Ç" [mouse-bindings region result nil code-function-pair current-entry mouse-code-function-pairs-of-region assoc setcdr mouse-code-to-mouse-list] 8))
  245.  
  246. (defun describe-mouse-bindings nil "\
  247. Lists all current mouse-event bindings." (interactive) (byte-code "¹Èˋдˆ!Ș È´¯!Ș È˘˙!Ș È´¨!Ș È´²!Ș È˘˚!Ș È´¸!Ș È´³!Ș È˘˝!ÑÇ" [nil "*Help*" princ "Text Region" terpri "---- ------" print-mouse-bindings text "Modeline Region" "-------- ------" modeline "Scrollbar Region" "--------- ------" scrollbar] 19))
  248.  
  249. (defun describe-mouse-briefly (mouse-list) "\
  250. Print a short description of the function bound to MOUSE-LIST." (interactive "xDescibe mouse list briefly: ") (byte-code "´Èˆ˜    !!¯˘    #Á¯˙    \")Ç" [function mouse-list nil mouse-lookup mouse-list-to-mouse-code message "%s runs the command %s" "%s is undefined"] 6))
  251.  
  252. (defun mouse-help-menu (function-and-binding) (byte-code "ˋ@!´ˆ@!CˋA!CD!BÇ" [function-and-binding prin1-to-string menu-create one-line-doc-string] 7))
  253.  
  254. (defun mouse-help-region (w x y &optional region) "\
  255. Displays a menu of mouse functions callable in this region." (byte-code "Å
  256. ˙    
  257. E!¨²K˚!\"¸³!C B!˝    ˛ $ˇ,Ç" [region w x y mlist menu item sm::window-region mapcar mouse-help-menu sm::event-bindings menu-create symbol-name sun-menu-evaluate 0 nil] 11))
  258.  
  259. (defun menu-create (items) "\
  260. Functional form for defmenu, given a list of ITEMS returns a menu.
  261. Each ITEM is a (STRING . VALUE) pair." (byte-code "ˋ´\"Ç" [items apply vector] 3))
  262.  
  263. (defmacro defmenu (menu &rest itemlist) "Defines MENU to be a menu, the ITEMS are (STRING . VALUE) pairs.
  264. See sun-menu-evaluate for interpretation of ITEMS." (byte-code "´ˆ˜    \"EÇ" [menu itemlist defconst funcall menu-create] 5))
  265.  
  266. (defun sun-menu-evaluate (*menu-window* *menu-x* *menu-y* menu) "\
  267. Display a pop-up menu in WINDOW at X Y and evaluate selected item
  268. of MENU.  MENU (or its symbol-value) should be a menu defined by defmenu.
  269.   A menu ITEM is a (STRING . FORM) pair;
  270. the FORM associated with the selected STRING is evaluated,
  271. and the resulting value is returned.  Generally these FORMs are
  272. evaluated for their side-effects rather than their values.
  273.   If the selected form is a menu or a symbol whose value is a menu, 
  274. then it is displayed and evaluated as a pullright menu item.
  275.   If the the FORM of the first ITEM is nil, the STRING of the item
  276. is used as a label for the menu, i.e. it's inverted and not selectible." (byte-code "9Ä    JÉȘ¯    
  277. ˘%!Ç" [menu *menu-window* *menu-x* *menu-y* eval sun-menu-internal 4] 7))
  278.  
  279. (defun sun-get-frame-data (code) "\
  280. Sends the tty-sub-window escape sequence CODE to terminal,
  281. and returns a cons of the two numbers in returned escape sequence.
  282. That is it returns (cons <car> <cdr>) from \"\\E[n;<car>;<cdr>t\". 
  283. CODE values: 13 = Tool-Position, 14 = Size-in-Pixels, 18 = Size-in-Chars." (byte-code "¯˘˙!¨Q!Ȳ²²²˚¸rÉ\"?Ä$    
  284. BÉÈÁȳ˝˛
  285. !ˇ#ÉÈ—±
  286. \"È
  287. ¼½!T¾½!OÉÈ
  288. ¾½!²OÉÈ—±
  289. \"È
  290. ¼½!T¾½!OÉÈà !à !B,Ç" [code char str x y send-string-to-terminal "" int-to-string "t" nil equal 116 mapconcat char-to-string nreverse "" string-match ";[0-9]*" match-beginning 0 match-end string-to-int] 16))
  291.  
  292. (defun sm::font-size nil "\
  293. Returns font size in pixels: (cons Ysize Xsize)" (byte-code "´ˆ!´˜!¯@    @\"¯A    A\"B*Ç" [pix chr sun-get-frame-data 14 18 /] 7))
  294.  
  295. (defvar sm::menu-kludge-x nil "\
  296. Cached frame-to-window X-Offset for sm::menu-kludge")
  297.  
  298. (defvar sm::menu-kludge-y nil "\
  299. Cached frame-to-window Y-Offset for sm::menu-kludge")
  300.  
  301. (defun sm::menu-kludge nil "\
  302. If sunfns.c uses <Menu_Base_Kludge> this function must be here!" (byte-code "Ř ¯    @\\˘É)È˙¨! @\\ A
  303. \\B)Ç" [sm::menu-kludge-y fs sm::menu-kludge-x wl sm::font-size 8 4 sun-get-frame-data 13] 5))
  304.  
  305. (defun sunview-yank-stuff nil "\
  306. Set mark and yank the contents of the current TTYSW `STUFF' selection
  307. into the current buffer at point.  The STUFF selection contains the currently
  308. or previously highlighted text from a TTYSW." (interactive "*") (byte-code "¹Èˋ¹!È´ˆ !Ç" [nil set-mark-command insert-string sun-get-selection] 4))
  309.  
  310. (defun display-host nil "\
  311. Extract <host> from DISPLAY environment variable, or return nil if not specified." (byte-code "´ˆ!Ę¯\"    Ä˘    !?Ä˙    O))Ç" [display colon_at getenv "DISPLAY" string-match ":" zerop 0] 6))
  312.  
  313. (defun sunview-yank-clipboard nil "\
  314. Set mark and yank the contents of the SunView Clipboard into the
  315. current buffer at point." (interactive "*") (byte-code "¹Èˆ¹!Ș     Â¯˘¹´´˜ ˙¨&Á\"¯˙¹´´¨%)Ç" [nil host t set-mark-command display-host call-process "rsh" "get_selection" "3"] 11))
  316.  
  317. (defun sunview-yank-current-selection nil "\
  318. Set mark and yank the contents of the current SunView selection
  319. into current buffer at point. The current selection is the currently
  320. highlighted text in either a textsw or a ttysw." (interactive "*") (byte-code "¹Èˆ¹!Ș     Â¯˘¹´´˜ ˙&Á ¯˙¹´´$)Ç" [nil host t set-mark-command display-host call-process "rsh" "get_selection"] 10))
  321.  
  322. (defun sunview-yank-any-selection (arg) "\
  323. Yank one of the sunview selections:
  324. with no arg, the current selection; with minus-only prefix, the clipboard;
  325. with any other arg, the ttysw STUFF." (interactive "*P") (byte-code "´È? ˆ Á˜=¯ Á˘ Ç" [arg t nil sunview-yank-current-selection - sunview-yank-clipboard sunview-yank-stuff] 4))
  326.  
  327. (defvar owselectionfilex nil "\
  328. Cache path to ttysw selection file (a kludge!).")
  329.  
  330. (defun owselectionfile nil (byte-code "Å&˜     Â¯    ˘QÁ˘˙
  331. ! 
  332. ÉÁ%¨²!Ȉ*Ç" [owselectionfilex host filex nil display-host "/net/" "/tmp/ttyselection" file-exists-p message "no TTYSW selection file"] 4))
  333.  
  334. (defun xv-yank-selection nil "\
  335. Set mark and yank the contents of the current Xview selection
  336. into the current buffer at point.  The STUFF selection contains the currently
  337. or previously highlighted text from a TTYSW." (interactive "*") (byte-code "¹Èˋ Ä´ˋ !Ȉ Ç" [nil owselectionfile insert-file exchange-point-and-mark] 5))
  338.  
  339. (defun xv-select-region (beg end) "\
  340. Set the TTYSW selection to the region in the current buffer." (interactive "r") (byte-code "´Èˆ Ä˜    ˆ ´¯%Ç" [beg end nil owselectionfile write-region noprint] 8))
  341.  
  342. (defun sun-yank-selection nil "\
  343. Set mark and yank the contents of the current TTYSW `STUFF' or Xview selection
  344. into the current buffer at point." (interactive "*") (byte-code "¹Èˋ´!ˆ Á˜ Ç" [nil getenv "DISPLAY" xv-yank-selection sunview-yank-stuff] 4))
  345.  
  346. (defun sun-select-region (beg end) "\
  347. Set the TTYSW 'STUFF' or Xview selection to the region in the current buffer." (interactive "r") (byte-code "´Èˆ˜!¯    \"Á˘˙    \"!Ç" [beg end nil getenv "DISPLAY" xv-select-region sun-set-selection buffer-substring] 6))
  348.  
  349. (defun suspend-emacstool (&optional stuffstring) "\
  350. If running under as a detached process emacstool,
  351. you don't want to suspend  (there is no way to resume), 
  352. just close the window, and wait for reopening." (interactive) (byte-code "ˆÈ˜¹!Ä    Ä¯!È    Ä˘    !È˘˙!Ș´!Ä#
  353. Ä)¯
  354. !Ç" [suspend-hook stuffstring suspend-resume-hook nil boundp funcall send-string-to-terminal "t"] 7))
  355.  
  356. (make-variable-buffer-local (quote current-local-mousemap))
  357.  
  358. (setq-default current-local-mousemap nil)
  359.  
  360. (defvar current-global-mousemap (make-mousemap))
  361.