diff options
Diffstat (limited to 'doc/mdk_mixguile.texi')
-rw-r--r-- | doc/mdk_mixguile.texi | 83 |
1 files changed, 75 insertions, 8 deletions
diff --git a/doc/mdk_mixguile.texi b/doc/mdk_mixguile.texi index 7637dc0..dc2d2b0 100644 --- a/doc/mdk_mixguile.texi +++ b/doc/mdk_mixguile.texi @@ -4,7 +4,7 @@ @c Free Software Foundation, Inc. @c See the file mdk.texi for copying conditions. -@c $Id: mdk_mixguile.texi,v 1.2 2001/09/26 23:13:15 jao Exp $ +@c $Id: mdk_mixguile.texi,v 1.3 2001/09/28 23:11:44 jao Exp $ @node mixguile, Problems, gmixvm, Top @chapter @code{mixguile}, the Scheme virtual machine @@ -124,11 +124,11 @@ library. @menu * mixvm wrappers:: Functions invoking mixvm commands. -* Additional VM functions:: Functions accessing the MIX virtual machine. * Hooks:: Adding hooks to mixvm commands. +* Additional VM functions:: Functions accessing the MIX virtual machine. @end menu -@node mixvm wrappers, Additional VM functions, Scheme functions reference, Scheme functions reference +@node mixvm wrappers, Hooks, Scheme functions reference, Scheme functions reference @subsection @code{mixvm} command wrappers For each of the @code{mixvm} commands listed in @ref{Commands}, there is @@ -246,7 +246,7 @@ MIX > next 5 MIX > (mix-next 5) @end example -@node Hooks, , Additional VM functions, Scheme functions reference +@node Hooks, Additional VM functions, mixvm wrappers, Scheme functions reference @subsection Hook functions Hooks are functions evaluated before or after executing a @code{mixvm} @@ -317,7 +317,7 @@ stands for your root install directory, usualy @code{/usr} or See @ref{Hook functions} for further examples on using hook functions. -@node Additional VM functions, Hooks, mixvm wrappers, Scheme functions reference +@node Additional VM functions, , Hooks, Scheme functions reference @subsection Additional VM functions When writing non-trivial Scheme extensions using the MIX/Scheme library, @@ -331,48 +331,115 @@ problems, the MIX/Scheme library provides the following additional functions: @defun mixvm-status +@defunx mix-vm-status +Return the current status of the virtual machine, as a number +(@code{mixvm-status}) or as a symbol (@code{mix-vm-status}). Posible +return values are: +@multitable {aamixvmaastatusaa} {aamixvmastatusaaaaaaa} {return valuesaaaaaaaaaaaaaaaaaaaaaaaaaa} +@item @code{(mixvm-status)} @tab @code{(mix-vm-status)} @tab +@item 0 @tab MIX_ERROR @tab Loading or execution error +@item 1 @tab MIX_BREAK @tab Breakpoint encountered +@item 2 @tab MIX_COND_BREAK @tab Conditional breakpoint +@item 3 @tab MIX_HALTED @tab Execution terminated +@item 4 @tab MIX_RUNNING @tab Execution stopped after @code{next} +@item 5 @tab MIX_LOADED @tab Program successfully loaded +@item 6 @tab MIX_EMPTY @tab No program loaded +@end multitable +@end defun + +@defun mix-vm-error? +@defunx mix-vm-break? +@defunx mix-vm-cond-break? +@defunx mix-vm-halted? +@defunx mix-vm-running? +@defunx mix-vm-loaded? +@defunx mix-vm-empty? +Predicates asking whether the current virtual machine status is +@code{MIX_ERROR}, @code{MIX_BREAK}, etc. @end defun @defun mix-reg register @defunx mix-set-reg! register value +@code{mix-reg} evaluates to a number which is the contents of the +specified @var{register}. @code{mix-set-reg} sets the contents of the +given @var{register} to @var{value}. The register can be specified +either as a string (@code{"A"}, @code{"X"}, etc.) or as a symbol +(@code{'A}, @code{'X}, etc.). For instance, + +@example +guile> (mix-reg 'A) +2341 +guile> (mix-set-reg! "A" 2000) +ok +guile> (define reg-a (mix-reg 'A)) +guile> (display reg-a) +2000 +guile> +@end example @end defun @defun mix-cell cell_no -@defunx mix-set-cell cell_no value +@defunx mix-set-cell! cell_no value +Evaluate and set the contents of the memory cell number +@var{cell_no}. Both @var{cell_no} and @var{value} are Scheme numbers. @end defun @defun mix-loc +Evaluates to the value of the location counter (i.e., the address of the +next instruction to be executed). @end defun @defun mix-over @defunx mix-set-over! #t|#f +@code{mix-over} evaluates to @code{#t} if the overflow toggle is set, +and to @code{#f} otherwise. The value of the overflow toggle can be +modified using @code{mix-set-over!}. @end defun @defun mix-cmp -@defun mix-set-cmp! 'L|'E|'G +@defunx mix-set-cmp! 'L|'E|'G +Evaluate and set the comparison flag. Possible values are the scheme +symbols @code{L} (lesser), @code{E} (equal) and @code{G} (greater). @end defun @defun mix-up-time +Evaluates to the current virtual machine uptime. @end defun @defun mix-lap-time +Evaluates to the current virtual machine lapsed time, i.e., the time +elapsed since the last @code{run} or @code{next} command. @end defun @defun mix-prog-time +Evaluates to the total time spent executing the currently loaded program. @end defun @defun mix-prog-name +Evaluates to a string containing the basename (without any leading path) +of the currently loaded MIX program. @end defun @defun mix-prog-path +Evaluates to a string containing the full path to the currently loaded +MIX program. @end defun @defun mix-src-path +Evaluates to a string containing the full path to the source file of the +currently loaded MIX program. @end defun -@defun mix-src-line +@defun mix-src-line [lineno] @defunx mix-src-line-no +@code{mix-src-line-no} evaluates to the current source file number +during the execution of a program. @code{mix-src-line} evaluates to a +string containing the source file line number @var{lineno}; when +invoked without argument, it evaluates to @code{(mix-src-line +(mix-src-line-no))}. @end defun @defun mix-ddir +Evaluates to a string containing the full path of the current device +directory. @end defun |