You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
28 lines
895 B
Racket
28 lines
895 B
Racket
#lang pitfall/racket
|
|
(require "jpeg.rkt" "png.rkt")
|
|
(provide PDFImage-open)
|
|
|
|
#;(define PDFImage
|
|
(class object%
|
|
(super-new)
|
|
|
|
(as-methods
|
|
)))
|
|
|
|
(define/contract (PDFImage-open src label)
|
|
(any/c any/c . -> . (or/c (is-a?/c PNG) (is-a?/c JPEG)))
|
|
(define data (cond
|
|
[(isBuffer? src) src]
|
|
;;else if src instanceof ArrayBuffer
|
|
;;data = new Buffer(new Uint8Array(src))
|
|
[(regexp-match #rx"^data:.+;base64,(.*)$" src)
|
|
(void)] ;; base64 ; todo
|
|
[else (file->bytes src)]))
|
|
(cond
|
|
[(equal? (subbytes data 0 2) (bytes #xff #xd8))
|
|
(make-object JPEG data label)]
|
|
[(equal? (subbytes data 0 4) (apply bytes (cons #x89 (map char->integer '(#\P #\N #\G)))))
|
|
(make-object PNG data label)]
|
|
[else (raise-argument-error 'PDFImage-open "valid image format" src)]))
|
|
|