BUG: ESQL-C: Divisor in Parentheses May Cause AV in NSQLPREP

Last reviewed: April 9, 1997
Article ID: Q158885
The information in this article applies to:
  • Microsoft Embedded SQL for C Programmer's Toolkit version 6.5
BUG #: 16003 (NT 6.50)

SYMPTOMS

NSQLPREP may experience an unhandled access violation (AV) when precompiling a C division expression in which the divisor is contained within parentheses. Additionally, the C modulus (%) operator causes the same problem.

WORKAROUND

To work around this problem, do either of the following:

  • Ensure that there is a character string variable assignment in the program, before the division expression.
  • Do not place the divisor in parentheses.

STATUS

Microsoft has confirmed this to be a problem in Microsoft Embedded SQL for C Programmer's Toolkit version 6.5. We are researching this problem and will post new information here in the Microsoft Knowledge Base as it becomes available.

MORE INFORMATION

Other operators (such as +, -, and *) do not cause an AV in NSQLPREP.

The following is a sample code fragment that will cause the ESQL-C precompiler to generate an AV:

   int main (int argc, char** argv, char** envp)
   {
      int x;

      EXEC SQL BEGIN DECLARE SECTION;
            char o[3];
      EXEC SQL END DECLARE SECTION;

      x = 1 / (1);   // causes AV
      return (0);
   } /* end program */

The following sample code fragment will not cause the precompiler to generate an AV, because there is a character string variable assignment before the division expression:

   int main (int argc, char** argv, char** envp)
   {
      int x;
      char string[] = "";  /* character string assignment */

      EXEC SQL BEGIN DECLARE SECTION;
            char o[3];
      EXEC SQL END DECLARE SECTION;

      x = 1 / (1);
      return (0);
   } /* end program */


Additional query words: ESQL/C ESQL-C
Keywords : kbbug6.50 kbprg SSrvESQL_C SSrvProg
Version : 6.5
Platform : WINDOWS


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: April 9, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.