aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNigel Tao <nigeltao@golang.org>2011-04-14 09:56:42 +1000
committerNigel Tao <nigeltao@golang.org>2011-04-14 09:56:42 +1000
commit4c60569e7cba9ff17805fc9a2763db596c871924 (patch)
treef74e80716198c2b5539e870446765dad3368a0d6
parenta2e286828be99c658b30ecb3daccd1b3dbcedb0e (diff)
downloadgo-4c60569e7cba9ff17805fc9a2763db596c871924.tar.gz
go-4c60569e7cba9ff17805fc9a2763db596c871924.zip
image: allow "?" wildcards when registering image formats.
R=r, nigeltao_gnome CC=golang-dev https://golang.org/cl/4404041
-rw-r--r--src/pkg/image/format.go22
1 files changed, 18 insertions, 4 deletions
diff --git a/src/pkg/image/format.go b/src/pkg/image/format.go
index 1d541b0940..b4859325e1 100644
--- a/src/pkg/image/format.go
+++ b/src/pkg/image/format.go
@@ -25,7 +25,8 @@ var formats []format
// RegisterFormat registers an image format for use by Decode.
// Name is the name of the format, like "jpeg" or "png".
-// Magic is the magic prefix that identifies the format's encoding.
+// Magic is the magic prefix that identifies the format's encoding. The magic
+// string can contain "?" wildcards that each match any one byte.
// Decode is the function that decodes the encoded image.
// DecodeConfig is the function that decodes just its configuration.
func RegisterFormat(name, magic string, decode func(io.Reader) (Image, os.Error), decodeConfig func(io.Reader) (Config, os.Error)) {
@@ -46,11 +47,24 @@ func asReader(r io.Reader) reader {
return bufio.NewReader(r)
}
-// sniff determines the format of r's data.
+// Match returns whether magic matches b. Magic may contain "?" wildcards.
+func match(magic string, b []byte) bool {
+ if len(magic) != len(b) {
+ return false
+ }
+ for i, c := range b {
+ if magic[i] != c && magic[i] != '?' {
+ return false
+ }
+ }
+ return true
+}
+
+// Sniff determines the format of r's data.
func sniff(r reader) format {
for _, f := range formats {
- s, err := r.Peek(len(f.magic))
- if err == nil && string(s) == f.magic {
+ b, err := r.Peek(len(f.magic))
+ if err == nil && match(f.magic, b) {
return f
}
}