better clean-up of index strings derved from body text

svn: r9886

original commit: 35d8fc32595922acbf91ddb89de13c95b163e1cc
This commit is contained in:
Matthew Flatt 2008-05-19 13:14:10 +00:00
parent 5f941495b6
commit 449670964d
2 changed files with 16 additions and 7 deletions

View File

@ -161,15 +161,22 @@
;; ----------------------------------------
(provide section-index index index* as-index index-section index-blocks)
(provide section-index index index* as-index index-section index-blocks
clean-up-index-string)
(define (section-index . elems)
(make-part-index-decl (map element->string elems) elems))
(define (clean-up s)
;; Remove leading spaces, which might appear there due to images or something
;; else that gets dropped in string form.
(regexp-replace #rx"^ +" s ""))
(define (clean-up-index-string s)
;; Remove leading spaces or trailing, which might appear there due
;; to images or something else that gets dropped in string form.
;; Then collapse whitespace.
(regexp-replace* #px"\\s+"
(regexp-replace #rx"^ +"
(regexp-replace #rx" +$"
s
""))
" "))
(define (record-index word-seq element-seq tag content)
(make-index-element #f
@ -190,7 +197,7 @@
(define (as-index . s)
(let ([key (make-generated-tag)]
[content (decode-content s)])
(record-index (list (clean-up (content->string content)))
(record-index (list (clean-up-index-string (content->string content)))
(if (= 1 (length content))
content
(list (make-element #f content)))

View File

@ -292,7 +292,9 @@
(define (indexed-file . str)
(let* ([f (apply filepath str)]
[s (element->string f)])
(index* (list (substring s 1 (sub1 (string-length s)))) (list f) f)))
(index* (list (clean-up-index-string (substring s 1 (sub1 (string-length s)))))
(list f)
f)))
(define (exec . str)
(if (andmap string? str)
(make-element 'tt str)