From e796837385175997fd30d907d0cd7fac06617dcd Mon Sep 17 00:00:00 2001 From: "Kim F. Storm" Date: Fri, 21 Apr 2006 20:56:06 +0000 Subject: [PATCH] (image-type): New defun split out of create-image. (create-image): Use it. --- lisp/image.el | 44 ++++++++++++++++++++++++++++---------------- 1 file changed, 28 insertions(+), 16 deletions(-) diff --git a/lisp/image.el b/lisp/image.el index 2212b0fb471..b388396ded7 100644 --- a/lisp/image.el +++ b/lisp/image.el @@ -280,27 +280,14 @@ be determined." ;;;###autoload -(defun image-type-available-p (type) - "Return non-nil if image type TYPE is available. -Image types are symbols like `xbm' or `jpeg'." - (and (fboundp 'init-image-library) - (init-image-library type image-library-alist))) - - -;;;###autoload -(defun create-image (file-or-data &optional type data-p &rest props) - "Create an image. +(defun image-type (file-or-data &optional type data-p) + "Determine and return image type. FILE-OR-DATA is an image file name or image data. Optional TYPE is a symbol describing the image type. If TYPE is omitted or nil, try to determine the image type from its first few bytes of image data. If that doesn't work, and FILE-OR-DATA is a file name, use its file extension as image type. -Optional DATA-P non-nil means FILE-OR-DATA is a string containing image data. -Optional PROPS are additional image attributes to assign to the image, -like, e.g. `:mask MASK'. -Value is the image created, or nil if images of type TYPE are not supported. - -Images should not be larger than specified by `max-image-size'." +Optional DATA-P non-nil means FILE-OR-DATA is a string containing image data." (when (and (not data-p) (not (stringp file-or-data))) (error "Invalid image file name `%s'" file-or-data)) (cond ((null data-p) @@ -319,6 +306,31 @@ Images should not be larger than specified by `max-image-size'." (error "Cannot determine image type")) (unless (symbolp type) (error "Invalid image type `%s'" type)) + type) + +;;;###autoload +(defun image-type-available-p (type) + "Return non-nil if image type TYPE is available. +Image types are symbols like `xbm' or `jpeg'." + (and (fboundp 'init-image-library) + (init-image-library type image-library-alist))) + + +;;;###autoload +(defun create-image (file-or-data &optional type data-p &rest props) + "Create an image. +FILE-OR-DATA is an image file name or image data. +Optional TYPE is a symbol describing the image type. If TYPE is omitted +or nil, try to determine the image type from its first few bytes +of image data. If that doesn't work, and FILE-OR-DATA is a file name, +use its file extension as image type. +Optional DATA-P non-nil means FILE-OR-DATA is a string containing image data. +Optional PROPS are additional image attributes to assign to the image, +like, e.g. `:mask MASK'. +Value is the image created, or nil if images of type TYPE are not supported. + +Images should not be larger than specified by `max-image-size'." + (setq type (image-type file-or-data type data-p)) (when (image-type-available-p type) (append (list 'image :type type (if data-p :data :file) file-or-data) props))) -- 2.39.2