This file is indexed.

/usr/share/guile/site/io/string.scm is in guile-library 0.2.1-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
;; (io string) -- input and output with strings
;; Written 1995, 1996 by Oleg Kiselyov (oleg@acm.org)
;; Modified 1996, 1997, 1998, 2001 by A. Jaffer (agj@alum.mit.edu)
;; Modified 2003 by Steve VanDevender (stevev@hexadecimal.uoregon.edu)
;; Modified 2004 Andy Wingo <wingo at pobox dot com>

;; This file is based SLIB's strsrch.scm, and is in the public domain.

;;; Commentary:
;;
;;@c texinfo, really
;; Procedures that do io with strings.
;;
;;; Code:

(define-module (io string)
  #:use-module (scheme documentation)
  #:export (find-string-from-port?))

(define-with-docs find-string-from-port?
  "Looks for @var{str} in @var{<input-port>}, optionally within the
first @var{max-no-char} characters."
  (lambda (str <input-port> . max-no-char)
    (set! max-no-char (if (null? max-no-char) #f (car max-no-char)))
    (letrec
        ((no-chars-read 0)
         (peeked? #f)
         (my-peek-char			; Return a peeked char or #f
          (lambda () (and (or (not (number? max-no-char))
                              (< no-chars-read max-no-char))
                          (let ((c (peek-char <input-port>)))
                            (cond (peeked? c)
                                  ((eof-object? c) #f)
                                  ((procedure? max-no-char)
                                   (set! peeked? #t)
                                   (if (max-no-char c) #f c))
                                  ((eqv? max-no-char c) #f)
                                  (else c))))))
         (next-char (lambda () (set! peeked? #f) (read-char <input-port>)
                            (set! no-chars-read  (+ 1 no-chars-read))))
         (match-1st-char                ; of the string str
          (lambda ()
            (let ((c (my-peek-char)))
              (and c
                   (begin (next-char)
                          (if (char=? c (string-ref str 0))
                              (match-other-chars 1)
                              (match-1st-char)))))))
         ;; There has been a partial match, up to the point pos-to-match
         ;; (for example, str[0] has been found in the stream)
         ;; Now look to see if str[pos-to-match] for would be found, too
         (match-other-chars
          (lambda (pos-to-match)
            (if (>= pos-to-match (string-length str))
                no-chars-read           ; the entire string has matched
                (let ((c (my-peek-char)))
                  (and c
                       (if (not (char=? c (string-ref str pos-to-match)))
                           (backtrack 1 pos-to-match)
                           (begin (next-char)
                                  (match-other-chars (+ 1 pos-to-match)))))))))

         ;; There had been a partial match, but then a wrong char showed up.
         ;; Before discarding previously read (and matched) characters, we check
         ;; to see if there was some smaller partial match. Note, characters read
         ;; so far (which matter) are those of str[0..matched-substr-len - 1]
         ;; In other words, we will check to see if there is such i>0 that
         ;; substr(str,0,j) = substr(str,i,matched-substr-len)
         ;; where j=matched-substr-len - i
         (backtrack
          (lambda (i matched-substr-len)
            (let ((j (- matched-substr-len i)))
              (if (<= j 0)
                  ;; backed off completely to the begining of str
                  (match-1st-char)
                  (let loop ((k 0))
                    (if (>= k j)
                        (match-other-chars j) ; there was indeed a shorter match
                        (if (char=? (string-ref str k)
                                    (string-ref str (+ i k)))
                            (loop (+ 1 k))
                            (backtrack (+ 1 i) matched-substr-len))))))))
         )
      (match-1st-char))))

;;; arch-tag: 99289f4f-5fdb-4c6e-924a-1c510a61a03e
;;; string.scm ends here