This file is indexed.

/usr/lib/gcl-2.6.12/gcl-tk/demos/mkCanvText.lisp is in gcl 2.6.12-1.

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
;;# mkCanvText w
;;
;; Create a top-level window containing a canvas displaying a text
;; string and allowing the string to be edited and re-anchored.
;;
;; Arguments:
;;    w -	Name to use for new top-level window.
(in-package "TK")
(defun mkCanvText ({w .ctext}) 
    (catch {destroy w})
    (toplevel w)
    (dpos w)
    (wm :title w "Canvas Text Demonstration")
    (wm :iconname w "Text")
    (setq c (conc w '.c))

    (message (conc w '.msg) :font -Adobe-Times-Medium-R-Normal-*-180-* :width 420 
	    :relief "raised" :bd 2 :text "This window displays a string of text to demonstrate the text facilities of canvas widgets.  You can point, click, and type.  You can also select and then delete with Control-d.  You can copy the selection with Control-v.  You can click in the boxes to adjust the position of the text relative to its positioning point or change its justification.")
    (canvas c :relief "raised" :width 500 :height 400)
    (button (conc w '.ok) :text "OK" :command (tk-conc "destroy " w))
    (pack (conc w '.msg) :side "top" :fill "both")
    (pack (conc w '.c) :side "top" :expand "yes" :fill "both")
    (pack (conc w '.ok) :side "bottom" :pady 5 :anchor "center")

    (setq font :Adobe-helvetica-medium-r-*-240-*)

    (funcall c :create rectangle 245 195 255 205 :outline "black" :fill "red")

    ;; First, create the text item and give it bindings so it can be edited.
    
    (funcall c :addtag text withtag (funcall c create text 250 200 :text "This is just a string of text to demonstrate the text facilities of canvas widgets. You can point, click, and type.  You can also select and then delete with Control-d." :width 440 :anchor "n" :font font :justify "left"))
    (funcall c :bind text "<1>" (textB1Press  c  |%x| |%y|))
    (funcall c :bind text "<B1-Motion>" (textB1Move  c  %x %y))
    (funcall c :bind text "<Shift-1>" (tk-conc c " select adjust current @%x,%y"))
    (funcall c :bind text "<Shift-B1-Motion>" (funcall 'textB1Move  c  |%x| |%y|))
    (funcall c :bind text "<KeyPress>" (tk-conc c " insert text insert %A"))
    (funcall c :bind text "<Shift-KeyPress>" (tk-conc c " insert text insert %A"))
    (funcall c :bind text "<Return>" (tk-conc c " insert text insert \\n"))
    (funcall c :bind text "<Control-h>" (funcall 'textBs c))
    (funcall c :bind text "<Delete>" (funcall  'textBs  c))
    (funcall c :bind text "<Control-d>" (tk-conc c " dchars text sel.first sel.last"))
    (funcall c :bind text "<Control-v>" (tk-conc c " insert text insert \[selection get\]"))

    ;; Next, create some items that allow the text's anchor position
    ;; to be edited.

    (setq x 50)
    (setq y 50)
    (setq color LightSkyBlue1)
    (mkTextConfig c x y :anchor "se" color)
    (mkTextConfig c (+ x 30) y :anchor "s" color)
    (mkTextConfig c (+ x 60) y :anchor "sw" color)
    (mkTextConfig c x (+ y 30) :anchor "e" color)
    (mkTextConfig c (+ x 30) (+ y 30) :anchor "center" color)
    (mkTextConfig c (+ x 60) (+ y 30) :anchor "w" color)
    (mkTextConfig c x (+ y 60) :anchor "ne" color)
    (mkTextConfig c (+ x 30) (+ y 60) :anchor "n" color)
    (mkTextConfig c (+ x 60) (+ y 60) :anchor "nw" color)
    (setq item (funcall c create rect (+ x 40) (+ y 40) (+ x 50) (+ y 50) 
	    :outline "black" :fill "red"))
    (funcall c :bind item "<1>" (tk-conc c " itemconf text :anchor ")center"")
     (funcall c :create text (+ x 45) (- y 5) :text "{Text Position}" :anchor "s" 
	    :font -Adobe-times-medium-r-normal--*-240-* :fill "brown")

    ;; Lastly, create some items that allow the text's justification to be
    ;; changed.
    
    (setq x 350)
    (setq y 50)
    (setq color SeaGreen2)
    (mkTextConfig c x y :justify "left" color)
    (mkTextConfig c (+ x 30) y :justify "center" color)
    (mkTextConfig c (+ x 60) y :justify "right" color)
    (funcall c :create text (+ x 45) (- y 5) :text "Justification" :anchor "s" 
	    :font -Adobe-times-medium-r-normal--*-240-* :fill "brown")

    (funcall c :bind config "<Enter>" (tk-conc "textEnter " c))
    (funcall c :bind config "<Leave>" (tk-conc c " itemconf current :fill \$textConfigFill"))
)

(defun mkTextConfig (w x y option value color) 
    (setq item (funcall w create rect x y (+ x 30) (+ y 30) 
	    :outline "black" :fill color :width 1))
    (funcall w :bind item "<1>" (tk-conc w " itemconf text " option " " value))
    (funcall w :addtag "config" "withtag" item)
)

(setq textConfigFill "")

(defun textEnter (w) 
    (global :textConfigFill)
    (setq textConfigFill [lindex (funcall w :itemconfig "current" :fill) 4])
    (funcall w :itemconfig "current" :fill "black")
)

(defun textB1Press (w x y) 
    (funcall w :icursor "current" (aT x y))
    (funcall w :focus "current")
    (focus w)
    (funcall w :select "from" "current" (aT x y))
)

(defun textB1Move (w x y) 
    (funcall w :select "to current" (aT x y))
)

(defun textBs (w &aux char) 
    (setq char  (atoi (funcall w :index "text" "insert")) - 1)
    (if (>= char  0) (funcall w :dchar "text" char))
)