static void dt_ctl_get_display_profile_colord_callback(GObject *source, GAsyncResult *res, gpointer user_data) { pthread_rwlock_wrlock(&darktable.control->xprofile_lock); int profile_changed = 0; CdWindow *window = CD_WINDOW(source); GError *error = NULL; CdProfile *profile = cd_window_get_profile_finish(window, res, &error); if(error == NULL && profile != NULL) { const gchar *filename = cd_profile_get_filename(profile); if(filename) { if(g_strcmp0(filename, darktable.control->colord_profile_file)) { /* the profile has changed (either because the user changed the colord settings or because we are on a different screen now) */ // update darktable.control->colord_profile_file g_free(darktable.control->colord_profile_file); darktable.control->colord_profile_file = g_strdup(filename); // read the file guchar *tmp_data = NULL; gsize size; g_file_get_contents(filename, (gchar**)&tmp_data, &size, NULL); profile_changed = size > 0 && (darktable.control->xprofile_size != size || memcmp(darktable.control->xprofile_data, tmp_data, size) != 0); if(profile_changed) { g_free(darktable.control->xprofile_data); darktable.control->xprofile_data = tmp_data; darktable.control->xprofile_size = size; dt_print(DT_DEBUG_CONTROL, "[color profile] colord gave us a new screen profile: '%s' (size: %ld)\n", filename, size); } } } } if(profile) g_object_unref(profile); g_object_unref(window); pthread_rwlock_unlock(&darktable.control->xprofile_lock); if(profile_changed) dt_control_signal_raise(darktable.signals, DT_SIGNAL_CONTROL_PROFILE_CHANGED); }
static void gcm_prefs_space_combo_changed_cb (GtkWidget *widget, GcmPickerPrivate *priv) { GtkTreeIter iter; GtkTreeModel *model; g_autoptr(CdProfile) profile = NULL; /* no selection */ if (!gtk_combo_box_get_active_iter (GTK_COMBO_BOX(widget), &iter)) return; /* get profile */ model = gtk_combo_box_get_model (GTK_COMBO_BOX(widget)); gtk_tree_model_get (model, &iter, GCM_PREFS_COMBO_COLUMN_PROFILE, &profile, -1); if (profile == NULL) return; priv->profile_filename = cd_profile_get_filename (profile); g_debug ("changed picker space %s", priv->profile_filename); gcm_picker_refresh_results (priv); }
/** * cd_util_get_standard_space_filename: **/ static gchar * cd_util_get_standard_space_filename (CdUtilPrivate *priv, CdStandardSpace standard_space, GError **error) { gchar *filename = NULL; g_autoptr(CdProfile) profile_tmp = NULL; /* try to find */ if (!cd_client_connect_sync (priv->client, NULL, error)) return NULL; profile_tmp = cd_client_get_standard_space_sync (priv->client, standard_space, NULL, error); if (profile_tmp == NULL) return NULL; /* get filename */ if (!cd_profile_connect_sync (profile_tmp, NULL, error)) return NULL; filename = g_strdup (cd_profile_get_filename (profile_tmp)); return filename; }
/** * cd_edid_get_profile: * @edid: the EDID data, typically just 128 bytes in size * @edid_len: the size in bytes of @edid_len * @profile_fn: the returned profile filename, use free() when done * * Get an associated monitor profile. * * Return value: a %CdEdidError, e.g. %CD_EDID_ERROR_OK * * Since: 0.1.34 **/ CdEdidError cd_edid_get_profile (unsigned char *edid, int edid_len, char **profile_fn) { CdClient *client = NULL; CdDevice *device = NULL; CdProfile *profile = NULL; const gchar *filename; gboolean ret; gchar *md5 = NULL; GError *error = NULL; CdEdidError rc = CD_EDID_ERROR_OK; /* bad input */ if (edid == NULL || edid_len == 0) { rc = CD_EDID_ERROR_NO_DATA; goto out; } /* conect to daemon */ client = cd_client_new (); ret = cd_client_connect_sync (client, NULL, &error); if (!ret) { rc = CD_EDID_ERROR_ACCESS_CONFIG; g_warning ("Failed to connect to colord: %s", error->message); g_error_free (error); goto out; } /* find device that matches the output EDID */ md5 = g_compute_checksum_for_string (G_CHECKSUM_MD5, (const gchar *)edid, (gssize) edid_len); device = cd_client_find_device_by_property_sync (client, CD_DEVICE_METADATA_OUTPUT_EDID_MD5, md5, NULL, &error); if (device == NULL) { rc = CD_EDID_ERROR_MONITOR_NOT_FOUND; g_warning ("Failed to find device that matches %s: %s", md5, error->message); g_error_free (error); goto out; } /* read device properties */ ret = cd_device_connect_sync (device, NULL, &error); if (!ret) { rc = CD_EDID_ERROR_ACCESS_CONFIG; g_warning ("device disappeared: %s", error->message); g_error_free (error); goto out; } /* get the default profile for the device */ profile = cd_device_get_default_profile (device); if (profile == NULL) { rc = CD_EDID_ERROR_NO_PROFILE; g_warning ("No profile for %s: %s", cd_device_get_id (device), error->message); g_error_free (error); goto out; } /* read profile properties */ ret = cd_profile_connect_sync (profile, NULL, &error); if (!ret) { rc = CD_EDID_ERROR_ACCESS_CONFIG; g_warning ("profile disappeared: %s", error->message); g_error_free (error); goto out; } /* get filename */ filename = cd_profile_get_filename (profile); if (filename == NULL) { rc = CD_EDID_ERROR_INVALID_PROFILE; goto out; } /* return filename of profile */ if (profile_fn != NULL) *profile_fn = strdup (filename); out: if (client != NULL) g_object_unref (client); if (device != NULL) g_object_unref (device); if (profile != NULL) g_object_unref (profile); g_free (md5); return rc; }
static void gcm_prefs_setup_space_combobox (GcmPickerPrivate *priv, GtkWidget *widget) { CdColorspace colorspace; CdDevice *device_tmp; CdProfile *profile; const gchar *filename; const gchar *tmp; gboolean has_profile = FALSE; gboolean has_vcgt; gboolean ret; GtkTreeIter iter; GtkTreeModel *model; guint i; g_autofree gchar *text = NULL; g_autoptr(GError) error = NULL; g_autoptr(GPtrArray) devices = NULL; g_autoptr(GPtrArray) profile_array = NULL; /* get new list */ profile_array = cd_client_get_profiles_sync (priv->client, NULL, &error); if (profile_array == NULL) { g_warning ("failed to get profiles: %s", error->message); return; } /* update each list */ for (i = 0; i < profile_array->len; i++) { profile = g_ptr_array_index (profile_array, i); /* connect to the profile */ ret = cd_profile_connect_sync (profile, NULL, &error); if (!ret) { g_warning ("failed to connect to profile: %s", error->message); return; } /* ignore profiles from other user accounts */ if (!cd_profile_has_access (profile)) continue; /* is a printer profile */ filename = cd_profile_get_filename (profile); if (filename == NULL) continue; /* only for correct kind */ has_vcgt = cd_profile_get_has_vcgt (profile); tmp = cd_profile_get_metadata_item (profile, CD_PROFILE_METADATA_STANDARD_SPACE); colorspace = cd_profile_get_colorspace (profile); if (!has_vcgt && tmp != NULL && colorspace == CD_COLORSPACE_RGB) { gcm_prefs_combobox_add_profile (widget, profile, &iter); /* set active option */ if (g_strcmp0 (tmp, "adobe-rgb") == 0) { priv->profile_filename = filename; gtk_combo_box_set_active_iter (GTK_COMBO_BOX (widget), &iter); } has_profile = TRUE; } } /* add device profiles */ devices = cd_client_get_devices_by_kind_sync (priv->client, CD_DEVICE_KIND_DISPLAY, NULL, &error); for (i = 0; i < devices->len; i++) { device_tmp = g_ptr_array_index (devices, i); /* connect to the device */ ret = cd_device_connect_sync (device_tmp, NULL, &error); if (!ret) { g_warning ("failed to connect to device: %s", error->message); return; } profile = cd_device_get_default_profile (device_tmp); if (profile == NULL) continue; /* connect to the profile */ ret = cd_profile_connect_sync (profile, NULL, &error); if (!ret) { g_warning ("failed to connect to profile: %s", error->message); return; } /* add device profile */ gcm_prefs_combobox_add_profile (widget, profile, NULL); g_object_unref (profile); has_profile = TRUE; } if (!has_profile) { /* TRANSLATORS: this is when there are no profiles that can be used; * the search term is either "RGB" or "CMYK" */ text = g_strdup_printf (_("No %s color spaces available"), cd_colorspace_to_localised_string (CD_COLORSPACE_RGB)); model = gtk_combo_box_get_model (GTK_COMBO_BOX (widget)); gtk_list_store_append (GTK_LIST_STORE(model), &iter); gtk_list_store_set (GTK_LIST_STORE(model), &iter, GCM_PREFS_COMBO_COLUMN_TEXT, text, -1); gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 0); gtk_widget_set_sensitive (widget, FALSE); } }