This file is indexed.

/usr/share/denemo/actions/denemo-modules/helpsystem.scm is in denemo-data 2.2.0-1build1.

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
(use-modules (ice-9 q))

#!(define-module (actions denemo-modules helpsystem)
    #:export (
         Help::RemoveTag
         Help::TimedNotice 
         Help::Push
         Help::Pop
    )) !#


; This help system is designed to give out messages in the second Denemo status bar.
;; You can push and pop to a message-queue. If you Pop the front message the one before that will appear again
;; Each help message consists of a tag-symbol and a help-string. Only one message of each tag is allowed in the queue. If you push a another message with an existing tag the old message gets deleted.
;; Please stick to the following tag convention
;;; 'timednotice - for a message that will delete itself after a few seconds (you might want use (Help::TimedNotice) anyway)
;;; 'doublestroketemp - for any message that tells the user that a command waits for another keypress, like a duration key.
;;; 'doublestroke - a permanent message that shows the current keybindings or give permanent info about some special mode you might be in.

(define Help::queue (make-q)) ; Prepare the message queue. Only one is used for the entire system.

(define (Q-remove! q obj)  ; A function that replaces Guiles q-remove!. Ours works with a pair and only looks for the car.
    (set-car! q (filter (lambda (x) (not (equal? (car x) obj))) (car q)))
    (sync-q! q))

(define (Help::RemoveTag tag) ; Remove all messages with this 'tag symbol
    (Q-remove! Help::queue tag)
    (Help::UpdateWriteStatus))

(define (Help::ClearQueue) ; Clear the entire queue
    (set! Help::queue (make-q))
    (Help::UpdateWriteStatus))

;Take the current front message and display it.
;;Help::UpdateWriteStatus is the only function that accesses the StatusBar.
;;If there is no message left in the queue, disable showing the message area.
(define (Help::UpdateWriteStatus)
    (if (q-empty? Help::queue)
        (d-WriteStatus "                                  ") ;;; keep the status bar visible
        (d-WriteStatus (cdr (q-front Help::queue)))))

;Push a message to the queue. 
;; Also Updates the StatusBar through UpdateWriteStatus
(define (Help::Push pair)
    (Help::RemoveTag (car pair)) ; remove all with the same tag first. TODO: evaluate if this is a heavy performance-loss   
    (q-push! Help::queue pair)
    (Help::UpdateWriteStatus))

;Remove the current front message from the queue
;; Also Updates the StatusBar through UpdateWriteStatus
(define (Help::Pop)
    (if (not (q-empty? Help::queue))
        (begin
            (q-pop! Help::queue)
            (Help::UpdateWriteStatus))))

; Display a message that deletes itself after timing (default 2500ms). No tag or Pop needed from the user.
(define* (Help::TimedNotice string #:optional (timing 2500))
    (Help::Push (cons 'timednotice string))
    (Help::Push (cons 'timednotice1 (string-append string "\n\n\n")))
     (Help::Push (cons 'timednotice2 (string-append string "\n\n\n")))
     (Help::Push (cons 'timednotice3 (string-append string "\n\n\n\n")))
     (Help::Push (cons 'timednotice4 (string-append string "\n\n\n\n\n")))
     (let ((at 0) (step 250))
        (set! at (+ at step))
        (d-OneShotTimer at "(Help::Pop)")
        (set! at (+ at step)) 
        (d-OneShotTimer at "(Help::Pop)")
        (set! at (+ at step))
        (d-OneShotTimer at "(Help::Pop)")        
        (set! at (+ at step))
        (d-OneShotTimer at "(Help::Pop)")        
        (set! at (+ at step))
  
        (d-OneShotTimer (* 2 timing) "(Help::Pop)")))
    

(define* (TimedNotice string #:optional (timing 2500))
    (Help::TimedNotice (string-append  "<span font_desc=\"16\" foreground=\"blue\">" string   "</span>") timing))