25
|
1 /*******************************************************************************
|
|
2 * Copyright (c) 2000, 2008 IBM Corporation and others.
|
|
3 * All rights reserved. This program and the accompanying materials
|
|
4 * are made available under the terms of the Eclipse Public License v1.0
|
|
5 * which accompanies this distribution, and is available at
|
|
6 * http://www.eclipse.org/legal/epl-v10.html
|
|
7 *
|
|
8 * Contributors:
|
|
9 * IBM Corporation - initial API and implementation
|
|
10 * Port to the D programming language:
|
|
11 * Frank Benoit <benoit@tionex.de>
|
|
12 *******************************************************************************/
|
|
13 module org.eclipse.swt.printing.PrinterData;
|
|
14
|
|
15 import java.lang.all;
|
|
16
|
|
17
|
|
18 import org.eclipse.swt.graphics.DeviceData;
|
|
19
|
|
20
|
|
21
|
|
22 /**
|
|
23 * Instances of this class are descriptions of a print job
|
|
24 * in terms of the printer, and the scope and type of printing
|
|
25 * that is desired. For example, the number of pages and copies
|
|
26 * can be specified, as well as whether or not the print job
|
|
27 * should go to a file.
|
|
28 * <p>
|
|
29 * Application code does <em>not</em> need to explicitly release the
|
|
30 * resources managed by each instance when those instances are no longer
|
|
31 * required, and thus no <code>dispose()</code> method is provided.
|
|
32 * </p>
|
|
33 *
|
|
34 * @see Printer
|
|
35 * @see Printer#getPrinterList
|
|
36 * @see PrintDialog#open
|
|
37 * @see <a href="http://www.eclipse.org/swt/snippets/#printing">Printing snippets</a>
|
|
38 * @see <a href="http://www.eclipse.org/swt/">Sample code and further information</a>
|
|
39 */
|
|
40
|
|
41 public final class PrinterData : DeviceData {
|
|
42
|
|
43 /**
|
|
44 * the printer driver
|
|
45 * On Windows systems, this is the name of the driver (often "winspool").
|
|
46 * On Mac OSX, this is the destination type ("Printer", "Fax", "File", or "Preview").
|
|
47 * On X/Window systems, this is the name of a display connection to the
|
|
48 * Xprt server (the default is ":1").
|
|
49 * On GTK+, this is the backend type name (eg. GtkPrintBackendCups).
|
|
50 */
|
|
51 // TODO: note that this api is not finalized for GTK+
|
|
52 public String driver;
|
|
53
|
|
54 /**
|
|
55 * the name of the printer
|
|
56 * On Windows systems, this is the name of the 'device'.
|
|
57 * On Mac OSX, X/Window systems, and GTK+, this is the printer's 'name'.
|
|
58 */
|
|
59 public String name;
|
|
60
|
|
61 /**
|
|
62 * the scope of the print job, expressed as one of the following values:
|
|
63 * <dl>
|
|
64 * <dt><code>ALL_PAGES</code></dt>
|
|
65 * <dd>Print all pages in the current document</dd>
|
|
66 * <dt><code>PAGE_RANGE</code></dt>
|
|
67 * <dd>Print the range of pages specified by startPage and endPage</dd>
|
|
68 * <dt><code>SELECTION</code></dt>
|
|
69 * <dd>Print the current selection</dd>
|
|
70 * </dl>
|
|
71 */
|
|
72 public int scope_ = ALL_PAGES;
|
|
73
|
|
74 /**
|
|
75 * the start page of a page range, used when scope is PAGE_RANGE.
|
|
76 * This value can be from 1 to the maximum number of pages for the platform.
|
|
77 */
|
|
78 public int startPage = 0;
|
|
79
|
|
80 /**
|
|
81 * the end page of a page range, used when scope is PAGE_RANGE.
|
|
82 * This value can be from 1 to the maximum number of pages for the platform.
|
|
83 */
|
|
84 public int endPage = 0;
|
|
85
|
|
86 /**
|
|
87 * whether or not the print job should go to a file
|
|
88 */
|
|
89 public bool printToFile = false;
|
|
90
|
|
91 /**
|
|
92 * the name of the file to print to if printToFile is true.
|
|
93 * Note that this field is ignored if printToFile is false.
|
|
94 */
|
|
95 public String fileName;
|
|
96
|
|
97 /**
|
|
98 * the number of copies to print.
|
|
99 * Note that this field may be controlled by the printer driver
|
|
100 * In other words, the printer itself may be capable of printing
|
|
101 * multiple copies, and if so, the value of this field will always be 1.
|
|
102 */
|
|
103 public int copyCount = 1;
|
|
104
|
|
105 /**
|
|
106 * whether or not the printer should collate the printed paper
|
|
107 * Note that this field may be controlled by the printer driver.
|
|
108 * In other words, the printer itself may be capable of doing the
|
|
109 * collation, and if so, the value of this field will always be false.
|
|
110 */
|
|
111 public bool collate = false;
|
|
112
|
|
113 /**
|
|
114 * <code>scope</code> field value indicating that
|
|
115 * all pages should be printed
|
|
116 */
|
|
117 public static const int ALL_PAGES = 0;
|
|
118
|
|
119 /**
|
|
120 * <code>scope</code> field value indicating that
|
|
121 * the range of pages specified by startPage and endPage
|
|
122 * should be printed
|
|
123 */
|
|
124 public static const int PAGE_RANGE = 1;
|
|
125
|
|
126 /**
|
|
127 * <code>scope</code> field value indicating that
|
|
128 * the current selection should be printed
|
|
129 */
|
|
130 public static const int SELECTION = 2;
|
|
131
|
|
132 /**
|
|
133 * private, platform-specific data
|
|
134 * On Windows, this contains a copy of the DEVMODE struct
|
|
135 * returned from the <code>PrintDialog</code>.
|
|
136 * On GTK, this contains a copy of the print_settings and page_setup
|
|
137 * returned from the <code>PrintDialog</code>.
|
|
138 * On OS X Carbon, this contains a copy of the PrintSettings and PageFormat
|
|
139 * returned from the <code>PrintDialog</code>.
|
|
140 * This field is not currently used on the X/Window System.
|
|
141 */
|
|
142 char [] otherData;
|
|
143
|
|
144 /**
|
|
145 * Constructs an instance of this class that can be
|
|
146 * used to print to the default printer.
|
|
147 *
|
|
148 * @see Printer#getDefaultPrinterData
|
|
149 */
|
|
150 public this() {
|
|
151 }
|
|
152
|
|
153 /**
|
|
154 * Constructs an instance of this class with the given
|
|
155 * printer driver and printer name.
|
|
156 *
|
|
157 * @param driver the printer driver for the printer
|
|
158 * @param name the name of the printer
|
|
159 *
|
|
160 * @see #driver
|
|
161 * @see #name
|
|
162 */
|
|
163 public this(String driver, String name) {
|
|
164 this.driver = driver;
|
|
165 this.name = name;
|
|
166 }
|
|
167
|
|
168 /**
|
|
169 * Returns a string containing a concise, human-readable
|
|
170 * description of the receiver.
|
|
171 *
|
|
172 * @return a string representation of the receiver
|
|
173 */
|
|
174 public override String toString() {
|
|
175 return Format( "PrinterData {{driver = {}, name = {}}", driver, name ); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
|
|
176 }
|
|
177 }
|