Skip to content

Commit b3e1298

Browse files
committed
Use boolean instead of traits
1 parent 4524d8e commit b3e1298

File tree

1 file changed

+20
-31
lines changed

1 file changed

+20
-31
lines changed

base/multimedia.jl

+20-31
Original file line numberDiff line numberDiff line change
@@ -33,21 +33,8 @@ mimewritable{mime}(::MIME{mime}, x) =
3333
show(io::IO, m::AbstractString, x) = show(io, MIME(m), x)
3434
mimewritable(m::AbstractString, x) = mimewritable(MIME(m), x)
3535

36-
abstract MIMETypeType
37-
38-
immutable IsText <: MIMETypeType end
39-
immutable IsBytes <: MIMETypeType end
40-
4136
verbose_show(io, m, x) = show(IOContext(io,limit=false), m, x)
4237

43-
"""
44-
MIME types are assumed to be binary data except for a set of types known to be
45-
text data (possibly Unicode). `mimetypetype(m)` returns `Multimedia.IsText` or
46-
`Multimedia.IsBytes` for text or binary data respectively.
47-
"""
48-
Base.@pure mimetypetype{M}(::MIME{M}) =
49-
startswith(string(M), "text/") ? IsText() : IsBytes()
50-
5138
"""
5239
reprmime(mime, x)
5340
@@ -65,20 +52,20 @@ As a special case, if `x` is an `AbstractString` (for textual MIME types) or a
6552
special case does not apply to the `"text/plain"` MIME type. This is useful so
6653
that raw data can be passed to `display(m::MIME, x)`.
6754
"""
68-
reprmime(m::MIME, x) = reprmime(mimetypetype(m), m, x)
69-
reprmime(::IsText, m::MIME, x) = sprint(verbose_show, m, x)
55+
reprmime(m::MIME, x) = istextmime(m) ? _textreprmime(m, x) : _binreprmime(m, x)
7056

7157
# strings are shown escaped for text/plain
72-
reprmime(::IsText, ::MIME, x::AbstractString) = x
73-
reprmime(::IsText, m::MIME"text/plain", x::AbstractString) =
58+
_textreprmime(m::MIME, x) = sprint(verbose_show, m, x)
59+
_textreprmime(::MIME, x::AbstractString) = x
60+
_textreprmime(m::MIME"text/plain", x::AbstractString) =
7461
sprint(verbose_show, m, x)
7562

76-
function reprmime(::IsBytes, m::MIME, x)
63+
function _binreprmime(m::MIME, x)
7764
s = IOBuffer()
7865
verbose_show(s, m, x)
7966
takebuf_array(s)
8067
end
81-
reprmime(::IsBytes, m::MIME, x::Vector{UInt8}) = x
68+
_binreprmime(m::MIME, x::Vector{UInt8}) = x
8269

8370
"""
8471
stringmime(mime, x)
@@ -87,30 +74,32 @@ Returns an `AbstractString` containing the representation of `x` in the
8774
requested `mime` type. This is similar to [`reprmime`](:func:`reprmime`) except
8875
that binary data is base64-encoded as an ASCII string.
8976
"""
90-
stringmime(m::MIME, x) = stringmime(mimetypetype(m), m, x)
91-
stringmime(::IsText, m::MIME, x) = reprmime(m, x)
92-
stringmime(::IsBytes, m::MIME, x) = base64encode(verbose_show, m, x)
93-
stringmime(::IsBytes, m::MIME, x::Vector{UInt8}) = base64encode(write, x)
77+
stringmime(m::MIME, x) = istextmime(m) ? reprmime(m, x) : _binstringmime(m, x)
78+
79+
_binstringmime(m::MIME, x) = base64encode(verbose_show, m, x)
80+
_binstringmime(m::MIME, x::Vector{UInt8}) = base64encode(write, x)
9481

9582
"""
9683
istextmime(m::MIME)
9784
98-
Determine whether a MIME type is text data.
85+
Determine whether a MIME type is text data. MIME types are assumed to be binary
86+
data except for a set of types known to be text data (possibly Unicode).
9987
"""
100-
istextmime(m::MIME) = isa(mimetypetype(m), IsText)
88+
istextmime(m::MIME) = startswith(string(m), "text/")
10189

10290
# it is convenient to accept strings instead of ::MIME
10391
istextmime(m::AbstractString) = istextmime(MIME(m))
10492
reprmime(m::AbstractString, x) = reprmime(MIME(m), x)
10593
stringmime(m::AbstractString, x) = stringmime(MIME(m), x)
10694

10795
for mime in ["application/atom+xml", "application/ecmascript",
108-
"application/javascript", "application/julia", "application/json",
109-
"application/postscript", "application/rdf+xml", "application/rss+xml",
110-
"application/x-latex", "application/xhtml+xml", "application/xml",
111-
"application/xml-dtd", "image/svg+xml", "model/vrml", "model/x3d+vrml",
112-
"model/x3d+xml"]
113-
mimetypetype(::MIME{Symbol(mime)}) = IsText()
96+
"application/javascript", "application/julia",
97+
"application/json", "application/postscript",
98+
"application/rdf+xml", "application/rss+xml",
99+
"application/x-latex", "application/xhtml+xml", "application/xml",
100+
"application/xml-dtd", "image/svg+xml", "model/vrml",
101+
"model/x3d+vrml", "model/x3d+xml"]
102+
istextmime(::MIME{Symbol(mime)}) = true
114103
end
115104

116105
###########################################################################

0 commit comments

Comments
 (0)