annotate dwt/printing/PrinterData.d @ 213:36f5cb12e1a2

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