view tests/Dnd/droptest.el @ 930:eaedf30d9d76

[xemacs-hg @ 2002-07-23 08:34:59 by youngs] 2002-07-15 Jerry James <james@xemacs.org> * make-docfile.c: Change whitespace and organization to reduce the size of the diff against FSF Emacs sources and synch to Emacs 21.2. Remove unused DO_REALLOC. Mark XEmacs changes and additions more clearly. Reintroduce previously deleted Emacs code inside #if 0 ... #endif. * make-docfile.c (next_extra_elc): Replace goto with do-while. * make-docfile.c (main): Put XEmacs-only args in one place. * make-docfile.c (write_c_args): Change buff to buf to match Emacs. Replace pointer arithmetic with simpler array syntax. * make-docfile.c (scan_c_file): Note that DEFSIMPLE and DEFPRED no longer exist. Correct the "name too long" test (off by one). Die with message if a DEFUN has no docstring instead of hanging. * make-docfile.c (scan_lisp_file): Introduce while loops used in Emacs sources to skip consecutive blank lines. 2002-07-21 John Paul Wallington <jpw@xemacs.org> * process.el (substitute-env-vars): New function; sync with GNU Emacs 21.1.50. (setenv): Add optional arg SUBSTITUTE-ENV-VARS; sync with GNU Emacs 21.1.50. 2002-07-20 Mike Sperber <mike@xemacs.org> * eval.c (run_post_gc_hook): Use more correct flags when running post-gc-hook. 2002-07-20 Mike Sperber <mike@xemacs.org> * process-unix.c (child_setup): Don't try to close file descriptors for chid process once again---it's already being done in close_process_descs. (unix_create_process): Call begin_dont_check_for_quit to inhibit unwanted interaction (and thus breaking of X event synchronicity) in the child. 2002-07-15 Jerry James <james@xemacs.org> * lisp.h: Make Qdll_error visible globally. * symbols.c (check_sane_subr): Revert 2002-06-26 change. Check only if !initialized. * symbols.c (check_module_subr): Add parameter. Duplicate check_sane_subr checks, but signal an error instead of asserting. * symbols.c (defsubr): Use check_module_subr parameter. * symbols.c (defsubr_macro): Ditto.
author youngs
date Tue, 23 Jul 2002 08:35:11 +0000
parents 3ecd8885ac67
children bc4f2511bbea
line wrap: on
line source

;; a short example how to use the new Drag'n'Drop API in
;; combination with extents.
;;

(defun dnd-drop-message (event object text)
  (message "Dropped %s with :%s" text object)
  ;; signal that we have done something with the data
  t)

(defun do-nothing (event object)
  ;; signal that the data is still unprocessed
  nil)

(defun start-drag (event what &optional typ)
  ;; short drag interface, until the real one is implemented
  (cond ((featurep 'offix)
	 (if (numberp typ)
	     (offix-start-drag event what typ)
	   (offix-start-drag event what)))
	((featurep 'cde)
	 (if (not typ)
	     (funcall (intern "cde-start-drag-internal") event nil (list what))
	   (funcall (intern "cde-start-drag-internal") event t what)))
	(t display-message 'error "no valid drag protocols implemented")))

(defun start-region-drag (event)
  (interactive "_e")
  (if (click-inside-extent-p event zmacs-region-extent)
      ;; okay, this is a drag
      (cond ((featurep 'offix)
	     (offix-start-drag-region event
				      (extent-start-position zmacs-region-extent)
				      (extent-end-position zmacs-region-extent)))
	    ((featurep 'cde)
	     ;; should also work with CDE
	     (cde-start-drag-region event
				    (extent-start-position zmacs-region-extent)
				    (extent-end-position zmacs-region-extent)))
	    (t (error "No offix or CDE support compiled in")))))

(defun make-drop-targets ()
  (let ((buf (get-buffer-create "*DND misc-user extent test buffer*"))
	(s nil)
	(e nil))
    (set-buffer buf)
    (pop-to-buffer buf)
    (setq s (point))
    (insert "[ DROP TARGET 1]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext
			 'experimental-dragdrop-drop-functions
			 '((do-nothing t t)
			   (dnd-drop-message t t "on target 1")))
    (set-extent-property ext 'mouse-face 'highlight)
    (insert "    ")
    (setq s (point))
    (insert "[ DROP TARGET 2]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext
			 'experimental-dragdrop-drop-functions
			 '((dnd-drop-message t t "on target 2")))
    (set-extent-property ext 'mouse-face 'highlight)
    (insert "    ")
    (setq s (point))
    (insert "[ DROP TARGET 3]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext
			 'experimental-dragdrop-drop-functions
			 '((dnd-drop-message t t "on target 3")))
    (set-extent-property ext 'mouse-face 'highlight)
    (newline 2)))

(defun make-drag-starters ()
  (let ((buf (get-buffer-create "*DND misc-user extent test buffer*"))
	(s nil)
	(e nil)
	(ext nil)
	(kmap nil))
    (set-buffer buf)
    (pop-to-buffer buf)
    (erase-buffer buf)
    (insert "Try to drag data from one of the upper extents to one\nof the lower extents. Make sure that your minibuffer is big\ncause it is used to display the data.\n\nYou may also try to select some of this text and drag it with button2.\n\nTo ")
    (setq s (point))
    (insert "EXIT")
    (setq e (point))
    (insert " this demo, press 'q'.")
    (setq ext (make-extent s e))
    (setq kmap (make-keymap))
    (define-key kmap [button1] 'end-dnd-demo)
    (set-extent-property ext 'keymap kmap)
    (set-extent-property ext 'mouse-face 'highlight)
    (newline 2)
    (setq s (point))
    (insert "[ TEXT DRAG TEST ]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext 'mouse-face 'isearch)
    (setq kmap (make-keymap))
    (define-key kmap [button1] 'text-drag)
    (set-extent-property ext 'keymap kmap)
    (insert "    ")
    (setq s (point))
    (insert "[ FILE DRAG TEST ]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext 'mouse-face 'isearch)
    (setq kmap (make-keymap))
    (if (featurep 'cde)
	(define-key kmap [button1] 'cde-file-drag)
      (define-key kmap [button1] 'file-drag))
    (set-extent-property ext 'keymap kmap)
    (insert "    ")
    (setq s (point))
    (insert "[ FILES DRAG TEST ]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext 'mouse-face 'isearch)
    (setq kmap (make-keymap))
    (define-key kmap [button1] 'files-drag)
    (set-extent-property ext 'keymap kmap)
    (insert "    ")
    (setq s (point))
    (insert "[ URL DRAG TEST ]")
    (setq e (point))
    (setq ext (make-extent s e))
    (set-extent-property ext 'mouse-face 'isearch)
    (setq kmap (make-keymap))
    (if (featurep 'cde)
	(define-key kmap [button1] 'cde-file-drag)
      (define-key kmap [button1] 'url-drag))
    (set-extent-property ext 'keymap kmap)
    (newline 3)))
    
(defun text-drag (event)
  (interactive "@e")
  (start-drag event "That's a test"))

(defun file-drag (event)
  (interactive "@e")
  (start-drag event "/tmp/DropTest.xpm" 2))

(defun cde-file-drag (event)
  (interactive "@e")
  (start-drag event '("/tmp/DropTest.xpm") t))

(defun url-drag (event)
  (interactive "@e")
  (start-drag event "http://www.xemacs.org/" 8))

(defun files-drag (event)
  (interactive "@e")
  (start-drag event '("/tmp/DropTest.html" "/tmp/DropTest.xpm" "/tmp/DropTest.tex") 3))

(setq experimental-dragdrop-drop-functions '((do-nothing t t)
				;; CDE does not have any button info...
				(dnd-drop-message 0 t "cde-drop somewhere else")
				(dnd-drop-message 2 t "region somewhere else")
				(dnd-drop-message 1 t "drag-source somewhere else")
				(do-nothing t t)))

(make-drag-starters)
(make-drop-targets)

(defun end-dnd-demo ()
  (interactive)
  (global-set-key [button2] button2-func)
  (bury-buffer))

(setq lmap (make-keymap))
(use-local-map lmap)
(local-set-key [q] 'end-dnd-demo)
(setq button2-func (lookup-key global-map [button2]))
(global-set-key [button2] 'start-region-drag)