Convert fltr_cache into a function. Enable output buffering which had been commented out for unknwon reasons.
This commit is contained in:
parent
9ff545ec83
commit
2e1f0dd32f
5 changed files with 44 additions and 42 deletions
35
bin/fltr_cache.rc
Executable file
35
bin/fltr_cache.rc
Executable file
|
|
@ -0,0 +1,35 @@
|
|||
#!/usr/bin/env rc
|
||||
|
||||
fn fltr_cache {
|
||||
a=()
|
||||
tmpf=()
|
||||
|
||||
proc=$1
|
||||
shift
|
||||
|
||||
if(~ $#* 0) {
|
||||
tmpf=/tmp/fmttmp.$pid
|
||||
f=$tmpf
|
||||
score=`{{tee $tmpf || exit 1} | sha1sum}
|
||||
}
|
||||
if not {
|
||||
f=$1
|
||||
if(~ $f */) {
|
||||
score=`{du -an $f | sha1sum || exit 1} # XXX using -n(bytes) instead of -t(lastmod) because sitemap proc touches files in tree.
|
||||
a=$f
|
||||
f=/dev/null
|
||||
}
|
||||
if not
|
||||
score=`{sha1sum $f || exit 1}
|
||||
}
|
||||
cachedir=/tmp/fltr_cache/$score
|
||||
mkdir -p $cachedir >[2]/dev/null
|
||||
|
||||
if(test -s $cachedir/$proc)
|
||||
cat $cachedir/$proc
|
||||
if not
|
||||
if($proc $a < $f | tee $cachedir/$pid)
|
||||
mv $cachedir/$pid $cachedir/$proc
|
||||
|
||||
rm $tmpf $cachedir/$pid >[2]/dev/null &
|
||||
}
|
||||
|
|
@ -1,34 +0,0 @@
|
|||
#!/usr/bin/env rc
|
||||
#. 9.rc # Not really needed when calling from werc, only would be needed if you use fproc_cache.rc standalone
|
||||
|
||||
a=()
|
||||
tmpf=()
|
||||
|
||||
proc=$1
|
||||
shift
|
||||
|
||||
if(~ $#* 0) {
|
||||
tmpf=/tmp/fmttmp.$pid
|
||||
f=$tmpf
|
||||
score=`{{tee $tmpf || exit 1} | sha1sum}
|
||||
}
|
||||
if not {
|
||||
f=$1
|
||||
if(~ $f */) {
|
||||
score=`{du -an $f | sha1sum || exit 1} # XXX using -n(bytes) instead of -t(lastmod) because sitemap proc touches files in tree.
|
||||
a=$f
|
||||
f=/dev/null
|
||||
}
|
||||
if not
|
||||
score=`{sha1sum $f || exit 1}
|
||||
}
|
||||
cachedir=/tmp/fproc_cache/$score
|
||||
mkdir -p $cachedir >[2]/dev/null
|
||||
|
||||
if(test -s $cachedir/$proc)
|
||||
cat $cachedir/$proc
|
||||
if not
|
||||
if($proc $a < $f | tee $cachedir/$pid)
|
||||
mv $cachedir/$pid $cachedir/$proc
|
||||
|
||||
rm $tmpf $cachedir/$pid >[2]/dev/null &
|
||||
|
|
@ -3,6 +3,7 @@
|
|||
. ./werclib.rc
|
||||
. ./wercconf.rc
|
||||
. ./corehandlers.rc
|
||||
. ./fltr_cache.rc
|
||||
cd ..
|
||||
|
||||
forbidden_uri_chars='[^a-zA-Z0-9_+\-\/\.]'
|
||||
|
|
@ -105,7 +106,7 @@ fn werc_exec_request {
|
|||
if(! ~ $#debug 0)
|
||||
dprint $"SERVER_NAME^$"REQUEST_URI - $"HTTP_USER_AGENT - $"REQUEST_METHOD - $"handler_body_main - $"master_template
|
||||
|
||||
template $headers $master_template #| awk_buffer
|
||||
template $headers $master_template | awk_buffer
|
||||
echo $res_tail
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue