Article: Q50521
Product(s): See article
Version(s): 2.01
Operating System(s): MS-DOS
Keyword(s): ENDUSER | buglist2.01 | mspl13_masm
Last Modified: 18-DEC-1989
Due to the INCLUDELIB directive, the QuickAssembler cannot debug
source code in libraries that are linked in. When tracing into the
library that is included with the directive, the debugger stops
execution of the program and reassembles the source for the library
routine. This is not the expected behavior of the assembler/debugger,
but the following workarounds are quite simple.
The first option is to debug the library routine before placing it in
the library. To do this, include the file in the program list, which
then links the object file instead of the library. In this form, the
routine can be traced into and the code can be debugged. When the
modules have been debugged, they can then be included in a library
that is linked in by use of the INCLUDELIB directive. After the
routines are included in the library, use the F10 key to step over the
calls to routines in the library. This executes the routine without
trying to display the source for it.
Another workaround is to put the library in the program list instead
of using INCLUDELIB. By including the library in the program list,
QuickAssembler will debug source code that is in the library routine.
Therefore, you can trace into the source code (even when it is
included in a library) without problem. Use this option if you want to
trace into any function in your program (meaning routines in both
object modules and libraries.
Microsoft has confirmed this to be a problem with QuickAssembler
Version 2.01. We are researching this problem and will post new
information as it becomes available.
Below is a sample program (consisting of two files) that demonstrates
the problem:
******** FILE 1 ********
; HELLO.ASM
;
; This is a simple hello world program that will use
; both DOS display string and DOS Write functions.
TITLE HELLO
DOSSEG
; Uncomment the following INCLUDELIB statement, then step through the
; CALL WRT line to step into the code for WRT. This will cause the
; problem.
;INCLUDELIB wrt.lib
.MODEL SMALL
.DATA
MSG DB "Hello World",0Dh,0Ah,24h
.STACK 800H
.CODE
EXTRN WRT:PROC
.STARTUP
PUSH DX
PUSH CX
PUSH BX
MOV AH, 09h ; DOS DISPLAY STRING
MOV DX, OFFSET MSG ; ADDRESS OF STRING
INT 21h
CALL WRT ; MAKE THE WRITE CALL!
XOR AL,AL ; SET UP RETURN CODE
.EXIT
END
******** FILE 2 ********
; WRT.ASM
;
; Assemble this file and put it into a library called WRT.LIB. (This
; can be done by typing LIB WRT.LIB+WRT.OBJ; after you have assembled
; WRT.ASM.
;
; This file MUST be linked to the above program to avoid unresolved
; externals. Either link the .OBJ file or the .LIB file with a program
; list, OR uncomment the INCLUDELIB directive above.
TITLE WRT
DOSSEG
.MODEL SMALL
.DATA
MYNAME DB "John Smith",0Dh, 0Ah,24h
LNAME EQU $-MYNAME-1
.CODE
PUBLIC WRT
WRT PROC
MOV AH, 40h ; DOS WRITE FUNCTION
MOV BX, 01h ; HANDLE FOR STDOUT
MOV CX, LNAME ; NUMBER OF CHARACTER TO WRITE
MOV DX, OFFSET MYNAME ; OFFSET OF STRING TO PRINT
INT 21h
RET
WRT ENDP
END