1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-27 14:04:05 +03:00

Use print_queue_length() by preference if we don't need a queue

as it doesn't do a traversal.
Jeremy.
This commit is contained in:
Jeremy Allison -
parent d00f461f43
commit 4bf4ee3f14
2 changed files with 4 additions and 21 deletions

View File

@ -848,6 +848,7 @@ int print_queue_length(int snum, print_status_struct *pstatus)
print_queue_update(snum); print_queue_update(snum);
/* also fetch the queue status */ /* also fetch the queue status */
memset(&status, 0, sizeof(status));
len = get_queue_status(snum, &status); len = get_queue_status(snum, &status);
if (pstatus) if (pstatus)
*pstatus = status; *pstatus = status;

View File

@ -1837,7 +1837,6 @@ static void spoolss_notify_status(int snum,
{ {
print_status_struct status; print_status_struct status;
memset(&status, 0, sizeof(status));
print_queue_length(snum, &status); print_queue_length(snum, &status);
data->notify_data.value[0]=(uint32) status.status; data->notify_data.value[0]=(uint32) status.status;
data->notify_data.value[1] = 0; data->notify_data.value[1] = 0;
@ -2428,7 +2427,6 @@ static WERROR printer_notify_info(pipes_struct *p, POLICY_HND *hnd, SPOOL_NOTIFY
case JOB_NOTIFY_TYPE: { case JOB_NOTIFY_TYPE: {
NT_PRINTER_INFO_LEVEL *printer = NULL; NT_PRINTER_INFO_LEVEL *printer = NULL;
memset(&status, 0, sizeof(status));
count = print_queue_status(snum, &queue, &status); count = print_queue_status(snum, &queue, &status);
if (!W_ERROR_IS_OK(get_a_printer(&printer, 2, if (!W_ERROR_IS_OK(get_a_printer(&printer, 2,
@ -2534,16 +2532,12 @@ static BOOL construct_printer_info_0(PRINTER_INFO_0 *printer, int snum)
uint32 global_counter; uint32 global_counter;
struct tm *t; struct tm *t;
time_t setuptime; time_t setuptime;
print_queue_struct *queue=NULL;
print_status_struct status; print_status_struct status;
memset(&status, 0, sizeof(status));
if (!W_ERROR_IS_OK(get_a_printer(&ntprinter, 2, lp_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(&ntprinter, 2, lp_servicename(snum))))
return False; return False;
count = print_queue_status(snum, &queue, &status); count = print_queue_length(snum, &status);
/* check if we already have a counter for this printer */ /* check if we already have a counter for this printer */
session_counter = (counter_printer_0 *)ubi_dlFirst(&counter_list); session_counter = (counter_printer_0 *)ubi_dlFirst(&counter_list);
@ -2625,7 +2619,6 @@ static BOOL construct_printer_info_0(PRINTER_INFO_0 *printer, int snum)
printer->unknown28 = 0; printer->unknown28 = 0;
printer->unknown29 = 0; printer->unknown29 = 0;
SAFE_FREE(queue);
free_a_printer(&ntprinter,2); free_a_printer(&ntprinter,2);
return (True); return (True);
} }
@ -2774,15 +2767,12 @@ static BOOL construct_printer_info_2(PRINTER_INFO_2 *printer, int snum)
int count; int count;
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
print_queue_struct *queue=NULL;
print_status_struct status; print_status_struct status;
memset(&status, 0, sizeof(status));
if (!W_ERROR_IS_OK(get_a_printer(&ntprinter, 2, lp_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(&ntprinter, 2, lp_servicename(snum))))
return False; return False;
memset(&status, 0, sizeof(status)); count = print_queue_length(snum, &status);
count = print_queue_status(snum, &queue, &status);
init_unistr(&printer->servername, ntprinter->info_2->servername); /* servername*/ init_unistr(&printer->servername, ntprinter->info_2->servername); /* servername*/
init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/ init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/
@ -2827,7 +2817,6 @@ static BOOL construct_printer_info_2(PRINTER_INFO_2 *printer, int snum)
} }
free_a_printer(&ntprinter, 2); free_a_printer(&ntprinter, 2);
SAFE_FREE(queue);
return True; return True;
} }
@ -4900,8 +4889,8 @@ WERROR _spoolss_enumjobs( pipes_struct *p, SPOOL_Q_ENUMJOBS *q_u, SPOOL_R_ENUMJO
uint32 *returned = &r_u->returned; uint32 *returned = &r_u->returned;
int snum; int snum;
print_queue_struct *queue=NULL;
print_status_struct prt_status; print_status_struct prt_status;
print_queue_struct *queue=NULL;
/* that's an [in out] buffer */ /* that's an [in out] buffer */
spoolss_move_buffer(q_u->buffer, &r_u->buffer); spoolss_move_buffer(q_u->buffer, &r_u->buffer);
@ -4909,8 +4898,6 @@ WERROR _spoolss_enumjobs( pipes_struct *p, SPOOL_Q_ENUMJOBS *q_u, SPOOL_R_ENUMJO
DEBUG(4,("_spoolss_enumjobs\n")); DEBUG(4,("_spoolss_enumjobs\n"));
ZERO_STRUCT(prt_status);
*needed=0; *needed=0;
*returned=0; *returned=0;
@ -4957,12 +4944,9 @@ WERROR _spoolss_setjob(pipes_struct *p, SPOOL_Q_SETJOB *q_u, SPOOL_R_SETJOB *r_u
uint32 command = q_u->command; uint32 command = q_u->command;
struct current_user user; struct current_user user;
print_status_struct prt_status;
int snum; int snum;
WERROR errcode = WERR_BADFUNC; WERROR errcode = WERR_BADFUNC;
memset(&prt_status, 0, sizeof(prt_status));
if (!get_printer_snum(p, handle, &snum)) { if (!get_printer_snum(p, handle, &snum)) {
return WERR_BADFID; return WERR_BADFID;
} }
@ -6751,8 +6735,6 @@ WERROR _spoolss_getjob( pipes_struct *p, SPOOL_Q_GETJOB *q_u, SPOOL_R_GETJOB *r_
DEBUG(5,("spoolss_getjob\n")); DEBUG(5,("spoolss_getjob\n"));
memset(&prt_status, 0, sizeof(prt_status));
*needed=0; *needed=0;
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum))