fixup rackets
This commit is contained in:
parent
2ba395aad1
commit
64ebb92ead
40
iputil.rkt
40
iputil.rkt
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
(require racket/struct)
|
(require racket/struct)
|
||||||
|
|
||||||
(provide peer subnet
|
(provide (struct-out peer) (struct-out subnet)
|
||||||
string->ip
|
string->ip
|
||||||
ip->string
|
ip->string
|
||||||
string->subnet
|
string->subnet
|
||||||
|
@ -24,31 +24,29 @@
|
||||||
(lambda (x) (list (subnet->string x)))))])
|
(lambda (x) (list (subnet->string x)))))])
|
||||||
|
|
||||||
(define (string->ip str)
|
(define (string->ip str)
|
||||||
(let ([parts (reverse (string-split str "."))])
|
(define parts (reverse (string-split str ".")))
|
||||||
(for/sum ([i (in-range 4)]
|
(for/sum ([part (in-list parts)]
|
||||||
[part parts])
|
[i (in-naturals)])
|
||||||
(arithmetic-shift (string->number part) (* i 8)))))
|
(arithmetic-shift (string->number part)
|
||||||
|
(* i 8))))
|
||||||
|
|
||||||
(define (ip->string ip)
|
(define (ip->string ip)
|
||||||
(string-join
|
(define parts
|
||||||
(reverse
|
(reverse (for/list ([i (in-range 4)])
|
||||||
(for/list ([i (in-range 4)])
|
(number->string (bitwise-and (arithmetic-shift ip (* i -8))
|
||||||
(number->string (bitwise-and
|
255)))))
|
||||||
(arithmetic-shift ip (* i -8)) 255))))
|
(string-join parts "."))
|
||||||
"."))
|
|
||||||
|
|
||||||
(define (string->subnet str)
|
(define (string->subnet str)
|
||||||
(match (string-split str "/")
|
(match-define (list ipstr maskstr) (string-split str "/"))
|
||||||
[(list ipstr maskstr) (subnet (string->ip ipstr)
|
(subnet (string->ip ipstr)
|
||||||
(string->number maskstr))]))
|
(string->number maskstr)))
|
||||||
|
|
||||||
(define (subnet->string sub)
|
(define (subnet->string sub)
|
||||||
(string-append
|
(format "~a/~a"
|
||||||
(ip->string (subnet-ip sub))
|
(subnet-ip sub)
|
||||||
"/"
|
(subnet-mask sub)))
|
||||||
(number->string (subnet-mask sub))))
|
|
||||||
|
|
||||||
(define (string->peer str)
|
(define (string->peer str)
|
||||||
(match (string-split str "-")
|
(match-define (list ip type) (string-split str "-"))
|
||||||
[(list ip type)
|
(peer (string->ip ip) (string->symbol type)))
|
||||||
(peer (string->ip ip) (string->symbol type))]))
|
|
||||||
|
|
Loading…
Reference in New Issue