1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-23 17:34:34 +03:00

My previous fix had a bug....

This is SO NASTY as some drivers need this to change, others need it
static. This value will change every second, and I must hope that this
is enough..... DON'T CHANGE THIS CODE WITHOUT A TEST MATRIX THE SIZE OF
UTAH !
Jeremy.
(This used to be commit 9fb780d951)
This commit is contained in:
Jeremy Allison 2002-01-08 23:50:14 +00:00
parent e54261b82c
commit eca00cab66

View File

@ -2628,13 +2628,18 @@ void get_printer_subst_params(int snum, fstring *printername, fstring *sharename
/****************************************************************************
Update the changeid time.
This is SO NASTY as some drivers need this to change, others need it
static. This value will change every second, and I must hope that this
is enough..... DON'T CHANGE THIS CODE WITHOUT A TEST MATRIX THE SIZE OF
UTAH ! JRA.
****************************************************************************/
static uint32 rev_changeid(uint32 changeid)
static uint32 rev_changeid(void)
{
if (changeid == 0)
changeid = time(NULL);
return changeid++;
static time_t start_time;
if (start_time == 0)
start_time = time(NULL);
return (((time(NULL) - start_time)+1)*1000);
}
/*
@ -2667,7 +2672,7 @@ WERROR mod_a_printer(NT_PRINTER_INFO_LEVEL printer, uint32 level)
of client's spoolss service in order for the
client's cache to show updates */
printer.info_2->changeid = rev_changeid(printer.info_2->changeid);
printer.info_2->changeid = rev_changeid();
/*
* Because one day someone will ask:
@ -2719,7 +2724,7 @@ WERROR add_a_printer(NT_PRINTER_INFO_LEVEL printer, uint32 level)
* --jerry
*/
printer.info_2->changeid = rev_changeid(printer.info_2->changeid);
printer.info_2->changeid = rev_changeid();
printer.info_2->c_setprinter++;
result=update_a_printer_2(printer.info_2);