summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gtk/gtkprintjob.c35
-rw-r--r--gtk/gtkprintjob.h4
2 files changed, 39 insertions, 0 deletions
diff --git a/gtk/gtkprintjob.c b/gtk/gtkprintjob.c
index 71a09f51b2..571d2b0572 100644
--- a/gtk/gtkprintjob.c
+++ b/gtk/gtkprintjob.c
@@ -444,6 +444,41 @@ gtk_print_job_set_source_file (GtkPrintJob *job,
}
/**
+ * gtk_print_job_set_source_fd:
+ * @job: a #GtkPrintJob
+ * @fd: a file descriptor
+ * @error: return location for errors
+ *
+ * Make the #GtkPrintJob send an existing document to the
+ * printing system. The file can be in any format understood
+ * by the platforms printing system (typically PostScript,
+ * but on many platforms PDF may work too). See
+ * gtk_printer_accepts_pdf() and gtk_printer_accepts_ps().
+ *
+ * This is similar to gtk_print_job_set_source_file(),
+ * but takes expects an open file descriptor for the file,
+ * instead of a filename.
+ *
+ * Returns: %FALSE if an error occurred
+ *
+ * Since: 3.22
+ */
+gboolean
+gtk_print_job_set_source_fd (GtkPrintJob *job,
+ int fd,
+ GError **error)
+{
+ g_return_val_if_fail (GTK_IS_PRINT_JOB (job), FALSE);
+ g_return_val_if_fail (fd >= 0, FALSE);
+
+ job->priv->spool_io = g_io_channel_unix_new (fd);
+ if (g_io_channel_set_encoding (job->priv->spool_io, NULL, error) != G_IO_STATUS_NORMAL)
+ return FALSE;
+
+ return TRUE;
+}
+
+/**
* gtk_print_job_get_surface:
* @job: a #GtkPrintJob
* @error: (allow-none): return location for errors, or %NULL
diff --git a/gtk/gtkprintjob.h b/gtk/gtkprintjob.h
index 09cddd9c81..3748650898 100644
--- a/gtk/gtkprintjob.h
+++ b/gtk/gtkprintjob.h
@@ -95,6 +95,10 @@ GDK_AVAILABLE_IN_ALL
gboolean gtk_print_job_set_source_file (GtkPrintJob *job,
const gchar *filename,
GError **error);
+GDK_AVAILABLE_IN_3_22
+gboolean gtk_print_job_set_source_fd (GtkPrintJob *job,
+ int fd,
+ GError **error);
GDK_AVAILABLE_IN_ALL
cairo_surface_t *gtk_print_job_get_surface (GtkPrintJob *job,
GError **error);