allow quote marks to be set for `smart-quotes` (closes #138)

pull/139/head
Matthew Butterick 8 years ago
parent 2eac1e419e
commit 146d95b49c

@ -1 +1 @@
1484775689 1488121531

@ -16,16 +16,29 @@ Quick & dirty utilities. I use them, but I haven't tested them with enough edge
@defproc[ @defproc[
(smart-quotes (smart-quotes
[xexpr (or/c string? txexpr?)]) [xexpr (or/c string? txexpr?)]
(or/c string? txexpr?)] [#:apostophe apostrophe-str string? ""]
Convert straight quotes in @racket[_xexepr] to curly according to American English conventions. [#:single-open single-open-str string? ""]
[#:single-close single-close-str string? ""]
[#:double-open double-open-str string? "“"]
[#:double-close double-close-str string? "”"])
(or/c string? txexpr?)]{
Convert straight quotes in @racket[xexpr] to curly. By default, American English curly quotes are used. The optional keyword arguments can be used to set different quotes suited to other languages or script systems.
@examples[#:eval my-eval @examples[#:eval my-eval
(define tricky-string (define tricky-string
"\"Why,\" she could've asked, \"are we in Oahu watching 'Mame'?\"") "\"Why,\" she could've asked, \"are we in Oahu watching 'Mame'?\"")
(display tricky-string) (display tricky-string)
(display (smart-quotes tricky-string)) (display (smart-quotes tricky-string))
(display (smart-quotes tricky-string
#:double-open "«" #:double-close "»"
#:single-open "" #:single-close ""))
(display (smart-quotes tricky-string
#:double-open "„" #:double-close "”"
#:single-open "" #:single-close ""))
] ]
}
@defproc[ @defproc[
(smart-dashes (smart-dashes

@ -20,22 +20,38 @@
(module-test-external (module-test-external
(check-equal? (smart-dashes "I had --- maybe 13 -- 20 --- hob-nobs.") "I had—maybe 1320—hob-nobs.") (check-equal? (smart-dashes "I had --- maybe 13 -- 20 --- hob-nobs.") "I had—maybe 1320—hob-nobs.")
(check-equal? (smart-quotes "\"Why,\" she could've asked, \"are we in Oahu watching 'Mame'?\"") (define tricky-string "\"Why,\" she could've asked, \"are we in Oahu watching 'Mame'?\"")
(check-equal? (smart-quotes tricky-string)
"“Why,” she couldve asked, “are we in Oahu watching Mame?”") "“Why,” she couldve asked, “are we in Oahu watching Mame?”")
(check-equal? (smart-quotes tricky-string
#:apostrophe "zing"
#:double-open "«" #:double-close "»"
#:single-open "" #:single-close "")
"«Why,» she couldzingve asked, «are we in Oahu watching Mame")
(check-equal? (smart-quotes "\"\'Impossible.\' Yes.\"") "Impossible. Yes.”") (check-equal? (smart-quotes "\"\'Impossible.\' Yes.\"") "Impossible. Yes.”")
(check-equal? (smart-quotes '(div "don'" (em "t"))) '(div "don" (em "t"))) (check-equal? (smart-quotes '(div "don'" (em "t"))) '(div "don" (em "t")))
(check-equal? (smart-quotes '(div "do '" (em "not'"))) '(div "do " (em "not")))) (check-equal? (smart-quotes '(div "do '" (em "not'"))) '(div "do " (em "not"))))
(define+provide/contract (smart-quotes x) (define+provide/contract (smart-quotes x
((or/c string? txexpr?) . -> . (or/c string? txexpr?)) #:apostrophe [apostrophe-str ""]
#:single-open [single-open-str ""]
#:single-close [single-close-str ""]
#:double-open [double-open-str ""]
#:double-close [double-close-str ""])
(((or/c string? txexpr?))
(#:apostrophe string?
#:single-open string?
#:single-close string?
#:double-open string?
#:double-close string?) . ->* . (or/c string? txexpr?))
(define quotes (define quotes
'((#px"(?<=\\w)'(?=\\w)" "") ; apostrophe `((#px"(?<=\\w)'(?=\\w)" ,apostrophe-str) ; apostrophe
(#px"(?<!\\w)'(?=\\S)" "") ; single_at_beginning (#px"(?<!\\w)'(?=\\S)" ,single-open-str) ; single_at_beginning
(#px"(?<=\\S)'(?!\\w)" "") ; single_at_end (#px"(?<=\\S)'(?!\\w)" ,single-close-str) ; single_at_end
(#px"(?<!\\w)\"(?=\\S)" "") ; double_at_beginning (#px"(?<!\\w)\"(?=\\S)" ,double-open-str) ; double_at_beginning
(#px"(?<=\\S)\"(?!\\w)" ""))) ; double_at_end (#px"(?<=\\S)\"(?!\\w)" ,double-close-str))) ; double_at_end
(cond (cond
[(string? x) ((make-replacer quotes) x)] [(string? x) ((make-replacer quotes) x)]

Loading…
Cancel
Save