Visualização da execução de um único arquivo no GNU Octave (echo fcnname on)

0

A pergunta é simples: no MATLAB, você pode simplesmente usar echo myFun on para definir o status echo de uma única função m-file para on , que então mostra cada um dos linhas executadas.

No GNU Octave, no entanto, essa sintaxe está faltando. help echo mostra:

octave:1> help echo
'echo' is a built-in function from the file libinterp/corefcn/input.cc

 -- Command: echo
 -- Command: echo on
 -- Command: echo off
 -- Command: echo on all
 -- Command: echo off all
     Control whether commands are displayed as they are executed.

     Valid options are:

     'on'
          Enable echoing of commands as they are executed in script
          files.

     'off'
          Disable echoing of commands as they are executed in script
          files.

     'on all'
          Enable echoing of commands as they are executed in script
          files and functions.

     'off all'
          Disable echoing of commands as they are executed in script
          files and functions.

     With no arguments, 'echo' toggles the current echo state.

Additional help for built-in functions and operators is
available in the online version of the manual.  Use the command
'doc <topic>' to search the manual index.

Help and information about Octave is also available on the WWW
at http://www.octave.org and via the [email protected]
mailing list.

Pesquisando mais profundamente, a página de informações diz mais:

 -- Built-in Function: VAL = echo_executing_commands ()
 -- Built-in Function: OLD_VAL = echo_executing_commands (NEW_VAL)
 -- Built-in Function: echo_executing_commands (NEW_VAL, "local")
     Query or set the internal variable that controls the echo state.

     It may be the sum of the following values:

     1
          Echo commands read from script files.

     2
          Echo commands from functions.

     4
          Echo commands read from command line.

     More than one state can be active at once.  For example, a value of
     3 is equivalent to the command 'echo on all'.

     The value of 'echo_executing_commands' may be set by the 'echo'
     command or the command line option '--echo-commands'.

     When called from inside a function with the "local" option, the
     variable is changed locally for the function and any subroutines it
     calls.  The original variable value is restored when exiting the
     function.

Então, algo como a minha tentativa abaixo pode potencialmente resolver o problema; no entanto, como a documentação sugere, afeta a função e qualquer chamada de sub-rotinas . Então o problema ainda não está resolvido; Eu pensei ter respondido a minha própria pergunta, mas descobri que não.

Basta adicionar echo_executing_commands(2, 'local'); no início do arquivo de função para depuração; em outras palavras, abra myFun.m e insira a instrução no início da função m-file. Note que esta é a única função Octave, portanto, para ser totalmente compatível, use:

if exist('OCTAVE_VERSION', 'builtin') ~= 0; echo_executing_commands(2, 'local');end

    
por hyiltiz 19.09.2015 / 03:39

1 resposta

0

Isto não funciona

Basta adicionar echo_executing_commands(2, 'local'); no início do arquivo de função para depuração; em outras palavras, abra myFun.m e insira a instrução no início da função m-file. Note que esta é a única função Octave, portanto, para ser totalmente compatível, use:

if exist('OCTAVE_VERSION', 'builtin') ~= 0; echo_executing_commands(2, 'local');end

    
por 19.09.2015 / 03:45