color: simplify color manager API with weston_output_color_outcome
I am going to need to add yet another output property to be set by a color manager: HDR Static Metadata Type 1. With the old color manager API design, I would have needed to add the fourth function pointer to be called always in the same group as the previous three. This seemed more convoluted than it needs to be. Therefore collapse the three existing function pointers in the API into just one that is resposible for setting up all three things. Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.com>
This commit is contained in:
committed by
Pekka Paalanen
parent
6c0524fd80
commit
dfba19abde
@@ -126,11 +126,10 @@ cmlcms_get_surface_color_transform(struct weston_color_manager *cm_base,
|
||||
}
|
||||
|
||||
static bool
|
||||
cmlcms_get_output_color_transform(struct weston_color_manager *cm_base,
|
||||
struct weston_output *output,
|
||||
struct weston_color_transform **xform_out)
|
||||
cmlcms_get_blend_to_output_color_transform(struct weston_color_manager_lcms *cm,
|
||||
struct weston_output *output,
|
||||
struct weston_color_transform **xform_out)
|
||||
{
|
||||
struct weston_color_manager_lcms *cm = get_cmlcms(cm_base);
|
||||
struct cmlcms_color_transform_search_param param = {};
|
||||
struct cmlcms_color_transform *xform;
|
||||
|
||||
@@ -148,11 +147,10 @@ cmlcms_get_output_color_transform(struct weston_color_manager *cm_base,
|
||||
}
|
||||
|
||||
static bool
|
||||
cmlcms_get_sRGB_to_output_color_transform(struct weston_color_manager *cm_base,
|
||||
cmlcms_get_sRGB_to_output_color_transform(struct weston_color_manager_lcms *cm,
|
||||
struct weston_output *output,
|
||||
struct weston_color_transform **xform_out)
|
||||
{
|
||||
struct weston_color_manager_lcms *cm = get_cmlcms(cm_base);
|
||||
struct cmlcms_color_transform_search_param param = {};
|
||||
struct cmlcms_color_transform *xform;
|
||||
|
||||
@@ -177,11 +175,10 @@ cmlcms_get_sRGB_to_output_color_transform(struct weston_color_manager *cm_base,
|
||||
}
|
||||
|
||||
static bool
|
||||
cmlcms_get_sRGB_to_blend_color_transform(struct weston_color_manager *cm_base,
|
||||
cmlcms_get_sRGB_to_blend_color_transform(struct weston_color_manager_lcms *cm,
|
||||
struct weston_output *output,
|
||||
struct weston_color_transform **xform_out)
|
||||
{
|
||||
struct weston_color_manager_lcms *cm = get_cmlcms(cm_base);
|
||||
struct cmlcms_color_transform_search_param param = {};
|
||||
struct cmlcms_color_transform *xform;
|
||||
|
||||
@@ -198,6 +195,36 @@ cmlcms_get_sRGB_to_blend_color_transform(struct weston_color_manager *cm_base,
|
||||
return true;
|
||||
}
|
||||
|
||||
static struct weston_output_color_outcome *
|
||||
cmlcms_create_output_color_outcome(struct weston_color_manager *cm_base,
|
||||
struct weston_output *output)
|
||||
{
|
||||
struct weston_color_manager_lcms *cm = get_cmlcms(cm_base);
|
||||
struct weston_output_color_outcome *co;
|
||||
|
||||
co = zalloc(sizeof *co);
|
||||
if (!co)
|
||||
return NULL;
|
||||
|
||||
if (!cmlcms_get_blend_to_output_color_transform(cm, output,
|
||||
&co->from_blend_to_output))
|
||||
goto out_fail;
|
||||
|
||||
if (!cmlcms_get_sRGB_to_blend_color_transform(cm, output,
|
||||
&co->from_sRGB_to_blend))
|
||||
goto out_fail;
|
||||
|
||||
if (!cmlcms_get_sRGB_to_output_color_transform(cm, output,
|
||||
&co->from_sRGB_to_output))
|
||||
goto out_fail;
|
||||
|
||||
return co;
|
||||
|
||||
out_fail:
|
||||
weston_output_color_outcome_destroy(&co);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
lcms_error_logger(cmsContext context_id,
|
||||
cmsUInt32Number error_code,
|
||||
@@ -264,13 +291,8 @@ weston_color_manager_create(struct weston_compositor *compositor)
|
||||
cm->base.destroy_color_profile = cmlcms_destroy_color_profile;
|
||||
cm->base.get_color_profile_from_icc = cmlcms_get_color_profile_from_icc;
|
||||
cm->base.destroy_color_transform = cmlcms_destroy_color_transform;
|
||||
cm->base.get_surface_color_transform =
|
||||
cmlcms_get_surface_color_transform;
|
||||
cm->base.get_output_color_transform = cmlcms_get_output_color_transform;
|
||||
cm->base.get_sRGB_to_output_color_transform =
|
||||
cmlcms_get_sRGB_to_output_color_transform;
|
||||
cm->base.get_sRGB_to_blend_color_transform =
|
||||
cmlcms_get_sRGB_to_blend_color_transform;
|
||||
cm->base.get_surface_color_transform = cmlcms_get_surface_color_transform;
|
||||
cm->base.create_output_color_outcome = cmlcms_create_output_color_outcome;
|
||||
|
||||
wl_list_init(&cm->color_transform_list);
|
||||
wl_list_init(&cm->color_profile_list);
|
||||
|
||||
Reference in New Issue
Block a user