diff options
Diffstat (limited to 'printdialog.c')
-rw-r--r-- | printdialog.c | 1396 |
1 files changed, 0 insertions, 1396 deletions
diff --git a/printdialog.c b/printdialog.c deleted file mode 100644 index 50d2a88..0000000 --- a/printdialog.c +++ /dev/null @@ -1,1396 +0,0 @@ -/* - * $Xorg: printdialog.c,v 1.1 2004/05/12 02:05:54 gisburn Exp $ - * -Copyright 2004 Roland Mainz <roland.mainz@nrubsig.org> - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - * - */ - -/* Force ANSI C prototypes from X11 headers */ -#ifndef FUNCPROTO -#define FUNCPROTO 15 -#endif /* !FUNCPROTO */ - -#include <X11/StringDefs.h> -#include <X11/Intrinsic.h> -#include <X11/Shell.h> -#include <X11/Xaw/Form.h> -#include <X11/Xaw/Toggle.h> -#include <X11/Xaw/List.h> -#include <X11/Xaw/Command.h> -#include <X11/Xaw/AsciiText.h> -#include <X11/Xaw/Dialog.h> - -#ifdef XKB -#include <X11/extensions/XKBbells.h> -#endif /* XKB */ - -#ifdef XEDIT -#include "xedit.h" -#endif /* XEDIT */ -#include "printdialog.h" -#include "printdialogprivates.h" -#include "print.h" - -#include <stdlib.h> -#include <ctype.h> -#include <stdio.h> - -/* Turn a NULL pointer string into an empty string */ -#define NULLSTR(x) (((x)!=NULL)?(x):("")) - -#define Error(x) { printf x ; exit(EXIT_FAILURE); } -#define Assertion(expr, msg) { if (!(expr)) { Error msg } } -#ifdef DEBUG -# define Log(x) { if(True) printf x; } -#else -# define Log(x) { if(False) printf x; } -#endif /* DEBUG */ - -/* Local prototypes */ -static void do_beep(PrintDialogWidget pdw); -static void center_popup(Widget parent, Widget popup); -static void updateWidgetStates(PrintDialogWidget pdw); -static void printSetupClose(PrintDialogWidget pdw); -static void printSetupOKXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printSetupCancelXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printSetupJobCopiesXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printDialogDestXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printSelectFileXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printOKXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printSetupXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printFileSelectedXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void buildFileDialog(PrintDialogWidget pdw); -static void closePrinterConnection(PrintDialogWidget pdw, Bool closeDisplay); -static Bool openPrinterConnection(PrintDialogWidget pdw); -static void destroyPrintSetupDialog(PrintDialogWidget pdw); -static Widget buildPrintSetupDialog(PrintDialogWidget pdw); -static String *xpprinterlist_to_widget_printerlist(XPPrinterList printerlist, int num_printers); -static String *xppaperlist_to_widget_paperlist(XpuMediumSourceSizeList paperlist, int num_papers); -static String *xpresolutionlist_to_widget_resolutionlist(XpuResolutionList reslist, int num_resolutions); -static String *xporientationlist_to_widget_orientationlist(XpuOrientationList orientationlist, int num_orientations); -static String *xpplexlist_to_widget_plexlist(XpuPlexList plexlist, int num_plex); -static String *xpcolorspacelist_to_widget_colorspacelist(XpuColorspaceList colorspacelist, int num_colorspaces); -static void printerSelectionPrinterSelectedXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printSelectPrinterXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printerSelectionClose(PrintDialogWidget pdw); -static void printerSelectionOKXtProc(Widget w, XtPointer client_data, XtPointer callData); -static void printerSelectionCancelXtProc(Widget w, XtPointer client_data, XtPointer callData); -static Bool buildPrinterSelectionDialog(PrintDialogWidget pdw); -static void destroyPrinterSelectionDialog(PrintDialogWidget pdw); -static void createprintdialogchildren(Widget w); - -static -void do_beep(PrintDialogWidget pdw) -{ - Log(("*** Beep!\n")); -#ifdef XKB - XkbStdBell(XtDisplay((Widget)pdw), XtWindow((Widget)pdw), 0, XkbBI_MinorError); -#else - XBell(XtDisplay((Widget)pdw), 0); -#endif /* XKB */ -} - -/* Center popup (on parent, not on screen - which would be a bad idea - * in the Xinerama case) */ -static -void center_popup(Widget parent, Widget popup) -{ - Dimension width, - height; - Position x, - y; - - XtVaGetValues(parent, - XtNx, &x, - XtNy, &y, - NULL); - XtVaGetValues(popup, - XtNwidth, &width, - XtNheight, &height, - NULL); - - x += (Position)width / 2; - y += (Position)height / 3; - - XtVaSetValues(popup, - XtNx, x, - XtNy, y, - NULL); -} - -static -void updateWidgetStates(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - /* Do not update anything if we will be destroyed */ - if (pdw->core.being_destroyed) - return; - - if (pdp->printToFile == False) { - XtVaSetValues(pdp->main.printtoprinter, XtNstate, True, NULL); - XtVaSetValues(pdp->main.printtofile, XtNstate, False, NULL); - /* Disable the widgets which depend on print-to-file */ - XtVaSetValues(pdp->main.filenamelabel, XtNsensitive, False, NULL); - XtVaSetValues(pdp->main.filename, XtNsensitive, False, NULL); - XtVaSetValues(pdp->main.selectfile, XtNsensitive, False, NULL); - } - else - { - XtVaSetValues(pdp->main.printtoprinter, XtNstate, False, NULL); - XtVaSetValues(pdp->main.printtofile, XtNstate, True, NULL); - /* Enable the widgets which depend on print-to-file */ - XtVaSetValues(pdp->main.filenamelabel, XtNsensitive, True, NULL); - XtVaSetValues(pdp->main.filename, XtNsensitive, True, NULL); - XtVaSetValues(pdp->main.selectfile, XtNsensitive, True, NULL); - } - - /* Update file name */ - XtVaSetValues(pdp->main.filename, XtNlabel, pdp->filename?pdp->filename:"-", NULL); - - /* General check whether we can print... */ - pdp->canPrint = True; - if (pdp->printer_name == NULL) { - pdp->canPrint = False; - } - else if (strlen(pdp->printer_name) == 0) { - pdp->canPrint = False; - } - - pdp->canReallyPrint = pdp->canPrint; - - /* Some extra checks for print-to-file */ - if (pdp->printToFile) { - if (pdp->filename == NULL) { - pdp->canReallyPrint = False; - } - else if (strlen(pdp->filename) == 0) { - pdp->canReallyPrint = False; - } - } - - XtVaSetValues(pdp->main.ok, XtNsensitive, pdp->canReallyPrint, NULL); - XtVaSetValues(pdp->main.setup, XtNsensitive, pdp->canPrint, NULL); -} - -static void -printSetupClose(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - if (pdp->setup.popup) { - XtPopdown(pdp->setup.popup); - } -} - -static void -printSetupOKXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - char *s; - XawListReturnStruct *lrs; - Log(("## printSetupOK: closing print setup!\n")); - - /* Set copy count (if the value is invalid beep and return to the user ) */ - XtVaGetValues(pdp->setup.jobcopies, XtNstring, &s, NULL); - if (s) { - int c = atoi(s); - if (c < 1 || c > 999) { - do_beep(pdw); - XtVaSetValues(pdp->setup.jobcopies, XtNstring, "1", NULL); - Log(("## printSetupOKXtProc: not a valid copy count value\n")); - return; - } - - /* Fix me: We should set the number of _job_ copies here, not _doc_ copies */ - XpuSetDocumentCopies(pdp->pdpy, pdp->pcontext, c); - } - - /* Set paper size */ - lrs = XawListShowCurrent(pdp->setup.paperlist); - if (lrs->list_index != XAW_LIST_NONE) { - Log(("selected paper is '%s'/'%d'\n", lrs->string, lrs->list_index)); - Assertion(lrs->list_index < pdp->num_papers, (("Error: lrs->list_index < pdp->num_papers\n"))); - XpuSetDocMediumSourceSize(pdp->pdpy, pdp->pcontext, &pdp->paperlist[lrs->list_index]); - } - XtFree((char *)lrs); - - /* Set resolution */ - lrs = XawListShowCurrent(pdp->setup.resolutionlist); - if (lrs->list_index != XAW_LIST_NONE) { - Log(("selected resolution is '%s'/'%d'\n", lrs->string, lrs->list_index)); - Assertion(lrs->list_index < pdp->num_resolutions, (("Error: lrs->list_index < pdp->num_resolutions\n"))); - XpuSetDocResolution(pdp->pdpy, pdp->pcontext, &pdp->resolutionlist[lrs->list_index]); - } - XtFree((char *)lrs); - - /* Set orientation */ - lrs = XawListShowCurrent(pdp->setup.orientationlist); - if (lrs->list_index != XAW_LIST_NONE) { - Log(("selected orientation is '%s'/'%d'\n", lrs->string, lrs->list_index)); - Assertion(lrs->list_index < pdp->num_orientations, (("Error: lrs->list_index < pdp->num_orientations\n"))); - XpuSetDocOrientation(pdp->pdpy, pdp->pcontext, &pdp->orientationlist[lrs->list_index]); - } - XtFree((char *)lrs); - - /* Set plex mode */ - lrs = XawListShowCurrent(pdp->setup.plexlist); - if (lrs->list_index != XAW_LIST_NONE) { - Log(("selected plex is '%s'/'%d'\n", lrs->string, lrs->list_index)); - Assertion(lrs->list_index < pdp->num_plex, (("Error: lrs->list_index < pdp->num_plex\n"))); - XpuSetDocPlex(pdp->pdpy, pdp->pcontext, &pdp->plexlist[lrs->list_index]); - } - XtFree((char *)lrs); - - /* Set colorspace */ - lrs = XawListShowCurrent(pdp->setup.colorspacelist); - if (lrs->list_index != XAW_LIST_NONE) { - Log(("selected colorspace is '%s'/'%d'\n", lrs->string, lrs->list_index)); - Assertion(lrs->list_index < pdp->num_colorspaces, (("Error: lrs->list_index < pdp->num_colorspaces\n"))); - pdp->selected_colorspace = &pdp->colorspacelist[lrs->list_index]; - } - XtFree((char *)lrs); - - printSetupClose(pdw); -} - -static void -printSetupCancelXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - Log(("## printSetupCancel: closing print setup!\n")); - - printSetupClose(pdw); -} - -static void -printSetupJobCopiesXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - char *string = NULL; - - Log(("## printSetupJobCopiesXtProc!\n")); - - /* Check whether the input is a valid number - and in the case of invalid input reset the value */ - XtVaGetValues(pdp->setup.jobcopies, XtNstring, &string, NULL); - if (string) { - char *s; - int i; - Bool isValidNumber = True; - - /* First check for invalid characters... */ - for( s = string ; *s != '\0' ; s++ ) { - if (!isdigit(*s)) { - isValidNumber = False; - break; - } - } - - /* .. and the do a range check... */ - i = atoi(string); - if (i < 1 || i > 999) { - isValidNumber = False; - } - - if (!isValidNumber) { - do_beep(pdw); - XtVaSetValues(pdp->setup.jobcopies, XtNstring, "1", NULL); - Log(("## printSetupJobCopiesXtProc: not a valid number\n")); - } - } -} - -static void -printCancelXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - - printSetupClose(pdw); - - if (pdp->cancel_callback) { - Log(("printCancelXtProc: calling callback\n")); - XtCallCallbackList((Widget)pdw, pdp->cancel_callback, NULL); - } -} - -static void -printDialogDestXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - - if (w == pdp->main.printtoprinter) { - pdp->printToFile = False; - } - else if (w == pdp->main.printtofile) { - pdp->printToFile = True; - } - else - { - Log(("printDialogDestXtProc: ERROR: Unknown widget.\n")); - } - - updateWidgetStates(pdw); -} - -static void -printSelectFileXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - - Log(("## printSelectFileXtProc!\n")); - - if (!pdp->selectFile.shell) { - buildFileDialog(pdw); - } - - center_popup((Widget)pdw, pdp->selectFile.shell); - - XtPopup(pdp->selectFile.shell, XtGrabExclusive); -} - -static void -printOKXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - Log(("## printing!\n")); - - if (!pdp->pdpy) { - Log(("printOKXtProc: no printer connection, opening one....\n")); - openPrinterConnection(pdw); - - if (!pdp->pdpy) { - Log(("printOKXtProc: still no printer connection - BAD (this should never happen).\n")); - do_beep(pdw); - return; - } - } - - if (pdp->ok_callback) { - XawPrintDialogCallbackStruct pdcs; - - Log(("printOKXtProc: calling callbacks...\n")); - memset(&pdcs, 0, sizeof(pdcs)); - pdcs.pdpy = pdp->pdpy; - pdcs.pcontext = pdp->pcontext; - pdcs.printToFile = pdp->printToFile; - pdcs.printToFileName = (const char *)pdp->filename; - pdcs.colorspace = pdp->selected_colorspace; - XtCallCallbackList((Widget)pdw, pdp->ok_callback, &pdcs); - } - - printSetupClose(pdw); -} - -static void -printSetupXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - - Log(("## setup!\n")); - - if (!pdp->setup.popup) { - if (buildPrintSetupDialog(pdw) == NULL) { - Log(("printSetupXtProc: buildPrintSetupDialog failure.\n")); - return; - } - } - - center_popup((Widget)pdw, pdp->setup.popup); - - XtPopup(pdp->setup.popup, XtGrabExclusive); -} - -static void -printFileSelectedXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - const char *filename; - - Log(("printFileSelectedXtProc: User selected file.\n")); - filename = XawDialogGetValueString(pdp->selectFile.dialog); - - if (pdp->filename) - free(pdp->filename); - pdp->filename = strdup(filename); - - XtPopdown(pdp->selectFile.shell); - - updateWidgetStates(pdw); -} - -static -void buildFileDialog(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - int n; - Arg args[20]; - - pdp->selectFile.shell = XtCreatePopupShell("selectfile", - transientShellWidgetClass, - (Widget)pdw, NULL, 0); - n = 0; - XtSetArg(args[n], XtNvalue, pdp->filename?pdp->filename:""); n++; - pdp->selectFile.dialog = XtCreateManagedWidget("dialog", dialogWidgetClass, - pdp->selectFile.shell, args, n); - XawDialogAddButton(pdp->selectFile.dialog, "Accept", printFileSelectedXtProc, pdw); - - XtRealizeWidget(pdp->selectFile.shell); -} - -static -void closePrinterConnection(PrintDialogWidget pdw, Bool closeDisplay) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - Log(("# closePrinterConnection\n")); - - destroyPrintSetupDialog(pdw); - - if (pdp->paperlist) { - XpuFreeMediumSourceSizeList(pdp->paperlist); - pdp->paperlist = NULL; - } - - if (pdp->widget_paperlist) { - free(pdp->widget_paperlist); - pdp->widget_paperlist = NULL; - } - - if (pdp->resolutionlist) { - XpuFreeResolutionList(pdp->resolutionlist); - pdp->resolutionlist = NULL; - } - - if (pdp->widget_resolutionlist) { - free(pdp->widget_resolutionlist); - pdp->widget_resolutionlist = NULL; - } - - - if (pdp->orientationlist) { - XpuFreeOrientationList(pdp->orientationlist); - pdp->orientationlist = NULL; - } - - if (pdp->widget_orientationlist) { - free(pdp->widget_orientationlist); - pdp->widget_orientationlist = NULL; - } - - if (pdp->plexlist) { - XpuFreePlexList(pdp->plexlist); - pdp->plexlist = NULL; - } - - if (pdp->widget_plexlist) { - free(pdp->widget_plexlist); - pdp->widget_plexlist = NULL; - } - - if (pdp->colorspacelist) { - XpuFreeColorspaceList(pdp->colorspacelist); - pdp->colorspacelist = NULL; - } - - if (pdp->widget_colorspacelist) { - free(pdp->widget_colorspacelist); - pdp->widget_colorspacelist = NULL; - } - pdp->selected_colorspace = NULL; - - if (pdp->pdpy) { - if (closeDisplay) { - XpuClosePrinterDisplay(pdp->pdpy, pdp->pcontext); - } - pdp->pdpy = NULL; - pdp->pcontext = None; - } - - updateWidgetStates(pdw); -} - -static -Bool openPrinterConnection(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - Log(("# openPrinterConnection\n")); - - /* Close any outstanding connection first... */ - closePrinterConnection(pdw, True); - - if (!pdp->printer_name) { - Log(("# error: openPrinterConnection: No printer name.\n")); - return False; - } - - if (XpuGetPrinter(pdp->printer_name, &pdp->pdpy, &pdp->pcontext) == False) { - Log(("openPrinterConnection: could not open printer.\n")); - return False; - } - - pdp->paperlist = XpuGetMediumSourceSizeList(pdp->pdpy, pdp->pcontext, &pdp->num_papers); - pdp->resolutionlist = XpuGetResolutionList(pdp->pdpy, pdp->pcontext, &pdp->num_resolutions); - pdp->orientationlist = XpuGetOrientationList(pdp->pdpy, pdp->pcontext, &pdp->num_orientations); - pdp->plexlist = XpuGetPlexList(pdp->pdpy, pdp->pcontext, &pdp->num_plex); - pdp->colorspacelist = XpuGetColorspaceList(pdp->pdpy, pdp->pcontext, &pdp->num_colorspaces); - - pdp->widget_paperlist = xppaperlist_to_widget_paperlist(pdp->paperlist, pdp->num_papers); - pdp->widget_resolutionlist = xpresolutionlist_to_widget_resolutionlist(pdp->resolutionlist, pdp->num_resolutions); - pdp->widget_orientationlist = xporientationlist_to_widget_orientationlist(pdp->orientationlist, pdp->num_orientations); - pdp->widget_plexlist = xpplexlist_to_widget_plexlist(pdp->plexlist, pdp->num_plex); - pdp->widget_colorspacelist = xpcolorspacelist_to_widget_colorspacelist(pdp->colorspacelist, pdp->num_colorspaces); - - updateWidgetStates(pdw); - - return True; -} - -#undef DEFAULT_WIDTH -#define DEFAULT_WIDTH 120 -#undef DEFAULT_INFOLABEL_WIDTH -#define DEFAULT_INFOLABEL_WIDTH 250 - -static -void destroyPrintSetupDialog(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - if (pdp->setup.popup) { - XtDestroyWidget(pdp->setup.popup); - } - - /* |XtDestroyWidget(pdp->setup.popup);| above will recursively destroy - * all children so we only have to reset the pointers here... */ - pdp->setup.popup = NULL; - pdp->setup.form = NULL; - pdp->setup.paperlist = NULL; - pdp->setup.resolutionlist = NULL; - pdp->setup.orientationlist = NULL; - pdp->setup.plexlist = NULL; - pdp->setup.colorspacelist = NULL; - pdp->setup.ok = NULL; - pdp->setup.cancel = NULL; -} - -static -Widget buildPrintSetupDialog(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - int n; - Arg args[20]; - Widget listform; - XpuSupportedFlags jobflags, - docflags; - Bool canChangeJobCopies, - canChangePaperSize, - canChangeResolution, - canChangeOrientation, - canChangePlex; - - if (!pdp->pdpy) { - Log(("buildPrintSetupDialog: no printer connection, opening one....\n")); - openPrinterConnection(pdw); - - if (!pdp->pdpy) { - Log(("buildPrintSetupDialog: still no printer connection - BAD.\n")); - do_beep(pdw); - return NULL; - } - } - - /* Get flags which types of attributes can be modified */ - jobflags = XpuGetSupportedDocAttributes(pdp->pdpy, pdp->pcontext); - docflags = XpuGetSupportedDocAttributes(pdp->pdpy, pdp->pcontext); - canChangeJobCopies = (jobflags & XPUATTRIBUTESUPPORTED_COPY_COUNT) == XPUATTRIBUTESUPPORTED_COPY_COUNT; - canChangePaperSize = (docflags & XPUATTRIBUTESUPPORTED_DEFAULT_MEDIUM) == XPUATTRIBUTESUPPORTED_DEFAULT_MEDIUM; - canChangeResolution = (docflags & XPUATTRIBUTESUPPORTED_DEFAULT_PRINTER_RESOLUTION) == XPUATTRIBUTESUPPORTED_DEFAULT_PRINTER_RESOLUTION; - canChangeOrientation = (docflags & XPUATTRIBUTESUPPORTED_CONTENT_ORIENTATION) == XPUATTRIBUTESUPPORTED_CONTENT_ORIENTATION; - canChangePlex = (docflags & XPUATTRIBUTESUPPORTED_PLEX) == XPUATTRIBUTESUPPORTED_PLEX; - - n = 0; - XtSetArg(args[n], XtNallowShellResize, True); n++; - pdp->setup.popup = XtCreatePopupShell("setup", transientShellWidgetClass, (Widget)pdw, args, n); - - n = 0; - pdp->setup.form = XtCreateManagedWidget("form", formWidgetClass, pdp->setup.popup, args, n); - - n = 0; - listform = XtCreateManagedWidget("list", formWidgetClass, pdp->setup.form, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNsensitive, canChangePaperSize); n++; - XtSetArg(args[n], XtNlist, pdp->widget_paperlist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->setup.paperlist = XtCreateManagedWidget("paperlist", listWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNsensitive, canChangeResolution); n++; - XtSetArg(args[n], XtNlist, pdp->widget_resolutionlist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->setup.resolutionlist = XtCreateManagedWidget("resolutionlist", listWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNsensitive, canChangeOrientation); n++; - XtSetArg(args[n], XtNlist, pdp->widget_orientationlist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->setup.orientationlist = XtCreateManagedWidget("orientationlist", listWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNsensitive, canChangePlex); n++; - XtSetArg(args[n], XtNlist, pdp->widget_plexlist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->setup.plexlist = XtCreateManagedWidget("plexlist", listWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNsensitive, True); n++; - XtSetArg(args[n], XtNlist, pdp->widget_colorspacelist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->setup.colorspacelist = XtCreateManagedWidget("colorspacelist", listWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyRight); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - XtSetArg(args[n], XtNsensitive, canChangeJobCopies); n++; - pdp->setup.jobcopieslabel = XtCreateManagedWidget("jobcopieslabel", labelWidgetClass, listform, args, n); - - n = 0; - XtSetArg(args[n], XtNstring, "1"); n++; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNeditType, XawtextEdit); n++; - XtSetArg(args[n], XtNsensitive, canChangeJobCopies); n++; - pdp->setup.jobcopies = XtCreateManagedWidget("jobcopies", asciiTextWidgetClass, listform, args, n); - XtAddCallback(pdp->setup.jobcopies, XtNpositionCallback, printSetupJobCopiesXtProc, pdw); - - n = 0; - pdp->setup.ok = XtCreateManagedWidget("ok", commandWidgetClass, pdp->setup.form, args, n); - XtAddCallback(pdp->setup.ok, XtNcallback, printSetupOKXtProc, pdw); - - n = 0; - pdp->setup.cancel = XtCreateManagedWidget("cancel", commandWidgetClass, pdp->setup.form, args, n); - XtAddCallback(pdp->setup.cancel, XtNcallback, printSetupCancelXtProc, pdw); - - XtRealizeWidget(pdp->setup.popup); - - return pdp->setup.popup; -} - -#undef DEFAULT_WIDTH -#define DEFAULT_WIDTH 150 - -static -String *xpprinterlist_to_widget_printerlist(XPPrinterList printerlist, int num_printers) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_printers+1)); - if(!names) - return NULL; - - for(i = 0 ; i < num_printers ; i++) - names[i] = printerlist[i].name; - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static -String *xppaperlist_to_widget_paperlist(XpuMediumSourceSizeList paperlist, int num_papers) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_papers+1)); - if (!names) - return NULL; - - for(i = 0 ; i < num_papers ; i++) - names[i] = (char *)paperlist[i].medium_name; /* FixMe: tray selection missing */ - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static -String *xpresolutionlist_to_widget_resolutionlist(XpuResolutionList reslist, int num_resolutions) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_resolutions+1)); - if (!names) - return NULL; - - for(i = 0 ; i < num_resolutions ; i++) - names[i] = (char *)reslist[i].name; - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static -String *xporientationlist_to_widget_orientationlist(XpuOrientationList orientationlist, int num_orientations) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_orientations+1)); - if (!names) - return NULL; - - for(i = 0 ; i < num_orientations ; i++) - names[i] = (char *)orientationlist[i].orientation; - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static -String *xpplexlist_to_widget_plexlist(XpuPlexList plexlist, int num_plex) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_plex+1)); - if(!names) - return NULL; - - for(i = 0 ; i < num_plex ; i++) - names[i] = (char *)plexlist[i].plex; - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static -String *xpcolorspacelist_to_widget_colorspacelist(XpuColorspaceList colorspacelist, int num_colorspaces) -{ - int i; - String *names; - - names = malloc(sizeof(String *) * (num_colorspaces+1)); - if(!names) - return NULL; - - for(i = 0 ; i < num_colorspaces ; i++) - names[i] = (char *)colorspacelist[i].name; - - names[i] = NULL; /* Terminate the list */ - - return names; -} - -static void -printerSelectionPrinterSelectedXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - XawListReturnStruct *lrs = (XawListReturnStruct *)callData; - int list_index; - - Log(("## user selected a printer\n")); - - list_index = lrs->list_index; - if (list_index == XAW_LIST_NONE) { - Log(("printerSelectionPrinterSelectedXtProc: Nothing selected.\n")); - return; - } - - Log(("selected printer is '%d'/'%s'/'%s'\n", - list_index, lrs->string, NULLSTR(pdp->printerlist[list_index].name))); - - /* Enable OK button */ - XtVaSetValues(pdp->selectPrinter.ok, XtNsensitive, True, NULL); -} - -static void -printSelectPrinterXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - - Log(("## select printer!\n")); - - if (!pdp->selectPrinter.popup) { - if (!buildPrinterSelectionDialog(pdw)) { - Log(("printSelectPrinterXtProc: buildPrinterSelectionDialog failure.\n")); - return; - } - } - - center_popup((Widget)pdw, pdp->selectPrinter.popup); - - XtPopup(pdp->selectPrinter.popup, XtGrabExclusive); -} - -static void -printerSelectionClose(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - if (pdp->selectPrinter.popup) { - XtPopdown(pdp->selectPrinter.popup); - } -} - -static void -printerSelectionOKXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - PrintDialogPart *pdp = &pdw->printdialog; - XawListReturnStruct *lrs; - int list_index; - - Log(("## printerSelectionOKXtProc: closing printer selection!\n")); - - /* Copy current selection in printer list widget and open a printer connection */ - lrs = XawListShowCurrent(pdp->selectPrinter.list); - if (!lrs) { - Log(("printerSelectionOKXtProc: |lrs|==NULL\n")); - return; - } - - list_index = lrs->list_index; - if (lrs->list_index == XAW_LIST_NONE) { - Log(("printerSelectionOKXtProc: rs->list_index == XAW_LIST_NONE\n")); - XtFree((char *)lrs); - return; - } - - /* Set printer name and description in main dialog */ - XtVaSetValues(pdp->main.name, XtNlabel, NULLSTR(pdp->printerlist[list_index].name), NULL); - XtVaSetValues(pdp->main.desc, XtNlabel, NULLSTR(pdp->printerlist[list_index].desc), NULL); - - if (pdp->printer_name) - free(pdp->printer_name); - pdp->printer_name = strdup(lrs->string); - - /* Close any outstanding printer connection since user has selected - * a different printer */ - closePrinterConnection(pdw, True); - - printerSelectionClose(pdw); - - XtFree((char *)lrs); -} - -static void -printerSelectionCancelXtProc(Widget w, XtPointer client_data, XtPointer callData) -{ - PrintDialogWidget pdw = (PrintDialogWidget)client_data; - Log(("## printerSelectionCancelXtProc: closing printer selection!\n")); - - printerSelectionClose(pdw); -} - -static -Bool buildPrinterSelectionDialog(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - int n; - Arg args[20]; - - n = 0; - XtSetArg(args[n], XtNallowShellResize, True); n++; - pdp->selectPrinter.popup = XtCreatePopupShell("printerselection", transientShellWidgetClass, (Widget)pdw, args, n); - - n = 0; - pdp->selectPrinter.form = XtCreateManagedWidget("form", formWidgetClass, pdp->selectPrinter.popup, args, n); - - n = 0; - XtSetArg(args[n], XtNresizable, True); n++; - XtSetArg(args[n], XtNforceColumns, True); n++; - XtSetArg(args[n], XtNdefaultColumns, 1); n++; - XtSetArg(args[n], XtNlist, pdp->widget_printerlist); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->selectPrinter.list = XtCreateManagedWidget("list", listWidgetClass, pdp->selectPrinter.form, args, n); - XtAddCallback(pdp->selectPrinter.list, XtNcallback, printerSelectionPrinterSelectedXtProc, pdw); - - n = 0; - XtSetArg(args[n], XtNsensitive, False); n++; - pdp->selectPrinter.ok = XtCreateManagedWidget("ok", commandWidgetClass, pdp->selectPrinter.form, args, n); - XtAddCallback(pdp->selectPrinter.ok, XtNcallback, printerSelectionOKXtProc, pdw); - - n = 0; - pdp->selectPrinter.cancel = XtCreateManagedWidget("cancel", commandWidgetClass, pdp->selectPrinter.form, args, n); - XtAddCallback(pdp->selectPrinter.cancel, XtNcallback, printerSelectionCancelXtProc, pdw); - - XtRealizeWidget(pdp->selectPrinter.popup); - - return True; -} - -static -void destroyPrinterSelectionDialog(PrintDialogWidget pdw) -{ - PrintDialogPart *pdp = &pdw->printdialog; - - if (pdp->selectPrinter.popup) { - XtDestroyWidget(pdp->selectPrinter.popup); - } - - /* |XtDestroyWidget(pdp->setup.popup);| above will recursively destroy - * all children so we only have to reset the pointers here... */ - pdp->selectPrinter.popup = NULL; - pdp->selectPrinter.form = NULL; - pdp->selectPrinter.list = NULL; - pdp->selectPrinter.popup = NULL; - pdp->selectPrinter.cancel = NULL; -} - -/* - * Function: - * createprintdialogchildren - * - * Parameters: - * w - print dialog widget - * - * Description: - * Creates the print dialog widgets. - * - * Note - * - - */ -static void -createprintdialogchildren(Widget w) -{ - int n; - Arg args[20]; - PrintDialogWidget pdw = (PrintDialogWidget)w; - PrintDialogPart *pdp = &pdw->printdialog; - const char *default_printername = NULL, - *default_printerdesc = NULL; - Bool has_default_printer = False; - - pdp->printerlist = XpuGetPrinterList(NULL, &pdp->num_printers); - pdp->widget_printerlist = xpprinterlist_to_widget_printerlist(pdp->printerlist, pdp->num_printers); - - if (pdp->num_printers > 0) { - if (pdp->printerlist[0].name && strlen(pdp->printerlist[0].name)) { - /* XprintUtils moves the default printer to the top */ - default_printername = pdp->printerlist[0].name; - default_printerdesc = pdp->printerlist[0].desc; - pdp->printer_name = strdup(pdp->printerlist[0].name); - has_default_printer = True; - } - } - else - { - PrintMsg(("No Xprint servers could be found.\n" - "Check whether the XPSERVERLIST environment variable contains any valid Xprint server(s).\n")); - } - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - pdp->main.form = XtCreateManagedWidget("main", formWidgetClass, (Widget)pdw, args, n); - - n = 0; - pdp->main.innerform = XtCreateManagedWidget("innerform", formWidgetClass, pdp->main.form, args, n); - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyRight); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->main.desclabel = XtCreateManagedWidget("desclabel", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyLeft); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_INFOLABEL_WIDTH); n++; - XtSetArg(args[n], XtNlabel, default_printerdesc?default_printerdesc:"-"); n++; - pdp->main.desc = XtCreateManagedWidget("desc", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - XtSetArg(args[n], XtNsensitive, has_default_printer); n++; - pdp->main.info = XtCreateManagedWidget("info", commandWidgetClass, pdp->main.innerform, args, n); - /* - XtAddCallback(pdp->main.info, XtNcallback, printerInfoXtProc, pdw); - */ - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyRight); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - pdp->main.namelabel = XtCreateManagedWidget("namelabel", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyLeft); n++; - XtSetArg(args[n], XtNlabel, default_printername?default_printername:"-"); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_INFOLABEL_WIDTH); n++; - pdp->main.name = XtCreateManagedWidget("name", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - pdp->main.selectprinter = XtCreateManagedWidget("selectprinter", commandWidgetClass, pdp->main.innerform, args, n); - XtAddCallback(pdp->main.selectprinter, XtNcallback, printSelectPrinterXtProc, pdw); - - /* Line: "File selection" */ - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyRight); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_WIDTH); n++; - XtSetArg(args[n], XtNsensitive, False); n++; - pdp->main.filenamelabel = XtCreateManagedWidget("filenamelabel", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - XtSetArg(args[n], XtNborderWidth, 0); n++; - XtSetArg(args[n], XtNresizable, False); n++; - XtSetArg(args[n], XtNjustify, XtJustifyLeft); n++; - XtSetArg(args[n], XtNlabel, "-"); n++; - XtSetArg(args[n], XtNwidth, DEFAULT_INFOLABEL_WIDTH); n++; - XtSetArg(args[n], XtNsensitive, False); n++; - pdp->main.filename = XtCreateManagedWidget("filename", labelWidgetClass, pdp->main.innerform, args, n); - - n = 0; - XtSetArg(args[n], XtNsensitive, False); n++; - pdp->main.selectfile = XtCreateManagedWidget("selectfile", commandWidgetClass, pdp->main.innerform, args, n); - XtAddCallback(pdp->main.selectfile, XtNcallback, printSelectFileXtProc, pdw); - - /* Line: Misc (Print destination toggles, copy-count etc.)*/ - n = 0; - XtSetArg(args[n], XtNstate, True); n++; - pdp->main.printtoprinter = XtCreateManagedWidget("printtoprinter", toggleWidgetClass, pdp->main.innerform, args, n); - XtAddCallback(pdp->main.printtoprinter, XtNcallback, printDialogDestXtProc, pdw); - - n = 0; - XtSetArg(args[n], XtNstate, False); n++; - pdp->main.printtofile = XtCreateManagedWidget("printtofile", toggleWidgetClass, pdp->main.innerform, args, n); - XtAddCallback(pdp->main.printtofile, XtNcallback, printDialogDestXtProc, pdw); - - /* End-of-Inner-Form-Content */ - - n = 0; - XtSetArg(args[n], XtNsensitive, has_default_printer); n++; - pdp->main.ok = XtCreateManagedWidget("ok", commandWidgetClass, pdp->main.form, args, n); - XtAddCallback(pdp->main.ok, XtNcallback, printOKXtProc, pdw); - - n = 0; - XtSetArg(args[n], XtNsensitive, has_default_printer); n++; - pdp->main.setup = XtCreateManagedWidget("setup", commandWidgetClass, pdp->main.form, args, n); - XtAddCallback(pdp->main.setup, XtNcallback, printSetupXtProc, pdw); - - n = 0; - pdp->main.cancel = XtCreateManagedWidget("cancel", commandWidgetClass, pdp->main.form, args, n); - XtAddCallback(pdp->main.cancel, XtNcallback, printCancelXtProc, pdw); -} - -/* - * Class Methods - */ -static void XawPrintDialogConstraintInitialize(Widget, Widget, ArgList, Cardinal *); -static void XawPrintDialogGetValuesHook(Widget, ArgList, Cardinal*); -static void XawPrintDialogInitialize(Widget, Widget, ArgList, Cardinal*); -static void XawPrintDialogDestroy(Widget); -static Boolean XawPrintDialogSetValues(Widget, Widget, Widget, ArgList, Cardinal *); - -/* - * Initialization - */ -static XtResource resources[] = { - { - XtNicon, - XtCIcon, - XtRBitmap, - sizeof(Pixmap), - XtOffsetOf(PrintDialogRec, printdialog.icon), - XtRImmediate, - 0 - }, - { - XawNOkCallback, XtCCallback, XtRCallback, - sizeof(XtCallbackList), XtOffsetOf(PrintDialogRec, printdialog.ok_callback), - XtRImmediate, (XtPointer)NULL - }, - { - XawNCancelCallback, XtCCallback, XtRCallback, - sizeof(XtCallbackList), XtOffsetOf(PrintDialogRec, printdialog.cancel_callback), - XtRImmediate, (XtPointer)NULL - }, -}; - -PrintDialogClassRec printdialogClassRec = { - /* core */ - { - (WidgetClass)&formClassRec, /* superclass */ - "PrintDialog", /* class_name */ - sizeof(PrintDialogRec), /* widget_size */ - XawInitializeWidgetSet, /* class_initialize */ - NULL, /* class_part init */ - False, /* class_inited */ - XawPrintDialogInitialize, /* initialize */ - NULL, /* initialize_hook */ - XtInheritRealize, /* realize */ - NULL, /* actions */ - 0, /* num_actions */ - resources, /* resources */ - XtNumber(resources), /* num_resources */ - NULLQUARK, /* xrm_class */ - True, /* compress_motion */ - True, /* compress_exposure */ - True, /* compress_enterleave */ - False, /* visible_interest */ - XawPrintDialogDestroy, /* destroy */ - XtInheritResize, /* resize */ - XtInheritExpose, /* expose */ - XawPrintDialogSetValues, /* set_values */ - NULL, /* set_values_hook */ - XtInheritSetValuesAlmost, /* set_values_almost */ - XawPrintDialogGetValuesHook, /* get_values_hook */ - NULL, /* accept_focus */ - XtVersion, /* version */ - NULL, /* callback_private */ - NULL, /* tm_table */ - XtInheritQueryGeometry, /* query_geometry */ - XtInheritDisplayAccelerator, /* display_accelerator */ - NULL, /* extension */ - }, - /* composite */ - { - XtInheritGeometryManager, /* geometry_manager */ - XtInheritChangeManaged, /* change_managed */ - XtInheritInsertChild, /* insert_child */ - XtInheritDeleteChild, /* delete_child */ - NULL, /* extension */ - }, - /* constraint */ - { - NULL, /* subresourses */ - 0, /* subresource_count */ - sizeof(PrintDialogConstraintsRec), /* constraint_size */ - XawPrintDialogConstraintInitialize, /* initialize */ - NULL, /* destroy */ - NULL, /* set_values */ - NULL, /* extension */ - }, - /* form */ - { - XtInheritLayout, /* layout */ - }, - /* printdialog */ - { - NULL, /* extension */ - } -}; - -WidgetClass printDialogWidgetClass = (WidgetClass)&printdialogClassRec; - -/* - * Implementation - */ -/*ARGSUSED*/ -static void -XawPrintDialogInitialize(Widget request, Widget cnew, ArgList args, Cardinal *num_args) -{ - PrintDialogWidget dw = (PrintDialogWidget)cnew; - Arg arglist[9]; - Cardinal arg_cnt = 0; - - XtSetArg(arglist[arg_cnt], XtNborderWidth, 0); arg_cnt++; - XtSetArg(arglist[arg_cnt], XtNleft, XtChainLeft); arg_cnt++; - - if (dw->printdialog.icon != (Pixmap)0) { - XtSetArg(arglist[arg_cnt], XtNbitmap, dw->printdialog.icon); arg_cnt++; - XtSetArg(arglist[arg_cnt], XtNright, XtChainLeft); arg_cnt++; - dw->printdialog.iconW = XtCreateManagedWidget("icon", labelWidgetClass, - cnew, arglist, arg_cnt); - arg_cnt = 2; - XtSetArg(arglist[arg_cnt], XtNfromHoriz, dw->printdialog.iconW); arg_cnt++; - } - else { - dw->printdialog.iconW = NULL; - } - - createprintdialogchildren((Widget)dw); -} - -/*ARGSUSED*/ -static void -XawPrintDialogConstraintInitialize(Widget request, Widget cnew, - ArgList args, Cardinal *num_args) -{ - PrintDialogWidget dw = (PrintDialogWidget)cnew->core.parent; - PrintDialogConstraints constraint = (PrintDialogConstraints)cnew->core.constraints; - - if (!XtIsSubclass(cnew, commandWidgetClass)) /* if not a button */ - return; /* then just use defaults */ - - constraint->form.left = constraint->form.right = XtChainLeft; - constraint->form.vert_base = dw->printdialog.main.form; - - if (dw->composite.num_children > 1) { - WidgetList children = dw->composite.children; - Widget *childP; - - for (childP = children + dw->composite.num_children - 1; - childP >= children; childP-- ) { - if (*childP == dw->printdialog.main.form) - break; - if (XtIsManaged(*childP) && - XtIsSubclass(*childP, commandWidgetClass)) { - constraint->form.horiz_base = *childP; - break; - } - } - } -} - -#define ICON 0 -#define NUM_CHECKS 1 -/*ARGSUSED*/ -static Boolean -XawPrintDialogSetValues(Widget current, Widget request, Widget cnew, - ArgList in_args, Cardinal *in_num_args) -{ - PrintDialogWidget w = (PrintDialogWidget)cnew; - PrintDialogWidget old = (PrintDialogWidget)current; - Arg args[5]; - unsigned int i; - Bool checks[NUM_CHECKS]; - - for (i = 0; i < NUM_CHECKS; i++) - checks[i] = False; - - for (i = 0; i < *in_num_args; i++) { - if (!strcmp(XtNicon, in_args[i].name)) - checks[ICON] = True; - } - - if (checks[ICON]) { - if (w->printdialog.icon != 0) { - XtSetArg(args[0], XtNbitmap, w->printdialog.icon); - if (old->printdialog.iconW != NULL) { - XtSetValues(old->printdialog.iconW, args, 1); - } - else { - XtSetArg(args[1], XtNborderWidth, 0); - XtSetArg(args[2], XtNleft, XtChainLeft); - XtSetArg(args[3], XtNright, XtChainLeft); - w->printdialog.iconW = XtCreateWidget("icon", labelWidgetClass, - cnew, args, 4); - XtManageChild(w->printdialog.iconW); - } - } - else if (old->printdialog.icon != 0) { - XtDestroyWidget(old->printdialog.iconW); - w->printdialog.iconW = NULL; - } - } - - return True; -} - -/* - * Function: - * XawPrintDialogGetValuesHook - * - * Parameters: - * w - Print Dialog Widget - * args - argument list - * num_args - number of args - * - * Description: - * This is a get values hook routine that gets the values in the dialog. - */ -static void -XawPrintDialogGetValuesHook(Widget w, ArgList args, Cardinal *num_args) -{ - /* NO-OP for now */ -} - -static void -XawPrintDialogDestroy(Widget w) -{ - PrintDialogWidget pdw = (PrintDialogWidget)w; - Log(("# XawPrintDialogDestroy: start.\n")); - - destroyPrintSetupDialog(pdw); - destroyPrinterSelectionDialog(pdw); - closePrinterConnection(pdw, True); - - Log(("# XawPrintDialogDestroy: done.\n")); -} - -/* - * Function: - * XawPrintDialogClosePrinterConnection - * - * Parameters: - * w - Print Dialog Widget - * closeDisplay - Boolean which decides whether |Display *| - * and |XPContext| should be disposed, too. - * - * Description: - * The print display connection is owned by the print dialog - * by default. - * If the application wishes to close the display connection - * to the print server, either to close it itself or force - * a disconnection for other reasons this function can be used. - * - * Notes - * 1. PUBLIC API - * 2. After this function returns all resources returned by the - * print dialog which are related to the status of the printer - * connection are stale. - */ -void -XawPrintDialogClosePrinterConnection(Widget w, Bool closeDisplay) -{ - closePrinterConnection((PrintDialogWidget)w, closeDisplay); -} - |