Forum OpenACS Q&A: Re: Can't exec a command in tcl page

Collapse
Posted by Benjamin Brink on
Antonio,

Try using a full pathname for "libreoffice", such as /usr/local/libreoffice but with the location of libreoffice.

It may be that the server's environmental variables are not set during startup, so the server cannot find "libreoffice".

cheers,

Ben

Collapse
Posted by Antonio Pisano on
Thanks Ben, it sounded reasonable, but unfortunately it is not the case: using the full path won't help...
Collapse
Posted by Antonio Pisano on
I've also tried issuing 'libreoffice --headless --help' as command, with just the relative path and it works on the server (shows the options properly).

I think it must be something more subtle related to execution into proxy...

Collapse
Posted by Benjamin Brink on
Examine the server log. Does the error message provide more detail?
Collapse
Posted by Antonio Pisano on
This is what the log says... nothing new...

child process exited abnormally
while executing
"exec libreoffice --headless --convert-to xls /tmp/filedNva4p.xls /tmp/filedNva4p"
invoked from within
"ns_proxy eval $handle "exec $call""
("uplevel" body line 2)
invoked from within
"uplevel $code"
invoked from within
"with_finally -code {
set return_string [ns_proxy eval $handle "exec $call"]
} -finally {
ns_proxy release $handle
}"
(procedure "proxy::exec" line 4)
invoked from within
"proxy::exec -call $args"
(procedure "exec" line 1)
invoked from within
"exec libreoffice --headless --convert-to xls ${tmpfile}.xls $tmpfile"
("uplevel" body line 212)
invoked from within...

Calling the very same exec command in tclsh by the command line (on the same server) works as expected.

Collapse
Posted by Antonio Pisano on
The real command is this, took the wrong part of the log.

exec libreoffice --headless --convert-to xls /tmp/fileBXXCcF.xls /tmp/fileBXXCcF.csv

Same error though.

Collapse
Posted by Dave Bauer on
Does the operation complete successfully?

We had this problem with many commands, where the output of the command causes Tcl exec to think the command has failed when it was fine.

We catch the exec and look for specific error responses in the output as necessary.

Many sites I have worked on used a modified exec replacement that took care of the catch automatically.

Collapse
Posted by Gustaf Neumann on
A common cause is that the executed script outputs to stderr. This leads per-default to the same failure like a non-zero return code. I would recommend to redirect stderr to stdout (adding the the script 2>@1)

A longer discussion is e.g. here: http://wiki.tcl.tk/1039