home *** CD-ROM | disk | FTP | other *** search
/ Power-Programmierung / CD2.mdf / c / library / dos / diverses / cexpress / files / priorsub.asm < prev    next >
Encoding:
Assembly Source File  |  1989-05-03  |  1.9 KB  |  71 lines

  1. ;unsigned short  prior_subdirectory(array_position,tree_array);
  2. ;  unsigned short  array_position;
  3. ;  char  *tree_array;
  4.  
  5.     EXTRN  _memory_model:byte
  6.     EXTRN  _error_code:byte
  7.     EXTRN  _tree_array_size:word
  8.  
  9. _TEXT    SEGMENT BYTE PUBLIC 'CODE'
  10.     ASSUME CS:_TEXT
  11.     PUBLIC _prior_subdirectory
  12. _prior_subdirectory proc near
  13.     push bp            ;
  14.     mov  bp,sp        ;
  15.     push di            ;
  16.     cmp  _memory_model,0    ;near or far?
  17.     jle  begin        ;jump if near
  18.     inc  bp            ;else add 2 to BP
  19.     inc  bp            ;
  20. begin:    mov  ax,[bp+4]        ;get current element
  21.     mov  _error_code,1    ;1 = ArrayPosition out of range
  22.     or   ax,ax        ;zero?
  23.     jz   L5            ;
  24.     cmp  ax,_tree_array_size ;too large?
  25.     ja   L5            ;
  26.     dec  _error_code    ;0 = No error
  27.     call FigureOffset    ;
  28.     mov  ax,es:[di+17]    ;get Prior
  29.     or   ax,ax        ;is there a Prior?
  30.     jnz  L2            ;go get Parent if not
  31.     mov  ax,es:[di+13]    ;get Parent
  32.     jmp  short L5        ;quit
  33. L2:    mov  bx,ax        ;copy current element number
  34.     call FigureOffset    ;point to Prior
  35. L3:    mov  ax,es:[di+15]    ;if there a Child?
  36.     or   ax,ax        ;
  37.     jnz  L4            ;jump ahead if Child exists
  38.     mov  ax,bx        ;set element number for return
  39.     jmp  short L5        ;quit
  40. L4:    mov  bx,ax        ;copy current element number
  41.     call FigureOffset    ;point to Child or next Next
  42.     mov  ax,es:[di+19]    ;if there a Next?
  43.     or   ax,ax        ;
  44.     jz   L3            ;jump ahead if not
  45.     jmp  short L4        ;go to last Next
  46. L5:    pop  di            ;
  47.     pop  bp            ;
  48.     cmp  _memory_model,0    ;quit
  49.     jle  quit        ;
  50.     db   0CBh        ;RET far
  51. quit:    ret            ;RET near
  52. _prior_subdirectory endp
  53. figureoffset PROC        ;figures offset of array element
  54.     cmp  _memory_model,2    ;data near or far?
  55.     jb   L6            ;jump if near
  56.     les  di,dword ptr[bp+6]    ;ES:DI pts to tree array
  57.     add  di,21        ;start with array element 1
  58.     jmp  short L7        ;
  59. L6:    push ds            ;
  60.     pop  es            ;
  61.     mov  di,[bp+6]        ;
  62.     add  di,21        ;start with array element 1
  63. L7:    dec  ax            ;count from zero
  64.     mov  dl,21        ;bytes per element
  65.     mul  dl            ;
  66.     add  di,ax        ;now ES:DI pts to element
  67.     ret            ;
  68. figureoffset endp        ;
  69. _TEXT    ENDS
  70.     END
  71.