| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 | <html lang="en"><head><title>Recoverable Operations - avram - a virtual machine code interpreter</title><meta http-equiv="Content-Type" content="text/html"><meta name="description" content="avram - a virtual machine code interpreter"><meta name="generator" content="makeinfo 4.13"><link title="Top" rel="start" href="index.html#Top"><link rel="up" href="Lists.html#Lists" title="Lists"><link rel="prev" href="Simple-Operations.html#Simple-Operations" title="Simple Operations"><link rel="next" href="List-Transformations.html#List-Transformations" title="List Transformations"><link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"><meta http-equiv="Content-Style-Type" content="text/css"><style type="text/css"><!--  pre.display { font-family:inherit }  pre.format  { font-family:inherit }  pre.smalldisplay { font-family:inherit; font-size:smaller }  pre.smallformat  { font-family:inherit; font-size:smaller }  pre.smallexample { font-size:smaller }  pre.smalllisp    { font-size:smaller }  span.sc    { font-variant:small-caps }  span.roman { font-family:serif; font-weight:normal; }   span.sansserif { font-family:sans-serif; font-weight:normal; } --></style></head><body><div class="node"><a name="Recoverable-Operations"></a><p>Next: <a rel="next" accesskey="n" href="List-Transformations.html#List-Transformations">List Transformations</a>,Previous: <a rel="previous" accesskey="p" href="Simple-Operations.html#Simple-Operations">Simple Operations</a>,Up: <a rel="up" accesskey="u" href="Lists.html#Lists">Lists</a><hr></div><h4 class="subsection">3.1.2 Recoverable Operations</h4><p>The functions in this section are similar to the ones in the previoussection except with regard to error handling. Whereas the other onescause an error message to be printed and the process to exit in theevent of an overflow, these return to the caller, whose responsibilityit is to take appropriate action. The functions in both sections aredeclared in <samp><span class="file">lists.h</span></samp>, and should be preceded by a call to<code>avm_initialize_lists</code>.<div class="defun">— Function: list <b>avm_recoverable_join</b> (<var>list left, list right</var>)<var><a name="index-avm_005frecoverable_005fjoin-418"></a></var><br><blockquote><p>This function is similar to <code>avm_join</code>, but will return a<code>NULL</code> pointer if memory that was needed can not be allocated. A<code>NULL</code> pointer would never be the result of a join under normalcircumstances, so the overflow can be detected by the caller. Regardlessof whether overflow occurs, the arguments are deallocated by this functionand should not be referenced thereafter. </p></blockquote></div><div class="defun">— Function: void <b>avm_recoverable_enqueue</b> (<var>list *front, list *back, list operand, int *fault</var>)<var><a name="index-avm_005frecoverable_005fenqueue-419"></a></var><br><blockquote><p>This version of the enqueue function will dispose of the <var>operand</var> if thereisn't room to append another item and set <code>*</code><var>fault</var> to a non-zerovalue. Other than that, it does the same as <code>avm_enqueue</code>. </p></blockquote></div><div class="defun">— Function: counter <b>avm_recoverable_length</b> (<var>list operand</var>)<var><a name="index-avm_005frecoverable_005flength-420"></a></var><br><blockquote><p>This function checks for arithmetic overflow when calculating the lengthof a list, and returns a zero value if overflow occurs. The caller candetect the error by noting that zero is not the length of any list otherthan <code>NULL</code>. This kind of overflow is impossible unless the hostdoes not have long enough integers for its address space. </p></blockquote></div><div class="defun">— Function: counter <b>avm_recoverable_area</b> (<var>list operand, int *fault</var>)<var><a name="index-avm_005frecoverable_005farea-421"></a></var><br><blockquote><p>This function is similar to <code>avm_area</code>, except that it reactsdifferently to arithmetic overflow. The <code>fault</code> parameter should bethe address of an integer known to the caller, which will be set to anon-zero value if overflow occurs. In that event, the value of zero willalso be returned for the area. Note that it is possible for non-emptylists to have an area of zero, so this condition alone is not indicativeof an error. </p></blockquote></div><div class="defun">— Function: list <b>avm_recoverable_natural</b> (<var>counter number</var>)<var><a name="index-avm_005frecoverable_005fnatural-422"></a></var><br><blockquote><p>This function returns the <code>list</code> representation of a nativeunsigned long integer, provided that there is enough memory, similarly to the<code>avm_natural</code> function. Unlike that function, this one will returna value of <code>NULL</code> rather than exiting the program in the event of amemory overflow. The overflow can be detected by the caller insofar as a<code>NULL</code> <code>list</code> does not represent any number other than zero. </p></blockquote></div>   </body></html>
 |