-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathredracket.rkt
49 lines (37 loc) · 1.48 KB
/
redracket.rkt
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
#lang racket
;; Redracket
(require "red.rkt"
"front.rkt"
racket/unsafe/ops
(for-syntax "red2.rkt"
"front.rkt"
racket
racket/unsafe/ops)
(for-meta 2 "red2.rkt"
"front.rkt"
racket
racket/unsafe/ops))
(provide dfa-match?)
;; For testing purposes -- numbers seem odd right now
(define (inspect string)
(let-values ([(start*? end*? dfa-in) (->redstring string)])
(let ([dfa-in (if start*? (add-anything dfa-in) dfa-in)])
(printf "~s~n" dfa-in)
(syntax->datum (dfa-expand (build-test-dfa dfa-in) end*?)))))
;; The macro for user level
(define-syntax (dfa-match? stx)
(syntax-case stx ()
[(_ regexp string)
(with-syntax
([dfa-matcher
(let-values ([(start*? end*? dfa-in) (->redstring (syntax->datum #'regexp))])
(let ([dfa-in (if start*? (add-anything dfa-in) dfa-in)])
(dfa-expand (build-test-dfa dfa-in) end*?)))])
#'(dfa-matcher string))]))
;;Example tests
(equal? (dfa-match? "a+" "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa") #t)
(equal? (dfa-match? "c(a|d)*r" "caadadadaddaadadadadadadddddaaaaar") #t)
(equal? (dfa-match? "schwers\\.r@gmail\\.com" "aosihdfasdfschwers.r@gmail.comaskdfas") #t)
(equal? (dfa-match? "schwers\\.r@gmail\\.com" "schwers.r@gmail.com") #t)
(equal? (dfa-match? "(node\\.js|ruby)" "node.jsasdf") #t)
(equal? (dfa-match? "(red|racket)(red|racket)" "redracket") #t)