/*
- * "$Id: lpstat.c 5527 2006-05-15 19:37:11Z mike $"
+ * "lpstat" command for CUPS.
*
- * "lpstat" command for the Common UNIX Printing System (CUPS).
+ * Copyright © 2007-2018 by Apple Inc.
+ * Copyright © 1997-2006 by Easy Software Products.
*
- * Copyright 1997-2006 by Easy Software Products.
- *
- * These coded instructions, statements, and computer programs are the
- * property of Easy Software Products and are protected by Federal
- * copyright law. Distribution and use rights are outlined in the file
- * "LICENSE.txt" which should have been included with this file. If this
- * file is missing or damaged please contact Easy Software Products
- * at:
- *
- * Attn: CUPS Licensing Information
- * Easy Software Products
- * 44141 Airport View Drive, Suite 204
- * Hollywood, Maryland 20636 USA
- *
- * Voice: (301) 373-9600
- * EMail: cups-info@cups.org
- * WWW: http://www.cups.org
- *
- * Contents:
- *
- * main() - Parse options and show status information.
- * check_dest() - Verify that the named destination(s) exists.
- * connect_server() - Connect to the server as necessary...
- * show_accepting() - Show acceptance status.
- * show_classes() - Show printer classes.
- * show_default() - Show default destination.
- * show_devices() - Show printer devices.
- * show_jobs() - Show active print jobs.
- * show_printers() - Show printers.
- * show_scheduler() - Show scheduler status.
+ * Licensed under Apache License v2.0. See the file "LICENSE" for more
+ * information.
*/
/*
* Include necessary headers...
*/
-#include <stdio.h>
-#include <stdlib.h>
-#include <errno.h>
-#include <cups/string.h>
-#include <cups/cups.h>
-#include <cups/i18n.h>
-#include <cups/debug.h>
+#include <cups/cups-private.h>
/*
* Local functions...
*/
-static void check_dest(const char *, http_t *, const char *, int *,
- cups_dest_t **);
-static http_t *connect_server(const char *, http_t *);
-static int show_accepting(http_t *, const char *, int, cups_dest_t *);
-static int show_classes(http_t *, const char *);
-static void show_default(int, cups_dest_t *);
-static int show_devices(http_t *, const char *, int, cups_dest_t *);
-static int show_jobs(http_t *, const char *, const char *, int, int,
- const char *);
-static int show_printers(http_t *, const char *, int, cups_dest_t *, int);
-static void show_scheduler(http_t *);
+static void check_dest(const char *command, const char *name,
+ int *num_dests, cups_dest_t **dests);
+static int match_list(const char *list, const char *name);
+static int show_accepting(const char *printers, int num_dests,
+ cups_dest_t *dests);
+static int show_classes(const char *dests);
+static void show_default(cups_dest_t *dest);
+static int show_devices(const char *printers, int num_dests,
+ cups_dest_t *dests);
+static int show_jobs(const char *dests, const char *users, int long_status,
+ int ranking, const char *which);
+static int show_printers(const char *printers, int num_dests,
+ cups_dest_t *dests, int long_status);
+static void show_scheduler(void);
+static void usage(void) _CUPS_NORETURN;
/*
*/
int
-main(int argc, /* I - Number of command-line arguments */
- char *argv[]) /* I - Command-line arguments */
+main(int argc, /* I - Number of command-line arguments */
+ char *argv[]) /* I - Command-line arguments */
{
- int i, /* Looping var */
- status; /* Exit status */
- http_t *http; /* Connection to server */
- int num_dests; /* Number of user destinations */
- cups_dest_t *dests; /* User destinations */
- int long_status; /* Long status report? */
- int ranking; /* Show job ranking? */
- const char *which; /* Which jobs to show? */
- char op; /* Last operation on command-line */
+ int i, /* Looping var */
+ status; /* Exit status */
+ char *opt; /* Option pointer */
+ int num_dests; /* Number of user destinations */
+ cups_dest_t *dests; /* User destinations */
+ int long_status; /* Long status report? */
+ int ranking; /* Show job ranking? */
+ const char *which; /* Which jobs to show? */
+ char op; /* Last operation on command-line */
+
+ _cupsSetLocale(argv);
/*
- * Set the locale so that times, etc. are displayed properly.
+ * Parse command-line options...
*/
- setlocale(LC_ALL, "");
-
- http = NULL;
num_dests = 0;
dests = NULL;
long_status = 0;
op = 0;
for (i = 1; i < argc; i ++)
- if (argv[i][0] == '-')
- switch (argv[i][1])
+ {
+ if (!strcmp(argv[i], "--help"))
+ usage();
+ else if (argv[i][0] == '-')
+ {
+ for (opt = argv[i] + 1; *opt; opt ++)
{
- case 'D' : /* Show description */
- long_status = 1;
- break;
+ switch (*opt)
+ {
+ case 'D' : /* Show description */
+ long_status = 1;
+ break;
- case 'E' : /* Encrypt */
+ case 'E' : /* Encrypt */
#ifdef HAVE_SSL
- cupsSetEncryption(HTTP_ENCRYPT_REQUIRED);
-
- if (http)
- httpEncryption(http, HTTP_ENCRYPT_REQUIRED);
+ cupsSetEncryption(HTTP_ENCRYPT_REQUIRED);
#else
- _cupsLangPrintf(stderr,
- _("%s: Sorry, no encryption support compiled in!\n"),
- argv[0]);
+ _cupsLangPrintf(stderr,
+ _("%s: Sorry, no encryption support."),
+ argv[0]);
#endif /* HAVE_SSL */
- break;
+ break;
- case 'P' : /* Show paper types */
- op = 'P';
- break;
+ case 'H' : /* Show server and port */
+ if (cupsServer()[0] == '/')
+ _cupsLangPuts(stdout, cupsServer());
+ else
+ _cupsLangPrintf(stdout, "%s:%d", cupsServer(), ippPort());
+ op = 'H';
+ break;
- case 'R' : /* Show ranking */
- ranking = 1;
- break;
+ case 'P' : /* Show paper types */
+ op = 'P';
+ break;
- case 'S' : /* Show charsets */
- op = 'S';
- if (!argv[i][2])
- i ++;
- break;
+ case 'R' : /* Show ranking */
+ ranking = 1;
+ break;
- case 'U' : /* Username */
- if (argv[i][2] != '\0')
- cupsSetUser(argv[i] + 2);
- else
- {
- i ++;
- if (i >= argc)
+ case 'S' : /* Show charsets */
+ op = 'S';
+ if (!argv[i][2])
+ i ++;
+ break;
+
+ case 'U' : /* Username */
+ if (opt[1] != '\0')
{
- _cupsLangPrintf(stderr,
- _("%s: Error - expected username after "
- "\'-U\' option!\n"),
- argv[0]);
- return (1);
+ cupsSetUser(opt + 1);
+ opt += strlen(opt) - 1;
}
-
- cupsSetUser(argv[i]);
- }
- break;
-
- case 'W' : /* Show which jobs? */
- if (argv[i][2])
- which = argv[i] + 2;
- else
- {
- i ++;
-
- if (i >= argc)
+ else
{
- _cupsLangPrintf(stderr,
- _("%s: Error - need \"completed\", "
- "\"not-completed\", or \"all\" after "
- "\'-W\' option!\n"),
- argv[0]);
- return (1);
- }
+ i ++;
+ if (i >= argc)
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - expected username after \"-U\" option."), argv[0]);
+ usage();
+ }
- which = argv[i];
- }
+ cupsSetUser(argv[i]);
+ }
+ break;
- if (strcmp(which, "completed") && strcmp(which, "not-completed") &&
- strcmp(which, "all"))
- {
- _cupsLangPrintf(stderr,
- _("%s: Error - need \"completed\", "
- "\"not-completed\", or \"all\" after "
- "\'-W\' option!\n"),
- argv[0]);
- return (1);
- }
- break;
+ case 'W' : /* Show which jobs? */
+ if (opt[1] != '\0')
+ {
+ which = opt + 1;
+ opt += strlen(opt) - 1;
+ }
+ else
+ {
+ i ++;
- case 'a' : /* Show acceptance status */
- op = 'a';
- http = connect_server(argv[0], http);
+ if (i >= argc)
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - need \"completed\", \"not-completed\", or \"all\" after \"-W\" option."), argv[0]);
+ usage();
+ }
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ which = argv[i];
+ }
- status |= show_accepting(http, argv[i] + 2, num_dests, dests);
- }
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
+ if (strcmp(which, "completed") && strcmp(which, "not-completed") && strcmp(which, "all"))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - need \"completed\", \"not-completed\", or \"all\" after \"-W\" option."), argv[0]);
+ usage();
+ }
+ break;
- check_dest(argv[0], http, argv[i], &num_dests, &dests);
+ case 'a' : /* Show acceptance status */
+ op = 'a';
- status |= show_accepting(http, argv[i], num_dests, dests);
- }
- else
- {
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
+ if (opt[1] != '\0')
+ {
+ check_dest(argv[0], opt + 1, &num_dests, &dests);
- status |= show_accepting(http, NULL, num_dests, dests);
- }
- break;
+ status |= show_accepting(opt + 1, num_dests, dests);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
-#ifdef __sgi
- case 'b' : /* Show both the local and remote status */
- op = 'b';
- http = connect_server(argv[0], http);
+ check_dest(argv[0], argv[i], &num_dests, &dests);
- if (argv[i][2] != '\0')
- {
- /*
- * The local and remote status are separated by a blank line;
- * since all CUPS jobs are networked, we only output the
- * second list for now... In the future, we might further
- * emulate this by listing the remote server's queue, but
- * for now this is enough to make the SGI printstatus program
- * happy...
- */
-
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
-
- puts("");
- status |= show_jobs(http, argv[i] + 2, NULL, 3, ranking, which);
- }
- else
- {
- _cupsLangPrintf(stderr,
- _("%s: Error - expected destination after "
- "\'-b\' option!\n"),
- argv[0]);
+ status |= show_accepting(argv[i], num_dests, dests);
+ }
+ else
+ {
+ if (num_dests <= 1)
+ {
+ cupsFreeDests(num_dests, dests);
+ num_dests = cupsGetDests(&dests);
- return (1);
- }
- break;
-#endif /* __sgi */
+ if (num_dests == 0 && (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST || cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
- case 'c' : /* Show classes and members */
- op = 'c';
- http = connect_server(argv[0], http);
+ status |= show_accepting(NULL, num_dests, dests);
+ }
+ break;
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ case 'c' : /* Show classes and members */
+ op = 'c';
- status |= show_classes(http, argv[i] + 2);
- }
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
+ if (opt[1] != '\0')
+ {
+ check_dest(argv[0], opt + 1, &num_dests, &dests);
- check_dest(argv[0], http, argv[i], &num_dests, &dests);
+ status |= show_classes(opt + 1);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
- status |= show_classes(http, argv[i]);
- }
- else
- status |= show_classes(http, NULL);
- break;
+ check_dest(argv[0], argv[i], &num_dests, &dests);
- case 'd' : /* Show default destination */
- op = 'd';
- http = connect_server(argv[0], http);
+ status |= show_classes(argv[i]);
+ }
+ else
+ status |= show_classes(NULL);
+ break;
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
+ case 'd' : /* Show default destination */
+ op = 'd';
- show_default(num_dests, dests);
- break;
+ if (num_dests != 1 || !dests[0].is_default)
+ {
+ cupsFreeDests(num_dests, dests);
- case 'f' : /* Show forms */
- op = 'f';
- if (!argv[i][2])
- i ++;
- break;
+ dests = cupsGetNamedDest(CUPS_HTTP_DEFAULT, NULL, NULL);
+ num_dests = dests ? 1 : 0;
- case 'h' : /* Connect to host */
- if (http)
- {
- httpClose(http);
- http = NULL;
- }
+ if (num_dests == 0 &&
+ (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
- if (argv[i][2] != '\0')
- cupsSetServer(argv[i] + 2);
- else
- {
- i ++;
+ show_default(dests);
+ break;
- if (i >= argc)
+ case 'e' : /* List destinations */
{
- _cupsLangPrintf(stderr,
- _("%s: Error - expected hostname after "
- "\'-h\' option!\n"),
- argv[0]);
- return (1);
+ cups_dest_t *temp = NULL, *dest;
+ int j, num_temp = cupsGetDests(&temp);
+
+ op = 'e';
+
+ for (j = num_temp, dest = temp; j > 0; j --, dest ++)
+ {
+ if (dest->instance)
+ printf("%s/%s", dest->name, dest->instance);
+ else
+ fputs(dest->name, stdout);
+
+ if (long_status)
+ {
+ const char *printer_uri_supported = cupsGetOption("printer-uri-supported", dest->num_options, dest->options);
+ const char *printer_is_temporary = cupsGetOption("printer-is-temporary", dest->num_options, dest->options);
+ const char *type = "network";
+
+ if (printer_is_temporary && !strcmp(printer_is_temporary, "true"))
+ type = "temporary";
+ else if (printer_uri_supported)
+ type = "permanent";
+
+ printf(" %s %s %s\n", type, printer_uri_supported ? printer_uri_supported : "none", cupsGetOption("device-uri", dest->num_options, dest->options));
+ }
+ else
+ putchar('\n');
+ }
+
+ cupsFreeDests(num_temp, temp);
}
+ break;
- cupsSetServer(argv[i]);
- }
- break;
+ case 'f' : /* Show forms */
+ op = 'f';
+ if (opt[1] != '\0')
+ {
+ opt += strlen(opt) - 1;
+ }
+ else
+ {
+ i ++;
+ if (i >= argc)
+ return (1);
+ }
+ break;
- case 'l' : /* Long status or long job status */
-#ifdef __sgi
- op = 'l';
- http = connect_server(argv[0], http);
+ case 'h' : /* Connect to host */
+ if (opt[1] != '\0')
+ {
+ cupsSetServer(opt + 1);
+ opt += strlen(opt) - 1;
+ }
+ else
+ {
+ i ++;
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ if (i >= argc)
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - expected hostname after \"-h\" option."), argv[0]);
+ return (1);
+ }
- status |= show_jobs(http, argv[i] + 2, NULL, 3, ranking, which);
- }
- else
-#endif /* __sgi */
+ cupsSetServer(argv[i]);
+ }
+ break;
+
+ case 'l' : /* Long status or long job status */
long_status = 2;
- break;
+ break;
- case 'o' : /* Show jobs by destination */
- op = 'o';
- http = connect_server(argv[0], http);
+ case 'o' : /* Show jobs by destination */
+ op = 'o';
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ if (opt[1])
+ {
+ check_dest(argv[0], opt + 1, &num_dests, &dests);
- status |= show_jobs(http, argv[i] + 2, NULL, long_status,
- ranking, which);
- }
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
+ status |= show_jobs(opt + 1, NULL, long_status, ranking, which);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
- check_dest(argv[0], http, argv[i], &num_dests, &dests);
+ check_dest(argv[0], argv[i], &num_dests, &dests);
- status |= show_jobs(http, argv[i], NULL, long_status,
- ranking, which);
- }
- else
- status |= show_jobs(http, NULL, NULL, long_status,
- ranking, which);
- break;
+ status |= show_jobs(argv[i], NULL, long_status, ranking, which);
+ }
+ else
+ status |= show_jobs(NULL, NULL, long_status, ranking, which);
+ break;
- case 'p' : /* Show printers */
- op = 'p';
- http = connect_server(argv[0], http);
+ case 'p' : /* Show printers */
+ op = 'p';
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ if (opt[1] != '\0')
+ {
+ check_dest(argv[0], opt + 1, &num_dests, &dests);
- status |= show_printers(http, argv[i] + 2, num_dests, dests, long_status);
- }
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
+ status |= show_printers(opt + 1, num_dests, dests,
+ long_status);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
- check_dest(argv[0], http, argv[i], &num_dests, &dests);
+ check_dest(argv[0], argv[i], &num_dests, &dests);
- status |= show_printers(http, argv[i], num_dests, dests, long_status);
- }
- else
- {
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
+ status |= show_printers(argv[i], num_dests, dests, long_status);
+ }
+ else
+ {
+ if (num_dests <= 1)
+ {
+ cupsFreeDests(num_dests, dests);
+ num_dests = cupsGetDests(&dests);
+
+ if (num_dests == 0 &&
+ (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
+
+ status |= show_printers(NULL, num_dests, dests, long_status);
+ }
+ break;
- status |= show_printers(http, NULL, num_dests, dests, long_status);
- }
- break;
-
- case 'r' : /* Show scheduler status */
- op = 'r';
- http = connect_server(argv[0], http);
-
- show_scheduler(http);
- break;
-
- case 's' : /* Show summary */
- op = 's';
- http = connect_server(argv[0], http);
-
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
-
- show_default(num_dests, dests);
- status |= show_classes(http, NULL);
- status |= show_devices(http, NULL, num_dests, dests);
- break;
-
- case 't' : /* Show all info */
- op = 't';
- http = connect_server(argv[0], http);
-
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
-
- show_scheduler(http);
- show_default(num_dests, dests);
- status |= show_classes(http, NULL);
- status |= show_devices(http, NULL, num_dests, dests);
- status |= show_accepting(http, NULL, num_dests, dests);
- status |= show_printers(http, NULL, num_dests, dests, long_status);
- status |= show_jobs(http, NULL, NULL, long_status, ranking, which);
- break;
-
- case 'u' : /* Show jobs by user */
- op = 'u';
- http = connect_server(argv[0], http);
-
- if (argv[i][2] != '\0')
- status |= show_jobs(http, NULL, argv[i] + 2, long_status,
- ranking, which);
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
- status |= show_jobs(http, NULL, argv[i], long_status,
- ranking, which);
- }
- else
- status |= show_jobs(http, NULL, NULL, long_status,
- ranking, which);
- break;
+ case 'r' : /* Show scheduler status */
+ op = 'r';
- case 'v' : /* Show printer devices */
- op = 'v';
- http = connect_server(argv[0], http);
+ show_scheduler();
+ break;
- if (argv[i][2] != '\0')
- {
- check_dest(argv[0], http, argv[i] + 2, &num_dests, &dests);
+ case 's' : /* Show summary */
+ op = 's';
- status |= show_devices(http, argv[i] + 2, num_dests, dests);
- }
- else if ((i + 1) < argc && argv[i + 1][0] != '-')
- {
- i ++;
+ if (num_dests <= 1)
+ {
+ cupsFreeDests(num_dests, dests);
+ num_dests = cupsGetDests(&dests);
- check_dest(argv[0], http, argv[i], &num_dests, &dests);
+ if (num_dests == 0 &&
+ (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
- status |= show_devices(http, argv[i], num_dests, dests);
- }
- else
- {
- if (num_dests == 0)
- num_dests = cupsGetDests2(http, &dests);
+ show_default(cupsGetDest(NULL, NULL, num_dests, dests));
+ status |= show_classes(NULL);
+ status |= show_devices(NULL, num_dests, dests);
+ break;
- status |= show_devices(http, NULL, num_dests, dests);
- }
- break;
+ case 't' : /* Show all info */
+ op = 't';
+
+ if (num_dests <= 1)
+ {
+ cupsFreeDests(num_dests, dests);
+ num_dests = cupsGetDests(&dests);
+
+ if (num_dests == 0 &&
+ (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
+
+ show_scheduler();
+ show_default(cupsGetDest(NULL, NULL, num_dests, dests));
+ status |= show_classes(NULL);
+ status |= show_devices(NULL, num_dests, dests);
+ status |= show_accepting(NULL, num_dests, dests);
+ status |= show_printers(NULL, num_dests, dests, long_status);
+ status |= show_jobs(NULL, NULL, long_status, ranking, which);
+ break;
+
+ case 'u' : /* Show jobs by user */
+ op = 'u';
+
+ if (opt[1] != '\0')
+ {
+ status |= show_jobs(NULL, opt + 1, long_status, ranking, which);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
+ status |= show_jobs(NULL, argv[i], long_status, ranking, which);
+ }
+ else
+ status |= show_jobs(NULL, NULL, long_status, ranking, which);
+ break;
+ case 'v' : /* Show printer devices */
+ op = 'v';
- default :
- _cupsLangPrintf(stderr,
- _("%s: Error - unknown option \'%c\'!\n"),
- argv[0], argv[i][1]);
- return (1);
+ if (opt[1] != '\0')
+ {
+ check_dest(argv[0], opt + 1, &num_dests, &dests);
+
+ status |= show_devices(opt + 1, num_dests, dests);
+ opt += strlen(opt) - 1;
+ }
+ else if ((i + 1) < argc && argv[i + 1][0] != '-')
+ {
+ i ++;
+
+ check_dest(argv[0], argv[i], &num_dests, &dests);
+
+ status |= show_devices(argv[i], num_dests, dests);
+ }
+ else
+ {
+ if (num_dests <= 1)
+ {
+ cupsFreeDests(num_dests, dests);
+ num_dests = cupsGetDests(&dests);
+
+ if (num_dests == 0 &&
+ (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED))
+ {
+ _cupsLangPrintf(stderr, _("%s: Error - add '/version=1.1' to server name."), argv[0]);
+ return (1);
+ }
+ }
+
+ status |= show_devices(NULL, num_dests, dests);
+ }
+ break;
+
+ default :
+ _cupsLangPrintf(stderr, _("%s: Error - unknown option \"%c\"."), argv[0], argv[i][1]);
+ usage();
+ }
}
+ }
else
{
- http = connect_server(argv[0], http);
-
- status |= show_jobs(http, argv[i], NULL, long_status, ranking, which);
+ status |= show_jobs(argv[i], NULL, long_status, ranking, which);
op = 'o';
}
+ }
if (!op)
- {
- http = connect_server(argv[0], http);
-
- status |= show_jobs(http, NULL, cupsUser(), long_status, ranking, which);
- }
+ status |= show_jobs(NULL, cupsUser(), long_status, ranking, which);
return (status);
}
static void
check_dest(const char *command, /* I - Command name */
- http_t *http, /* I - HTTP connection */
- const char *name, /* I - Name of printer/class(es) */
+ const char *name, /* I - List of printer/class names */
int *num_dests, /* IO - Number of destinations */
cups_dest_t **dests) /* IO - Destinations */
{
- const char *dptr;
- char *pptr,
- printer[128];
+ const char *dptr; /* Pointer into name */
+ char *pptr, /* Pointer into printer */
+ printer[1024]; /* Current printer/class name */
/*
* Load the destination list as necessary...
*/
- if (*num_dests == 0)
- *num_dests = cupsGetDests2(http, dests);
+ if (*num_dests <= 1)
+ {
+ if (*num_dests)
+ cupsFreeDests(*num_dests, *dests);
+
+ if (strchr(name, ','))
+ *num_dests = cupsGetDests(dests);
+ else
+ {
+ strlcpy(printer, name, sizeof(printer));
+ if ((pptr = strchr(printer, '/')) != NULL)
+ *pptr++ = '\0';
+
+ if ((*dests = cupsGetNamedDest(CUPS_HTTP_DEFAULT, printer, pptr)) == NULL)
+ {
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ command);
+ else
+ _cupsLangPrintf(stderr,
+ _("%s: Invalid destination name in list \"%s\"."),
+ command, name);
+
+ exit(1);
+ }
+ else
+ {
+ *num_dests = 1;
+ return;
+ }
+ }
+ }
/*
* Scan the name string for printer/class name(s)...
*/
- for (dptr = name; *dptr != '\0';)
+ for (dptr = name; *dptr;)
{
/*
* Skip leading whitespace and commas...
while (isspace(*dptr & 255) || *dptr == ',')
dptr ++;
- if (*dptr == '\0')
+ if (!*dptr)
break;
/*
* Extract a single destination name from the name string...
*/
- for (pptr = printer; !isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0';)
+ for (pptr = printer; !isspace(*dptr & 255) && *dptr != ',' && *dptr;)
{
- if ((pptr - printer) < (sizeof(printer) - 1))
+ if ((size_t)(pptr - printer) < (sizeof(printer) - 1))
*pptr++ = *dptr++;
else
{
_cupsLangPrintf(stderr,
- _("%s: Invalid destination name in list \"%s\"!\n"),
+ _("%s: Invalid destination name in list \"%s\"."),
command, name);
exit(1);
}
* Check the destination...
*/
- if (cupsGetDest(printer, NULL, *num_dests, *dests) == NULL)
+ if (!cupsGetDest(printer, NULL, *num_dests, *dests))
{
- _cupsLangPrintf(stderr,
- _("%s: Unknown destination \"%s\"!\n"), command, printer);
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ command);
+ else
+ _cupsLangPrintf(stderr,
+ _("%s: Unknown destination \"%s\"."), command, printer);
+
exit(1);
}
}
/*
- * 'connect_server()' - Connect to the server as necessary...
+ * 'match_list()' - Match a name from a list of comma or space-separated names.
*/
-static http_t * /* O - New HTTP connection */
-connect_server(const char *command, /* I - Command name */
- http_t *http) /* I - Current HTTP connection */
+static int /* O - 1 on match, 0 on no match */
+match_list(const char *list, /* I - List of names */
+ const char *name) /* I - Name to find */
{
- if (!http)
+ const char *nameptr; /* Pointer into name */
+
+
+ /*
+ * An empty list always matches...
+ */
+
+ if (!list || !*list)
+ return (1);
+
+ if (!name)
+ return (0);
+
+ while (*list)
{
- http = httpConnectEncrypt(cupsServer(), ippPort(),
- cupsEncryption());
+ /*
+ * Skip leading whitespace and commas...
+ */
- if (http == NULL)
- {
- _cupsLangPrintf(stderr, _("%s: Unable to connect to server\n"), command);
- exit(1);
- }
+ while (isspace(*list & 255) || *list == ',')
+ list ++;
+
+ if (!*list)
+ break;
+
+ /*
+ * Compare names...
+ */
+
+ for (nameptr = name;
+ *nameptr && *list && tolower(*nameptr & 255) == tolower(*list & 255);
+ nameptr ++, list ++);
+
+ if (!*nameptr && (!*list || *list == ',' || isspace(*list & 255)))
+ return (1);
+
+ while (*list && !isspace(*list & 255) && *list != ',')
+ list ++;
}
- return (http);
+ return (0);
}
*/
static int /* O - 0 on success, 1 on fail */
-show_accepting(http_t *http, /* I - HTTP connection to server */
- const char *printers, /* I - Destinations */
+show_accepting(const char *printers, /* I - Destinations */
int num_dests, /* I - Number of user-defined dests */
cups_dest_t *dests) /* I - User-defined destinations */
{
*message; /* Printer device URI */
int accepting; /* Accepting requests? */
time_t ptime; /* Printer state time */
- struct tm *pdate; /* Printer state date & time */
char printer_state_time[255];/* Printer state time */
- const char *dptr, /* Pointer into destination list */
- *ptr; /* Pointer into printer name */
- int match; /* Non-zero if this job matches */
static const char *pattrs[] = /* Attributes we need for printers... */
{
"printer-name",
};
- DEBUG_printf(("show_accepting(%p, %p)\n", http, printers));
-
- if (http == NULL)
- return (1);
-
if (printers != NULL && !strcmp(printers, "all"))
printers = NULL;
* Do the request and get back a response...
*/
- if ((response = cupsDoRequest(http, request, "/")) != NULL)
- {
- DEBUG_puts("show_accepting: request succeeded...");
+ response = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/");
- if (response->request.status.status_code > IPP_OK_CONFLICT)
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- ippDelete(response);
- return (1);
- }
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ {
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ "lpstat");
+ ippDelete(response);
+ return (1);
+ }
+ else if (cupsLastError() > IPP_STATUS_OK_CONFLICTING)
+ {
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
+ ippDelete(response);
+ return (1);
+ }
+ if (response)
+ {
/*
* Loop through the printers returned in the list and display
* their devices...
continue;
}
- /*
- * See if this is a printer we're interested in...
- */
-
- match = printers == NULL;
-
- if (printers != NULL)
- {
- for (dptr = printers; *dptr != '\0';)
- {
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = printer;
- *ptr != '\0' && *dptr != '\0' && tolower(*ptr & 255) == tolower(*dptr & 255);
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
- {
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
- }
- }
-
/*
* Display the printer entry if needed...
*/
- if (match)
+ if (match_list(printers, printer))
{
- pdate = localtime(&ptime);
- strftime(printer_state_time, sizeof(printer_state_time), "%c", pdate);
+ _cupsStrDate(printer_state_time, sizeof(printer_state_time), ptime);
if (accepting)
- _cupsLangPrintf(stdout, _("%s accepting requests since %s\n"),
+ _cupsLangPrintf(stdout, _("%s accepting requests since %s"),
printer, printer_state_time);
else
- _cupsLangPrintf(stdout, _("%s not accepting requests since %s -\n"
- "\t%s\n"),
- printer, printer_state_time,
- message == NULL ? "reason unknown" : message);
+ {
+ _cupsLangPrintf(stdout, _("%s not accepting requests since %s -"),
+ printer, printer_state_time);
+ _cupsLangPrintf(stdout, _("\t%s"),
+ (message == NULL || !*message) ?
+ "reason unknown" : message);
+ }
for (i = 0; i < num_dests; i ++)
- if (!strcasecmp(dests[i].name, printer) && dests[i].instance)
+ if (!_cups_strcasecmp(dests[i].name, printer) && dests[i].instance)
{
if (accepting)
- _cupsLangPrintf(stdout, _("%s/%s accepting requests since %s\n"),
+ _cupsLangPrintf(stdout, _("%s/%s accepting requests since %s"),
printer, dests[i].instance, printer_state_time);
else
- _cupsLangPrintf(stdout, _("%s/%s not accepting requests since "
- "%s -\n\t%s\n"),
- printer, dests[i].instance, printer_state_time,
- message == NULL ? "reason unknown" : message);
+ {
+ _cupsLangPrintf(stdout,
+ _("%s/%s not accepting requests since %s -"),
+ printer, dests[i].instance, printer_state_time);
+ _cupsLangPrintf(stdout, _("\t%s"),
+ (message == NULL || !*message) ?
+ "reason unknown" : message);
+ }
}
}
ippDelete(response);
}
- else
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- return (1);
- }
return (0);
}
*/
static int /* O - 0 on success, 1 on fail */
-show_classes(http_t *http, /* I - HTTP connection to server */
- const char *dests) /* I - Destinations */
+show_classes(const char *dests) /* I - Destinations */
{
int i; /* Looping var */
ipp_t *request, /* IPP Request */
server[HTTP_MAX_URI], /* Server name */
resource[HTTP_MAX_URI]; /* Resource name */
int port; /* Port number */
- const char *dptr, /* Pointer into destination list */
- *ptr; /* Pointer into printer name */
- int match; /* Non-zero if this job matches */
static const char *cattrs[] = /* Attributes we need for classes... */
{
"printer-name",
};
- DEBUG_printf(("show_classes(%p, %p)\n", http, dests));
-
- if (http == NULL)
- return (1);
-
if (dests != NULL && !strcmp(dests, "all"))
dests = NULL;
* Do the request and get back a response...
*/
- if ((response = cupsDoRequest(http, request, "/")) != NULL)
+ response = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/");
+
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ {
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ "lpstat");
+ ippDelete(response);
+ return (1);
+ }
+ else if (cupsLastError() > IPP_STATUS_OK_CONFLICTING)
{
- DEBUG_puts("show_classes: request succeeded...");
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
+ ippDelete(response);
+ return (1);
+ }
+ if (response)
+ {
if (response->request.status.status_code > IPP_OK_CONFLICT)
{
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
ippDelete(response);
return (1);
}
username, sizeof(username), server, sizeof(server),
&port, resource, sizeof(resource));
- if (!strcasecmp(server, http->hostname))
- http2 = http;
+ if (!_cups_strcasecmp(server, cupsServer()))
+ http2 = CUPS_HTTP_DEFAULT;
else
http2 = httpConnectEncrypt(server, port, cupsEncryption());
- if (http2 != NULL)
- {
- /*
- * Build an IPP_GET_PRINTER_ATTRIBUTES request, which requires the
- * following attributes:
- *
- * attributes-charset
- * attributes-natural-language
- * printer-uri
- * requested-attributes
- */
+ /*
+ * Build an IPP_GET_PRINTER_ATTRIBUTES request, which requires the
+ * following attributes:
+ *
+ * attributes-charset
+ * attributes-natural-language
+ * printer-uri
+ * requested-attributes
+ */
- request = ippNewRequest(IPP_GET_PRINTER_ATTRIBUTES);
+ request = ippNewRequest(IPP_GET_PRINTER_ATTRIBUTES);
- ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI,
- "printer-uri", NULL, printer_uri);
+ ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI,
+ "printer-uri", NULL, printer_uri);
- ippAddStrings(request, IPP_TAG_OPERATION, IPP_TAG_KEYWORD,
- "requested-attributes",
- sizeof(cattrs) / sizeof(cattrs[0]),
- NULL, cattrs);
+ ippAddStrings(request, IPP_TAG_OPERATION, IPP_TAG_KEYWORD,
+ "requested-attributes",
+ sizeof(cattrs) / sizeof(cattrs[0]),
+ NULL, cattrs);
- if ((response2 = cupsDoRequest(http2, request, "/")) != NULL)
- members = ippFindAttribute(response2, "member-names", IPP_TAG_NAME);
+ if ((response2 = cupsDoRequest(http2, request, "/")) != NULL)
+ members = ippFindAttribute(response2, "member-names", IPP_TAG_NAME);
- if (http2 != http)
- httpClose(http2);
- }
+ if (http2)
+ httpClose(http2);
}
/*
if (printer == NULL)
{
- if (response2)
- ippDelete(response2);
-
- if (attr == NULL)
- break;
- else
- continue;
- }
-
- /*
- * See if this is a printer we're interested in...
- */
-
- match = dests == NULL;
-
- if (dests != NULL)
- {
- for (dptr = dests; *dptr != '\0';)
- {
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = printer;
- *ptr != '\0' && *dptr != '\0' && tolower(*ptr & 255) == tolower(*dptr & 255);
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
- {
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
+ if (response2)
+ ippDelete(response2);
- if (*dptr == '\0')
- break;
- }
+ if (attr == NULL)
+ break;
+ else
+ continue;
}
/*
* Display the printer entry if needed...
*/
- if (match)
+ if (match_list(dests, printer))
{
- _cupsLangPrintf(stdout, _("members of class %s:\n"), printer);
+ _cupsLangPrintf(stdout, _("members of class %s:"), printer);
if (members)
{
for (i = 0; i < members->num_values; i ++)
- _cupsLangPrintf(stdout, "\t%s\n",
- members->values[i].string.text);
+ _cupsLangPrintf(stdout, "\t%s", members->values[i].string.text);
}
else
- _cupsLangPuts(stdout, "\tunknown\n");
+ _cupsLangPuts(stdout, "\tunknown");
}
if (response2)
ippDelete(response);
}
- else
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- return (1);
- }
return (0);
}
*/
static void
-show_default(int num_dests, /* I - Number of user-defined dests */
- cups_dest_t *dests) /* I - User-defined destinations */
+show_default(cups_dest_t *dest) /* I - Default destination */
{
- cups_dest_t *dest; /* Destination */
const char *printer, /* Printer name */
*val; /* Environment variable name */
- if ((dest = cupsGetDest(NULL, NULL, num_dests, dests)) != NULL)
+
+ if (dest)
{
if (dest->instance)
- _cupsLangPrintf(stdout, _("system default destination: %s/%s\n"),
+ _cupsLangPrintf(stdout, _("system default destination: %s/%s"),
dest->name, dest->instance);
else
- _cupsLangPrintf(stdout, _("system default destination: %s\n"),
+ _cupsLangPrintf(stdout, _("system default destination: %s"),
dest->name);
}
else
else
val = "LPDEST";
- if (printer && !cupsGetDest(printer, NULL, num_dests, dests))
+ if (printer)
_cupsLangPrintf(stdout,
_("lpstat: error - %s environment variable names "
- "non-existent destination \"%s\"!\n"),
+ "non-existent destination \"%s\"."),
val, printer);
else
- _cupsLangPuts(stdout, _("no system default destination\n"));
+ _cupsLangPuts(stdout, _("no system default destination"));
}
}
*/
static int /* O - 0 on success, 1 on fail */
-show_devices(http_t *http, /* I - HTTP connection to server */
- const char *printers, /* I - Destinations */
+show_devices(const char *printers, /* I - Destinations */
int num_dests, /* I - Number of user-defined dests */
cups_dest_t *dests) /* I - User-defined destinations */
{
ipp_attribute_t *attr; /* Current attribute */
const char *printer, /* Printer name */
*uri, /* Printer URI */
- *device, /* Printer device URI */
- *dptr, /* Pointer into destination list */
- *ptr; /* Pointer into printer name */
- int match; /* Non-zero if this job matches */
+ *device; /* Printer device URI */
static const char *pattrs[] = /* Attributes we need for printers... */
{
"printer-name",
};
- DEBUG_printf(("show_devices(%p, %p)\n", http, dests));
-
- if (http == NULL)
- return (1);
-
if (printers != NULL && !strcmp(printers, "all"))
printers = NULL;
* Do the request and get back a response...
*/
- if ((response = cupsDoRequest(http, request, "/")) != NULL)
- {
- DEBUG_puts("show_devices: request succeeded...");
+ response = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/");
- if (response->request.status.status_code > IPP_OK_CONFLICT)
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- ippDelete(response);
- return (1);
- }
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ {
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ "lpstat");
+ ippDelete(response);
+ return (1);
+ }
+ else if (cupsLastError() > IPP_STATUS_OK_CONFLICTING)
+ {
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
+ ippDelete(response);
+ return (1);
+ }
+ if (response)
+ {
/*
* Loop through the printers returned in the list and display
* their devices...
continue;
}
- /*
- * See if this is a printer we're interested in...
- */
-
- match = printers == NULL;
-
- if (printers != NULL)
- {
- for (dptr = printers; *dptr != '\0';)
- {
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = printer;
- *ptr != '\0' && *dptr != '\0' && tolower(*ptr & 255) == tolower(*dptr & 255);
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
- {
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
- }
- }
-
/*
* Display the printer entry if needed...
*/
- if (match)
+ if (match_list(printers, printer))
{
-#ifdef __osf__ /* Compaq/Digital like to do it their own way... */
- char method[HTTP_MAX_URI], /* Components of printer URI */
- username[HTTP_MAX_URI],
- hostname[HTTP_MAX_URI],
- resource[HTTP_MAX_URI];
- int port;
-
-
- if (device == NULL)
- {
- httpSeparateURI(HTTP_URI_CODING_ALL, uri, method, sizeof(method),
- username, sizeof(username), hostname,
- sizeof(hostname), &port, resource, sizeof(resource));
- _cupsLangPrintf(stdout,
- _("Output for printer %s is sent to remote "
- "printer %s on %s\n"),
- printer, strrchr(resource, '/') + 1, hostname);
- }
- else if (!strncmp(device, "file:", 5))
- _cupsLangPrintf(stdout,
- _("Output for printer %s is sent to %s\n"),
- printer, device + 5);
- else
- _cupsLangPrintf(stdout,
- _("Output for printer %s is sent to %s\n"),
- printer, device);
-
- for (i = 0; i < num_dests; i ++)
- if (!strcasecmp(printer, dests[i].name) && dests[i].instance)
- {
- if (device == NULL)
- _cupsLangPrintf(stdout,
- _("Output for printer %s/%s is sent to "
- "remote printer %s on %s\n"),
- printer, dests[i].instance,
- strrchr(resource, '/') + 1, hostname);
- else if (!strncmp(device, "file:", 5))
- _cupsLangPrintf(stdout,
- _("Output for printer %s/%s is sent to %s\n"),
- printer, dests[i].instance, device + 5);
- else
- _cupsLangPrintf(stdout,
- _("Output for printer %s/%s is sent to %s\n"),
- printer, dests[i].instance, device);
- }
-#else
if (device == NULL)
- _cupsLangPrintf(stdout, _("device for %s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s: %s"),
printer, uri);
else if (!strncmp(device, "file:", 5))
- _cupsLangPrintf(stdout, _("device for %s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s: %s"),
printer, device + 5);
else
- _cupsLangPrintf(stdout, _("device for %s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s: %s"),
printer, device);
for (i = 0; i < num_dests; i ++)
- if (!strcasecmp(printer, dests[i].name) && dests[i].instance)
+ {
+ if (!_cups_strcasecmp(printer, dests[i].name) && dests[i].instance)
{
if (device == NULL)
- _cupsLangPrintf(stdout, _("device for %s/%s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s/%s: %s"),
printer, dests[i].instance, uri);
else if (!strncmp(device, "file:", 5))
- _cupsLangPrintf(stdout, _("device for %s/%s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s/%s: %s"),
printer, dests[i].instance, device + 5);
else
- _cupsLangPrintf(stdout, _("device for %s/%s: %s\n"),
+ _cupsLangPrintf(stdout, _("device for %s/%s: %s"),
printer, dests[i].instance, device);
}
-#endif /* __osf__ */
+ }
}
if (attr == NULL)
ippDelete(response);
}
- else
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- return (1);
- }
return (0);
}
*/
static int /* O - 0 on success, 1 on fail */
-show_jobs(http_t *http, /* I - HTTP connection to server */
- const char *dests, /* I - Destinations */
+show_jobs(const char *dests, /* I - Destinations */
const char *users, /* I - Users */
int long_status, /* I - Show long status? */
int ranking, /* I - Show job ranking? */
const char *which) /* I - Show which jobs? */
{
+ int i; /* Looping var */
ipp_t *request, /* IPP Request */
*response; /* IPP Response */
- ipp_attribute_t *attr; /* Current attribute */
+ ipp_attribute_t *attr, /* Current attribute */
+ *reasons; /* Job state reasons attribute */
const char *dest, /* Pointer into job-printer-uri */
*username, /* Pointer to job-originating-user-name */
- *title; /* Pointer to job-name */
+ *message, /* Pointer to job-printer-state-message */
+ *time_at; /* time-at-xxx attribute name to use */
int rank, /* Rank in queue */
jobid, /* job-id */
size; /* job-k-octets */
time_t jobtime; /* time-at-creation */
- struct tm *jobdate; /* Date & time */
- const char *dptr, /* Pointer into destination list */
- *ptr; /* Pointer into printer name */
- int match; /* Non-zero if this job matches */
char temp[255], /* Temporary buffer */
date[255]; /* Date buffer */
static const char *jattrs[] = /* Attributes we need for jobs... */
"job-id",
"job-k-octets",
"job-name",
- "time-at-creation",
+ "job-originating-user-name",
+ "job-printer-state-message",
"job-printer-uri",
- "job-originating-user-name"
+ "job-state-reasons",
+ "time-at-creation",
+ "time-at-completed"
};
- DEBUG_printf(("show_jobs(%p, %p, %p)\n", http, dests, users));
-
- if (http == NULL)
- return (1);
-
if (dests != NULL && !strcmp(dests, "all"))
dests = NULL;
*
* attributes-charset
* attributes-natural-language
- * job-uri
+ * printer-uri
* requested-attributes
+ * requesting-user-name
+ * which-jobs
*/
request = ippNewRequest(IPP_GET_JOBS);
+ ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI, "printer-uri",
+ NULL, "ipp://localhost/");
+
ippAddStrings(request, IPP_TAG_OPERATION, IPP_TAG_KEYWORD,
"requested-attributes", sizeof(jattrs) / sizeof(jattrs[0]),
NULL, jattrs);
- ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI, "job-uri",
- NULL, "ipp://localhost/jobs/");
+ ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_NAME, "requesting-user-name",
+ NULL, cupsUser());
ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_KEYWORD, "which-jobs",
NULL, which);
* Do the request and get back a response...
*/
- if ((response = cupsDoRequest(http, request, "/")) != NULL)
+ response = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/");
+
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ {
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ "lpstat");
+ ippDelete(response);
+ return (1);
+ }
+ else if (cupsLastError() > IPP_STATUS_OK_CONFLICTING)
+ {
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
+ ippDelete(response);
+ return (1);
+ }
+
+ if (response)
{
/*
* Loop through the job list and display them...
*/
- if (response->request.status.status_code > IPP_OK_CONFLICT)
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- ippDelete(response);
- return (1);
- }
+ if (!strcmp(which, "aborted") ||
+ !strcmp(which, "canceled") ||
+ !strcmp(which, "completed"))
+ time_at = "time-at-completed";
+ else
+ time_at = "time-at-creation";
rank = -1;
username = NULL;
dest = NULL;
jobtime = 0;
- title = "no title";
+ message = NULL;
+ reasons = NULL;
while (attr != NULL && attr->group_tag == IPP_TAG_JOB)
{
if (!strcmp(attr->name, "job-id") &&
attr->value_tag == IPP_TAG_INTEGER)
jobid = attr->values[0].integer;
-
- if (!strcmp(attr->name, "job-k-octets") &&
- attr->value_tag == IPP_TAG_INTEGER)
+ else if (!strcmp(attr->name, "job-k-octets") &&
+ attr->value_tag == IPP_TAG_INTEGER)
size = attr->values[0].integer;
-
- if (!strcmp(attr->name, "time-at-creation") &&
- attr->value_tag == IPP_TAG_INTEGER)
+ else if (!strcmp(attr->name, time_at) && attr->value_tag == IPP_TAG_INTEGER)
jobtime = attr->values[0].integer;
-
- if (!strcmp(attr->name, "job-printer-uri") &&
- attr->value_tag == IPP_TAG_URI)
+ else if (!strcmp(attr->name, "job-printer-state-message") &&
+ attr->value_tag == IPP_TAG_TEXT)
+ message = attr->values[0].string.text;
+ else if (!strcmp(attr->name, "job-printer-uri") &&
+ attr->value_tag == IPP_TAG_URI)
+ {
if ((dest = strrchr(attr->values[0].string.text, '/')) != NULL)
dest ++;
-
- if (!strcmp(attr->name, "job-originating-user-name") &&
- attr->value_tag == IPP_TAG_NAME)
+ }
+ else if (!strcmp(attr->name, "job-originating-user-name") &&
+ attr->value_tag == IPP_TAG_NAME)
username = attr->values[0].string.text;
-
- if (!strcmp(attr->name, "job-name") &&
- attr->value_tag == IPP_TAG_NAME)
- title = attr->values[0].string.text;
+ else if (!strcmp(attr->name, "job-state-reasons") &&
+ attr->value_tag == IPP_TAG_KEYWORD)
+ reasons = attr;
attr = attr->next;
}
}
/*
- * See if this is a job we're interested in...
+ * Display the job...
*/
- match = (dests == NULL && users == NULL);
rank ++;
- if (dests != NULL)
+ if (match_list(dests, dest) && match_list(users, username))
{
- for (dptr = dests; *dptr != '\0';)
- {
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = dest;
- *ptr != '\0' && *dptr != '\0' && tolower(*ptr & 255) == tolower(*dptr & 255);
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
- {
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
+ snprintf(temp, sizeof(temp), "%s-%d", dest, jobid);
- if (*dptr == '\0')
- break;
- }
- }
+ _cupsStrDate(date, sizeof(date), jobtime);
- if (users != NULL && username != NULL)
- {
- for (dptr = users; *dptr != '\0';)
+ if (ranking)
+ _cupsLangPrintf(stdout, "%3d %-21s %-13s %8.0f %s",
+ rank, temp, username ? username : "unknown",
+ 1024.0 * size, date);
+ else
+ _cupsLangPrintf(stdout, "%-23s %-13s %8.0f %s",
+ temp, username ? username : "unknown",
+ 1024.0 * size, date);
+ if (long_status)
{
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
+ if (message)
+ _cupsLangPrintf(stdout, _("\tStatus: %s"), message);
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = username;
- *ptr != '\0' && *dptr != '\0' && *ptr == *dptr;
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
+ if (reasons)
{
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
- }
- }
-
- /*
- * Display the job...
- */
+ char alerts[1024], /* Alerts string */
+ *aptr; /* Pointer into alerts string */
- if (match)
- {
- jobdate = localtime(&jobtime);
- snprintf(temp, sizeof(temp), "%s-%d", dest, jobid);
+ for (i = 0, aptr = alerts; i < reasons->num_values; i ++)
+ {
+ if (i)
+ snprintf(aptr, sizeof(alerts) - (size_t)(aptr - alerts), " %s", reasons->values[i].string.text);
+ else
+ strlcpy(alerts, reasons->values[i].string.text, sizeof(alerts));
- if (long_status == 3)
- {
- /*
- * Show the consolidated output format for the SGI tools...
- */
+ aptr += strlen(aptr);
+ }
- if (!strftime(date, sizeof(date), "%b %d %H:%M", jobdate))
- strcpy(date, "Unknown");
+ _cupsLangPrintf(stdout, _("\tAlerts: %s"), alerts);
+ }
- _cupsLangPrintf(stdout, "%s;%s;%d;%s;%s\n",
- temp, username ? username : "unknown",
- size, title ? title : "unknown", date);
- }
- else
- {
- if (!strftime(date, sizeof(date), "%c", jobdate))
- strcpy(date, "Unknown");
-
- if (ranking)
- _cupsLangPrintf(stdout, "%3d %-21s %-13s %8.0f %s\n",
- rank, temp, username ? username : "unknown",
- 1024.0 * size, date);
- else
- _cupsLangPrintf(stdout, "%-23s %-13s %8.0f %s\n",
- temp, username ? username : "unknown",
- 1024.0 * size, date);
- if (long_status)
- _cupsLangPrintf(stdout, _("\tqueued for %s\n"), dest);
+ _cupsLangPrintf(stdout, _("\tqueued for %s"), dest);
}
}
ippDelete(response);
}
- else
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- return (1);
- }
return (0);
}
*/
static int /* O - 0 on success, 1 on fail */
-show_printers(http_t *http, /* I - HTTP connection to server */
- const char *printers, /* I - Destinations */
+show_printers(const char *printers, /* I - Destinations */
int num_dests, /* I - Number of user-defined dests */
cups_dest_t *dests, /* I - User-defined destinations */
int long_status) /* I - Show long status? */
{
- int i; /* Looping var */
+ int i, j; /* Looping vars */
ipp_t *request, /* IPP Request */
*response, /* IPP Response */
*jobs; /* IPP Get Jobs response */
ipp_pstate_t pstate; /* Printer state */
cups_ptype_t ptype; /* Printer type */
time_t ptime; /* Printer state time */
- struct tm *pdate; /* Printer state date & time */
int jobid; /* Job ID of current job */
- const char *dptr, /* Pointer into destination list */
- *ptr; /* Pointer into printer name */
- int match; /* Non-zero if this job matches */
char printer_uri[HTTP_MAX_URI],
/* Printer URI */
printer_state_time[255];/* Printer state time */
- const char *root; /* Server root directory... */
+ _cups_globals_t *cg = _cupsGlobals(); /* Global data */
static const char *pattrs[] = /* Attributes we need for printers... */
{
"printer-name",
};
static const char *jattrs[] = /* Attributes we need for jobs... */
{
- "job-id"
+ "job-id",
+ "job-state"
};
- DEBUG_printf(("show_printers(%p, %p)\n", http, dests));
-
- if (http == NULL)
- return (1);
-
- if ((root = getenv("CUPS_SERVERROOT")) == NULL)
- root = CUPS_SERVERROOT;
-
if (printers != NULL && !strcmp(printers, "all"))
printers = NULL;
* Do the request and get back a response...
*/
- if ((response = cupsDoRequest(http, request, "/")) != NULL)
- {
- DEBUG_puts("show_printers: request succeeded...");
+ response = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/");
- if (response->request.status.status_code > IPP_OK_CONFLICT)
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- ippDelete(response);
- return (1);
- }
+ if (cupsLastError() == IPP_STATUS_ERROR_BAD_REQUEST ||
+ cupsLastError() == IPP_STATUS_ERROR_VERSION_NOT_SUPPORTED)
+ {
+ _cupsLangPrintf(stderr,
+ _("%s: Error - add '/version=1.1' to server name."),
+ "lpstat");
+ ippDelete(response);
+ return (1);
+ }
+ else if (cupsLastError() > IPP_STATUS_OK_CONFLICTING)
+ {
+ _cupsLangPrintf(stderr, "lpstat: %s", cupsLastErrorString());
+ ippDelete(response);
+ return (1);
+ }
+ if (response)
+ {
/*
* Loop through the printers returned in the list and display
* their status...
continue;
}
- /*
- * See if this is a printer we're interested in...
- */
-
- match = printers == NULL;
-
- if (printers != NULL)
- {
- for (dptr = printers; *dptr != '\0';)
- {
- /*
- * Skip leading whitespace and commas...
- */
-
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
-
- /*
- * Compare names...
- */
-
- for (ptr = printer;
- *ptr != '\0' && *dptr != '\0' && tolower(*ptr & 255) == tolower(*dptr & 255);
- ptr ++, dptr ++);
-
- if (*ptr == '\0' && (*dptr == '\0' || *dptr == ',' || isspace(*dptr & 255)))
- {
- match = 1;
- break;
- }
-
- /*
- * Skip trailing junk...
- */
-
- while (!isspace(*dptr & 255) && *dptr != ',' && *dptr != '\0')
- dptr ++;
- while (isspace(*dptr & 255) || *dptr == ',')
- dptr ++;
-
- if (*dptr == '\0')
- break;
- }
- }
-
/*
* Display the printer entry if needed...
*/
- if (match)
+ if (match_list(printers, printer))
{
/*
* If the printer state is "IPP_PRINTER_PROCESSING", then grab the
ippAddString(request, IPP_TAG_OPERATION, IPP_TAG_URI,
"printer-uri", NULL, printer_uri);
- if ((jobs = cupsDoRequest(http, request, "/")) != NULL)
+ if ((jobs = cupsDoRequest(CUPS_HTTP_DEFAULT, request, "/")) != NULL)
{
/*
* Get the current active job on this queue...
*/
+ ipp_jstate_t jobstate = IPP_JOB_PENDING;
jobid = 0;
for (jobattr = jobs->attrs; jobattr; jobattr = jobattr->next)
{
if (!jobattr->name)
- continue;
+ {
+ if (jobstate == IPP_JOB_PROCESSING)
+ break;
+ else
+ continue;
+ }
if (!strcmp(jobattr->name, "job-id") &&
jobattr->value_tag == IPP_TAG_INTEGER)
jobid = jobattr->values[0].integer;
else if (!strcmp(jobattr->name, "job-state") &&
- jobattr->value_tag == IPP_TAG_ENUM &&
- jobattr->values[0].integer == IPP_JOB_PROCESSING)
- break;
+ jobattr->value_tag == IPP_TAG_ENUM)
+ jobstate = (ipp_jstate_t)jobattr->values[0].integer;
}
+ if (jobstate != IPP_JOB_PROCESSING)
+ jobid = 0;
+
ippDelete(jobs);
}
}
* Display it...
*/
- pdate = localtime(&ptime);
- strftime(printer_state_time, sizeof(printer_state_time), "%c", pdate);
+ _cupsStrDate(printer_state_time, sizeof(printer_state_time), ptime);
switch (pstate)
{
case IPP_PRINTER_IDLE :
- _cupsLangPrintf(stdout,
- _("printer %s is idle. enabled since %s\n"),
- printer, printer_state_time);
+ if (ippContainsString(reasons, "hold-new-jobs"))
+ _cupsLangPrintf(stdout, _("printer %s is holding new jobs. enabled since %s"), printer, printer_state_time);
+ else
+ _cupsLangPrintf(stdout, _("printer %s is idle. enabled since %s"), printer, printer_state_time);
break;
case IPP_PRINTER_PROCESSING :
- _cupsLangPrintf(stdout,
- _("printer %s now printing %s-%d. "
- "enabled since %s\n"),
- printer, printer, jobid, printer_state_time);
+ _cupsLangPrintf(stdout, _("printer %s now printing %s-%d. enabled since %s"), printer, printer, jobid, printer_state_time);
break;
case IPP_PRINTER_STOPPED :
- _cupsLangPrintf(stdout,
- _("printer %s disabled since %s -\n"),
- printer, printer_state_time);
+ _cupsLangPrintf(stdout, _("printer %s disabled since %s -"), printer, printer_state_time);
break;
}
if ((message && *message) || pstate == IPP_PRINTER_STOPPED)
{
if (!message || !*message)
- _cupsLangPuts(stdout, _("\treason unknown\n"));
+ _cupsLangPuts(stdout, _("\treason unknown"));
else
- _cupsLangPrintf(stdout, "\t%s\n", message);
+ _cupsLangPrintf(stdout, "\t%s", message);
}
if (long_status > 1)
- _cupsLangPuts(stdout,
- _("\tForm mounted:\n"
- "\tContent types: any\n"
- "\tPrinter types: unknown\n"));
+ {
+ _cupsLangPuts(stdout, _("\tForm mounted:"));
+ _cupsLangPuts(stdout, _("\tContent types: any"));
+ _cupsLangPuts(stdout, _("\tPrinter types: unknown"));
+ }
if (long_status)
{
- _cupsLangPrintf(stdout, _("\tDescription: %s\n"),
+ _cupsLangPrintf(stdout, _("\tDescription: %s"),
description ? description : "");
if (reasons)
{
- _cupsLangPuts(stdout, _("\tAlerts:"));
- for (i = 0; i < reasons->num_values; i ++)
- _cupsLangPrintf(stdout, " %s",
- reasons->values[i].string.text);
- _cupsLangPuts(stdout, "\n");
+ char alerts[1024], /* Alerts string */
+ *aptr; /* Pointer into alerts string */
+
+ for (i = 0, aptr = alerts; i < reasons->num_values; i ++)
+ {
+ if (i)
+ snprintf(aptr, sizeof(alerts) - (size_t)(aptr - alerts), " %s", reasons->values[i].string.text);
+ else
+ strlcpy(alerts, reasons->values[i].string.text, sizeof(alerts));
+
+ aptr += strlen(aptr);
+ }
+
+ _cupsLangPrintf(stdout, _("\tAlerts: %s"), alerts);
}
}
if (long_status > 1)
{
- _cupsLangPrintf(stdout, _("\tLocation: %s\n"),
+ _cupsLangPrintf(stdout, _("\tLocation: %s"),
location ? location : "");
if (ptype & CUPS_PRINTER_REMOTE)
{
- _cupsLangPuts(stdout, _("\tConnection: remote\n"));
+ _cupsLangPuts(stdout, _("\tConnection: remote"));
if (make_model && !strstr(make_model, "System V Printer") &&
!strstr(make_model, "Raw Printer") && uri)
- _cupsLangPrintf(stdout, _("\tInterface: %s.ppd\n"),
+ _cupsLangPrintf(stdout, _("\tInterface: %s.ppd"),
uri);
}
else
{
- _cupsLangPuts(stdout, _("\tConnection: direct\n"));
+ _cupsLangPuts(stdout, _("\tConnection: direct"));
- if (make_model && strstr(make_model, "System V Printer"))
+ if (make_model && !strstr(make_model, "Raw Printer"))
_cupsLangPrintf(stdout,
- _("\tInterface: %s/interfaces/%s\n"),
- root, printer);
- else if (make_model && !strstr(make_model, "Raw Printer"))
- _cupsLangPrintf(stdout,
- _("\tInterface: %s/ppd/%s.ppd\n"), root, printer);
+ _("\tInterface: %s/ppd/%s.ppd"),
+ cg->cups_serverroot, printer);
}
- _cupsLangPuts(stdout, _("\tOn fault: no alert\n"));
- _cupsLangPuts(stdout, _("\tAfter fault: continue\n"));
+ _cupsLangPuts(stdout, _("\tOn fault: no alert"));
+ _cupsLangPuts(stdout, _("\tAfter fault: continue"));
/* TODO update to use printer-error-policy */
if (allowed)
{
- _cupsLangPuts(stdout, _("\tUsers allowed:\n"));
- for (i = 0; i < allowed->num_values; i ++)
- _cupsLangPrintf(stdout, "\t\t%s\n",
- allowed->values[i].string.text);
+ _cupsLangPuts(stdout, _("\tUsers allowed:"));
+ for (j = 0; j < allowed->num_values; j ++)
+ _cupsLangPrintf(stdout, "\t\t%s",
+ allowed->values[j].string.text);
}
else if (denied)
{
- _cupsLangPuts(stdout, _("\tUsers denied:\n"));
- for (i = 0; i < denied->num_values; i ++)
- _cupsLangPrintf(stdout, "\t\t%s\n",
- denied->values[i].string.text);
+ _cupsLangPuts(stdout, _("\tUsers denied:"));
+ for (j = 0; j < denied->num_values; j ++)
+ _cupsLangPrintf(stdout, "\t\t%s",
+ denied->values[j].string.text);
}
else
{
- _cupsLangPuts(stdout, _("\tUsers allowed:\n"));
- _cupsLangPuts(stdout, _("\t\t(all)\n"));
+ _cupsLangPuts(stdout, _("\tUsers allowed:"));
+ _cupsLangPuts(stdout, _("\t\t(all)"));
}
- _cupsLangPuts(stdout, _("\tForms allowed:\n"));
- _cupsLangPuts(stdout, _("\t\t(none)\n"));
- _cupsLangPuts(stdout, _("\tBanner required\n"));
- _cupsLangPuts(stdout, _("\tCharset sets:\n"));
- _cupsLangPuts(stdout, _("\t\t(none)\n"));
- _cupsLangPuts(stdout, _("\tDefault pitch:\n"));
- _cupsLangPuts(stdout, _("\tDefault page size:\n"));
- _cupsLangPuts(stdout, _("\tDefault port settings:\n"));
+ _cupsLangPuts(stdout, _("\tForms allowed:"));
+ _cupsLangPuts(stdout, _("\t\t(none)"));
+ _cupsLangPuts(stdout, _("\tBanner required"));
+ _cupsLangPuts(stdout, _("\tCharset sets:"));
+ _cupsLangPuts(stdout, _("\t\t(none)"));
+ _cupsLangPuts(stdout, _("\tDefault pitch:"));
+ _cupsLangPuts(stdout, _("\tDefault page size:"));
+ _cupsLangPuts(stdout, _("\tDefault port settings:"));
}
for (i = 0; i < num_dests; i ++)
- if (!strcasecmp(printer, dests[i].name) && dests[i].instance)
+ if (!_cups_strcasecmp(printer, dests[i].name) && dests[i].instance)
{
switch (pstate)
{
case IPP_PRINTER_IDLE :
_cupsLangPrintf(stdout,
_("printer %s/%s is idle. "
- "enabled since %s\n"),
+ "enabled since %s"),
printer, dests[i].instance,
printer_state_time);
break;
case IPP_PRINTER_PROCESSING :
_cupsLangPrintf(stdout,
_("printer %s/%s now printing %s-%d. "
- "enabled since %s\n"),
+ "enabled since %s"),
printer, dests[i].instance, printer, jobid,
printer_state_time);
break;
case IPP_PRINTER_STOPPED :
_cupsLangPrintf(stdout,
- _("printer %s/%s disabled since %s -\n"),
+ _("printer %s/%s disabled since %s -"),
printer, dests[i].instance,
printer_state_time);
break;
if ((message && *message) || pstate == IPP_PRINTER_STOPPED)
{
if (!message || !*message)
- _cupsLangPuts(stdout, _("\treason unknown\n"));
+ _cupsLangPuts(stdout, _("\treason unknown"));
else
- _cupsLangPrintf(stdout, "\t%s\n", message);
+ _cupsLangPrintf(stdout, "\t%s", message);
}
if (long_status > 1)
- _cupsLangPuts(stdout,
- _("\tForm mounted:\n"
- "\tContent types: any\n"
- "\tPrinter types: unknown\n"));
+ {
+ _cupsLangPuts(stdout, _("\tForm mounted:"));
+ _cupsLangPuts(stdout, _("\tContent types: any"));
+ _cupsLangPuts(stdout, _("\tPrinter types: unknown"));
+ }
if (long_status)
{
- _cupsLangPrintf(stdout, _("\tDescription: %s\n"),
+ _cupsLangPrintf(stdout, _("\tDescription: %s"),
description ? description : "");
if (reasons)
{
- _cupsLangPuts(stdout, _("\tAlerts:"));
- for (i = 0; i < reasons->num_values; i ++)
- _cupsLangPrintf(stdout, " %s",
- reasons->values[i].string.text);
- _cupsLangPuts(stdout, "\n");
+ char alerts[1024], /* Alerts string */
+ *aptr; /* Pointer into alerts string */
+
+ for (i = 0, aptr = alerts; i < reasons->num_values; i ++)
+ {
+ if (i)
+ snprintf(aptr, sizeof(alerts) - (size_t)(aptr - alerts), " %s", reasons->values[i].string.text);
+ else
+ strlcpy(alerts, reasons->values[i].string.text, sizeof(alerts));
+
+ aptr += strlen(aptr);
+ }
+
+ _cupsLangPrintf(stdout, _("\tAlerts: %s"), alerts);
}
}
if (long_status > 1)
{
- _cupsLangPrintf(stdout, _("\tLocation: %s\n"),
+ _cupsLangPrintf(stdout, _("\tLocation: %s"),
location ? location : "");
if (ptype & CUPS_PRINTER_REMOTE)
{
- _cupsLangPuts(stdout, _("\tConnection: remote\n"));
+ _cupsLangPuts(stdout, _("\tConnection: remote"));
if (make_model && !strstr(make_model, "System V Printer") &&
!strstr(make_model, "Raw Printer") && uri)
- _cupsLangPrintf(stdout, _("\tInterface: %s.ppd\n"),
- uri);
+ _cupsLangPrintf(stdout, _("\tInterface: %s.ppd"), uri);
}
else
{
- _cupsLangPuts(stdout, _("\tConnection: direct\n"));
+ _cupsLangPuts(stdout, _("\tConnection: direct"));
- if (make_model && strstr(make_model, "System V Printer"))
- _cupsLangPrintf(stdout,
- _("\tInterface: %s/interfaces/%s\n"),
- root, printer);
- else if (make_model && !strstr(make_model, "Raw Printer"))
+ if (make_model && !strstr(make_model, "Raw Printer"))
_cupsLangPrintf(stdout,
- _("\tInterface: %s/ppd/%s.ppd\n"), root, printer);
+ _("\tInterface: %s/ppd/%s.ppd"),
+ cg->cups_serverroot, printer);
}
- _cupsLangPuts(stdout, _("\tOn fault: no alert\n"));
- _cupsLangPuts(stdout, _("\tAfter fault: continue\n"));
+ _cupsLangPuts(stdout, _("\tOn fault: no alert"));
+ _cupsLangPuts(stdout, _("\tAfter fault: continue"));
/* TODO update to use printer-error-policy */
if (allowed)
{
- _cupsLangPuts(stdout, _("\tUsers allowed:\n"));
- for (i = 0; i < allowed->num_values; i ++)
- _cupsLangPrintf(stdout, "\t\t%s\n",
- allowed->values[i].string.text);
+ _cupsLangPuts(stdout, _("\tUsers allowed:"));
+ for (j = 0; j < allowed->num_values; j ++)
+ _cupsLangPrintf(stdout, "\t\t%s",
+ allowed->values[j].string.text);
}
else if (denied)
{
- _cupsLangPuts(stdout, _("\tUsers denied:\n"));
- for (i = 0; i < denied->num_values; i ++)
- _cupsLangPrintf(stdout, "\t\t%s\n",
- denied->values[i].string.text);
+ _cupsLangPuts(stdout, _("\tUsers denied:"));
+ for (j = 0; j < denied->num_values; j ++)
+ _cupsLangPrintf(stdout, "\t\t%s",
+ denied->values[j].string.text);
}
else
{
- _cupsLangPuts(stdout, _("\tUsers allowed:\n"));
- _cupsLangPuts(stdout, _("\t\t(all)\n"));
+ _cupsLangPuts(stdout, _("\tUsers allowed:"));
+ _cupsLangPuts(stdout, _("\t\t(all)"));
}
- _cupsLangPuts(stdout, _("\tForms allowed:\n"));
- _cupsLangPuts(stdout, _("\t\t(none)\n"));
- _cupsLangPuts(stdout, _("\tBanner required\n"));
- _cupsLangPuts(stdout, _("\tCharset sets:\n"));
- _cupsLangPuts(stdout, _("\t\t(none)\n"));
- _cupsLangPuts(stdout, _("\tDefault pitch:\n"));
- _cupsLangPuts(stdout, _("\tDefault page size:\n"));
- _cupsLangPuts(stdout, _("\tDefault port settings:\n"));
+ _cupsLangPuts(stdout, _("\tForms allowed:"));
+ _cupsLangPuts(stdout, _("\t\t(none)"));
+ _cupsLangPuts(stdout, _("\tBanner required"));
+ _cupsLangPuts(stdout, _("\tCharset sets:"));
+ _cupsLangPuts(stdout, _("\t\t(none)"));
+ _cupsLangPuts(stdout, _("\tDefault pitch:"));
+ _cupsLangPuts(stdout, _("\tDefault page size:"));
+ _cupsLangPuts(stdout, _("\tDefault port settings:"));
}
}
}
ippDelete(response);
}
- else
- {
- _cupsLangPrintf(stderr, "lpstat: %s\n", cupsLastErrorString());
- return (1);
- }
return (0);
}
*/
static void
-show_scheduler(http_t *http) /* I - HTTP connection to server */
+show_scheduler(void)
{
- if (http)
- _cupsLangPuts(stdout, _("scheduler is running\n"));
+ http_t *http; /* Connection to server */
+
+
+ if ((http = httpConnectEncrypt(cupsServer(), ippPort(),
+ cupsEncryption())) != NULL)
+ {
+ _cupsLangPuts(stdout, _("scheduler is running"));
+ httpClose(http);
+ }
else
- _cupsLangPuts(stdout, _("scheduler is not running\n"));
+ _cupsLangPuts(stdout, _("scheduler is not running"));
}
/*
- * End of "$Id: lpstat.c 5527 2006-05-15 19:37:11Z mike $".
+ * 'usage()' - Show program usage and exit.
*/
+
+static void
+usage(void)
+{
+ _cupsLangPuts(stdout, _("Usage: lpstat [options]"));
+ _cupsLangPuts(stdout, _("Options:"));
+ _cupsLangPuts(stdout, _("-E Encrypt the connection to the server"));
+ _cupsLangPuts(stdout, _("-h server[:port] Connect to the named server and port"));
+ _cupsLangPuts(stdout, _("-l Show verbose (long) output"));
+ _cupsLangPuts(stdout, _("-U username Specify the username to use for authentication"));
+
+ _cupsLangPuts(stdout, _("-H Show the default server and port"));
+ _cupsLangPuts(stdout, _("-W completed Show completed jobs"));
+ _cupsLangPuts(stdout, _("-W not-completed Show pending jobs"));
+ _cupsLangPuts(stdout, _("-a [destination(s)] Show the accepting state of destinations"));
+ _cupsLangPuts(stdout, _("-c [class(es)] Show classes and their member printers"));
+ _cupsLangPuts(stdout, _("-d Show the default destination"));
+ _cupsLangPuts(stdout, _("-e Show available destinations on the network"));
+ _cupsLangPuts(stdout, _("-o [destination(s)] Show jobs"));
+ _cupsLangPuts(stdout, _("-p [printer(s)] Show the processing state of destinations"));
+ _cupsLangPuts(stdout, _("-r Show whether the CUPS server is running"));
+ _cupsLangPuts(stdout, _("-R Show the ranking of jobs"));
+ _cupsLangPuts(stdout, _("-s Show a status summary"));
+ _cupsLangPuts(stdout, _("-t Show all status information"));
+ _cupsLangPuts(stdout, _("-u [user(s)] Show jobs queued by the current or specified users"));
+ _cupsLangPuts(stdout, _("-v [printer(s)] Show the devices for each destination"));
+
+ exit(1);
+}