192 |
|
sprintf(errmsg, "cannot open ambient file \"%s\"", ambfile); |
193 |
|
error(SYSTEM, errmsg); |
194 |
|
} |
195 |
< |
nunflshed++; /* lie */ |
196 |
< |
ambsync(); |
195 |
> |
ambsync(); /* load previous values */ |
196 |
|
} |
197 |
|
|
198 |
|
|
453 |
|
for (i = al; i-- > 0; ) |
454 |
|
amb.weight *= AVGREFL; |
455 |
|
if (r->rweight < 0.1*amb.weight) /* heuristic override */ |
456 |
< |
amb.weight = r->rweight; |
456 |
> |
amb.weight = 1.25*r->rweight; |
457 |
|
setcolor(acol, AVGREFL, AVGREFL, AVGREFL); |
458 |
|
/* compute ambient */ |
459 |
|
amb.rad = doambient(acol, r, amb.weight, gp, gd); |
876 |
|
AMBVAL avs; |
877 |
|
register int n; |
878 |
|
|
880 |
– |
if (nunflshed == 0) |
881 |
– |
return(0); |
879 |
|
if (lastpos < 0) /* initializing (locked in initambfile) */ |
880 |
|
goto syncend; |
881 |
< |
/* gain exclusive access */ |
882 |
< |
aflock(F_WRLCK); |
881 |
> |
/* gain appropriate access */ |
882 |
> |
aflock(nunflshed ? F_WRLCK : F_RDLCK); |
883 |
|
/* see if file has grown */ |
884 |
|
if ((flen = lseek(fileno(ambfp), (off_t)0, SEEK_END)) < 0) |
885 |
|
goto seekerr; |
932 |
|
extern int |
933 |
|
ambsync(void) /* flush ambient file */ |
934 |
|
{ |
938 |
– |
if (nunflshed == 0) |
939 |
– |
return(0); |
935 |
|
nunflshed = 0; |
936 |
|
return(fflush(ambfp)); |
937 |
|
} |