/** * 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; }
/** * cd_edid_remove_profile: * @edid: the EDID data, typically just 128 bytes in size * @edid_len: the size in bytes of @edid_len * @profile_fn: the profile filename to remove * * Un-install a profile for a given monitor. * * Return value: a %CdEdidError, e.g. %CD_EDID_ERROR_OK * * Since: 0.1.34 **/ CdEdidError cd_edid_remove_profile (unsigned char *edid, int edid_len, char *profile_fn) { CdClient *client = NULL; CdDevice *device = NULL; CdProfile *profile = NULL; gboolean ret; gchar *md5 = NULL; GError *error = NULL; GFile *file = NULL; CdEdidError rc = CD_EDID_ERROR_OK; g_return_val_if_fail (profile_fn != NULL, CD_EDID_ERROR_RESOURCE); /* 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; } /* find profile */ file = g_file_new_for_path (profile_fn); profile = cd_client_find_profile_by_filename_sync (client, profile_fn, NULL, &error); if (profile == NULL) { rc = CD_EDID_ERROR_NO_PROFILE; g_warning ("Could not find profile %s: %s", profile_fn, 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; } /* remove profile from device */ ret = cd_device_remove_profile_sync (device, profile, NULL, &error); if (!ret) { rc = CD_EDID_ERROR_SET_CONFIG; g_warning ("could not remove profile %s from device %s: %s", cd_profile_get_id (profile), cd_device_get_id (device), error->message); g_error_free (error); goto out; } out: if (file != NULL) g_object_unref (file); 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; }
/** * main: **/ int main (int argc, char **argv) { CdClient *client = NULL; CdProfile *profile_tmp = NULL; const gchar *copyright; const gchar *description; const gchar *title; const gchar *lang; gboolean ret; gchar **files = NULL; CdIcc *icc = NULL; GError *error = NULL; GFile *destination = NULL; GFile *file = NULL; GOptionContext *context; GString *string = NULL; GtkResponseType response; GtkWidget *image = NULL; GtkWidget *dialog; guint retval = 1; const GOptionEntry options[] = { { G_OPTION_REMAINING, '\0', 0, G_OPTION_ARG_FILENAME_ARRAY, &files, /* TRANSLATORS: command line option: a list of catalogs to install */ _("ICC profile to install"), NULL }, { NULL} }; setlocale (LC_ALL, ""); bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); textdomain (GETTEXT_PACKAGE); gtk_init (&argc, &argv); context = g_option_context_new ("gnome-color-manager import program"); g_option_context_add_main_entries (context, options, NULL); g_option_context_add_group (context, gcm_debug_get_option_group ()); g_option_context_add_group (context, gtk_get_option_group (TRUE)); g_option_context_parse (context, &argc, &argv, NULL); g_option_context_free (context); /* nothing sent */ if (files == NULL) { /* TRANSLATORS: nothing was specified on the command line */ dialog = gtk_message_dialog_new (NULL, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, _("No filename specified")); gtk_window_set_icon_name (GTK_WINDOW (dialog), GCM_STOCK_ICON); gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_destroy (dialog); goto out; } /* load profile */ icc = cd_icc_new (); file = g_file_new_for_path (files[0]); ret = cd_icc_load_file (icc, file, CD_ICC_LOAD_FLAGS_FALLBACK_MD5, NULL, &error); if (!ret) { /* TRANSLATORS: could not read file */ dialog = gtk_message_dialog_new (NULL, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, _("Failed to open ICC profile")); gtk_window_set_icon_name (GTK_WINDOW (dialog), GCM_STOCK_ICON); /* TRANSLATORS: parsing error */ gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dialog), _("Failed to parse file: %s"), error->message); gtk_dialog_run (GTK_DIALOG (dialog)); g_error_free (error); gtk_widget_destroy (dialog); goto out; } /* get data */ lang = g_getenv ("LANG"); description = cd_icc_get_description (icc, lang, NULL); copyright = cd_icc_get_copyright (icc, lang, NULL); /* use the same icon as the color control panel */ image = gtk_image_new_from_icon_name ("preferences-color", GTK_ICON_SIZE_DIALOG); gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0); gtk_widget_show (image); /* create message */ string = g_string_new (""); /* TRANSLATORS: message text */ g_string_append_printf (string, _("Profile description: %s"), description != NULL ? description : files[0]); /* add copyright */ if (copyright != NULL) { if (g_str_has_prefix (copyright, "Copyright ")) copyright += 10; if (g_str_has_prefix (copyright, "Copyright, ")) copyright += 11; /* TRANSLATORS: message text */ g_string_append_printf (string, "\n%s %s", _("Profile copyright:"), copyright); } /* check file does't already exist as system-wide */ client = cd_client_new (); ret = cd_client_connect_sync (client, NULL, &error); if (!ret) { g_warning ("failed to connect to colord: %s", error->message); g_error_free (error); goto out; } profile_tmp = cd_client_find_profile_by_property_sync (client, CD_PROFILE_METADATA_FILE_CHECKSUM, cd_icc_get_checksum (icc), NULL, NULL); if (profile_tmp != NULL) { ret = cd_profile_connect_sync (profile_tmp, NULL, &error); if (!ret) { g_warning ("failed to connect to profile %s: %s", cd_profile_get_object_path (profile_tmp), error->message); g_error_free (error); goto out; } /* TRANSLATORS: color profile already been installed */ dialog = gtk_message_dialog_new (NULL, 0, GTK_MESSAGE_INFO, GTK_BUTTONS_CLOSE, _("Color profile is already imported")); gtk_window_set_icon_name (GTK_WINDOW (dialog), GCM_STOCK_ICON); gtk_message_dialog_set_image (GTK_MESSAGE_DIALOG (dialog), image); gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dialog), "%s", string->str); gtk_dialog_add_button (GTK_DIALOG (dialog), _("Show Details"), GTK_RESPONSE_HELP); response = gtk_dialog_run (GTK_DIALOG (dialog)); if (response == GTK_RESPONSE_HELP) { gcm_import_show_details (GTK_WINDOW (dialog), TRUE, cd_profile_get_id (profile_tmp)); goto try_harder; } gtk_widget_destroy (dialog); goto out; } /* get correct title */ switch (cd_icc_get_kind (icc)) { case CD_PROFILE_KIND_DISPLAY_DEVICE: /* TRANSLATORS: the profile type */ title = _("Import display color profile?"); break; case CD_PROFILE_KIND_OUTPUT_DEVICE: /* TRANSLATORS: the profile type */ title = _("Import device color profile?"); break; case CD_PROFILE_KIND_NAMED_COLOR: /* TRANSLATORS: the profile type */ title = _("Import named color profile?"); break; default: /* TRANSLATORS: the profile type */ title = _("Import color profile?"); break; } /* ask confirmation */ dialog = gtk_message_dialog_new (NULL, 0, GTK_MESSAGE_INFO, GTK_BUTTONS_CANCEL, "%s", title); gtk_message_dialog_set_image (GTK_MESSAGE_DIALOG (dialog), image); gtk_window_set_icon_name (GTK_WINDOW (dialog), GCM_STOCK_ICON); gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dialog), "%s", string->str); /* TRANSLATORS: button text */ gtk_dialog_add_button (GTK_DIALOG (dialog), _("Import"), GTK_RESPONSE_OK); gtk_dialog_add_button (GTK_DIALOG (dialog), _("Show Details"), GTK_RESPONSE_HELP); try_harder: response = gtk_dialog_run (GTK_DIALOG (dialog)); if (response == GTK_RESPONSE_HELP) { gcm_import_show_details (GTK_WINDOW (dialog), FALSE, files[0]); goto try_harder; } gtk_widget_destroy (dialog); /* not the correct response */ if (response != GTK_RESPONSE_OK) goto out; /* copy icc file to users profile path */ profile_tmp = cd_client_import_profile_sync (client, file, NULL, &error); if (profile_tmp == NULL) { /* TRANSLATORS: could not read file */ dialog = gtk_message_dialog_new (NULL, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, _("Failed to import file")); gtk_window_set_icon_name (GTK_WINDOW (dialog), GCM_STOCK_ICON); gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dialog), "%s", error->message); gtk_dialog_run (GTK_DIALOG (dialog)); g_error_free (error); gtk_widget_destroy (dialog); goto out; } out: if (file != NULL) g_object_unref (file); if (string != NULL) g_string_free (string, TRUE); if (icc != NULL) g_object_unref (icc); if (client != NULL) g_object_unref (client); if (profile_tmp != NULL) g_object_unref (profile_tmp); if (destination != NULL) g_object_unref (destination); g_strfreev (files); return retval; }
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); } }