mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
Ensure we don't do lp_servicename()'s in tdb traverse as this
allocates lots of memory. Jeremy.
This commit is contained in:
parent
230941d2fb
commit
fbc8c6a109
@ -115,10 +115,12 @@ store a job structure back to the database
|
||||
static BOOL print_job_store(int jobid, struct printjob *pjob)
|
||||
{
|
||||
TDB_DATA d;
|
||||
BOOL ret;
|
||||
|
||||
d.dptr = (void *)pjob;
|
||||
d.dsize = sizeof(*pjob);
|
||||
|
||||
return (tdb_store(tdb, print_key(jobid), d, TDB_REPLACE) == 0);
|
||||
ret = (tdb_store(tdb, print_key(jobid), d, TDB_REPLACE) == 0);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
@ -185,7 +187,7 @@ static int traverse_fn_delete(TDB_CONTEXT *t, TDB_DATA key, TDB_DATA data, void
|
||||
memcpy(&jobid, key.dptr, sizeof(jobid));
|
||||
memcpy(&pjob, data.dptr, sizeof(pjob));
|
||||
|
||||
if (!strequal(lp_servicename(ts->snum), pjob.queuename)) {
|
||||
if (ts->snum != lp_servicenumber(pjob.queuename)) {
|
||||
/* this isn't for the queue we are looking at */
|
||||
ts->total_jobs++;
|
||||
return 0;
|
||||
@ -1176,7 +1178,7 @@ static int traverse_fn_queue(TDB_CONTEXT *t, TDB_DATA key, TDB_DATA data, void *
|
||||
memcpy(&pjob, data.dptr, sizeof(pjob));
|
||||
|
||||
/* maybe it isn't for this queue */
|
||||
if (!strequal(lp_servicename(ts->snum), pjob.queuename))
|
||||
if (ts->snum != lp_servicenumber(pjob.queuename))
|
||||
return 0;
|
||||
|
||||
if (ts->qcount >= ts->maxcount) return 0;
|
||||
@ -1213,7 +1215,7 @@ static int traverse_count_fn_queue(TDB_CONTEXT *t, TDB_DATA key, TDB_DATA data,
|
||||
memcpy(&pjob, data.dptr, sizeof(pjob));
|
||||
|
||||
/* maybe it isn't for this queue */
|
||||
if (!strequal(lp_servicename(ts->snum), pjob.queuename))
|
||||
if (ts->snum != lp_servicenumber(pjob.queuename))
|
||||
return 0;
|
||||
|
||||
ts->count++;
|
||||
|
Loading…
Reference in New Issue
Block a user