app: validate 'icc-profile' parasites before attaching them
The must be persistent and undoable and contain an RGB ICC profile.
This commit is contained in:
@ -35,7 +35,7 @@
|
|||||||
|
|
||||||
#include "config/gimpcoreconfig.h"
|
#include "config/gimpcoreconfig.h"
|
||||||
|
|
||||||
#include "core/gimp.h"
|
#include "gimp.h"
|
||||||
#include "gimperror.h"
|
#include "gimperror.h"
|
||||||
#include "gimpimage.h"
|
#include "gimpimage.h"
|
||||||
#include "gimpimage-profile.h"
|
#include "gimpimage-profile.h"
|
||||||
@ -45,6 +45,67 @@
|
|||||||
|
|
||||||
/* public functions */
|
/* public functions */
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
gimp_image_validate_icc_profile (GimpImage *image,
|
||||||
|
const GimpParasite *icc_profile,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
GimpColorProfile *profile;
|
||||||
|
|
||||||
|
g_return_val_if_fail (GIMP_IS_IMAGE (image), FALSE);
|
||||||
|
g_return_val_if_fail (icc_profile != NULL, FALSE);
|
||||||
|
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
|
||||||
|
|
||||||
|
if (strcmp (gimp_parasite_name (icc_profile),
|
||||||
|
GIMP_ICC_PROFILE_PARASITE_NAME) != 0)
|
||||||
|
{
|
||||||
|
g_set_error_literal (error, GIMP_ERROR, GIMP_FAILED,
|
||||||
|
_("ICC profile validation failed: "
|
||||||
|
"Parasite's name is not 'icc-profile'"));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gimp_parasite_flags (icc_profile) != (GIMP_PARASITE_PERSISTENT |
|
||||||
|
GIMP_PARASITE_UNDOABLE))
|
||||||
|
{
|
||||||
|
g_set_error_literal (error, GIMP_ERROR, GIMP_FAILED,
|
||||||
|
_("ICC profile validation failed: "
|
||||||
|
"Parasite's flags are not (PERSISTENT | UNDOABLE)"));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gimp_image_get_base_type (image) == GIMP_GRAY)
|
||||||
|
{
|
||||||
|
g_set_error_literal (error, GIMP_ERROR, GIMP_FAILED,
|
||||||
|
_("ICC profile validation failed: "
|
||||||
|
"Cannot attach a color profile to a GRAY image"));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
profile = gimp_lcms_profile_open_from_data (gimp_parasite_data (icc_profile),
|
||||||
|
gimp_parasite_data_size (icc_profile),
|
||||||
|
NULL, error);
|
||||||
|
|
||||||
|
if (! profile)
|
||||||
|
{
|
||||||
|
g_prefix_error (error, _("ICC profile validation failed: "));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! gimp_lcms_profile_is_rgb (profile))
|
||||||
|
{
|
||||||
|
g_set_error_literal (error, GIMP_ERROR, GIMP_FAILED,
|
||||||
|
_("ICC profile validation failed: "
|
||||||
|
"Color profile is not for RGB color space"));
|
||||||
|
cmsCloseProfile (profile);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
cmsCloseProfile (profile);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
const GimpParasite *
|
const GimpParasite *
|
||||||
gimp_image_get_icc_profile (GimpImage *image)
|
gimp_image_get_icc_profile (GimpImage *image)
|
||||||
{
|
{
|
||||||
@ -61,11 +122,8 @@ gimp_image_set_icc_profile (GimpImage *image,
|
|||||||
|
|
||||||
if (icc_profile)
|
if (icc_profile)
|
||||||
{
|
{
|
||||||
g_return_if_fail (strcmp (gimp_parasite_name (icc_profile),
|
g_return_if_fail (gimp_image_validate_icc_profile (image, icc_profile,
|
||||||
GIMP_ICC_PROFILE_PARASITE_NAME) == 0);
|
NULL) == TRUE);
|
||||||
g_return_if_fail (gimp_parasite_flags (icc_profile) ==
|
|
||||||
(GIMP_PARASITE_PERSISTENT |
|
|
||||||
GIMP_PARASITE_UNDOABLE));
|
|
||||||
|
|
||||||
gimp_image_parasite_attach (image, icc_profile);
|
gimp_image_parasite_attach (image, icc_profile);
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,9 @@
|
|||||||
#define GIMP_ICC_PROFILE_PARASITE_NAME "icc-profile"
|
#define GIMP_ICC_PROFILE_PARASITE_NAME "icc-profile"
|
||||||
|
|
||||||
|
|
||||||
|
gboolean gimp_image_validate_icc_profile (GimpImage *image,
|
||||||
|
const GimpParasite *icc_profile,
|
||||||
|
GError **error);
|
||||||
const GimpParasite * gimp_image_get_icc_profile (GimpImage *image);
|
const GimpParasite * gimp_image_get_icc_profile (GimpImage *image);
|
||||||
void gimp_image_set_icc_profile (GimpImage *image,
|
void gimp_image_set_icc_profile (GimpImage *image,
|
||||||
const GimpParasite *icc_profile);
|
const GimpParasite *icc_profile);
|
||||||
|
@ -3055,10 +3055,19 @@ gimp_image_parasite_validate (GimpImage *image,
|
|||||||
const GimpParasite *parasite,
|
const GimpParasite *parasite,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
|
const gchar *name;
|
||||||
|
|
||||||
g_return_val_if_fail (GIMP_IS_IMAGE (image), FALSE);
|
g_return_val_if_fail (GIMP_IS_IMAGE (image), FALSE);
|
||||||
g_return_val_if_fail (parasite != NULL, FALSE);
|
g_return_val_if_fail (parasite != NULL, FALSE);
|
||||||
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
|
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
|
||||||
|
|
||||||
|
name = gimp_parasite_name (parasite);
|
||||||
|
|
||||||
|
if (strcmp (name, GIMP_ICC_PROFILE_PARASITE_NAME) == 0)
|
||||||
|
{
|
||||||
|
return gimp_image_validate_icc_profile (image, parasite, error);
|
||||||
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user