Article: Q58732
Product(s): See article
Version(s): 4.50
Operating System(s): MS-DOS
Keyword(s): ENDUSER | SR# S900210-1 buglist4.50 | mspl13_basic
Last Modified: 1-MAR-1990
A QuickBASIC 4.50 program that calls a subprogram located in a
separate module (such as in a library or Quick library) can have a
parameter's contents become corrupt under the specific circumstances
described further below. After the parameter has been corrupted,
PRINTing that parameter may display "garbage" instead of the correct
results.
Microsoft has confirmed this to be a problem in Microsoft QuickBASIC
Version 4.50. We are researching this problem and will post new
information here as it becomes available.
This problem does NOT occur in earlier versions of QuickBASIC, in
Microsoft BASIC Compiler Versions 6.00 or 6.00b for MS-DOS and MS
OS/2, or in Microsoft BASIC Professional Development System (PDS)
Version 7.00 for MS-DOS and MS OS/2.
The conditions under which parameters may become corrupt are as
follows:
1. Variables are passed using argument and parameter lists to a
subprogram located in a separate module (a linked .OBJ, a library,
or a Quick library). (This problem does not occur if variables are
passed through a COMMON SHARED statement.)
2. The second argument passed is of type SINGLE, DOUBLE, or INTEGER.
(This problem does not occur with long integers.)
3. In the subprogram, the variable in the first position of the
parameter list is multiplied by the variable in the second
position, giving the result to a third variable such as a third
parameter or a variable local to the subroutine. The problem
does not occur if the order of multiplication is switched.
4. If all of the above conditions are met, the variable that is
defined in the second position of the parameter list shows garbage
when PRINTed even though no changes were made to this variable.
All other variables are displayed correctly.
The following program exhibits the problem:
Main Level Code
---------------
x = 5
y = 6
Print "Before Call "; x, y, z
CALL Garbage(x, y, z)
PRINT "After Call "; x, y, z '--Correct values are displayed
' after exiting the sub
Separate Module (.OBJ, Library, or Quick Library) Code
------------------------------------------------------
SUB Garbage (x, y, z)
PRINT "In sub, before multiplying "; x, y, z '--Correct values
' are displayed
z = x * y '--Change this line to z = y * x
' and program will work correctly
PRINT "In sub, after multiplying "; x, y, z '--y displays garbage
END SUB
Workarounds
-----------
One workaround to the problem is to assign the variable located in the
second position of the parameter list to a temporary variable and work
with that temporary variable. At the end of the procedure, assign the
parameter variable the value of the temporary variable. For example,
the procedure in the library or Quick library would look like the
following:
SUB Garbage (x, y, z)
ytemp = y
z = x * ytemp
y = ytemp
PRINT "Printing ytemp "; ytemp
PRINT "Printing y "; y
END SUB
Another workaround is to pass variables through a COMMON SHARED
statement instead of a parameter list.