home *** CD-ROM | disk | FTP | other *** search
/ C/C++ Interactive Guide / c-cplusplus-interactive-guide.iso / c_ref / csource4 / 256_01 / fndnext.a < prev    next >
Text File  |  1988-01-08  |  2KB  |  50 lines

  1. ;---------------------------------------------------------------------
  2. ;    ASM88 FILE:     FNDNEXT.A     Find Next Matching File....use ONLY
  3. ;    ----------                    after FNDFIRST function.
  4. ;    WRITTEN:        25/10/87
  5. ;    -------
  6. ;    PURPOSE:        This is one of a series of files which take
  7. ;    -------         advantage of INT 21H functions under MS-DOS.
  8. ;                    In each case the error situation is marked by
  9. ;                    the carry flag being set.   We use the De Smet
  10. ;                    external variable '_carryf' to see whether the
  11. ;                    carry is set on return from the function.
  12. ;                    If so, the error code can be used to obtain
  13. ;                    information about the specific error.
  14. ;
  15. ;    USAGE:          int FNDNEXT(&_carryf)
  16. ;    -----
  17. ;                    char *_carryf;
  18. ;
  19. ;    DEPENDENCIES:           De Smet C V 2.44+
  20. ;    ------------
  21. ;    Copyright 1987 - Cogar Computer Services Pty. Ltd
  22. ;---------------------------------------------------------------------
  23.  
  24. CSEG
  25. PUBLIC FNDNEXT_
  26.  
  27. FNDNEXT_:
  28.     push    bp    ; normal De Smet C start
  29.     mov    bp,sp    ; point to the stack
  30.     mov    ax,ds    ; and make ES common with DS
  31.     mov    es,ax
  32. ;----------------------------------------------------------------------
  33. ;  The unique programme follows.
  34. ;----------------------------------------------------------------------
  35.     mov    ah,4fh    ; the Function No.
  36.     int    21h
  37.     jc    FNDNEXT_ERROR
  38.     xor    ax,ax    ; prepare for normal return
  39.     jmp    FNDNEXT_QUIT
  40. FNDNEXT_ERROR:
  41.     mov    si,[bp+4]    ; get address of '_carryf' variable
  42.     mov    byte [si],1    ; return with _carryf = 1
  43. ;----------------------------------------------------------------------
  44. ;  Normal programme termination.
  45. ;----------------------------------------------------------------------
  46. FNDNEXT_QUIT:
  47.     pop    bp    ; restore starting conditions
  48.     ret
  49. ;----------------------------------------------------------------------
  50.