**This is an old revision of the document!** ----

A PCRE internal error occured. This might be caused by a faulty plugin

August 10: Still trying to reduce the code. Tried to remove the int *success parameter of the expand_string() function. This parameter tells the calling function whether a new word was recognised. However, I had some problems in case of the line-continuation \. for i in 1 2 3 \ 4 5 6 # the space at the beginning of this line causes the problem do echo ${i} done seems to require some way to see that the \<newline> is not a new word. August 11: Decided to try using the gen_stack for the arithmetic parser code. The benefits should include a simpler memory allocation strategy. The idea is to use an explicit stack to store the operands. When an operator is found, the top of the stack should contain the (evaluated) left operator. Then the right operator is evaluated, and pushed on the stack by recursive calls to the parsing function. Then the top two elements of the stack are popped, evaluated, and the result is pushed back. If at any time an error is found, the top-level function frees the stack. This frees up the other functions from having to free the temporary values. August 13: Finally used the gen_stack for arith.c. Size check: After: 2276 8 16 2300 8fc bin/arith.o Before 2172 0 16 2188 88c bin/arith.o However, I had some problems with the branches and loops, so that doesn't work just yet. Have to fix it next. Also split the gen_stack commit out of the quoting patch. * [[http://git.etherboot.org/?p=people/lynusvaz/gpxe.git;a=commit;h=d3725fcfd4eba7e570ba1a83951a4117bb898b7b|Use stacks for arith.c]] * [[http://git.etherboot.org/?p=people/lynusvaz/gpxe.git;a=commit;h=98742e4106dbb030b82a526e0b1ad9018d04b15b|Implement gen_stack]]


QR Code
QR Code soc:2009:lynusvaz:journal:week12 (generated for current page)